Skip to content

Python scripts to push data from Radarr/Sonarr into your Trakt collection

Notifications You must be signed in to change notification settings

rg9400/Trakt-Arr-Integration

Repository files navigation

Trakt-Arr-Integration

Python scripts to push data from Radarr/Sonarr into your Trakt collection.

All 5 scripts require you to have Radarr aphrodite and have set up the Trakt connection in Radarr.

Requires Python3 (developed with Python 3.8). You need the requests model, i.e. python -m pip install requests replacing python with whatever your python3 binary is.

Force Resync will first delete ALL your movie or show data in your collections (depending on the script) before pushing the data from Sonarr/Radarr. The benefit is that this removes any possible entities in Trakt that are not in Sonarr, forcing them to be fully in sync. If False, it will update the relevant data for existing items while adding new items in Sonarr/Radarr but not Trakt.

Use Collected Date will utilize the download date from Sonarr/Radarr when syncing the data to your Trakt collection. If True, it will replace existing items' dates with those in the Arrs. If False, it will keep any existing item dates, and if a new item is being added, then it will use the airdate/release date for that item instead.

Chunk Size was recommended by the Trakt developer. It slows down the runtime for the syncs and increases API calls, but higher values can result in Trakt being unable to process your request. If you do a forced resync, then Trakt will handle larger chunk sizes and be generally faster as there is no validation or data matching happening.

Desriptions of scripts

  1. radarr_collection_sync will use Radarr data to upload downloaded movie info to Trakt

  2. sonarr_collection_sync will use Sonarr data to upload downloaded episode info to Trakt

  3. sonarr_trakt_connection is a temporary script that can be used as a connection in Sonarr, similar to the one in Radarr, to push new episode downloads into your Trakt collection to keep it up to date. A native connection PR is open at Sonarr/Sonarr#3917 and should hopefully be added in the near future to make this script obsolete.

  4. radarr_delete_list is a script that can be used as a connection in Radarr to delete a movie from either your watchlist or a custom list you made. The usecase is to keep a list of movies as "Wanted" in Trakt that is synced to the one in Radarr. If you use the Collection sync/connection, then you can easily filter movies you want, have, or are not in Radarr when navigating Trakt.

  5. radarr_missing_list_sync will push all movies marked as missing in Radarr to a list or your watchlist. This can help get your list up to speed for script #4 to then keep in sync going forward.

Limitations

  1. Current metadata mapping is based on the available options in Trakt or the Arrs. It is fairly robust already and handles multiple edge cases; however, there are limitations.
  • Detailed HDR/3D info in the Arrs is not available, so we cannot map these in Trakt.
  • Trakt does not have a category for TV/PVR releases yet, so we map them to DVDs (might switch to VHS).
  • Trakt does not differentiate between TrueHD ATMOS and Dolby Digital Plus ATMOS, so both are mapped to ATMOS.
  • Trakt does not have an option for DTS-ES
  • Trakt does not differentiate between Vorbis and Opus OGG tracks
  • Trakt does not differentiate between MP3 and MP2 tracks
  1. Radarr/Sonarr do not have an On Delete notification yet, though there is a PR open at Radarr/Radarr#4869 to add this in Radarr that should hopefully be added soon. This means that deletions in the Arrs are not going to result in deletions in Trakt, so these have to be done manually or via script for now

About

Python scripts to push data from Radarr/Sonarr into your Trakt collection

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages