add of compression encryptino decryption process
This commit is contained in:
parent
6d9f3f4b9f
commit
c3dbdefc3f
1
encryption/example.bin
Normal file
1
encryption/example.bin
Normal file
@ -0,0 +1 @@
|
||||
Ϩ-‡Ş™oŹÂh`–h’Ń´´dď*ă_6j–>/Ä7zCqóŢąS´’WK#ĐŇ\بŠ‰G>o,>çU§ t'–Qΰńp2GXpć_ü#v2üŻŽ_}4zŘ)_Ý<5F>úŘ·Y>erĂ^®S”!µÇb˛˘‰[ßó
|
96
encryption/main.py
Executable file
96
encryption/main.py
Executable file
@ -0,0 +1,96 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
import sys
|
||||
from ffmpy import FFmpeg
|
||||
from cryptography.hazmat.primitives.asymmetric import ec
|
||||
from cryptography.hazmat.primitives import hashes
|
||||
from cryptography.hazmat.primitives.kdf.hkdf import HKDF
|
||||
from cryptography.hazmat.primitives.ciphers import Cipher, algorithms, modes
|
||||
from cryptography.hazmat.primitives import serialization
|
||||
from cryptography.hazmat.primitives import padding
|
||||
from cryptography.hazmat.backends import default_backend
|
||||
import os
|
||||
import subprocess
|
||||
|
||||
private_key = ec.generate_private_key(ec.SECP256R1(), default_backend())
|
||||
public_key = private_key.public_key()
|
||||
public_key_bytes = public_key.public_bytes(
|
||||
encoding=serialization.Encoding.PEM,
|
||||
format=serialization.PublicFormat.SubjectPublicKeyInfo
|
||||
)
|
||||
|
||||
|
||||
|
||||
def encrypt_bitstream(bitstream, peer_public_key_bytes):
|
||||
peer_public_key = serialization.load_pem_public_key(peer_public_key_bytes, backend=default_backend())
|
||||
shared_key = private_key.exchange(ec.ECDH(), peer_public_key)
|
||||
derived_key = HKDF(
|
||||
algorithm=hashes.SHA256(),
|
||||
length=32,
|
||||
salt=None,
|
||||
info=b'handshake data',
|
||||
backend=default_backend()
|
||||
).derive(shared_key)
|
||||
iv = os.urandom(16)
|
||||
cipher = Cipher(algorithms.AES(derived_key), modes.CBC(iv), backend=default_backend())
|
||||
encryptor = cipher.encryptor()
|
||||
padder = padding.PKCS7(algorithms.AES.block_size).padder()
|
||||
padded_data = padder.update(bitstream) + padder.finalize()
|
||||
ciphertext = encryptor.update(padded_data) + encryptor.finalize()
|
||||
return iv + ciphertext
|
||||
|
||||
|
||||
|
||||
def decrypt_bitstream(ciphertext, peer_public_key_bytes):
|
||||
peer_public_key = serialization.load_pem_public_key(peer_public_key_bytes, backend=default_backend())
|
||||
shared_key = private_key.exchange(ec.ECDH(), peer_public_key)
|
||||
derived_key = HKDF(
|
||||
algorithm=hashes.SHA256(),
|
||||
length=32,
|
||||
salt=None,
|
||||
info=b'handshake data',
|
||||
backend=default_backend()
|
||||
).derive(shared_key)
|
||||
iv = ciphertext[:16]
|
||||
actual_ciphertext = ciphertext[16:]
|
||||
cipher = Cipher(algorithms.AES(derived_key), modes.CBC(iv), backend=default_backend())
|
||||
decryptor = cipher.decryptor()
|
||||
padded_data = decryptor.update(actual_ciphertext) + decryptor.finalize()
|
||||
unpadder = padding.PKCS7(algorithms.AES.block_size).unpadder()
|
||||
data = unpadder.update(padded_data) + unpadder.finalize()
|
||||
return data
|
||||
|
||||
|
||||
|
||||
def process_audio(input_wav):
|
||||
|
||||
process = subprocess.Popen(
|
||||
['ffmpeg', '-i', input_wav, '-ar', '8000', '-b:a', '128k', '-f', 'mp3', 'pipe:1'],
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=subprocess.PIPE
|
||||
)
|
||||
return process.stdout.read()
|
||||
|
||||
|
||||
def main():
|
||||
input_wav = 'CantinaBand60.wav'
|
||||
|
||||
with open(input_wav, 'rb') as f:
|
||||
original_bitstream = f.read()
|
||||
|
||||
processed_bitstream = process_audio(input_wav)
|
||||
|
||||
print("Original WAV bitstream length:", len(original_bitstream))
|
||||
print("Processed MP3 bitstream length:", len(processed_bitstream))
|
||||
|
||||
chunk_size = 1024
|
||||
for i in range(0, len(processed_bitstream), chunk_size):
|
||||
chunk = processed_bitstream[i:i + chunk_size]
|
||||
ciphertext = encrypt_bitstream(chunk, public_key_bytes)
|
||||
decrypted_chunk = decrypt_bitstream(ciphertext, public_key_bytes)
|
||||
with open('output.mp3', 'ab') as f:
|
||||
f.write(decrypted_chunk)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
1
encryption/requirements.txt
Normal file
1
encryption/requirements.txt
Normal file
@ -0,0 +1 @@
|
||||
cryptography
|
Reference in New Issue
Block a user