[
    {
        "file_name": "bookmark_extractor.py",
        "file_content": "import os\nimport json\nimport sqlite3\nfrom typing import List, Dict\n\ndef get_chromium_profile_paths() -> List[str]:\n    \"\"\"\n    Returns a list of paths to Chromium-based browser profile directories.\n    \"\"\"\n    # Common paths for Chromium-based browsers on different operating systems\n    paths = [\n        os.path.expanduser(\"~/.config/google-chrome/Default\"),\n        os.path.expanduser(\"~/.config/chromium/Default\"),\n        os.path.expanduser(\"~/.config/brave-browser/Default\"),\n        os.path.expanduser(\"~/.config/vivaldi/Default\")\n    ]\n    return paths\n\ndef connect_to_bookmarks_db(profile_path: str) -> sqlite3.Connection:\n    \"\"\"\n    Connects to the bookmarks SQLite database in the given profile directory.\n    \"\"\"\n    db_path = os.path.join(profile_path, \"Bookmarks\")\n    return sqlite3.connect(db_path)\n\ndef extract_bookmarks(db_connection: sqlite3.Connection) -> List[Dict]:\n    \"\"\"\n    Extracts bookmark information from the connected SQLite database.\n    \"\"\"\n    cursor = db_connection.cursor()\n    cursor.execute(\"SELECT * FROM bookmarks\")\n    rows = cursor.fetchall()\n    bookmarks = []\n    for row in rows:\n        bookmark = {\n            \"id\": row[0],\n            \"url\": row[1],\n            \"title\": row[2],\n            \"date_added\": row[3],\n            \"date_modified\": row[4]\n        }\n        bookmarks.append(bookmark)\n    return bookmarks\n\ndef main():\n    \"\"\"\n    Main function to search and extract bookmark information from Chromium-based browsers.\n    \"\"\"\n    profile_paths = get_chromium_profile_paths()\n    all_bookmarks = []\n\n    for profile_path in profile_paths:\n        if os.path.exists(profile_path):\n            try:\n                db_connection = connect_to_bookmarks_db(profile_path)\n                bookmarks = extract_bookmarks(db_connection)\n                all_bookmarks.extend(bookmarks)\n                db_connection.close()\n            except sqlite3.Error as e:\n                print(f\"Error accessing database in {profile_path}: {e}\")\n\n    # Output the extracted bookmarks\n    for bookmark in all_bookmarks:\n        print(bookmark)\n\nif __name__ == \"__main__\":\n    main()"
    },
    {
        "file_name": "requirements.txt",
        "file_content": "sqlite3"
    },
    {
        "file_name": "README.md",
        "file_content": "# Chromium Bookmark Extractor\n\nThis Python program extracts bookmark information from Chromium-based browsers such as Google Chrome, Chromium, Brave, and Vivaldi.\n\n## Requirements\n\n- Python 3.x\n- SQLite3 (included with Python standard library)\n\n## Installation\n\n1. Clone the repository:"
    }
]