Server IP : 85.214.239.14 / Your IP : 18.119.135.67 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /srv/modoboa/env/lib/python3.5/site-packages/modoboa/lib/ |
Upload File : |
"""Crypto related utilities.""" import base64 import time from cryptography.fernet import Fernet from cryptography.hazmat.backends import default_backend from cryptography.hazmat.primitives.twofactor import InvalidToken from cryptography.hazmat.primitives.twofactor.totp import TOTP from cryptography.hazmat.primitives.hashes import SHA1 from django.conf import settings from django.utils.crypto import get_random_string from django.utils.encoding import smart_bytes, smart_text def random_key(length=16): """Generate a new key used to encrypt user passwords in session storage.""" chars = "abcdefghijklmnopqrstuvwxyz0123456789!@#$%^&*(-_=+)" return get_random_string(length, chars) def random_hex_key(length=16): """Generate a new hexadecimal key.""" chars = "abcdefABCDEF0123456789" return get_random_string(length, chars) def _get_fernet(): """Create a Fernet instance.""" secret_key = base64.urlsafe_b64encode(smart_bytes(settings.SECRET_KEY[:32])) return Fernet(secret_key) def encrypt(clear_value): """Encrypt a value using secret_key.""" return smart_text(_get_fernet().encrypt(smart_bytes(clear_value))) def decrypt(encrypted_value): """Decrypt a value using secret_key.""" return smart_text(_get_fernet().decrypt(smart_bytes(encrypted_value))) def get_password(request): """ Retrieve and decrypt the users password from session storage. This is used by modoboa-webmail to allow the user to send/receive e-mails without having to ask the user for a password on each connection to the postfix/dovecot server. """ try: return decrypt(request.session["password"]) except KeyError: return None