title | slug | description | upstream | sponsorship | links | ||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Seamless Plex / Debrid automation with Riven |
Riven |
Riven is a WIP rewrite of plex_debrid, supporting Plex torrent streaming through Real Debrid and 3rd party services like Overseerr, Mdblist, etc. |
|
|
Riven is a re-imagining of original functions of [plex-debrid][plex-debrid], enabling Plex-based torrent streaming through Real Debrid and 3rd party services like Overseerr, Mdblist, etc.
!!! tip "Riven gets revenue! ❤️" Riven is an "Elf-illiated" app - the devs are actively supporting users in our [Discord][discord] community, the app itself is tuned to work perfectly with ElfHosted "out-of-the-box", and 100% of your subscriptions are contributed to the Riven devs to further development!
<iframe width="560" height="315" src="https://www.youtube.com/embed/ZHZAEhLuJqk?si=t5HJ5RT8UOfDDuXs" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe>Unlike most ElfHosted apps, Riven is (currently) split into two - the frontend, and the backend:
A lot of progress has been made on the frontend UI! It can be used for the entire on-boarding process, with the exception of the quality/ranking settings. These settings are currently configuired in the settings.json
file found in `config/riven via [FileBrowser][filebrowser]. All of the other settings can be directly modified with the frontend UI, in addition to a number of Riven functions.
The Riven backend is what's functionally complete. On the backend, you'll see the logs displayed as Riven searches for your content, adds it to your RealDebrid library, symlinks it to /storage/symlinks
, and updates Plex accordingly
To restart the backend, hit CTRL-C
once in the ttyd/browser UI to terminate the process, and then hit Enter
to reconnect to the session and watch it restart.
At a minimum, Riven requires:
- Your RealDebrid API key
- A [claimed][elfbot] [Plex][plex] server
- A [Plex token][plex-token]
And optionally, Riven will work with:
- An [Overseerr][overseerr] instance, for managing media requests
- A [Jackett][jackett] instance, to provide additional content scraping targets
- A [Prowlarr][prowlarr] instance, to provide additional content scraping targets
First and formost, you must first setup Zurg before any setup can be completed with Riven itself.
- Retrive your Real-Debrid API token via their website.
- Navigate to Zurg's
config.yml
file found inconfig/riven
via [FileBrowser][filebrowser]. - Add your Real-Debrid token Zurg's
confiig.yml
file and save your changes. - Restart Zurg, either by using the Elfbot command
elfbot restart realdebird-zurg
or by deleting the pod for Zurg via [Kubernetes][kubernetes].
Claim your Plex server:
- See [this guide][plex-token] for instructions regarding claiming your Plex token.
Create your Plex libraries:
Using the Plex button on your Dashboard, go to your newly claimed Plex server.
- Create a library for you Movies and set the path to
/storage/symlinks/movies/
. - Create a library for you TV Shows and set the path to
/storage/symlinks/shows/
. NOTE: Make certain you are not enabling any of the features to generate thumbnails or intro/credit detection.
NOTE: Some of the Overseerr setup is already done by default for new installations or following a reset of the Overseerr app.
To integrate Overseerr with Riven, first setup Overseerr to integrate with Plex, and then...
- Configure a webhook pointing to
http://riven:8080/webhook/overseerr
:
- Enable your webhook for
Request Automatically Approved
andRequest Approved
:
- Retrieve your Overseerr API key, which will be used in Riven:
To perform a basic Riven setup, use the frontend, and navigate to Settings:
General Settings
- Enable your chosen option in the
Downloaders
section. - Input your API key for that downloader.
- Save your changes.
Media Server Settings
- Enable
Plex Updater
in theUpdaters
section. - Authenticate your Plex server within the
Plex Token
section. - Save your changes.
Content
- Enable your preferred options (you must choose at least one) in the
Content Providers
section. Please see theContent Request Providers
sections found below. - Apply the relevant settings.
- Save your changes.
Scrapers
- Enable
Torrentio
,Knightcrawler
,Annatar
,Mediafusion
, andZilean
. (up to you if you want use others) - Enable
Ratelimit
for all scrapers. - Save your changes.
Ranking
Note: These settings will soon appear in the Riven frontend UI. Currently, these settings are configuired in the settings.json
file found in config/riven
via [FileBrowser][filebrowser].
Please refer to these guides:
- Navigate to the Watchlist section of your Plex Media Server settings.
https://<username>-plex.elfhosted.cc/web/index.html#!/settings/watchlist
- Copy the appropriate washlist RSS feed link(s)
- Enable
Plex Watchlist
within the Riven frontend UIContent
section of its settings. - Add the RSS feed link(s) to the
Plex Watchlist Rss
setting. - Save your changes.
- Retrieve your Overseerr API key:
- Enable
Overseerr
within the Riven frontend UIContent
section of its settings. - Apply the relevant settings:
- The Overseerr URL is
http://overseerr:5055
- Add your Overseerr API key.
- Enable the
Use Webhook
setting.
- Save your changes.
- Visit the Create a Trakt API app page.
- Name it whatever you like.
- For
Redirect uri:
use the default value ofurn:ietf:wg:oauth:2.0:oob
. Description:
,Javascript (cors) origins:
, andPermissions:
can be left blank/default.- Click on
SAVE APP
. - Enable
Trakt
within the Riven frontend UIContent
section of its settings. - Apply the relevant settings:
- Use the
Client ID:
provided is yourTrakt Api Key
. - The various Trakt functions are optional, but you should enable one or more of them if you wish to use Trakt with Riven.
- Save your changes.
That's it, a minimal configuration! 🥳 Now load the backend, and watch the magic! 🪄
{% include 'app_footer.md' %}