-
Notifications
You must be signed in to change notification settings - Fork 162
/
Copy pathgithub_client.py
104 lines (87 loc) · 5.24 KB
/
github_client.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
# src/github_client.py
import requests # 导入requests库用于HTTP请求
from datetime import datetime, date, timedelta # 导入日期处理模块
import os # 导入os模块用于文件和目录操作
from logger import LOG # 导入日志模块
class GitHubClient:
def __init__(self, token):
self.token = token # GitHub API令牌
self.headers = {'Authorization': f'token {self.token}'} # 设置HTTP头部认证信息
def fetch_updates(self, repo, since=None, until=None):
# 获取指定仓库的更新,可以指定开始和结束日期
updates = {
'commits': self.fetch_commits(repo, since, until), # 获取提交记录
'issues': self.fetch_issues(repo, since, until), # 获取问题
'pull_requests': self.fetch_pull_requests(repo, since, until) # 获取拉取请求
}
return updates
def fetch_commits(self, repo, since=None, until=None):
LOG.debug(f"准备获取 {repo} 的 Commits")
url = f'https://api.github.com/repos/{repo}/commits' # 构建获取提交的API URL
params = {}
if since:
params['since'] = since # 如果指定了开始日期,添加到参数中
if until:
params['until'] = until # 如果指定了结束日期,添加到参数中
try:
response = requests.get(url, headers=self.headers, params=params, timeout=10)
response.raise_for_status() # 检查请求是否成功
return response.json() # 返回JSON格式的数据
except Exception as e:
LOG.error(f"从 {repo} 获取 Commits 失败:{str(e)}")
LOG.error(f"响应详情:{response.text if 'response' in locals() else '无响应数据可用'}")
return [] # Handle failure case
def fetch_issues(self, repo, since=None, until=None):
LOG.debug(f"准备获取 {repo} 的 Issues。")
url = f'https://api.github.com/repos/{repo}/issues' # 构建获取问题的API URL
params = {'state': 'closed', 'since': since, 'until': until}
try:
response = requests.get(url, headers=self.headers, params=params, timeout=10)
response.raise_for_status()
return response.json()
except Exception as e:
LOG.error(f"从 {repo} 获取 Issues 失败:{str(e)}")
LOG.error(f"响应详情:{response.text if 'response' in locals() else '无响应数据可用'}")
return []
def fetch_pull_requests(self, repo, since=None, until=None):
LOG.debug(f"准备获取 {repo} 的 Pull Requests。")
url = f'https://api.github.com/repos/{repo}/pulls' # 构建获取拉取请求的API URL
params = {'state': 'closed', 'since': since, 'until': until}
try:
response = requests.get(url, headers=self.headers, params=params, timeout=10)
response.raise_for_status() # 确保成功响应
return response.json()
except Exception as e:
LOG.error(f"从 {repo} 获取 Pull Requests 失败:{str(e)}")
LOG.error(f"响应详情:{response.text if 'response' in locals() else '无响应数据可用'}")
return []
def export_daily_progress(self, repo):
LOG.debug(f"[准备导出项目进度]:{repo}")
today = datetime.now().date().isoformat() # 获取今天的日期
updates = self.fetch_updates(repo, since=today) # 获取今天的更新数据
repo_dir = os.path.join('daily_progress', repo.replace("/", "_")) # 构建存储路径
os.makedirs(repo_dir, exist_ok=True) # 确保目录存在
file_path = os.path.join(repo_dir, f'{today}.md') # 构建文件路径
with open(file_path, 'w') as file:
file.write(f"# Daily Progress for {repo} ({today})\n\n")
file.write("\n## Issues Closed Today\n")
for issue in updates['issues']: # 写入今天关闭的问题
file.write(f"- {issue['title']} #{issue['number']}\n")
LOG.info(f"[{repo}]项目每日进展文件生成: {file_path}") # 记录日志
return file_path
def export_progress_by_date_range(self, repo, days):
today = date.today() # 获取当前日期
since = today - timedelta(days=days) # 计算开始日期
updates = self.fetch_updates(repo, since=since.isoformat(), until=today.isoformat()) # 获取指定日期范围内的更新
repo_dir = os.path.join('daily_progress', repo.replace("/", "_")) # 构建目录路径
os.makedirs(repo_dir, exist_ok=True) # 确保目录存在
# 更新文件名以包含日期范围
date_str = f"{since}_to_{today}"
file_path = os.path.join(repo_dir, f'{date_str}.md') # 构建文件路径
with open(file_path, 'w') as file:
file.write(f"# Progress for {repo} ({since} to {today})\n\n")
file.write(f"\n## Issues Closed in the Last {days} Days\n")
for issue in updates['issues']: # 写入在指定日期内关闭的问题
file.write(f"- {issue['title']} #{issue['number']}\n")
LOG.info(f"[{repo}]项目最新进展文件生成: {file_path}") # 记录日志
return file_path