Skip to content

Commit

Permalink
feat: add jupyter notebooks and comments for explanation on GitHubCli…
Browse files Browse the repository at this point in the history
…ent, ReportGenerator and LLM module.
  • Loading branch information
DjangoPeng committed Aug 18, 2024
1 parent 753aa05 commit 730e2d9
Show file tree
Hide file tree
Showing 10 changed files with 15,487 additions and 870 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -163,4 +163,5 @@ cython_debug/

# User-defined
daily_progress/*

src/jupyter/*.md
src/jupyter/daily_progress/*
79 changes: 41 additions & 38 deletions src/github_client.py
Original file line number Diff line number Diff line change
@@ -1,37 +1,40 @@
import requests
from datetime import datetime, date, timedelta
import os
from logger import LOG
# 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
self.headers = {'Authorization': f'token {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)
'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):
url = f'https://api.github.com/repos/{repo}/commits'
url = f'https://api.github.com/repos/{repo}/commits' # 构建获取提交的API URL
params = {}
if since:
params['since'] = since
params['since'] = since # 如果指定了开始日期,添加到参数中
if until:
params['until'] = until
params['until'] = until # 如果指定了结束日期,添加到参数中

response = requests.get(url, headers=self.headers, params=params)
response.raise_for_status()
return response.json()
response.raise_for_status() # 检查请求是否成功
return response.json() # 返回JSON格式的数据

def fetch_issues(self, repo, since=None, until=None):
url = f'https://api.github.com/repos/{repo}/issues'
url = f'https://api.github.com/repos/{repo}/issues' # 构建获取问题的API URL
params = {
'state': 'closed',
'state': 'closed', # 仅获取已关闭的问题
'since': since,
'until': until
}
Expand All @@ -40,9 +43,9 @@ def fetch_issues(self, repo, since=None, until=None):
return response.json()

def fetch_pull_requests(self, repo, since=None, until=None):
url = f'https://api.github.com/repos/{repo}/pulls'
url = f'https://api.github.com/repos/{repo}/pulls' # 构建获取拉取请求的API URL
params = {
'state': 'closed',
'state': 'closed', # 仅获取已合并的拉取请求
'since': since,
'until': until
}
Expand All @@ -51,46 +54,46 @@ def fetch_pull_requests(self, repo, since=None, until=None):
return response.json()

def export_daily_progress(self, repo):
today = datetime.now().date().isoformat()
updates = self.fetch_updates(repo, since=today)
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)
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')
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']:
for issue in updates['issues']: # 写入今天关闭的问题
file.write(f"- {issue['title']} #{issue['number']}\n")
file.write("\n## Pull Requests Merged Today\n")
for pr in updates['pull_requests']:
for pr in updates['pull_requests']: # 写入今天合并的拉取请求
file.write(f"- {pr['title']} #{pr['number']}\n")

LOG.info(f"Exported daily progress to {file_path}")
LOG.info(f"Exported daily progress to {file_path}") # 记录日志
return file_path

def export_progress_by_date_range(self, repo, days):
today = date.today()
since = today - timedelta(days=days)
today = date.today() # 获取当前日期
since = today - timedelta(days=days) # 计算开始日期

updates = self.fetch_updates(repo, since=since.isoformat(), until=today.isoformat())
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)
repo_dir = os.path.join('daily_progress', repo.replace("/", "_")) # 构建目录路径
os.makedirs(repo_dir, exist_ok=True) # 确保目录存在

# Updated filename with date range
# 更新文件名以包含日期范围
date_str = f"{since}_to_{today}"
file_path = os.path.join(repo_dir, f'{date_str}.md')
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("\n## Issues Closed in the Last {days} Days\n")
for issue in updates['issues']:
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")
file.write("\n## Pull Requests Merged in the Last {days} Days\n")
for pr in updates['pull_requests']:
file.write(f"\n## Pull Requests Merged in the Last {days} Days\n")
for pr in updates['pull_requests']: # 写入在指定日期内合并的拉取请求
file.write(f"- {pr['title']} #{pr['number']}\n")

LOG.info(f"Exported time-range progress to {file_path}")
LOG.info(f"Exported time-range progress to {file_path}") # 记录日志
return file_path
Loading

0 comments on commit 730e2d9

Please sign in to comment.