Can't decide what to watch? Movie Roulette helps you pick random movies from your Plex and/or Jellyfin libraries, with features like cinema poster mode, service integrations, and device control.
This project was extended with the assistance of AI tools. The core functionality is based on Random-Plex-Movie and has been expanded with additional features and integrations.
- 🎬 Media Server Support: Get random movies with Plex, Jellyfin, Emby
- 🎫 Cinema Poster Mode: Digital movie poster display with real-time progress
- 🔍 Smart Discovery: Filter by watch status, genre, year, and rating
- 📱 PWA Support: Install as app on mobile and desktop
- 🎮 Device Control: Power on Apple TV and TV devices directly in the selected service application
- 🔄 Service Integration:
- Trakt for global watch status
- Overseerr/Jellyseerr/Ombi for requests
- YouTube for trailers
Note: Ensure your client devices and Plex server are on the same network. On the first run, a Plex cache file will be created to enhance movie loading speeds.
- Apple TV - with turn on function and app start
- Plex HTPC MacOS Client
- iPhone
- Plex for LGTV (WebOS) - with turn on function and app start
- Xiaomi MI TV Box S (Android)
- All cast capable devices
- Apple TV - with turn on function and app start
- Jellyfin for LGTV (WebOS) - with turn on function and app start
- All cast capable devices
- Apple TV - with turn on function and app start
- Emby for LGTV (WebOS) - with turn on function and app start
Registry | Architecture | Version | Image Path |
---|---|---|---|
Docker Hub | AMD64 | Latest | sahara101/movie-roulette:latest |
Docker Hub | ARM64/ARMv7 | Latest | sahara101/movie-roulette:arm-latest |
GHCR | AMD64 | Latest | ghcr.io/sahara101/movie-roulette:latest |
GHCR | ARM64/ARMv7 | Latest | ghcr.io/sahara101/movie-roulette:arm-latest |
Instead of latest you can also use the version number.
services:
movie-roulette:
image: #See above
container_name: movie-roulette
ports:
- "4000:4000"
volumes:
- ./movie_roulette_data:/app/data
restart: unless-stopped
Visit http://your-server:4000
and configure your services.
Note: For device control (Apple TV/LG TV), use
network_mode: host
instead of port mapping.
For MacOS non-docker application please check here
- Automatically redirects to settings if no services configured
- Set up at least one media server (Plex/Jellyfin/Emby)
- Wait for initial cache building for Plex
- Optional: Configure additional services (Trakt, Overseerr, etc.)
- Server URL
- Token (OAuth available)
- Movie Libraries (auto-scan available)
- Server URL
- API Key
- User ID
- Server URL
- API Key
- User ID
- TMDb (built-in key provided or custom API)
- Trakt (built-in app or custom credentials)
- Overseerr/Jellyseerr/Ombi (optional, for requests)
- Apple TV (auto-discovery available)
- LG WebOS, Samusng Tizen (pre-alpha), Android Sony (pre-alpha) (network scanning available)
See sample-compose.yml for full configuration options.
-
Standard Mode
- Random movie selection
- Filter options
- Search movies
- Movie details and trailers
- Cast/crew filmographies
-
Cinema Poster Mode
- Real-time playback status
- Now Playing display
- Custom default text
- Multiple user monitoring
-
Homepage Mode
- Minimalist widget
Movie Roulette offers two ways to configure the application:
-
Settings UI (Recommended)
- Easy-to-use interface at
/settings
- Auto-discovery features
- Real-time validation
- Visual configuration
- Easy-to-use interface at
-
Environment Variables
- Override UI settings
- Lock settings in UI
⚠️ Important: When a setting is configured through ENV variables, it will:
- Take precedence over UI settings
- Show as "Set by environment variable" in UI
- Be locked/disabled in settings interface
Variable | Description | Default | UI Alternative |
---|---|---|---|
PLEX_URL |
Plex server URL | - | ✅ Settings with test |
PLEX_TOKEN |
Plex auth token | - | ✅ OAuth flow |
PLEX_MOVIE_LIBRARIES |
Movie library names | "Movies" | ✅ Library scanner |
JELLYFIN_URL |
Jellyfin server URL | - | ✅ Settings |
JELLYFIN_API_KEY |
Jellyfin API key | - | ✅ Auto setup |
JELLYFIN_USER_ID |
Jellyfin user ID | - | ✅ Auto setup |
EMBY_URL |
Emby server URL | - | ✅ Settings |
EMBY_API_KEY |
Emby API key | - | ✅ Settings |
EMBY_USER_ID |
Emby user ID | - | ✅ Settings |
Variable | Description | Default | UI Alternative |
---|---|---|---|
DISABLE_SETTINGS |
Lock Settings page | FALSE | - |
HOMEPAGE_MODE |
Homepage widget mode | FALSE | ✅ Settings |
TMDB_API_KEY |
Custom TMDb key | Built-in key | ✅ Settings |
USE_LINKS |
Show links buttons | TRUE | ✅ Settings |
USE_FILTER |
Show filter button | TRUE | ✅ Settings |
USE_WATCH_BUTTON |
Show Watch button | TRUE | ✅ Settings |
USE_NEXT_BUTTON |
Show next button | TRUE | ✅ Settings |
ENABLE_MOBILE_TRUNCATION |
Choose if descriptions are truncated on mobile | FALSE | ✅ Settings |
Variable | Description | Default | UI Alternative |
---|---|---|---|
OVERSEERR_URL |
Overseerr URL | - | ✅ Settings |
OVERSEERR_API_KEY |
Overseerr API key | - | ✅ Settings |
JELLYSEERR_URL |
Jellyseerr URL | - | ✅ Settings |
JELLYSEERR_API_KEY |
Jellyseerr API key | - | ✅ Settings |
OMBI_URL |
Ombi server URL | - | ✅ Settings |
OMBI_API_KEY |
Ombi API key | - | ✅ Settings |
REQUEST_SERVICE_DEFAULT |
Default request service | "auto" | ✅ Settings |
REQUEST_SERVICE_PLEX |
Plex request service override | "auto" | ✅ Settings |
REQUEST_SERVICE_JELLYFIN |
Jellyfin request service override | "auto" | ✅ Settings |
REQUEST_SERVICE_EMBY |
Emby request service override | "auto" | ✅ Settings |
Variable | Description | Default | UI Alternative |
---|---|---|---|
APPLE_TV_ID |
Apple TV identifier | - | ✅ Auto-discovery |
TV_<NAME>_TYPE |
TV type (webos , tizen , android ) |
- | ✅ Auto-discovery |
TV_<NAME>_IP |
TV IP address | - | ✅ Auto-discovery |
TV_<NAME>_MAC |
TV MAC address | - | ✅ Auto-discovery |
Note: Replace with your chosen TV identifier (e.g., TV_LIVING_ROOM_TYPE: "webos"). Only use letters, numbers, and underscores.
Variable | Description | Default | UI Alternative |
---|---|---|---|
TZ |
Poster timezone | UTC | ✅ Settings |
DEFAULT_POSTER_TEXT |
Default text | - | ✅ Settings |
PLEX_POSTER_USERS |
Plex users to monitor | - | ✅ User selector |
JELLYFIN_POSTER_USERS |
Jellyfin users to monitor | - | ✅ User selector |
EMBY_POSTER_USERS |
Emby users to monitor | - | ✅ User selector |
Variable | Description | Default | UI Alternative |
---|---|---|---|
TRAKT_CLIENT_ID |
Custom Trakt app ID | Built-in app | ✅ Built-in auth |
TRAKT_CLIENT_SECRET |
Custom Trakt secret | Built-in app | ✅ Built-in auth |
TRAKT_ACCESS_TOKEN |
Custom access token | - | ✅ Built-in auth |
TRAKT_REFRESH_TOKEN |
Custom refresh token | - | ✅ Built-in auth |
Navigate to settings and enable Advertise as Player.
Go to settings → Network and activate Enable Local Network Discovery (GDM).
-
Get Apple TV ID:
docker exec -ti movie-roulette /bin/sh atvremote scan
-
Note the Apple TV Identifier (format: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx)
-
Add to environment: environment: APPLE_TV_ID: "your-apple-tv-identifier"
-
Pair with Apple TV:
docker exec -ti movie-roulette /bin/sh atvremote --id YOUR-ID --protocol companion pair
-
Enter PIN shown on Apple TV
Movie Roulette supports multiple TV instances using a dynamic naming pattern. Each TV is configured with a name and its required parameters. The application supports multiple TV platforms:
Supported TV Types:
webos
: LG WebOS TVstizen
: Samsung Tizen TVsandroid
: Android-based TVs
Configuration example:
environment:
# Example for LG WebOS TV in living room
TV_LIVING_ROOM_TYPE: "webos"
TV_LIVING_ROOM_IP: "192.168.1.100"
TV_LIVING_ROOM_MAC: "AA:BB:CC:DD:EE:FF"
# Example for Samsung TV in bedroom
TV_BEDROOM_TYPE: "tizen"
TV_BEDROOM_IP: "192.168.1.101"
TV_BEDROOM_MAC: "11:22:33:44:55:66"
# Example for Android TV in kitchen
TV_KITCHEN_TYPE: "android"
TV_KITCHEN_IP: "192.168.1.102"
TV_KITCHEN_MAC: "CC:DD:EE:FF:00:11"
Add to Homepage's services.yaml:
- Movie Roulette:
- Movie Roulette:
icon: /images/icons/movie-roulette.png
widget:
type: iframe
src: "http://your-server:4000"
classes: h-96 w-full
referrerPolicy: same-origin
Issue: Pressing the "WATCH" button doesn’t show any client.
- Verify Advertise as Player is enabled on the Plex client and restart the app.
- Check for active clients using:
curl -X GET "http://PLEXIP:32400/clients?X-Plex-Token=PLEXTOKEN"
- (Apple TV) Disable and re-enable Advertise as Player, force close the app, and restart.
Issue: Apple TV doesn’t turn on.
- You need to re-pair the Apple TV after recreating the container.
Issue: Browser doesn’t load the poster or background.
- Use the FQDN (Fully Qualified Domain Name) for Plex/Jellyfin in the environment variables/settings instead of the IP address.
If you find Movie Roulette useful, consider supporting development: