mirror of
https://github.com/MichaelMure/git-bug.git
synced 2025-01-05 17:33:12 +03:00
141 lines
2.8 KiB
Go
141 lines
2.8 KiB
Go
package gitlab
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/MichaelMure/git-bug/util/text"
|
|
"github.com/xanzy/go-gitlab"
|
|
)
|
|
|
|
// Issues returns a channel with gitlab project issues, ascending order.
|
|
func Issues(ctx context.Context, client *gitlab.Client, pid string, since time.Time) <-chan *gitlab.Issue {
|
|
out := make(chan *gitlab.Issue)
|
|
|
|
go func() {
|
|
defer close(out)
|
|
|
|
opts := gitlab.ListProjectIssuesOptions{
|
|
UpdatedAfter: &since,
|
|
Scope: gitlab.String("all"),
|
|
Sort: gitlab.String("asc"),
|
|
}
|
|
|
|
for {
|
|
issues, resp, err := client.Issues.ListProjectIssues(pid, &opts, gitlab.WithContext(ctx))
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
for _, issue := range issues {
|
|
out <- issue
|
|
}
|
|
|
|
if resp.CurrentPage >= resp.TotalPages {
|
|
break
|
|
}
|
|
|
|
opts.Page = resp.NextPage
|
|
}
|
|
}()
|
|
|
|
return out
|
|
}
|
|
|
|
// Notes returns a channel with note events
|
|
func Notes(ctx context.Context, client *gitlab.Client, issue *gitlab.Issue) <-chan Event {
|
|
out := make(chan Event)
|
|
|
|
go func() {
|
|
defer close(out)
|
|
|
|
opts := gitlab.ListIssueNotesOptions{
|
|
OrderBy: gitlab.String("created_at"),
|
|
Sort: gitlab.String("asc"),
|
|
}
|
|
|
|
for {
|
|
notes, resp, err := client.Notes.ListIssueNotes(issue.ProjectID, issue.IID, &opts, gitlab.WithContext(ctx))
|
|
|
|
if err != nil {
|
|
out <- ErrorEvent{Err: err, Time: time.Now()}
|
|
}
|
|
|
|
for _, note := range notes {
|
|
out <- NoteEvent{*note}
|
|
}
|
|
|
|
if resp.CurrentPage >= resp.TotalPages {
|
|
break
|
|
}
|
|
|
|
opts.Page = resp.NextPage
|
|
}
|
|
}()
|
|
|
|
return out
|
|
}
|
|
|
|
// LabelEvents returns a channel with label events.
|
|
func LabelEvents(ctx context.Context, client *gitlab.Client, issue *gitlab.Issue) <-chan Event {
|
|
out := make(chan Event)
|
|
|
|
go func() {
|
|
defer close(out)
|
|
|
|
opts := gitlab.ListLabelEventsOptions{}
|
|
|
|
for {
|
|
events, resp, err := client.ResourceLabelEvents.ListIssueLabelEvents(issue.ProjectID, issue.IID, &opts, gitlab.WithContext(ctx))
|
|
|
|
if err != nil {
|
|
out <- ErrorEvent{Err: err, Time: time.Now()}
|
|
}
|
|
|
|
for _, e := range events {
|
|
le := LabelEvent{*e}
|
|
le.Label.Name = text.CleanupOneLine(le.Label.Name)
|
|
out <- le
|
|
}
|
|
|
|
if resp.CurrentPage >= resp.TotalPages {
|
|
break
|
|
}
|
|
|
|
opts.Page = resp.NextPage
|
|
}
|
|
}()
|
|
|
|
return out
|
|
}
|
|
|
|
// StateEvents returns a channel with state change events.
|
|
func StateEvents(ctx context.Context, client *gitlab.Client, issue *gitlab.Issue) <-chan Event {
|
|
out := make(chan Event)
|
|
|
|
go func() {
|
|
defer close(out)
|
|
|
|
opts := gitlab.ListStateEventsOptions{}
|
|
|
|
for {
|
|
events, resp, err := client.ResourceStateEvents.ListIssueStateEvents(issue.ProjectID, issue.IID, &opts, gitlab.WithContext(ctx))
|
|
if err != nil {
|
|
out <- ErrorEvent{Err: err, Time: time.Now()}
|
|
}
|
|
|
|
for _, e := range events {
|
|
out <- StateEvent{*e}
|
|
}
|
|
|
|
if resp.CurrentPage >= resp.TotalPages {
|
|
break
|
|
}
|
|
|
|
opts.Page = resp.NextPage
|
|
}
|
|
}()
|
|
|
|
return out
|
|
}
|