Revoke stale sessions after password change
After a successful password change, revoke all browser sessions for the same user except the one that submitted the request. This prevents stale sessions on other devices from remaining valid after credentials are updated. Keep API-token behavior unchanged. The current browser session is preserved so the user can continue from the tab that changed the password. Add focused regression tests for preserving the current session, revoking other sessions, persisting revocation, and avoiding revocation when the current password is incorrect.
This commit is contained in:
committed by
GitHub
parent
7d10fb6260
commit
5dd5847d4b
16
core/auth.py
16
core/auth.py
@@ -479,6 +479,22 @@ class AuthManager:
|
||||
self._sessions.pop(token, None)
|
||||
self._save_sessions()
|
||||
|
||||
def revoke_user_sessions(self, username: str, except_token: Optional[str] = None) -> int:
|
||||
"""Revoke active browser sessions for a user, optionally preserving one."""
|
||||
username = username.strip().lower()
|
||||
revoked = 0
|
||||
with self._sessions_lock:
|
||||
to_drop = [
|
||||
token for token, session in self._sessions.items()
|
||||
if token != except_token and (session or {}).get("username") == username
|
||||
]
|
||||
for token in to_drop:
|
||||
self._sessions.pop(token, None)
|
||||
revoked += 1
|
||||
if revoked:
|
||||
self._save_sessions()
|
||||
return revoked
|
||||
|
||||
def status(self, token: Optional[str]) -> Dict[str, Any]:
|
||||
username = self.get_username_for_token(token)
|
||||
authenticated = username is not None
|
||||
|
||||
Reference in New Issue
Block a user