Current Path: > > opt > cloudlinux > venv > lib64 > python3.11 > site-packages > aiohttp_session > >
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
__init__.py | File | 8336 bytes | April 17 2025 13:10:58. | |
cookie_storage.py | File | 2196 bytes | April 17 2025 13:10:58. | |
log.py | File | 54 bytes | April 17 2025 13:10:58. | |
memcached_storage.py | File | 2871 bytes | April 17 2025 13:10:58. | |
nacl_storage.py | File | 2257 bytes | April 17 2025 13:10:58. | |
redis_storage.py | File | 3218 bytes | April 17 2025 13:10:58. |
import binascii import json import nacl.secret import nacl.utils import nacl.exceptions from nacl.encoding import Base64Encoder from . import AbstractStorage, Session from .log import log class NaClCookieStorage(AbstractStorage): """NaCl Encrypted JSON storage. """ def __init__(self, secret_key, *, cookie_name="AIOHTTP_SESSION", domain=None, max_age=None, path='/', secure=None, httponly=True, encoder=json.dumps, decoder=json.loads): super().__init__(cookie_name=cookie_name, domain=domain, max_age=max_age, path=path, secure=secure, httponly=httponly, encoder=encoder, decoder=decoder) self._secretbox = nacl.secret.SecretBox(secret_key) def empty_session(self): return Session(None, data=None, new=True, max_age=self.max_age) async def load_session(self, request): cookie = self.load_cookie(request) if cookie is None: return self.empty_session() else: try: data = self._decoder( self._secretbox.decrypt( cookie.encode('utf-8'), encoder=Base64Encoder).decode('utf-8') ) return Session(None, data=data, new=False, max_age=self.max_age) except (binascii.Error, nacl.exceptions.CryptoError): log.warning("Cannot decrypt cookie value, " "create a new fresh session") return self.empty_session() async def save_session(self, request, response, session): if session.empty: return self.save_cookie(response, session._mapping, max_age=session.max_age) cookie_data = self._encoder( self._get_session_data(session) ).encode('utf-8') nonce = nacl.utils.random(nacl.secret.SecretBox.NONCE_SIZE) self.save_cookie( response, self._secretbox.encrypt(cookie_data, nonce, encoder=Base64Encoder).decode('utf-8'), max_age=session.max_age )
SILENT KILLER Tool