You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
111 lines
4.8 KiB
111 lines
4.8 KiB
import logging, re, requests
|
|
from modules import util
|
|
from modules.util import Failed
|
|
from retrying import retry
|
|
|
|
logger = logging.getLogger("Plex Meta Manager")
|
|
|
|
class RadarrAPI:
|
|
def __init__(self, tmdb, params):
|
|
self.url_params = {"apikey": "{}".format(params["token"])}
|
|
self.base_url = "{}/api{}".format(params["url"], "/v3/" if params["version"] == "v3" else "/")
|
|
try:
|
|
response = requests.get("{}system/status".format(self.base_url), params=self.url_params)
|
|
result = response.json()
|
|
except Exception as e:
|
|
util.print_stacktrace()
|
|
raise Failed("Radarr Error: Could not connect to Radarr at {}".format(params["url"]))
|
|
if "error" in result and result["error"] == "Unauthorized":
|
|
raise Failed("Radarr Error: Invalid API Key")
|
|
if "version" not in result:
|
|
raise Failed("Radarr Error: Unexpected Response Check URL")
|
|
response = requests.get("{}{}".format(self.base_url, "qualityProfile" if params["version"] == "v3" else "profile"), params=self.url_params)
|
|
self.quality_profile_id = None
|
|
profiles = ""
|
|
for profile in response.json():
|
|
if len(profiles) > 0:
|
|
profiles += ", "
|
|
profiles += profile["name"]
|
|
if profile["name"] == params["quality_profile"]:
|
|
self.quality_profile_id = profile["id"]
|
|
if not self.quality_profile_id:
|
|
raise Failed("Radarr Error: quality_profile: {} does not exist in radarr. Profiles available: {}".format(params["quality_profile"], profiles))
|
|
self.tmdb = tmdb
|
|
self.url = params["url"]
|
|
self.version = params["version"]
|
|
self.token = params["token"]
|
|
self.root_folder_path = params["root_folder_path"]
|
|
self.add = params["add"]
|
|
self.search = params["search"]
|
|
self.tag = params["tag"]
|
|
|
|
def add_tmdb(self, tmdb_ids, tag=None):
|
|
logger.info("")
|
|
logger.debug("TMDb IDs: {}".format(tmdb_ids))
|
|
tag_nums = []
|
|
add_count = 0
|
|
if tag is None:
|
|
tag = self.tag
|
|
if tag:
|
|
tag_cache = {}
|
|
for label in tag:
|
|
self.send_post("{}tag".format(self.base_url), {"label": str(label)})
|
|
for t in self.send_get("{}tag".format(self.base_url)).json():
|
|
tag_cache[t["label"]] = t["id"]
|
|
for label in tag:
|
|
if label in tag_cache:
|
|
tag_nums.append(tag_cache[label])
|
|
for tmdb_id in tmdb_ids:
|
|
try:
|
|
movie = self.tmdb.get_movie(tmdb_id)
|
|
except Failed as e:
|
|
logger.error(e)
|
|
continue
|
|
|
|
try:
|
|
year = movie.release_date.split("-")[0]
|
|
except AttributeError:
|
|
logger.error("TMDb Error: No year for ({}) {}".format(tmdb_id, movie.title))
|
|
continue
|
|
|
|
if year.isdigit() is False:
|
|
logger.error("TMDb Error: No release date yet for ({}) {}".format(tmdb_id, movie.title))
|
|
continue
|
|
|
|
poster = "https://image.tmdb.org/t/p/original{}".format(movie.poster_path)
|
|
|
|
titleslug = re.sub(r"([^\s\w]|_)+", "", "{} {}".format(movie.title, year)).replace(" ", "-").lower()
|
|
|
|
url_json = {
|
|
"title": movie.title,
|
|
"{}".format("qualityProfileId" if self.version == "v3" else "profileId"): self.quality_profile_id,
|
|
"year": int(year),
|
|
"tmdbid": int(tmdb_id),
|
|
"titleslug": titleslug,
|
|
"monitored": True,
|
|
"rootFolderPath": self.root_folder_path,
|
|
"images": [{"covertype": "poster", "url": poster}],
|
|
"addOptions": {"searchForMovie": self.search}
|
|
}
|
|
if tag_nums:
|
|
url_json["tags"] = tag_nums
|
|
response = self.send_post("{}movie".format(self.base_url), url_json)
|
|
if response.status_code < 400:
|
|
logger.info("Added to Radarr | {:<6} | {}".format(tmdb_id, movie.title))
|
|
add_count += 1
|
|
else:
|
|
try:
|
|
logger.error("Radarr Error: ({}) {}: ({}) {}".format(tmdb_id, movie.title, response.status_code, response.json()[0]["errorMessage"]))
|
|
except KeyError as e:
|
|
logger.debug(url_json)
|
|
logger.error("Radarr Error: {}".format(response.json()))
|
|
logger.info("{} Movie{} added to Radarr".format(add_count, "s" if add_count > 1 else ""))
|
|
|
|
@retry(stop_max_attempt_number=6, wait_fixed=10000)
|
|
def send_get(self, url, url_json):
|
|
return requests.get(url, json=url_json, params=self.url_params)
|
|
|
|
@retry(stop_max_attempt_number=6, wait_fixed=10000)
|
|
def send_post(self, url, url_json):
|
|
return requests.post(url, json=url_json, params=self.url_params)
|