LocaleInterceptor leads to hanging page if user is logged in and previous requests became stale#5076
Open
jlipka wants to merge 1 commit intoDSpace:mainfrom
Open
LocaleInterceptor leads to hanging page if user is logged in and previous requests became stale#5076jlipka wants to merge 1 commit intoDSpace:mainfrom
jlipka wants to merge 1 commit intoDSpace:mainfrom
Conversation
Set the variable “ignoreEPersonSettings” when the “epersons” endpoint is called. Otherwise, this will result in an infinite loop of interceptors and subsequent requests.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
The current implementation of the "LocaleInterceptor" leads Dspace to hang if the current user is logged in and the (previous) "eperson/epersons"-request has become stale.
References
Description
Requirements:
The LocaleInterceptor adds a http header ("Accept-Language") to almost each request. While this works in most cases, the interceptor should set "ignoreEPersonSettings" to "true", if the request url itself leads to the endpoint of "server/api/eperson/epersons" and the state of the previous request got stale. Otherwise, the following chain is called again and again:
"LocaleService.getLanguageCodeList()" -> "AuthService.getAuthenticatedUserFromStore()" -> epersonService.findById() -> ...which leads to process the LocaleInterceptor again.
Instructions for Reviewers
List of changes in this PR:
ignoreEPersonSettingstotrueTest the behaviour before the fix following these steps
Even though the circumstances sound unusual, our colleagues have experienced the “MyDSpace” page remaining open in the browser for a longer time. As soon as they start working again with DSpace, the effect described above occurs. Especially since the auto-logout in the default configuration occurs regulary after 20 minutes.
This video should show the problem:
https://github.com/user-attachments/assets/b862bfb4-fb2a-499a-84e1-9ef784ca9077
Checklist
This checklist provides a reminder of what we are going to look for when reviewing your PR. You do not need to complete this checklist prior creating your PR (draft PRs are always welcome).
However, reviewers may request that you complete any actions in this list if you have not done so. If you are unsure about an item in the checklist, don't hesitate to ask. We're here to help!
mainbranch of code (unless it is a backport or is fixing an issue specific to an older branch).npm run lintnpm run check-circ-deps)package.json), I've made sure their licenses align with the DSpace BSD License based on the Licensing of Contributions documentation.