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 now includes a web dashboard built with Nuxt 3 and Vue 3, providing a modern interface to manage all your sync operations.
Access your dashboard at: http://localhost:3222
For the most stable experience, use the source code from the latest release here.
Get ListSync running in under 3 minutes:
# 1. Clone and enter directory
git clone https://github.com/Woahai321/list-sync.git && cd list-sync
# 2. Copy environment file
cp .env.example .env
# 3. Edit .env - Add these key settings:
# OVERSEERR_URL=http://your-overseerr:5055
# OVERSEERR_API_KEY=your-api-key
# TRAKT_CLIENT_ID=your-client-id
# IMDB_LISTS=top
# 4. Start ListSync
docker-compose up -dThat's it! Your first sync will start automatically. π
ListSync offers flexible deployment options to suit different use cases, from quick testing to full production deployments with web dashboard.
π¦ Option 1: Full Stack Deployment (Recommended)
Complete solution with web dashboard, API, and 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 default docker-compose.yml
docker-compose up -d
# That's it! Access your dashboard at http://localhost:3222Access Points:
- π Web Dashboard:
http://localhost:3222 - π‘ API Documentation:
http://localhost:4222/docs - π₯ Health Check:
http://localhost:4222/api/system/health
βοΈ 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 for Trakt)
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:
# 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:
# 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:
# TVDB API Configuration
TVDB_KEY=your_api_key_hereListSync supports multiple list services. You can add them using either the raw URL or the list ID.
π 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 three settings:
OVERSEERR_URL=http://your-overseerr:5055 # Your Overseerr/Jellyseerr URL
OVERSEERR_API_KEY=your-api-key-here # Get from Overseerr Settings β General
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)
TRAKT_CLIENT_ID=... # Trakt API Client ID (for better performance)
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!
π§ Local Development & Manual Setup
For developers or advanced users who want to run ListSync without Docker or need a development environment.
- Python 3.9+
- Node.js 18+ (for web dashboard)
- Chrome/Chromium browser
- Git
Additional Resources:
- π Detailed Installation Guide
- π₯ Contributing Guide
- ποΈ Architecture Overview
π 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
graph TD
%% User Journey
User[π€ User Opens Docker<br/>localhost:3222] --> AddLists[π Add Lists via Web UI<br/>IMDb β’ Trakt β’ AniList β’ Letterboxd β’ etc.]
AddLists --> Config[βοΈ Configure Settings<br/>Sync Interval β’ API Keys β’ Notifications]
%% Application Stack
Config --> Frontend[π₯οΈ Nuxt 3 Dashboard<br/>Port 3222]
Frontend --> API[π FastAPI Backend<br/>Port 4222]
API --> Core[βοΈ Core Sync Engine<br/>Python Orchestration]
Core --> DB[(πΎ SQLite Database<br/>Lists β’ History β’ Tracking)]
%% Provider System
Core --> Providers[π¦ Provider System<br/>Multiple Data Sources]
%% Selenium Web Scraping
Providers --> Selenium[π Selenium Web Scraping<br/>Chrome Headless Browser]
Selenium --> IMDb[IMDb Lists<br/>Charts β’ User Lists β’ Watchlists]
Selenium --> Letterboxd[Letterboxd<br/>User Lists β’ Watchlists]
Selenium --> MDBList[MDBList<br/>Curated Collections]
Selenium --> Simkl[Simkl API Watchlists<br/>(OAuth)]
Selenium --> TVDB[TVDB<br/>User Favorites β’ Public Lists]
%% Direct API Calls
Providers --> TraktAPI[π Trakt API<br/>Direct REST API Calls]
TraktAPI --> Trakt[Trakt Lists<br/>User Lists β’ Trending β’ Popular]
%% TMDB API
Providers --> TMDBAPI[π TMDB API<br/>The Movie Database API]
TMDBAPI --> TMDB[TMDB Lists<br/>Public Lists β’ Collections]
%% AniList GraphQL API
Providers --> AniListAPI[β¨ AniList GraphQL<br/>Anime Database API]
AniListAPI --> AniList[AniList Lists<br/>User Anime Lists β’ Watchlists]
%% Steven Lu S3 Bucket
Providers --> StevenLuAPI[π¦ Steven Lu S3<br/>JSON File from S3 Bucket]
StevenLuAPI --> StevenLu[Steven Lu<br/>Popular Movies List]
%% Processing Pipeline
Providers --> Extract[π Extract Media Data<br/>Title β’ Year β’ IMDb ID β’ Type]
Extract --> Dedupe[π Deduplicate Items<br/>by IMDb ID]
Dedupe --> Search[π Search in Overseerr<br/>Fuzzy Matching β’ Levenshtein Distance]
Search --> CheckStatus[β
Check Media Status<br/>Available? Requested? Needs Request?]
CheckStatus --> CreateRequests[π€ Create Media Requests<br/>Movies β’ TV Seasons]
%% Target System
CreateRequests --> Overseerr[π― Overseerr/Jellyseerr<br/>Media Request Management]
CreateRequests --> DB
%% Styling
style User fill:#c4b5fd,stroke:#6b21a8,stroke-width:2px
style AddLists fill:#a78bfa,stroke:#7c3aed,stroke-width:2px
style Config fill:#8b5cf6,stroke:#8b5cf6,stroke-width:2px
style Frontend fill:#9333ea,stroke:#a855f7,stroke-width:3px
style API fill:#7c3aed,stroke:#9333ea,stroke-width:3px
style Core fill:#6b21a8,stroke:#7c3aed,stroke-width:3px
style DB fill:#581c87,stroke:#6b21a8,stroke-width:3px
style Providers fill:#a855f7,stroke:#9333ea,stroke-width:2px
style Selenium fill:#8b5cf6,stroke:#7c3aed,stroke-width:2px
style TraktAPI fill:#7c3aed,stroke:#6b21a8,stroke-width:2px
style TMDBAPI fill:#6b21a8,stroke:#581c87,stroke-width:2px
style StevenLuAPI fill:#9333ea,stroke:#7c2d12,stroke-width:2px
style Extract fill:#9333ea,stroke:#6b21a8,stroke-width:2px
style Search fill:#7c3aed,stroke:#581c87,stroke-width:2px
style Overseerr fill:#581c87,stroke:#4c1d95,stroke-width:3px
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.