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.
Plex-Meta-Manager/modules/github.py

112 lines
4.7 KiB

import re
from modules import util
from modules.util import Failed
logger = util.logger
raw_url = "https://raw.githubusercontent.com"
base_url = "https://api.github.com"
kometa_base = f"{base_url}/repos/Kometa-Team/Kometa"
configs_raw_url = f"{raw_url}/Kometa-Team/Community-Configs"
class GitHub:
def __init__(self, requests, params):
self.requests = requests
self.token = params["token"]
self.headers = None
if self.token:
logger.separator()
logger.info("Connecting to GitHub...")
logger.secret(self.token)
self.headers = {"Authorization": f"token {self.token}"}
try:
response = self._requests("https://api.github.com/user", err_msg="The GitHub token specified could not be validated. Please verify that the token is correct.")
logger.info(f"GitHub token validated successfully. Authenticated as {response['login']}")
except Failed as e:
self.token = None
self.headers = None
logger.error(e)
self.images_raw_url = f"{raw_url}/Kometa-Team/Image-Sets/master/sets/"
self.translation_url = f"{raw_url}/Kometa-Team/Translations/master/defaults/"
self._configs_url = None
self._config_tags = []
self._translation_keys = []
self._translations = {}
def _requests(self, url, err_msg=None, params=None, yaml=False):
if not err_msg:
err_msg = f"URL Not Found: {url}"
if yaml:
return self.requests.get_yaml(url, headers=self.headers, params=params)
response = self.requests.get(url, headers=self.headers, params=params)
if response.status_code >= 400:
raise Failed(f"GitHub Error: {err_msg} Response: {response.status_code} - {response.reason} ")
try:
return response.json()
except ValueError:
logger.stacktrace()
logger.error(str(response.content))
raise Failed("GitHub JSON Unpack Error")
def get_top_tree(self, repo):
if not str(repo).startswith("/"):
repo = f"/{repo}"
if not str(repo).endswith("/"):
repo = f"{repo}/"
data = self._requests(f"{base_url}/repos{repo}commits", f"No repo found at https://github.com{repo}")
return self.get_tree(data[0]["commit"]["tree"]["url"]), repo
def get_tree(self, tree_url):
return {i["path"]: i for i in self._requests(tree_url, f"No tree found at {tree_url}")["tree"]}
def latest_release_notes(self):
return self._requests(f"{kometa_base}/releases/latest")["body"]
def get_commits(self, dev_version, nightly=False):
master_sha = self._requests(f"{kometa_base}/commits/master")["sha"]
response = self._requests(f"{kometa_base}/commits", params={"sha": "nightly" if nightly else "develop"})
commits = []
for commit in response:
if commit["sha"] == master_sha:
break
message = commit["commit"]["message"]
match = re.match(r"^\[(\d)]", message)
if match and int(match.group(1)) <= dev_version:
break
commits.append(message)
return "\n".join(commits)
@property
def config_tags(self):
if not self._config_tags:
try:
self._config_tags = [r["ref"][11:] for r in self._requests(f"{base_url}/repos/Kometa-Team/Community-Configs/git/refs/tags")]
except TypeError:
pass
return self._config_tags
@property
def configs_url(self):
if self._configs_url is None:
self._configs_url = f"{configs_raw_url}/master/"
if self.requests.local.main in self.config_tags and (self.requests.latest.main != self.requests.local.main or self.requests.branch == "master"):
self._configs_url = f"{configs_raw_url}/v{self.requests.local.main}/"
return self._configs_url
@property
def translation_keys(self):
if not self._translation_keys:
tree, repo = self.get_top_tree("Kometa-Team/Translations")
self._translation_keys = [tk[:-4] for tk in self.get_tree(tree["defaults"]["url"])]
return self._translation_keys
def translation_yaml(self, translation_key):
if translation_key not in self._translations:
yaml = self._requests(f"{self.translation_url}{translation_key}.yml", yaml=True).data
output = {"collections": {}, "key_names": {}, "variables": {}}
for k in output:
if k in yaml:
output[k] = yaml[k]
self._translations[translation_key] = output
return self._translations[translation_key]