5 Commits

2 changed files with 13 additions and 10 deletions

View File

@@ -42,7 +42,7 @@ ENV PATH="${PATH}:/root/.local/bin" \
COPY --chown=root:root pyproject.toml main.py /app/
# install dependencies
RUN python -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple
RUN python -m pip install /app/ -i https://pypi.tuna.tsinghua.edu.cn/simple
# execute program
CMD python /app/main.py

21
main.py
View File

@@ -44,7 +44,7 @@ from typing import Any
from faker import Faker
# from github import ContentFile, Github, GithubException, InputGitAuthor, Repository
from gitea import *
import gitea
from requests import get as rq_get
from requests.exceptions import RequestException
@@ -136,7 +136,7 @@ class WakaInput:
gitea_url: str | None = os.getenv("GITHUB_SERVER_URL", "https://gitea.com")
waka_key: str | None = os.getenv("INPUT_WAKATIME_API_KEY")
api_base_url: str | None = os.getenv("INPUT_API_BASE_URL", "https://wakatime.com/api")
repository: str | None = os.getenv("INPUT_REPOSITORY")
repository: str | None = os.getenv("INPUT_REPOSITORY", ".profile")
# # depends
commit_message: str = os.getenv(
"INPUT_COMMIT_MESSAGE", "Updated WakaReadme graph with new metrics"
@@ -428,13 +428,13 @@ def churn(old_readme: str, /):
# def qualify_target(gitea_repo: Repository.Repository):
def qualify_target(gitea_repo: Repository, gitea_connect: Gitea):
def qualify_target(gitea_repo: gitea.Repository, gitea_connect: gitea.Gitea):
"""Qualify target repository defaults."""
@dataclass
class TargetRepository:
# this: ContentFile.ContentFile
this: Content
this: gitea.Content
path: str
commit_message: str
sha: str
@@ -448,9 +448,9 @@ def qualify_target(gitea_repo: Repository, gitea_connect: Gitea):
# if wk_i.target_branch != "NOT_SET":
# gitea_branch = gitea_repo.get_branch(wk_i.target_branch)
readme_content = Content(gitea_connect)
readme_content = gitea.Content(gitea_connect)
readme_content.path = "README.md"
readme_content.type = Content.FILE
readme_content.type = gitea.Content.FILE
target = gitea_repo.get_file_content(readme_content) # base64 encoded
# target = gitea_repo.get_readme()
@@ -483,14 +483,18 @@ def qualify_target(gitea_repo: Repository, gitea_connect: Gitea):
def genesis():
"""Run Program."""
logger.debug("Connecting to Gitea")
gitea_connect = Gitea(wk_i.gitea_url, wk_i.gitea_token)
gitea_connect = gitea.Gitea(wk_i.gitea_url, wk_i.gitea_token)
logger.debug("logged into gitea\n")
# since a validator is being used earlier, casting
# `wk_i.ENV_VARIABLE` to a string here, is okay
# gitea_repo = gitea_connect.get_repo(str(wk_i.repository))
owner = "sangge"
repo_name = ".profile"
gitea_repo = Repository.request(gitea_connect, owner, repo_name)
gitea_repo = gitea.Repository.request(gitea_connect, owner, repo_name)
if len(sys.argv) == 2 and sys.argv[1] == "--dev":
logger.debug("Detected run in `dev` mode.,fetched repo \n")
target = qualify_target(gitea_repo, gitea_connect)
logger.debug("Decoding readme contents\n")
@@ -516,7 +520,6 @@ def genesis():
b64_new_content = b64encode(bytes(new_content, "utf-8"))
repo_content = gitea_repo.get_git_content()
readmes = [c for c in repo_content if c.name == "README.md"]
sha = readmes[0].sha
str_new_content = b64_new_content.decode("utf-8")
gitea_repo.change_file(readmes[0].name, readmes[0].sha, str_new_content)
logger.info("Stats updated successfully")