rework more

This commit is contained in:
6543 2023-06-23 15:59:06 +02:00
parent 183ce4c5d4
commit 72cc266cf7
No known key found for this signature in database
GPG Key ID: B8BE6D610E61C862
1 changed files with 100 additions and 35 deletions

View File

@ -23,63 +23,75 @@ type GitHub struct {
Token string
Repo string
Issues bool
client *github.Client
}
const (
stateClosed = "closed"
perPage = 100
)
// Generate returns a GitHub changelog
func (gh *GitHub) Generate() (string, []Entry, error) {
ctx := context.Background()
var entries []Entry
var err error
tagURL := fmt.Sprintf("## [%s](https://github.com/%s/releases/tag/%s) - %s", gh.Milestone, gh.Repo, gh.GitTag, time.Now().Format("2006-01-02"))
client := github.NewClient(httpClient())
ctx := context.Background()
prs := make([]Entry, 0)
state := "merged"
if gh.Issues {
state = "closed"
}
gh.client = github.NewClient(httpClient())
repoParts := strings.SplitN(gh.Repo, "/", 2)
if len(repoParts) != 2 {
return "", nil, fmt.Errorf("repo: '%s' can not be split into repoOwner and repoName", gh.Repo)
}
p := 1
perPage := 100
if gh.Issues {
entries, err = gh.generateByIssues(ctx, repoParts[0], repoParts[1])
} else {
entries, err = gh.generateByPulls(ctx, repoParts[0], repoParts[1])
}
return tagURL, entries, err
}
func (gh *GitHub) generateByIssues(ctx context.Context, repoOwner, repoName string) ([]Entry, error) {
page := 1
issues := make([]Entry, 0, 10)
for {
result, _, err := client.Issues.ListByRepo(ctx, repoParts[0], repoParts[1], &github.IssueListByRepoOptions{
result, _, err := gh.client.Issues.ListByRepo(ctx, repoOwner, repoName, &github.IssueListByRepoOptions{
ListOptions: github.ListOptions{
Page: p,
Page: page,
PerPage: perPage,
},
State: state,
State: stateClosed,
Milestone: gh.Milestone,
})
if err != nil {
return "", nil, err
return nil, err
}
p++
page++
isPull := !(gh.Issues)
for _, pr := range result {
if pr.IsPullRequest() == isPull {
p := Entry{
Title: CleanTitle(pr.GetTitle()),
Index: int64(pr.GetNumber()),
}
labels := make([]Label, len(pr.Labels))
for idx, lbl := range pr.Labels {
labels[idx] = Label{
Name: lbl.GetName(),
}
}
p.Labels = labels
prs = append(prs, p)
for _, item := range result {
if item.IsPullRequest() {
continue
}
e := Entry{
Title: CleanTitle(item.GetTitle()),
Index: int64(item.GetNumber()),
}
labels := make([]Label, len(item.Labels))
for idx, lbl := range item.Labels {
labels[idx] = Label{
Name: lbl.GetName(),
}
}
e.Labels = labels
issues = append(issues, e)
}
if len(result) != perPage {
@ -87,7 +99,60 @@ func (gh *GitHub) Generate() (string, []Entry, error) {
}
}
return tagURL, prs, nil
return issues, nil
}
func (gh *GitHub) generateByPulls(ctx context.Context, repoOwner, repoName string) ([]Entry, error) {
page := 1
pulls := make([]Entry, 0, 10)
for {
result, _, err := gh.client.PullRequests.List(ctx, repoOwner, repoName, &github.PullRequestListOptions{
ListOptions: github.ListOptions{
Page: page,
PerPage: perPage,
},
State: stateClosed,
})
if err != nil {
return nil, err
}
page++
for _, item := range result {
// only merged pulls
if item.Merged == nil || !*item.Merged {
continue
}
// only with right milestone
if item.GetMilestone() == nil ||
item.GetMilestone().GetTitle() != gh.Milestone {
continue
}
p := Entry{
Title: CleanTitle(item.GetTitle()),
Index: int64(item.GetNumber()),
}
labels := make([]Label, len(item.Labels))
for idx, lbl := range item.Labels {
labels[idx] = Label{
Name: lbl.GetName(),
}
}
p.Labels = labels
pulls = append(pulls, p)
}
if len(result) != perPage {
break
}
}
return pulls, nil
}
// Contributors returns a list of contributors from GitHub