I have a file encrypted in Python and pycryptodome like this:
from Crypto.PublicKey import RSA from Crypto.Random import get_random_bytes from Crypto.Cipher import AES, PKCS1_OAEP key = RSA.generate(2048) secret_key = key.exportKey(passphrase='letmein', pkcs=8, protection='scryptAndAES128-CBC') public_key = key.publickey().exportKey() rsa_key = RSA.importKey(public_key) session_key = get_random_bytes(16) cipher_rsa = PKCS1_OAEP.new(rsa_key) cipher_aes = AES.new(session_key, AES.MODE_EAX) ciphertext, tag = cipher_aes.encrypt_and_digest(data) dst.write(cipher_rsa.encrypt(session_key)) dst.write(cipher_aes.nonce) dst.write(tag) dst.write(ciphertext) And I am able to decode it like this:
rsa_key = RSA.importKey(secret_key, 'letmein') enc_session_key, nonce, tag, ciphertext = [ src.read(x) for x in (rsa_key.size_in_bytes(), 16, 16, -1) ] cipher_rsa = PKCS1_OAEP.new(rsa_key) session_key = cipher_rsa.decrypt(enc_session_key) cipher_aes = AES.new(session_key, AES.MODE_EAX, nonce) decoded = cipher_aes.decrypt_and_verify(ciphertext, tag) Is there a way to decrypt the file using command line with openssl? Or how should I modify the code so that it would be possible?