Plex-Meta-Manager/modules/webhooks.py

96 lines
4.6 KiB
Python
Raw Normal View History

2021-11-03 14:36:11 +00:00
import logging
2021-11-19 19:28:11 +00:00
from json import JSONDecodeError
2021-11-03 14:36:11 +00:00
from modules.util import Failed
logger = logging.getLogger("Plex Meta Manager")
class Webhooks:
def __init__(self, config, system_webhooks, library=None, notifiarr=None):
self.config = config
self.error_webhooks = system_webhooks["error"] if "error" in system_webhooks else []
self.run_start_webhooks = system_webhooks["run_start"] if "run_start" in system_webhooks else []
self.run_end_webhooks = system_webhooks["run_end"] if "run_end" in system_webhooks else []
2021-11-03 14:36:11 +00:00
self.library = library
self.notifiarr = notifiarr
def _request(self, webhooks, json):
if self.config.trace_mode:
logger.debug("")
logger.debug(f"JSON: {json}")
2021-11-16 16:44:03 +00:00
for webhook in list(set(webhooks)):
2021-11-03 14:36:11 +00:00
if self.config.trace_mode:
logger.debug(f"Webhook: {webhook}")
if webhook == "notifiarr":
url, params = self.notifiarr.get_url("notification/plex/")
2021-11-30 15:18:30 +00:00
for x in range(6):
response = self.config.get(url, json=json, params=params)
if response.status_code < 500:
break
2021-11-03 14:36:11 +00:00
else:
response = self.config.post(webhook, json=json)
2021-11-19 19:28:11 +00:00
try:
response_json = response.json()
if self.config.trace_mode:
logger.debug(f"Response: {response_json}")
2021-11-22 21:17:13 +00:00
if "result" in response_json and response_json["result"] == "error" and "details" in response_json and "response" in response_json["details"]:
raise Failed(f"Notifiarr Error: {response_json['details']['response']}")
2021-11-19 19:28:11 +00:00
if response.status_code >= 400 or ("result" in response_json and response_json["result"] == "error"):
raise Failed(f"({response.status_code} [{response.reason}]) {response_json}")
except JSONDecodeError:
if response.status_code >= 400:
raise Failed(f"({response.status_code} [{response.reason}])")
2021-11-03 14:36:11 +00:00
def start_time_hooks(self, start_time):
if self.run_start_webhooks:
2021-12-01 05:38:20 +00:00
self._request(self.run_start_webhooks, {"start_time": start_time.strftime("%Y-%m-%d %H:%M:%S")})
2021-11-03 14:36:11 +00:00
2021-12-01 05:38:20 +00:00
def end_time_hooks(self, start_time, end_time, run_time, stats):
2021-11-03 14:36:11 +00:00
if self.run_end_webhooks:
self._request(self.run_end_webhooks, {
2021-12-01 05:38:20 +00:00
"start_time": start_time.strftime("%Y-%m-%d %H:%M:%S"),
"end_time": end_time.strftime("%Y-%m-%d %H:%M:%S"),
2021-11-03 14:36:11 +00:00
"run_time": run_time,
"collections_created": stats["created"],
"collections_modified": stats["modified"],
"collections_deleted": stats["deleted"],
"items_added": stats["added"],
"items_removed": stats["removed"],
"added_to_radarr": stats["radarr"],
"added_to_sonarr": stats["sonarr"],
})
def error_hooks(self, text, library=None, collection=None, critical=True):
if self.error_webhooks:
json = {"error": str(text), "critical": critical}
if library:
json["server_name"] = library.PlexServer.friendlyName
json["library_name"] = library.name
if collection:
json["collection"] = str(collection)
self._request(self.error_webhooks, json)
def collection_hooks(self, webhooks, collection, created=False, deleted=False, additions=None, removals=None):
2021-11-03 14:36:11 +00:00
if self.library:
thumb = None
if collection.thumb and next((f for f in collection.fields if f.name == "thumb"), None):
thumb = self.config.get_image_encoded(f"{self.library.url}{collection.thumb}?X-Plex-Token={self.library.token}")
art = None
if collection.art and next((f for f in collection.fields if f.name == "art"), None):
art = self.config.get_image_encoded(f"{self.library.url}{collection.art}?X-Plex-Token={self.library.token}")
json = {
"server_name": self.library.PlexServer.friendlyName,
"library_name": self.library.name,
"type": "movie" if self.library.is_movie else "show",
"collection": collection.title,
"created": created,
"deleted": deleted,
2021-11-03 14:36:11 +00:00
"poster": thumb,
"background": art
}
if additions:
json["additions"] = additions
if removals:
json["removals"] = removals
self._request(webhooks, json)