Skip to main content

Subtitle Download Web Service for Sonarr

Project description

Build Status Docker Automated buil Pypi package PyPI Coveralls codecov Maintainability MIT licensed

Subtitle Download Web Service for Sonarr or Radarr. It uses Subliminal to search automatically for missing subtitles on download notification.

Usage

The best usage is through the docker image.

Use with Docker

Use my docker image:

docker create \
    --name dopplerr \
    -p 8086:8086 \
    -e PUID=<UID> \
    -e PGID=<GID> \
    -v <path/to/animes>:/animes \
    -v <path/to/movies>:/movies \
    -v <path/to/tvseries>:/tv \
    -e DOPPLERR_LANGUAGES="fra,eng" \
    stibbons31/dopplerr

Mount your media directory in /media. This directory exists in the docker image, so if you have several media directory (/series, /tv, /animes), mount them all in /media and set the following environment variable: DOPPLERR_BASEDIR=/media.

It is a good practive to run Sonarr and Radarr in their own container, so they also “see” their media in path such as /series, /tv, /animes. Mount these volume with the same name in the dopplerr container. They will all communicate with the same path.

Base directory (DOPPLERR_BASEDIR environment variable) can be used to put all these folder in same directory. If DOPPLERR_BASEDIR is not defined, Dopplerr will assume the path communicated by Sonarr or Radarr also exists locally. So mount your series folder to /series, TV show folder to /tv, and animes to /animes and so on.

Parameters

The parameters are split into two halves, separated by a colon, the left hand side representing the host and the right the container side. For example with a port -p external:internal - what this shows is the port mapping from internal to external of the container. So -p 8080:80 would expose port 80 from inside the container to be accessible from the host’s IP on port 8080 (Ex: http://192.168.x.x:8080).

Example of starting command line arguments: - -p 8086:8086 - the port webinterface - -v /path/to/anime:/anime - location of Anime library on disk - -v /path/to/movies:/movies - location of Movies library on disk - -v /path/to/tv:/tv - location of TV library on disk - -e PGID=1000 - for for GroupID. See below for explanation - -e PUID=100 - for for UserID. See below for explanation - -e DOPPLERR_LANGUAGES=fra,eng - set wanted subtitles languages (mandatory) - -e DOPPLERR_BASEDIR=/app - set media base directory (optional) - -e DOPPLERR_VERBOSE=1 - set verbosity. 1=verbose, 0=silent (optional)

User / Group Identifiers

Sometimes when using data volumes (-v flags) permissions issues can arise between the host OS and the container. We avoid this issue by allowing you to specify the user PUID and group PGID. Ensure the data volume directory on the host is owned by the same user you specify and it will “just work” TM.

In this instance PUID=1001 and PGID=1001. To find yours use id user as below:

$ id <dockeruser>
uid=1001(dockeruser) gid=1001(dockergroup) groups=1001(dockergroup)

Wanted subtitle languages

Use a comma-separated list of 3-letter language descriptors you want Subliminal to try to download them.

Example:

DOPPLERR_LANGUAGES=fra,eng

Descriptors are ISO-639-3 names of the language. See the official Babelfish table to find your prefered languages.

Local installation:

Create a dedicated virtual environment and install it properly with the following commands:

sudo ./bootstrap-system.sh
make install-local

This will install dopplerr in a local virtual environment will all its dependencies without messing with your system’s Python environment.

Installing in your system

Do NOT install a Python application in your system. Always use a Virtualenv. Or let it be handled by your distribution’s maintainer.

This method is used when building the docker image (and the travis build):

sudo ./bootstrap-system.sh
sudo make install-system

Radarr/Sonarr Configuration

Go in Settings to configure a “Connect” WebHook:

  • Settings > Connect > add WebHook notification

  • Select On Download and On Upgrade

  • URL: http://<ip address>:8086/notify

  • Method: POST

Two READMEs ?

There is a little trick to know about READMEs:

  • Docker Hub does not render README written in restructuredText correctly

  • Pypi does not render README written in Markdown correctly

So, a restructuredText version of the README is created from README.md on upload to Pypi. Simple. So, when updating README.md, do not forget to regenerate README.rst using make readme.

Contributing

Bootstrap your system with

sudo ./bootstrap-system.sh

System dependencies:

  • git

  • make

  • pandoc

  • pip

  • pipenv

Setup your environment with

make dev

Unit Tests with:

make test-unit

or run it live with

make run-local

Activate the environment (to start your editor from, for example):

$ make shell

Publishing to Pypi

(This part should be automatically done by Travis on successful tag build)

Build Wheel package:

make wheels

Register and publish your package to Pypi:

make pypi-publish

Create a release: create a tag with a semver syntax. Optionally you can tag code locally and push to GitHub.

git tag 1.2.3
git push --tags

On successful travis build on the Tag branch, your Pypi package will be automatically updated.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dopplerr-0.2.12.tar.gz (25.5 kB view details)

Uploaded Source

Built Distribution

dopplerr-0.2.12-py2.py3-none-any.whl (15.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file dopplerr-0.2.12.tar.gz.

File metadata

  • Download URL: dopplerr-0.2.12.tar.gz
  • Upload date:
  • Size: 25.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for dopplerr-0.2.12.tar.gz
Algorithm Hash digest
SHA256 ee18ab05b68db82bfe31d74a9581af973495b4e7045f3951da8042df7a711789
MD5 8039694428da246d13cb54c0b3b521f9
BLAKE2b-256 7c045cb3c6daede0e9fb64e11d7d0822f525a3ff448300182e70b138f15faeff

See more details on using hashes here.

File details

Details for the file dopplerr-0.2.12-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for dopplerr-0.2.12-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f23240dc0916401e340e91ee73ed89f6c096468b282e4b7b8cb8d2222820311e
MD5 f28cd365be078433545276ba6ec2d78e
BLAKE2b-256 a4e43bf44ca7475bd19d2fe923a9e66c4bcfa10afff5c4447b140378314433ce

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page