Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xtruder/ffbookmarks-to-markdown
Firefox bookmarks to markdown
https://github.com/xtruder/ffbookmarks-to-markdown
bookmarks firefox markdown obsidian obsidian-md sync
Last synced: 5 days ago
JSON representation
Firefox bookmarks to markdown
- Host: GitHub
- URL: https://github.com/xtruder/ffbookmarks-to-markdown
- Owner: xtruder
- Created: 2025-02-08T15:47:01.000Z (12 days ago)
- Default Branch: main
- Last Pushed: 2025-02-15T16:10:40.000Z (5 days ago)
- Last Synced: 2025-02-15T16:23:08.498Z (5 days ago)
- Topics: bookmarks, firefox, markdown, obsidian, obsidian-md, sync
- Language: Go
- Homepage:
- Size: 70.3 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Firefox Bookmarks to Markdown
[data:image/s3,"s3://crabby-images/a9d87/a9d8792a380bf823fdee9a421e985d2a89d5c9ee" alt="Latest Release"](https://github.com/xtruder/ffbookmarks-to-markdown/releases/latest)
[data:image/s3,"s3://crabby-images/0c579/0c57902b2fbc15f9b1e77d42846b1c1ba0c0b181" alt="Docker Image"](https://github.com/xtruder/ffbookmarks-to-markdown/pkgs/container/ffbookmarks-to-markdown)A tool that syncs Firefox bookmarks to markdown files for use with tools like Obsidian.
- **Firefox Sync Integration**: Syncs bookmarks directly from Firefox Sync service using [ffsclient](https://github.com/Mikescher/firefox-sync-client)
- **Content download**:
- Downloads content from the web using [markdowner](https://md.dhr.wtf/dashboard) service
- Special handing for github repositories and youtube videos
- **Content Processing**:
- Markdown cleanup using LLM (gemini)
- Fixes relative links
- Preserves code blocks and technical content
- **Screenshots**: Captures website screenshots using [gowitness](https://github.com/sensepost/gowitness)
- **Caching**: Caches web content and LLM responses for efficiency
- **Obsidian Integration**:
- Creates year-based index files
- Adds proper frontmatter
- Compatible with Dataview plugin## Usage
### Basic Usage
```shell
# Sync bookmarks from Firefox toolbar folder
ffbookmarks-to-markdown -folder toolbar -output bookmarks# List available bookmarks
ffbookmarks-to-markdown -list# Enable verbose logging
ffbookmarks-to-markdown -verbose
```### Advanced Options
```shell
# Ignore specific folders
ffbookmarks-to-markdown -ignore "Archive,Old Stuff"# Use custom LLM settings
ffbookmarks-to-markdown -llm-key "your-key" -llm-model "your-model"# Use custom screenshot API
ffbookmarks-to-markdown -screenshot-api "https://your-screenshot-service"
```## Installing
Here is a single-liner to install the binary to your local bin directory:
```shell
mkdir -p ~/.local/bin
curl -L https://github.com/xtruder/ffbookmarks-to-markdown/releases/download/v0.1.0/ffbookmarks-to-markdown-linux-amd64.tar.gz | tar -xz -C ~/.local/bin
```## Running
First you need to login to your Firefox Sync account using `ffsclient` tool:
```shell
ffsclient login
```It will ask you for your username and password.
After that you can run the tool, which will sync bookmarks from your Firefox Sync account and save them to the specified directory:
```shell
ffbookmarks-to-markdown -folder toolbar -output bookmarks
```If you want to use LLM to clean up the markdown content, you need to set `GEMINI_API_KEY` environment variable:
```shell
export GEMINI_API_KEY="your-key"
```## Full docker-compose example
Here is a full example of docker-compose file that will run gowitness, obsidian and ffbookmarks-to-markdown.
You must make sure to copy your Firefox Sync credentials to the `obsidian-config` volume.```yaml
version: '3.9'
name: obsidian-stack
services:
obsidian:
container_name: obsidian
image: linuxserver/obsidian:1.8.4
networks:
- net
environment:
- PUID=1000
- PGID=1000
- TZ=UTC
- DOCKER_MODS=linuxserver/mods:universal-package-installer
volumes:
- obsidian-config:/config
shm_size: "1gb"
deploy:
resources:
reservations:
devices:
- driver: nvidia
count: 1
capabilities: [compute,video,graphics,utility]
restart: unless-stopped
gowitness:
image: ghcr.io/sensepost/gowitness:latest
restart: unless-stopped
command: gowitness report server --host 0.0.0.0 --screenshot-path /data/screenshots --db-uri sqlite:///data/gowitness.sqlite3
volumes:
- gowitness-storage:/data
networks:
- net
ffbookmarks-to-markdown:
image: ghcr.io/xtruder/ffbookmarks-to-markdown:0.1.0
command: -output /data/my-vault/Bookmarks -screenshot-api http://gowitness
environment:
- TZ=UTC
- GEMINI_API_KEY=${GEMINI_API_KEY}
- HOME=/home/user
working_dir: /home/user
user: 1000:1000
restart: never
volumes:
- obsidian-config:/data
- ffbookmarks-home:/home/user
networks:
- netvolumes:
gowitness-storage:
obsidian-config:
ffbookmarks-home:networks:
net:
```## Usage
```shell
Usage of ./ffbookmarks-to-markdown:
-folder string
Base folder name to sync from Firefox bookmarks (default "toolbar")
-ignore string
Comma-separated list of folder names to ignore
-list
List all available bookmarks
-llm-key string
API key for LLM service
-llm-model string
Model to use for LLM service (default "gemini-2.0-flash")
-llm-url string
Base URL for LLM service (default "https://generativelanguage.googleapis.com/v1beta/openai/")
-output string
Output directory for markdown files (default "bookmarks")
-screenshot-api string
Screenshot API base URL (default "https://gowitness.cloud.x-truder.net")
-verbose
Enable verbose logging
```## Environment Variables
- `GEMINI_API_KEY`: API key for Gemini LLM service (optional)
## Output Structure
The tool creates the following structure in your output directory:
```text
bookmarks/
├── 2024.md # Year index
├── 2023.md # Year index
└── folder/ # Bookmark folders
└── bookmark.md # Bookmark files
```Each bookmark file contains:
- Frontmatter with metadata
- Cleaned markdown content
- Screenshot (if available)
- Original URL and creation date## License
MIT License