ListSync automatically syncs your watchlists from IMDb, Trakt and many more with Overseerr/Jellyseerr. No more manual adding - just add movies, shows, and anime to your favorite watchlist, and they'll appear in your media server automatically.
ListSync includes a web dashboard built with Nuxt 3 and Vue 3, providing an interface to manage all your sync operations.
For the most stable experience, use the source code from the latest release here.
No configuration needed! Just run this command to start the container and use the setup wizard:
docker run -d --name listsync-full -p 3222:3222 -p 4222:4222 -v listsync-data:/usr/src/app/data ghcr.io/woahai321/list-sync:mainAccess the dashboard at http://localhost:3222 and complete the setup wizard to connect your media server and watchlists.
ListSync offers flexible deployment options to suit different use cases, from quick testing to full production deployments with web dashboard.
πΏ Full Stack Deployment (Recommended)
# Clone and setup
git clone https://github.com/Woahai321/list-sync.git && cd list-sync
# (Optional: Configure a .env file)
# Use pre-built image
docker-compose up -d
# Or build from source
docker-compose -f docker-compose.local.yml up -d --buildAccess:
- Dashboard:
http://localhost:3222 - API Docs:
http://localhost:4222/docs - Health:
http://localhost:4222/api/system/health
All 3 services (Core Sync, FastAPI Backend, Nuxt Frontend) run in a single container managed by supervisor.
πΏ Option 2: Core-Only Deployment (Lightweight)
Minimal setup with just the sync engine
# 1. Clone the repository
git clone https://github.com/Woahai321/list-sync.git
cd list-sync
# 2. Copy and configure environment file
cp .env.example .env
nano .env # Add your Overseerr URL, API key, and lists
# 3. Start with the core docker-compose file
docker-compose -f docker-compose.core.yml up -d
# Done! Sync runs automatically in the backgroundMonitoring Core-Only:
# View logs
docker-compose -f docker-compose.core.yml logs -f
π Trakt API Configuration (Required)
ListSync now uses the official Trakt API v2 for improved reliability and performance. To use Trakt lists, you need to configure API credentials:
- Go to https://trakt.tv/oauth/applications
- Click "New Application"
- Fill in the required fields:
- Name:
ListSync(or any name you prefer) - Redirect URI:
urn:ietf:wg:oauth:2.0:oob(not used but required) - Other fields can be left as default
- Name:
- Click "Save App"
- After creating the app, you'll see your Client ID and Client Secret
- Copy the Client ID (the Client Secret is not needed for ListSync)
Add your Client ID to your .env file or via the web dashboard:
# Trakt API Configuration
TRAKT_CLIENT_ID=your_client_id_hereπ TMDB API Configuration (Optional)
ListSync can use the official TMDB API for improved reliability and performance. To use TMDB lists with API access, you need to configure API credentials:
- Go to https://www.themoviedb.org/settings/api
- Click "Request an API Key"
- Fill in the required fields:
- Application Name:
ListSync(or any name you prefer) - Application Summary:
Media list synchronization tool - Application URL:
https://github.com/Woahai321/list-sync
- Application Name:
- Click "Submit"
- After approval, you'll receive your API Key (v3 auth)
- Copy the API key
Add your API key to your .env file or via the web dashboard:
# TMDB API Configuration
TMDB_KEY=your_api_key_hereπ TVDB API Configuration (Optional)
ListSync can use the official TVDB API for enhanced data quality. To use TVDB with API access, you need to configure API credentials:
- Go to https://thetvdb.com/api-information
- Click "Register" to create an account
- Verify your email address
- Go to https://thetvdb.com/dashboard/account/apikey
- Click "Create New API Key"
- Fill in the required fields:
- Application Name:
ListSync - Application Summary:
Media list synchronization tool
- Application Name:
- Click "Create"
Add your API key to your .env file or via the web dashboard:
# TVDB API Configuration
TVDB_KEY=your_api_key_hereπ IMDb
- Navigate to your IMDb list in your browser.
- Copy the URL from the address bar. Examples:
- Custom lists:
https://www.imdb.com/list/ls012345678/ - IMDb charts:
https://www.imdb.com/chart/top/(Top 250),https://www.imdb.com/chart/boxoffice/(Box Office) - Watchlists:
https://www.imdb.com/user/ur12345678/watchlist
- Custom lists:
- Paste the URL directly into ListSync.
- Look at the URL:
- Custom lists:
ls012345678 - IMDb charts: Use the chart name (e.g.,
top,boxoffice) - Watchlists:
ur12345678
- Custom lists:
- Use the list ID in ListSync.
top(Top 250 Movies)boxoffice(Box Office)moviemeter(MovieMeter)tvmeter(TVMeter)
π Trakt
- Navigate to your Trakt list in your browser.
- Copy the URL from the address bar. Examples:
- User Watchlist:
https://trakt.tv/users/username/watchlist - Custom List:
https://app.trakt.tv/users/username/lists/listname
- User Watchlist:
- Paste the URL directly into ListSync.
ListSync supports a shortcut format of list-type:media-type. Examples:
trending:movies- Top trending moviespopular:shows- Popular TV showsanticipated:movies- Most anticipated movies
Available Types:
- List types: trending, popular, anticipated, watched, collected, boxoffice, streaming, recommendations, favorited
- Media types: movies, shows
Note: The boxoffice list type is only available for movies.
These special lists sync a configurable number of items (default: 20, can be set via TRAKT_SPECIAL_ITEMS_LIMIT environment variable).
π TMDB
- Navigate to your TMDB list in your browser.
- Copy the URL from the address bar. Examples:
https://www.themoviedb.org/list/12345https://www.themoviedb.org/list/67890-my-favorite-movies
- Paste the URL directly into ListSync.
Note: TMDB lists require the full URL format for proper access.
π TVDB
- Navigate to your TVDB list in your browser.
- Copy the URL from the address bar. Examples:
https://www.thetvdb.com/lists/67890
- Paste the URL directly into ListSync.
Note: TVDB requires the full URL format.
π Letterboxd
- Navigate to your Letterboxd list in your browser.
- Copy the URL from the address bar. Examples:
- Custom Lists:
https://letterboxd.com/username/list/my-list/ - User Watchlist:
https://letterboxd.com/username/watchlist/
- Custom Lists:
- Paste the URL directly into ListSync.
Note: Please have patience with this list provider as it relies on web scraping.
π AniList
- Navigate to your AniList profile in your browser.
- Copy the URL from the address bar. Examples:
- All Lists:
https://anilist.co/user/username/animelist - Specific Status:
https://anilist.co/user/username/animelist/Planning
- All Lists:
- Paste the URL directly into ListSync.
- You can also just enter the username:
username
- This will sync all their anime lists (Watching, Planning, Completed, etc.)
- β Planning - Anime planned to watch
- β Watching - Currently watching
- β Completed - Finished anime
- β Paused - On hold
- β Dropped - Dropped anime
- β Custom Lists - User-created custom lists
Note: Anime titles are automatically resolved to TMDB IDs via Trakt API for Overseerr compatibility. Resolution works with both English and Romaji titles.
π MDBList
- Navigate to your MDBList list in your browser.
- Copy the URL from the address bar. Example:
https://mdblist.com/lists/username/listname
- Paste the URL directly into ListSync.
- You can also use the simpler format:
username/listname
- ListSync will automatically expand this to the full URL.
π SIMKL
SIMKL API currently only supports authenticated user watchlists and does not support custom public lists. We have been in contact with the developers and the required API endpoint for this tool does not have an ETA.
Future Plans: SIMKL support may be re-enabled if/when SIMKL API adds support for custom public lists.
For now, please use Trakt, IMDB, Letterboxd or any other provider for list syncing.
π Steven Lu
This is a curated list of popular movies maintained by Steven Lu, available at:
https://s3.amazonaws.com/popular-movies/movies.json
To enable this list, simply add the below variable:
STEVENLU_LISTS=stevenlu
This will be recognized as the Steven Lu Popular Movies list.
πΏ Basic Configuration
All you need is a .env file with four settings:
OVERSEERR_URL=http://your-overseerr:5055 # Your Overseerr/Jellyseerr URL
OVERSEERR_API_KEY=your-api-key-here # Get from Overseerr Settings β General
TRAKT_CLIENT_ID=your-api-key-here # Trakt API Client ID
IMDB_LISTS=top # Start with IMDb Top 250Optional Settings:
SYNC_INTERVAL=24 # Hours between syncs (default: 24)
AUTOMATED_MODE=true # Enable automatic syncing (default: true)
OVERSEERR_4K=false # Request 4K versions (default: false)
DISCORD_WEBHOOK_URL=... # Discord notifications (optional)
TZ=America/New_York # Your timezone (default: GMT)
# API Keys for Enhanced Functionality (Optional)
TMDB_KEY=... # TMDB API Key (for better performance)
TVDB_KEY=... # TVDB API Key (for enhanced data)
# List Configuration
IMDB_LISTS=top,boxoffice # IMDb lists to sync
TRAKT_LISTS=... # Trakt lists to sync
LETTERBOXD_LISTS=... # Letterboxd lists to sync
ANILIST_LISTS=... # AniList anime lists to sync (username or full URL)
MDBLIST_LISTS=... # MDBList lists to sync
# SIMKL_CLIENT_ID=... # SIMKL API Client ID (DISABLED - see SIMKL section)
# SIMKL_USER_TOKEN=... # SIMKL OAuth Token (DISABLED - see SIMKL section)
TVDB_LISTS=... # TVDB lists to sync (full URLs)
TMDB_LISTS=... # TMDB lists to sync (full URLs)
STEVENLU_LISTS=stevenlu # Steven Lu popular moviesπΏ Pre-configured Lists Template
Want instant content? Use our plug-and-play configuration with curated lists:
cp .env.plugnplay .env
# Then edit your Overseerr URL and API keyIncludes these pre-configured lists:
| Provider | List Type | Description |
|---|---|---|
| IMDb | Chart & Lists | Top 250 Movies, Disney Movies |
| Trakt | Trending & Popular | Trending Movies, Popular Movies, Trending Shows, Popular Shows |
| MDBList | Curated Collections | Top Weekly Movies, Pixar Movies, Pirated Movies Charts |
| Steven Lu | Popular Collection | Popular Movies Collection |
πΏ Timezone Configuration
ListSync automatically timestamps all sync activities and displays them in the web interface. To ensure timestamps match your local time, configure your timezone using any of the three supported formats below.
ListSync supports three timezone formats for maximum flexibility:
# docker-compose.yml or .env file
environment:
- TZ=Europe/Paris # France (CET/CEST with DST)
- TZ=America/New_York # US Eastern (EST/EDT with DST)
- TZ=America/Los_Angeles # US Pacific (PST/PDT with DST)
- TZ=America/Chicago # US Central (CST/CDT with DST)
- TZ=Asia/Tokyo # Japan
- TZ=Australia/Sydney # Australia Eastern
- TZ=Europe/London # UK (GMT/BST with DST)# docker-compose.yml or .env file
environment:
- TZ=EST # US Eastern Standard Time
- TZ=PST # US Pacific Standard Time
- TZ=CET # Central European Time
- TZ=GMT # Greenwich Mean Time
- TZ=BST # British Summer Time
- TZ=AEST # Australian Eastern Standard Time# docker-compose.yml or .env file
environment:
# UTC offsets
- TZ=UTC # Coordinated Universal Time
- TZ=UTC+1 # Central European Time
- TZ=UTC-5 # US Eastern Time
- TZ=UTC-8 # US Pacific Time
- TZ=UTC+8 # China/Singapore Time
- TZ=UTC+5:30 # India Standard Time
# GMT offsets (equivalent to UTC)
- TZ=GMT+1 # Central European Time
- TZ=GMT-5 # US Eastern Time- πΏ IANA Names: Wikipedia TZ Database
- πΏ UTC Offsets: timeanddate.com/time/zones
- π₯οΈ Linux/macOS: Run
timedatectlorcat /etc/timezone - πͺ Windows: Check "Time zone" in Settings β Time & Language
| Format | Best For | Handles DST? | Example |
|---|---|---|---|
| IANA Names | Production use | β Yes | Europe/Paris |
| Abbreviations | Quick setup | β Yes | EST, CET |
| UTC/GMT Offsets | Testing, fixed offsets | β No | UTC+1, GMT-5 |
Tip: Use IANA timezone names for production deployments as they automatically handle Daylight Saving Time (DST) transitions!
πΏ Running ListSync Locally (Without Docker)
- Python 3.9+, Node.js 18+, Chrome/Chromium, Git
# Clone and install dependencies
git clone https://github.com/Woahai321/list-sync.git && cd list-sync
pip install -r requirements.txt -r api_requirements.txt
cd listsync-nuxt && npm install && cd ..Create .env file with:
OVERSEERR_URL=http://your-overseerr:5055
OVERSEERR_API_KEY=your-api-key-here
IMDB_LISTS=topRun these commands in 3 separate terminals:
Terminal 1 - Core Sync Service:
python -m list_syncTerminal 2 - FastAPI Backend:
python start_api.pyTerminal 3 - Nuxt Frontend:
cd listsync-nuxt && npm run devAccess:
- Dashboard:
http://localhost:3222 - API Docs:
http://localhost:4222/docs - Health:
http://localhost:4222/api/system/health
πΏ SeerrBridge Integration
SeerrBridge is our companion application that provides an alternative to traditional *arr stack (Radarr/Sonarr) setup. It works alongside ListSync to create a complete media management solution:
- Automated Processing: When ListSync adds requests to Jellyseerr/Overseerr, SeerrBridge automatically processes them
- Browser Automation: Uses Selenium to automate media fetching through Debrid Media Manager
- Simplified Setup: Eliminates the need for complex *arr stack configuration
- ListSync adds media requests to Jellyseerr/Overseerr
- SeerrBridge detects the requests via webhook
- SeerrBridge automatically processes the requests through DMM
- Media becomes available in your RD library
For detailed information about SeerrBridge, visit the SeerrBridge Repository.
View System Architecture Diagram
%%{init: {'flowchart': {'diagramPadding': 20, 'nodeSpacing': 25, 'rankSpacing': 35, 'curve': 'linear'}}}%%
graph LR
%% Condensed Flow with Reduced Text and More Padding
%% UI
subgraph ui["User Interaction"]
U["πΏ User Opens Dashboard\n(localhost:3222)"] --> D["πΏ Nuxt Dashboard\n(Port 3222)"] --> B["π FastAPI Backend\n(Port 4222)"]
end
%% Core
subgraph core["Core System"]
B --> C["βοΈ Core Sync Engine\n(Python)"] --> DB[("πΎ SQLite DB\n(Lists, History)")]
end
%% Providers
subgraph prov["Data Providers"]
C --> P["πΏ Provider System\n(Multiple Sources)"]
subgraph scrap["Web Scraping (Selenium)"]
P --> S["π Selenium\n(Chrome Browser)"]
S --> I["πΏ IMDb\n(Charts, Lists)"]
S --> L["πΏ Letterboxd\n(Lists)"]
S --> M["πΏ MDBList\n(Collections)"]
S --> Si["πΏ Simkl\n(Watchlists (OAuth))"]
S --> T["πΏ TVDB\n(Favorites, Lists)"]
end
subgraph api["Direct APIs"]
P --> Tr["π Trakt API --> πΏ Trakt\n(Lists, Trending)"]
P --> Tm["π TMDB API --> πΏ TMDB\n(Lists, Collections)"]
P --> A["πΏ AniList GraphQL --> πΏ AniList\n(Anime Lists)"]
P --> St["πΏ Steven Lu S3 --> πΏ Steven Lu\n(Movies List)"]
end
end
%% Pipeline
subgraph pipe["Processing Pipeline"]
P --> E["π Extract Data\n(Title, Year, ID)"]
E --> De["π Deduplicate\n(IMDb ID)"]
De --> Se["π Search Overseerr\n(Fuzzy Match)"]
Se --> Ch["β
Check Status\n(Available?)"]
Ch --> R["πΏ Create Requests\n(Movies, Seasons)"]
end
%% Output
subgraph out["Output & Storage"]
R --> O["π― Overseerr\n(Media Requests)"]
R --> DB
end
%% Feedback
DB -.->|"Feedback Loop"| C
%% Darker Colors
style U fill:#a78bfa,stroke:#6b21a8,stroke-width:2px
style D fill:#8b5cf6,stroke:#7c3aed,stroke-width:2px
style B fill:#7c3aed,stroke:#8b5cf6,stroke-width:2px
style C fill:#9333ea,stroke:#a855f7,stroke-width:3px
style DB fill:#581c87,stroke:#6b21a8,stroke-width:3px
style P fill:#a855f7,stroke:#9333ea,stroke-width:2px
style S fill:#8b5cf6,stroke:#7c3aed,stroke-width:2px
style Tr fill:#7c3aed,stroke:#6b21a8,stroke-width:2px
style Tm fill:#6b21a8,stroke:#581c87,stroke-width:2px
style A fill:#9333ea,stroke:#7c2d12,stroke-width:2px
style St fill:#9333ea,stroke:#7c2d12,stroke-width:2px
style E fill:#9333ea,stroke:#6b21a8,stroke-width:2px
style De fill:#7c3aed,stroke:#581c87,stroke-width:2px
style Se fill:#7c3aed,stroke:#581c87,stroke-width:2px
style Ch fill:#7c3aed,stroke:#581c87,stroke-width:2px
style R fill:#7c3aed,stroke:#581c87,stroke-width:2px
style O fill:#581c87,stroke:#4c1d95,stroke-width:3px
%% Subgraph Style
classDef sub fill:none,stroke:#a855f7,stroke-width:1px,stroke-dasharray: 3 3
class ui,core,prov,scrap,api,pipe,out sub
For a detailed technical breakdown, see our Architecture Documentation.
If you encounter any issues while using ListSync, please check our Troubleshooting Guide for solutions to common problems.
Quick Fixes:
- Sync not working? Check your Overseerr API key and URL
- Lists not loading? Verify list URLs are public and accessible
- Docker issues? Ensure ports 3222 and 4222 are available
- Need help? Join our Discord community for support
For comprehensive documentation, visit our Documentation Hub or explore specific guides:
- User Guide - Complete usage guide with examples
- Installation Guide - Detailed installation instructions
- Configuration Guide - Environment setup and configuration
- API Documentation - Complete REST API reference
- Architecture Overview - Technical architecture and design
If you find ListSync useful and would like to support its development, consider becoming a sponsor:
β‘οΈ Sponsor us on GitHub
Thank you for your support!
We welcome contributions! For guidelines on how to contribute, please see our Contributing Guide.
- Security Best Practices: Please read scripts you find online before running them.
- API Credentials: Always keep your API credentials secure.
- Rate Limiting: Be mindful of provider's rate limiting policies during imports.
- Permissions: Only import and manage media you have the rights to handle.
This project is licensed under the MIT License. Review the LICENSE file for more details.
For important legal information about using ListSync, please refer to our Legal Disclaimer.