parch-iso-template/tools/upload_asset.py

66 lines
1.5 KiB
Python
Raw Normal View History

2023-06-08 13:57:51 -04:00
import hashlib
2022-06-26 23:43:37 +04:30
import logging
import os
import sys
from datetime import datetime
2023-06-08 13:57:51 -04:00
from pathlib import Path
2022-06-26 23:43:37 +04:30
from github import Github
logging.basicConfig(level=logging.INFO, format="%(levelname)s: %(message)s")
api_key = os.getenv("api_key", None)
current_date = datetime.today().strftime("%Y-%m-%d")
2023-06-08 13:57:51 -04:00
def _compute_sha256(file_name):
hash_sha256 = hashlib.sha256()
with open(file_name, "rb") as f:
for chunk in iter(lambda: f.read(4096), b""):
hash_sha256.update(chunk)
return hash_sha256.hexdigest()
_path = list(Path().cwd().glob("out/*.iso"))[0]
path = _path.as_posix()
file_name = _path.name
hash = _compute_sha256(path)
2022-06-26 23:43:37 +04:30
repo_name = os.getenv("name", None)
release_name = os.getenv("release_name", None)
logging.info("Starting at %s", current_date)
if not (repo_name and api_key and release_name):
logging.error(
"'repo_name'/'api_key'/'release_name' not found in your envs."
"please add this and run again"
)
sys.exit(1)
gh = Github(api_key)
2023-06-08 13:57:51 -04:00
print(repo_name, api_key)
repo = gh.get_repo(f"parchlinux/{repo_name}")
2022-06-26 23:43:37 +04:30
release = repo.get_release(release_name)
logging.info("statrting Upload ISO to release")
release.upload_asset(path=path)
logging.info("ISO upload is done")
2023-06-08 13:57:51 -04:00
# update release
msg = (
release.body
+ f"""
| name | sha256 |
| :---: | :---: |
| {file_name} | {hash} |"""
)
logging.info("Starting Update release msg with: \n %s" % msg)
release.update_release(name=release.tag_name, message=msg)
logging.info("Release Update is done.")