Co-authored-by: rlauu <46294892+rlauu@users.noreply.github.com>
Intro Skipper (beta)
Jellyfin 10.8
👉👉👉 Jellyfin 10.8 Instructions
System requirements
- Jellyfin 10.9.3 (or newer)
- Jellyfin's fork of
ffmpeg
must be installed, version6.0.1-5
or newerjellyfin/jellyfin
10.9.z container: preinstalledlinuxserver/jellyfin
10.9.z container: preinstalled- Debian Linux based native installs: provided by the
jellyfin-ffmpeg6
package - MacOS native installs: build ffmpeg with chromaprint support (instructions)
Detection parameters
Show introductions will be detected if they are:
- Located within the first 25% of an episode or the first 10 minutes, whichever is smaller
- Between 15 seconds and 2 minutes long
Ending credits will be detected if they are shorter than 4 minutes.
These parameters can be configured by opening the plugin settings
Installation
Step 1: Install the plugin
- Add this plugin repository to your server:
https://raw.githubusercontent.com/jumoog/intro-skipper/master/manifest.json
- Install the Intro Skipper plugin from the General section
- Restart Jellyfin
Step 2: Configure the plugin
- OPTIONAL: Enable automatic skipping or skip button
- Go to Dashboard -> Plugins -> Intro Skipper
- Check "Automatically skip intros" or "Show skip intro button" and click Save
- Go to Dashboard -> Scheduled Tasks -> Analyze Episodes and click the play button
- After a season has completed analyzing, play some episodes from it and observe the results
- Status updates are logged before analyzing each season of a show
Troubleshooting
Scheduled tasks fail instantly
- Verify that Intro Skipper can detect ffmpeg with Chromaprint
- Dashboard -> Plugins -> Intro Skipper -> Support Bundle Info
- Verify that ffmpeg is installed and detected by jellyfin
- Dashboard -> Playback -> FFmpeg path
- Verify that Chromaprint is enabled in ffmpeg (
--enable-chromaprint
)
Skip button is not visible
-
Verify you have successfully completed the scheduled task at least once
-
Clear your browser cache and reload the Jellyfin server webpage
-
Fix any permission mismatches between the web folder and Jellyfin server
-
Official Jellyfin Docker: The container is being run as a non-root user while having been built as a root user, causing the web files to be owned by root. To solve this, you can remove any lines like
User: 1000:1000
, etc. from the Jellyfin Docker Compose file. -
LinuxServer Docker Container: Set an environment variable
DOCKER_MODS=ghcr.io/jumoog/intro-skipper
to ensure the permissions are set correctly for the skip button:services: jellyfin: image: lscr.io/linuxserver/jellyfin:latest container_name: jellyfin environment: - PUID=1000 - PGID=1000 - TZ=Etc/UTC - DOCKER_MODS=ghcr.io/jumoog/intro-skipper
- Install from distro repositories - the jellyfin-server will execute as
jellyfin
user while the web files will be owned byroot
,www-data
, etc. This can likely be fixed by adding thejellyfin
user (or whichever user executes the jellyfin server) to the same group that owns the jellyfin-web folders. You should only do this if they are owned by a group other than root.
-
-
The official Android TV app do not support the skip button. For this app, you will need to use the autoskip option. Please note that there is currently an issue with autoskip not working because the apps never receive the seek command from Jellyfin.
Installation (MacOS)
- Build ffmpeg with chromaprint support using brew:
- macOS 12 or newer can install the portable jellyfin-ffmpeg
brew uninstall --force --ignore-dependencies ffmpeg
brew install chromaprint amiaopensource/amiaos/decklinksdk
brew tap homebrew-ffmpeg/ffmpeg
brew install homebrew-ffmpeg/ffmpeg/ffmpeg --with-chromaprint
brew link --overwrite ffmpeg
- Open ~/.config/jellyfin/encoding.xml and add or edit the following lines
- Replace [FFMPEG_PATH] with the path returned by
whereis ffmpeg
- Replace [FFMPEG_PATH] with the path returned by
<EncoderAppPath>[FFMPEG_PATH]</EncoderAppPath>
<EncoderAppPathDisplay>[FFMPEG_PATH]</EncoderAppPathDisplay>
- Follow the general installation instructions above
Documentation
Documentation about how the API works can be found in api.md.