Compare commits
5 Commits
Author | SHA1 | Date | |
---|---|---|---|
c1b28d7f43 | |||
512d27739c | |||
ad3a3b38e6 | |||
1d9eeae447 | |||
e9ab3581aa |
@@ -42,7 +42,7 @@ ENV PATH="${PATH}:/root/.local/bin" \
|
|||||||
COPY --chown=root:root pyproject.toml main.py /app/
|
COPY --chown=root:root pyproject.toml main.py /app/
|
||||||
|
|
||||||
# install dependencies
|
# 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
|
# execute program
|
||||||
CMD python /app/main.py
|
CMD python /app/main.py
|
||||||
|
21
main.py
21
main.py
@@ -44,7 +44,7 @@ from typing import Any
|
|||||||
from faker import Faker
|
from faker import Faker
|
||||||
|
|
||||||
# from github import ContentFile, Github, GithubException, InputGitAuthor, Repository
|
# from github import ContentFile, Github, GithubException, InputGitAuthor, Repository
|
||||||
from gitea import *
|
import gitea
|
||||||
from requests import get as rq_get
|
from requests import get as rq_get
|
||||||
from requests.exceptions import RequestException
|
from requests.exceptions import RequestException
|
||||||
|
|
||||||
@@ -136,7 +136,7 @@ class WakaInput:
|
|||||||
gitea_url: str | None = os.getenv("GITHUB_SERVER_URL", "https://gitea.com")
|
gitea_url: str | None = os.getenv("GITHUB_SERVER_URL", "https://gitea.com")
|
||||||
waka_key: str | None = os.getenv("INPUT_WAKATIME_API_KEY")
|
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")
|
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
|
# # depends
|
||||||
commit_message: str = os.getenv(
|
commit_message: str = os.getenv(
|
||||||
"INPUT_COMMIT_MESSAGE", "Updated WakaReadme graph with new metrics"
|
"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.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."""
|
"""Qualify target repository defaults."""
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
class TargetRepository:
|
class TargetRepository:
|
||||||
# this: ContentFile.ContentFile
|
# this: ContentFile.ContentFile
|
||||||
this: Content
|
this: gitea.Content
|
||||||
path: str
|
path: str
|
||||||
commit_message: str
|
commit_message: str
|
||||||
sha: str
|
sha: str
|
||||||
@@ -448,9 +448,9 @@ def qualify_target(gitea_repo: Repository, gitea_connect: Gitea):
|
|||||||
# if wk_i.target_branch != "NOT_SET":
|
# if wk_i.target_branch != "NOT_SET":
|
||||||
# gitea_branch = gitea_repo.get_branch(wk_i.target_branch)
|
# 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.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_file_content(readme_content) # base64 encoded
|
||||||
# target = gitea_repo.get_readme()
|
# target = gitea_repo.get_readme()
|
||||||
|
|
||||||
@@ -483,14 +483,18 @@ def qualify_target(gitea_repo: Repository, gitea_connect: Gitea):
|
|||||||
def genesis():
|
def genesis():
|
||||||
"""Run Program."""
|
"""Run Program."""
|
||||||
logger.debug("Connecting to Gitea")
|
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
|
# since a validator is being used earlier, casting
|
||||||
# `wk_i.ENV_VARIABLE` to a string here, is okay
|
# `wk_i.ENV_VARIABLE` to a string here, is okay
|
||||||
# gitea_repo = gitea_connect.get_repo(str(wk_i.repository))
|
# gitea_repo = gitea_connect.get_repo(str(wk_i.repository))
|
||||||
|
|
||||||
owner = "sangge"
|
owner = "sangge"
|
||||||
repo_name = ".profile"
|
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)
|
target = qualify_target(gitea_repo, gitea_connect)
|
||||||
logger.debug("Decoding readme contents\n")
|
logger.debug("Decoding readme contents\n")
|
||||||
|
|
||||||
@@ -516,7 +520,6 @@ def genesis():
|
|||||||
b64_new_content = b64encode(bytes(new_content, "utf-8"))
|
b64_new_content = b64encode(bytes(new_content, "utf-8"))
|
||||||
repo_content = gitea_repo.get_git_content()
|
repo_content = gitea_repo.get_git_content()
|
||||||
readmes = [c for c in repo_content if c.name == "README.md"]
|
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")
|
str_new_content = b64_new_content.decode("utf-8")
|
||||||
gitea_repo.change_file(readmes[0].name, readmes[0].sha, str_new_content)
|
gitea_repo.change_file(readmes[0].name, readmes[0].sha, str_new_content)
|
||||||
logger.info("Stats updated successfully")
|
logger.info("Stats updated successfully")
|
||||||
|
Reference in New Issue
Block a user