request.user cached value does not track request.session change
|Reported by:||Vlada Macek||Owned by:||nobody|
|Cc:||Melvyn Sopacua||Triage Stage:||Design decision needed|
|Has patch:||no||Needs documentation:||no|
|Needs tests:||no||Patch needs improvement:||no|
During the Single-Sign On technique implementation I came to the need of replacing request.session with a new session or just setting request.session = None.
The descriptor in AuthenticationMiddleware nevertheless does not remember the session for which it sets the request._cached_user.
IMHO, the descriptor should cache the session key when it saves the _cached_user and allow _cached_user to be used only when the session key did not unchange.
Currently everyone who changes the session during the request processing HAS to dig into the AuthenticationMiddleware internals and modify the _cached_user to get valid request.user. That's hard to maintain.
I can offer the patch, but would like to get some response first.
Change History (5)
comment:1 Changed 4 years ago by
|Patch needs improvement:||unset|
|Type:||Uncategorized → New feature|
comment:2 Changed 4 years ago by
|Cc:||Melvyn Sopacua added|
|Triage Stage:||Unreviewed → Design decision needed|