This Python-based application is designed to automate the management and organization of media cover art, posters, and fanart for your Jellyfin libraries. It helps maintain a clean and consistent media artwork structure by processing, organizing, and managing cover images for movies, TV shows, and collections.
- ZIP file support for batch processing (ThePosterDB, MediUX)
- Management of unmatched content and automatic reprocessing
- Blacklist system for problematic entries or libraries
- Multi-language title support (TMDb API)
- Movie, TV show, season, episode, and backdrop image management
- Content change detection for Jellyfin libraries
- Tracks missing and unused folders
- Webhook support to trigger manual poster updates
- Mediux set downloader
- Python 3.12+ (if running locally)
- Docker and Docker Compose (if running containerized)
- Jellyfin server
- TMDb API key
- Create a
docker-compose.yml
:
services:
jellyfinupdateposter:
image: iceshadow/jellyfinupdateposter:latest
environment:
- JELLYFIN_URL=http://jellyfin:8096
- JELLYFIN_API_KEY=your-jellyfin-api-key
- TMDB_API_KEY=your-tmdb-api-key
- INCLUDE_EPISODES=false
- TZ=Europe/Berlin
- ENABLE_WEBHOOK=false
- SCHEDULED_TIMES=06:00,12:00,18:00 # Optional: Schedule poster updates at specific times (HH:MM)
volumes:
- ./your-local-path:/mount
ports:
- 8080:8080
restart: unless-stopped
command: "--force"
- Clone the repository:
git clone https://github.com/Iceshadow1404/JellyfinUpdatePoster
cd JellyfinUpdatePoster
- Install required dependencies:
pip install -r requirements.txt
Create a .env
file in the root directory:
JELLYFIN_URL=http://your-jellyfin-server:8096
JELLYFIN_API_KEY=your-jellyfin-api-key
TMDB_API_KEY=your-tmdb-api-key
INCLUDE_EPISODES=false
ENABLE_WEBHOOK=false
SCHEDULED_TIMES=06:00,12:00,18:00 # Optional: Schedule poster updates at specific times (HH:MM)
Required configuration variables:
JELLYFIN_URL
: The URL of your Jellyfin serverJELLYFIN_API_KEY
: Your Jellyfin API keyTMDB_API_KEY
: Your TMDb API key (required for multi-language support)INCLUDE_EPISODES
: Whether to include episode images (true/false)
The application creates and manages the following directory structure:
├── RawCover/ # Drop your cover images here
├── Cover/ # Processed cover images
│ ├── Poster/ # Movie and TV show posters
│ ├── Collections/ # Collection artwork
│ └── No-Match/ # Unmatched artwork
├── Consumed/ # Processed source files
├── Replaced/ # Archived replaced artwork
The application supports various file naming patterns:
- Movie posters:
MovieName (Year).ext
- TV Show posters:
ShowName (Year).ext
- TV Show episodes:
ShowName/S01E02.ext
- Season posters:
ShowName/Season01.ext
- Collection posters:
CollectionName.ext
- Backdrop images:
backdrop.ext
Start the container:
docker compose up
Drop your image or .zip files into the RawCover
folder.
Run the main script:
python main.py
For a force update:
python main.py --force
Drop your image or .zip files into the RawCover
folder.
- Fetches titles from TMDb in multiple languages (English, German, and alternative titles)
- Handles both original titles and localized versions
- Monitors Jellyfin library for new or modified content
- Automatically triggers updates when changes are detected
- Supports multiple image types (Movie, TV show, season, episode, and backdrop)
- Tracks missing and unused folders
- When enabled, sends POST requests to http://your_ip:8080/trigger to manually trigger cover processing.
- Check status via GET request to /status.
- Simply paste a Mediux set link into the mediux.txt file
- Feel free to message me on discord
Iceshadow_
if you have any questions or need help
This project is licensed under the MIT License - see the LICENSE file for details.