mirror of
https://github.com/LiteyukiStudio/LiteyukiBot.git
synced 2024-11-26 14:05:03 +08:00
📦 docs: 资源商店新增发布资源功能
This commit is contained in:
parent
db1fb58717
commit
f402799f28
@ -15,3 +15,5 @@ RESOURCE_JSON = "docs/public/resources.json"
|
|||||||
edit_content_tip = "若要修改请编辑这段front matter,不要编辑正文/If you want to modify, please edit the front matter, do not edit the body"
|
edit_content_tip = "若要修改请编辑这段front matter,不要编辑正文/If you want to modify, please edit the front matter, do not edit the body"
|
||||||
|
|
||||||
edit_tip = "如需修改请直接编辑issue,请不要新建issue,我会自动检查"
|
edit_tip = "如需修改请直接编辑issue,请不要新建issue,我会自动检查"
|
||||||
|
|
||||||
|
bot_id = "liteyuki-flow"
|
||||||
|
@ -10,7 +10,7 @@ from github.Repository import Repository
|
|||||||
import json
|
import json
|
||||||
import yaml
|
import yaml
|
||||||
|
|
||||||
from liteyuki_flow.const import OPENED, EDITED, CLOSED, REOPENED, RESOURCE_JSON, edit_tip
|
from liteyuki_flow.const import OPENED, EDITED, CLOSED, REOPENED, RESOURCE_JSON, bot_id, edit_tip
|
||||||
from liteyuki_flow.markdown_parser import MarkdownParser
|
from liteyuki_flow.markdown_parser import MarkdownParser
|
||||||
from liteyuki_flow.typ import err, nil
|
from liteyuki_flow.typ import err, nil
|
||||||
|
|
||||||
@ -21,20 +21,26 @@ headers = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def push_check_result(issue: Issue, result: str):
|
||||||
|
cid = None
|
||||||
|
for cm in issue.get_comments():
|
||||||
|
if cm.body.startswith("检查结果") and cm.user.login == bot_id:
|
||||||
|
cid = cm.id
|
||||||
|
break
|
||||||
|
if cid is not None:
|
||||||
|
issue.get_comment(cid).edit("检查结果: " + result)
|
||||||
|
else:
|
||||||
|
issue.create_comment("检查结果: " + result)
|
||||||
|
|
||||||
|
|
||||||
# opened: 创建新的资源包,预审核
|
# opened: 创建新的资源包,预审核
|
||||||
# edited: 编辑资源包信息,需重新审核
|
# edited: 编辑资源包信息,需重新审核
|
||||||
# closed: 审核通过,修改json并提交
|
# closed: 审核通过,修改json并提交
|
||||||
# reopened: 重新打开,无操作
|
# reopened: 重新打开,无操作
|
||||||
def on_first_open(github: Github, issue: Issue, repo: Repository):
|
def on_first_open(github: Github, issue: Issue, repo: Repository):
|
||||||
issue.create_comment("已收到资源包发布请求,我会马上开始预检. " + edit_tip)
|
issue.create_comment("已收到资源包发布请求,我会马上开始预检. " + edit_tip)
|
||||||
cid = issue.create_comment("请等待检查结果").id
|
push_check_result(issue, "请等待")
|
||||||
parser = MarkdownParser(issue.body)
|
|
||||||
parser.parse_front_matters()
|
|
||||||
parser.front_matters["cid"] = str(cid)
|
|
||||||
|
|
||||||
new_issue_body = parser.build_front_matters()
|
|
||||||
issue.add_to_labels("Resource")
|
issue.add_to_labels("Resource")
|
||||||
issue.edit(body=new_issue_body)
|
|
||||||
|
|
||||||
|
|
||||||
# opened | edited
|
# opened | edited
|
||||||
@ -46,16 +52,16 @@ def pre_check(github: Github, issue: Issue, repo: Repository) -> err:
|
|||||||
link = parser.front_matters.get("link")
|
link = parser.front_matters.get("link")
|
||||||
homepage = parser.front_matters.get("homepage") # optional
|
homepage = parser.front_matters.get("homepage") # optional
|
||||||
author = parser.front_matters.get("author")
|
author = parser.front_matters.get("author")
|
||||||
cid = int(parser.front_matters.get("cid")) # optional auto
|
|
||||||
if not all((name, desc, link, author)):
|
if not all((name, desc, link, author)):
|
||||||
issue.get_comment(cid).edit("name, desc, link, homepage 及 author 为必填字段.")
|
push_check_result(issue, "❌ name, desc, link, homepage 及 author 为必填字段.")
|
||||||
return ValueError("name, desc, link, homepage 及 author 为必填字段.")
|
return ValueError("name, desc, link, homepage 及 author 为必填字段.")
|
||||||
|
|
||||||
# 下载并解析资源包
|
# 下载并解析资源包
|
||||||
r = requests.get(link, headers=headers)
|
r = requests.get(link, headers=headers)
|
||||||
print(r.text)
|
print(r.text)
|
||||||
if r.status_code != 200:
|
if r.status_code != 200:
|
||||||
issue.get_comment(cid).edit("下载失败.")
|
push_check_result(issue, "❌ 下载失败.")
|
||||||
return ValueError("下载失败.")
|
return ValueError("下载失败.")
|
||||||
try:
|
try:
|
||||||
with open(f"{name}.zip", "wb") as f:
|
with open(f"{name}.zip", "wb") as f:
|
||||||
@ -66,12 +72,12 @@ def pre_check(github: Github, issue: Issue, repo: Repository) -> err:
|
|||||||
# 检测包内metadata.yml文件
|
# 检测包内metadata.yml文件
|
||||||
data = yaml.load(open(f"{name}/metadata.yml"), Loader=yaml.SafeLoader)
|
data = yaml.load(open(f"{name}/metadata.yml"), Loader=yaml.SafeLoader)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
issue.get_comment(cid).edit("解析资源包失败,可能是格式问题或metadata.yml不存在: " + str(e))
|
push_check_result(issue, "❌ 解析资源包失败,可能是格式问题或metadata.yml不存在: " + str(e))
|
||||||
return e
|
return e
|
||||||
|
|
||||||
# 检测必要字段 name,description,version
|
# 检测必要字段 name,description,version
|
||||||
if not all((data.get("name"), data.get("description"), data.get("version"))):
|
if not all((data.get("name"), data.get("description"), data.get("version"))):
|
||||||
issue.get_comment(cid).edit("元数据中缺少必要字段 name, description 或 version.")
|
push_check_result(issue, "❌ 元数据中缺少必要字段 name, description 或 version.")
|
||||||
return ValueError("元数据中缺少必要字段 name, description 或 version.")
|
return ValueError("元数据中缺少必要字段 name, description 或 version.")
|
||||||
|
|
||||||
# 不检测重复资源包,因为资源包可能有多个版本
|
# 不检测重复资源包,因为资源包可能有多个版本
|
||||||
@ -96,7 +102,7 @@ def pre_check(github: Github, issue: Issue, repo: Repository) -> err:
|
|||||||
|
|
||||||
issue.edit(body=new_issue_body)
|
issue.edit(body=new_issue_body)
|
||||||
issue.add_to_labels("pre-checked")
|
issue.add_to_labels("pre-checked")
|
||||||
issue.get_comment(cid).edit("✅ 预检查通过,等待管理员人工审核\n## 元数据\n" + metadata_markdown)
|
push_check_result(issue, "✅ 预检查通过,等待管理员人工审核\n## 元数据\n" + metadata_markdown)
|
||||||
return nil
|
return nil
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user