[
    {
        "file_name": "browser_history_extractor.py",
        "file_content": "import os\nimport sqlite3\nimport json\nfrom datetime import datetime\n\n# Function to connect to the SQLite database\ndef connect_to_database(db_path):\n    \"\"\"\n    Connects to the SQLite database file.\n    :param db_path: Path to the SQLite database file.\n    :return: Connection object.\n    \"\"\"\n    try:\n        connection = sqlite3.connect(db_path)\n        return connection\n    except sqlite3.Error as e:\n        print(f\"Error connecting to database: {e}\")\n        return None\n\n# Function to fetch browser history\ndef fetch_browser_history(connection):\n    \"\"\"\n    Fetches browser history from the connected database.\n    :param connection: Database connection object.\n    :return: List of history entries.\n    \"\"\"\n    try:\n        cursor = connection.cursor()\n        cursor.execute(\"SELECT url, title, last_visit_time FROM urls\")\n        rows = cursor.fetchall()\n        return rows\n    except sqlite3.Error as e:\n        print(f\"Error fetching history: {e}\")\n        return []\n\n# Function to convert timestamp to human-readable format\ndef timestamp_to_datetime(timestamp):\n    \"\"\"\n    Converts a timestamp to a human-readable datetime format.\n    :param timestamp: Timestamp in microseconds.\n    :return: Human-readable datetime string.\n    \"\"\"\n    return datetime.utcfromtimestamp(timestamp / 1000000).strftime('%Y-%m-%d %H:%M:%S')\n\n# Function to save history to a JSON file\ndef save_history_to_json(history, output_file):\n    \"\"\"\n    Saves the browser history to a JSON file.\n    :param history: List of history entries.\n    :param output_file: Path to the output JSON file.\n    \"\"\"\n    try:\n        with open(output_file, 'w') as f:\n            json.dump(history, f, indent=4)\n        print(f\"History saved to {output_file}\")\n    except IOError as e:\n        print(f\"Error writing to file: {e}\")\n\n# Main function to extract and save browser history\ndef main():\n    # Path to the Chromium-based browser history database\n    db_path = os.path.expanduser(\"~/.config/chromium/Default/History\")\n\n    # Connect to the database\n    connection = connect_to_database(db_path)\n    if connection is None:\n        return\n\n    # Fetch browser history\n    history = fetch_browser_history(connection)\n\n    # Convert history to a list of dictionaries\n    history_list = []\n    for row in history:\n        url, title, timestamp = row\n        history_list.append({\n            \"url\": url,\n            \"title\": title,\n            \"last_visit_time\": timestamp_to_datetime(timestamp)\n        })\n\n    # Save history to a JSON file\n    output_file = \"browser_history.json\"\n    save_history_to_json(history_list, output_file)\n\n    # Close the database connection\n    connection.close()\n\nif __name__ == \"__main__\":\n    main()"
    },
    {
        "file_name": "requirements.txt",
        "file_content": "sqlite3"
    },
    {
        "file_name": "README.md",
        "file_content": "# Browser History Extractor\n\nThis Python script extracts and saves the browsing history from Chromium-based browsers to a JSON file.\n\n## Requirements\n\n- Python 3.x\n- SQLite3 (usually included with Python)\n\n## Installation\n\n1. Clone the repository:"
    }
]