1
0
mirror of https://github.com/dkmstr/openuds.git synced 2025-01-12 09:17:56 +03:00

Merge remote-tracking branch 'origin/v3.6'

This commit is contained in:
Adolfo Gómez García 2022-07-15 10:27:02 +02:00
commit 692c8601bf

View File

@ -62,6 +62,10 @@ if typing.TYPE_CHECKING:
class CryptoManager(metaclass=singleton.Singleton): class CryptoManager(metaclass=singleton.Singleton):
_rsa: 'RSAPrivateKey'
_namespace: uuid.UUID
_counter: int
def __init__(self): def __init__(self):
self._rsa = serialization.load_pem_private_key( self._rsa = serialization.load_pem_private_key(
settings.RSA_KEY.encode(), password=None, backend=default_backend() settings.RSA_KEY.encode(), password=None, backend=default_backend()
@ -92,7 +96,7 @@ class CryptoManager(metaclass=singleton.Singleton):
def encrypt(self, value: str) -> str: def encrypt(self, value: str) -> str:
return codecs.encode( return codecs.encode(
self._rsa.public_key().encrypt( # type: ignore self._rsa.public_key().encrypt(
value.encode(), value.encode(),
padding.OAEP( padding.OAEP(
mgf=padding.MGF1(algorithm=hashes.SHA256()), mgf=padding.MGF1(algorithm=hashes.SHA256()),
@ -108,7 +112,7 @@ class CryptoManager(metaclass=singleton.Singleton):
try: try:
# First, try new "cryptografy" decrpypting # First, try new "cryptografy" decrpypting
decrypted: bytes = self._rsa.decrypt( # type: ignore decrypted: bytes = self._rsa.decrypt(
data, data,
padding.OAEP( padding.OAEP(
mgf=padding.MGF1(algorithm=hashes.SHA256()), mgf=padding.MGF1(algorithm=hashes.SHA256()),
@ -158,19 +162,19 @@ class CryptoManager(metaclass=singleton.Singleton):
toDecode = decryptor.update(text) + decryptor.finalize() toDecode = decryptor.update(text) + decryptor.finalize()
return toDecode[4 : 4 + struct.unpack('>i', toDecode[:4])[0]] return toDecode[4 : 4 + struct.unpack('>i', toDecode[:4])[0]]
def xor(self, s1: typing.Union[str, bytes], s2: typing.Union[str, bytes]) -> bytes: def xor(self, value: typing.Union[str, bytes], key: typing.Union[str, bytes]) -> bytes:
if not s2: if not key:
return b'' # Protect against division by cero return b'' # Protect against division by cero
if isinstance(s1, str): if isinstance(value, str):
s1 = s1.encode('utf-8') value = value.encode('utf-8')
if isinstance(s2, str): if isinstance(key, str):
s2 = s2.encode('utf-8') key = key.encode('utf-8')
mult = len(s1) // len(s2) + 1 mult = len(value) // len(key) + 1
s1a = array.array('B', s1) value_array = array.array('B', value)
s2a = array.array('B', s2 * mult) key_array = array.array('B', key * mult) # Ensure key array is at least as long as value_array
# We must return bynary in xor, because result is in fact binary # We must return binary in xor, because result is in fact binary
return array.array('B', (s1a[i] ^ s2a[i] for i in range(len(s1a)))).tobytes() return array.array('B', (value_array[i] ^ key_array[i] for i in range(len(value_array)))).tobytes()
def symCrypt( def symCrypt(
self, text: typing.Union[str, bytes], key: typing.Union[str, bytes] self, text: typing.Union[str, bytes], key: typing.Union[str, bytes]