Refactor addr
This commit is contained in:
@@ -105,8 +105,10 @@ class SessionInterface(QuartSessionInterface):
|
|||||||
request: BaseRequestWebsocket
|
request: BaseRequestWebsocket
|
||||||
) -> Optional[SecureCookieSession]:
|
) -> Optional[SecureCookieSession]:
|
||||||
sid = request.cookies.get(app.session_cookie_name)
|
sid = request.cookies.get(app.session_cookie_name)
|
||||||
addr = request.headers.get('X-Forwarded-For', request.remote_addr) if \
|
if self._config['SESSION_HIJACK_REVERSE_PROXY'] is True:
|
||||||
self._config['SESSION_HIJACK_PROTECTION'] else None
|
addr = request.headers.get('X-Forwarded-For', request.remote_addr)
|
||||||
|
else:
|
||||||
|
addr = request.remote_addr
|
||||||
options = {"sid": sid, "permanent": self.permanent, "addr": addr}
|
options = {"sid": sid, "permanent": self.permanent, "addr": addr}
|
||||||
|
|
||||||
if not sid:
|
if not sid:
|
||||||
@@ -139,12 +141,7 @@ class SessionInterface(QuartSessionInterface):
|
|||||||
return self.session_class(**options)
|
return self.session_class(**options)
|
||||||
|
|
||||||
prevent_hijack = self._config['SESSION_HIJACK_PROTECTION']
|
prevent_hijack = self._config['SESSION_HIJACK_PROTECTION']
|
||||||
if prevent_hijack is True:
|
if prevent_hijack is True and data.get('_addr', addr) != addr:
|
||||||
if self._config['SESSION_HIJACK_REVERSE_PROXY'] is True:
|
|
||||||
addr = request.headers.get('X-Forwarded-For', request.remote_addr)
|
|
||||||
else:
|
|
||||||
addr = request.remote_addr
|
|
||||||
if data.get('_addr', addr) != addr:
|
|
||||||
await self._backend_delete(app, self.key_prefix + sid)
|
await self._backend_delete(app, self.key_prefix + sid)
|
||||||
options['sid'] = self._generate_sid()
|
options['sid'] = self._generate_sid()
|
||||||
return self.session_class(**options)
|
return self.session_class(**options)
|
||||||
|
|||||||
Reference in New Issue
Block a user