[
    {
        "file_name": "chrome_password_decryptor.py",
        "file_content": "import os\nimport sqlite3\nimport win32crypt\nfrom Crypto.Cipher import AES\nfrom Crypto.Protocol.KDF import PBKDF2\nfrom base64 import b64decode\nimport struct\nimport hashlib\n\n# Function to decrypt passwords for Chrome versions less than 80 using DPAPI\ndef decrypt_password_dpapi(encrypted_password):\n    try:\n        # Decrypt the password using DPAPI\n        decrypted_password = win32crypt.CryptUnprotectData(encrypted_password, None, None, None, 0)[1]\n        return decrypted_password.decode('utf-8')\n    except Exception as e:\n        print(f\"Error decrypting password with DPAPI: {e}\")\n        return None\n\n# Function to decrypt passwords for Chrome versions 80 and above using AES-GCM\ndef decrypt_password_aes_gcm(encrypted_password, key):\n    try:\n        # Decode the encrypted password\n        encrypted_password = b64decode(encrypted_password)\n        nonce, ciphertext, tag = encrypted_password[3:15], encrypted_password[15:-16], encrypted_password[-16:]\n        cipher = AES.new(key, AES.MODE_GCM, nonce=nonce)\n        decrypted_password = cipher.decrypt_and_verify(ciphertext, tag)\n        return decrypted_password.decode('utf-8')\n    except Exception as e:\n        print(f\"Error decrypting password with AES-GCM: {e}\")\n        return None\n\n# Function to get the encryption key for Chrome versions 80 and above\ndef get_chrome_key():\n    try:\n        local_state_path = os.path.join(os.environ['USERPROFILE'], 'AppData', 'Local', 'Google', 'Chrome', 'User Data', 'Local State')\n        with open(local_state_path, 'r', encoding='utf-8') as f:\n            local_state = f.read()\n            local_state = json.loads(local_state)\n\n        key = base64.b64decode(local_state['os_crypt']['encrypted_key'])\n        key = key[5:]  # Remove DPAPI struct\n        key = win32crypt.CryptUnprotectData(key, None, None, None, 0)[1]\n        return key\n    except Exception as e:\n        print(f\"Error getting Chrome encryption key: {e}\")\n        return None\n\n# Function to decrypt Chrome passwords\ndef decrypt_chrome_passwords(chrome_version):\n    try:\n        # Connect to the Chrome database\n        db_path = os.path.join(os.environ['USERPROFILE'], 'AppData', 'Local', 'Google', 'Chrome', 'User Data', 'Default', 'Login Data')\n        conn = sqlite3.connect(db_path)\n        cursor = conn.cursor()\n\n        # Fetch encrypted passwords\n        cursor.execute('SELECT origin_url, action_url, username_value, password_value, date_created, date_last_used FROM logins')\n        for row in cursor.fetchall():\n            origin_url, action_url, username, encrypted_password = row[0], row[1], row[2], row[3]\n            if chrome_version < 80:\n                password = decrypt_password_dpapi(encrypted_password)\n            else:\n                key = get_chrome_key()\n                password = decrypt_password_aes_gcm(encrypted_password, key)\n            if password:\n                print(f'Origin URL: {origin_url}')\n                print(f'Action URL: {action_url}')\n                print(f'Username: {username}')\n                print(f'Password: {password}')\n                print('-' * 40)\n        conn.close()\n    except Exception as e:\n        print(f\"Error decrypting Chrome passwords: {e}\")\n\nif __name__ == '__main__':\n    chrome_version = 85  # Example Chrome version, change as needed\n    decrypt_chrome_passwords(chrome_version)"
    },
    {
        "file_name": "requirements.txt",
        "file_content": "pycryptodome\npywin32"
    },
    {
        "file_name": "README.md",
        "file_content": "# Chrome Password Decryptor\n\nThis Python script decrypts saved passwords from Google Chrome. It supports both Chrome versions less than 80 (using DPAPI) and versions 80 and above (using AES-GCM).\n\n## Requirements\n\n- Python 3.x\n- pycryptodome\n- pywin32\n\n## Installation\n\n1. Clone the repository:"
    }
]