plex-prerolls/modules/plex_connector.py

53 lines
1.6 KiB
Python
Raw Normal View History

2023-12-14 08:06:45 +00:00
from typing import List, Union, Tuple
from plexapi.server import PlexServer
from plexapi.exceptions import BadRequest
import modules.logs as logging
2023-12-14 08:06:45 +00:00
def prepare_pre_roll_string(paths: List[str]) -> Tuple[Union[str, None], int]:
if not paths:
2023-12-14 08:06:45 +00:00
return None, 0
# Filter out empty paths
paths = [path for path in paths if path]
2023-12-14 08:06:45 +00:00
return ";".join(paths), len(paths)
class PlexConnector:
def __init__(self, host: str, token: str):
self._host = host
self._token = token
logging.info(f"Connecting to Plex server at {self._host}")
self._plex_server = PlexServer(baseurl=self._host, token=self._token)
def update_pre_roll_paths(self, paths: List[str], testing: bool = False) -> None:
2023-12-14 08:06:45 +00:00
pre_roll_string, count = prepare_pre_roll_string(paths=paths)
if not pre_roll_string:
logging.info("No pre-roll paths to update")
return
2023-12-14 08:06:45 +00:00
logging.info(f"Using {count} pre-roll paths")
if testing:
logging.debug(f"Testing: Would have updated pre-roll to: {pre_roll_string}")
return
logging.info(f"Updating pre-roll to: {pre_roll_string}")
self._plex_server.settings.get("cinemaTrailersPrerollID").set(pre_roll_string) # type: ignore
try:
self._plex_server.settings.save() # type: ignore
except BadRequest as e:
if "Too Large" in str(e):
logging.error("Failed to update pre-roll: Too many paths")
return
except Exception as e:
logging.error(f"Failed to save pre-roll: {e}")
return
logging.info("Successfully updated pre-roll")