[
    {
        "file_name": "main.py",
        "file_content": "import encryption\nimport key_cracker\n\ndef main():\n    # Known plaintext and ciphertext for testing\n    known_plaintext = \"hello\"\n    ciphertext = \"encrypted_text\"  # Replace with actual encrypted text\n\n    # Initialize the key cracker with the known plaintext and ciphertext\n    cracker = key_cracker.KeyCracker(known_plaintext, ciphertext)\n\n    # Attempt to crack the key\n    cracked_key = cracker.crack_key()\n\n    # Output the cracked key\n    if cracked_key:\n        print(f\"Cracked Key: {cracked_key}\")\n    else:\n        print(\"Key cracking failed.\")\n\nif __name__ == \"__main__\":\n    main()"
    },
    {
        "file_name": "encryption.py",
        "file_content": "def encrypt(plaintext, key):\n    \"\"\"\n    Encrypts the plaintext using the given key with a simple XOR operation.\n    \n    :param plaintext: The text to be encrypted.\n    :param key: The encryption key.\n    :return: The encrypted text.\n    \"\"\"\n    encrypted_text = ''.join(chr(ord(c) ^ key) for c in plaintext)\n    return encrypted_text\n\ndef decrypt(ciphertext, key):\n    \"\"\"\n    Decrypts the ciphertext using the given key with a simple XOR operation.\n    \n    :param ciphertext: The text to be decrypted.\n    :param key: The decryption key.\n    :return: The decrypted text.\n    \"\"\"\n    decrypted_text = ''.join(chr(ord(c) ^ key) for c in ciphertext)\n    return decrypted_text"
    },
    {
        "file_name": "key_cracker.py",
        "file_content": "import encryption\n\nclass KeyCracker:\n    def __init__(self, known_plaintext, ciphertext):\n        \"\"\"\n        Initializes the KeyCracker with known plaintext and ciphertext.\n        \n        :param known_plaintext: The known plaintext used for cracking.\n        :param ciphertext: The ciphertext to be cracked.\n        \"\"\"\n        self.known_plaintext = known_plaintext\n        self.ciphertext = ciphertext\n\n    def crack_key(self):\n        \"\"\"\n        Attempts to crack the key by trying different key values and comparing the decrypted text with the known plaintext.\n        \n        :return: The cracked key if found, otherwise None.\n        \"\"\"\n        for key in range(256):  # Assuming key is a single byte\n            decrypted_text = encryption.decrypt(self.ciphertext, key)\n            if decrypted_text == self.known_plaintext:\n                return key\n        return None"
    }
]