Home

Awesome

<h1 align="center">Jellyfin TubeArchivist Plugin</h1> <p align="center"> <img alt="Plugin Banner" src="https://raw.githubusercontent.com/tubearchivist/tubearchivist-jf-plugin/master/images/logo.png"/> <br/> </p>

[!IMPORTANT] Jellyfin release cycle has changed in the past few months and now it is shorter than before. The plugin supports only the latest Jellyfin release, in order to continue using this plugin with all the latest features you will need to upgrade your Jellyfin installation.

About

<p>This plugin adds the metadata provider for <a href="https://www.tubearchivist.com/">TubeArchivist</a>, offering improved flexibility and native integration with Jellyfin compared to previous solutions.</p>

How it works

The media organization is a Shows collection, where each channel is a show and its videos are the episodes, organized in seasons by year.<br> The plugin interacts with TubeArchivist APIs to fetch videos and channels metadata.

Features

Installation

From official repository (recommended)

  1. Go to Dashboard -> Plugins and select the Repositories tab
  2. Add a new repository with the following details:
  1. Go to the Catalog tab
  2. Find TubeArchivistMetadata in the Metadata section and install it Find plugin
  3. Restart Jellyfin to apply the changes

From ZIP in GitHub releases

  1. Download the latest available release (tubearchivistmetadata_*.zip) from the repository releases section
  2. Extract the contained files in the plugins/TubeArchivistMetadata folder (you might need to create the folders) of your Jellyfin installation
  3. Restart Jellyfin to apply the changes

Configuration

<p>This plugin requires that you have already an instance of TubeArchivist up and running.</p> Once installed, you have to configure the following parameters in the plugin configuration: <ul> <li>Collection display name</li> <li>TubeArchivist instance address</li> <li>TubeArchivist API key</li> <li>Overviews length (channels and videos descriptions)</li> <li>Playback synchronization settings discussed in the <a href="#playback-synchronization">Playback synchronization</a> paragraph</li> </ul>

Plugin configuration

Use the plugin

<p>Using the plugin is very simple. Let's start from the beginning:</p>

NOTE: If you are using Docker containers, it is important to mount the TubeArchivist media path into Jellyfin container as read-only, in order to avoid possible operations on the media files that will break TubeArchivist. <br>

  1. Go to Dashboard -> Libraries and add a media library

  2. In the form select Shows as Content type, set a display name for the library and set the TubeArchivist media folder in the Folders section Add library

  3. Scrolling down, uncheck all metadata and image providers except TubeArchivist. (You won't find TubeArchivist in seasons providers, so just disable everything there)

  4. Save and come back to Home, you will see the newly added library. Jellyfin will have executed the metadata fetching for you after the collection creation and then you will see the metadata and the images of channels and videos

Playback synchronization

<p>Starting from v1.3.1 this plugin offers playback progress and watched status bidirectional synchronization, but you can choose to enable only a one way synchronization (Jellyfin->TubeArchivist or TubeArchivist->Jellyfin) too.</p>

Jellyfin->TubeArchivist synchronization

<p>This kind of synchronization is done listening for progress and watched status changes while playing the videos for the specified users.<br>Furthermore, there is a task that runs at Jellyfin startup to synchronize the whole library.</p> <p>In the plugin configuration you will find these settings:</p>

JF->TA playback synchronization settings

<p>In the text field you can specify one Jellyfin username to synchronize data of to TubeArchivist.</p>

TubeArchivist->Jellyfin synchronization

<p>This kind of synchronization is done using a Jellyfin scheduled task that regularly synchronizes data from TubeArchivist API to Jellyfin.</p> <p>In the plugin configuration you will find these settings:</p>

TA->JF playback synchronization settings

<p>In the first text field you can specify one or more Jellyfin usernames to update data for.<br> In the second field you can specify the interval in seconds the task should run at, so that you can choose according to your system requirements. The lower is the interval the higher will be the resources consuption on your system.</p>

Build

  1. To build this plugin you will need .Net 8.x.

  2. Build plugin with following command

$ dotnet publish Jellyfin.Plugin.TubeArchivistMetadata --configuration Release --output bin
  1. Place the dll-file in the plugins/tubearchivist-jf-plugin folder (you might need to create the folders) of your Jellyfin installation

License

This plugins code and packages are distributed under the GPLv3 License. See LICENSE for more information.