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.
112 lines
4.7 KiB
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]
|