2019-05-07 03:12:51 +02:00
|
|
|
|
// Copyright 2014 The go-github AUTHORS. All rights reserved.
|
|
|
|
|
//
|
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
|
|
package github
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"fmt"
|
|
|
|
|
"strings"
|
|
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// IssueEvent represents an event that occurred around an Issue or Pull Request.
|
|
|
|
|
type IssueEvent struct {
|
|
|
|
|
ID *int64 `json:"id,omitempty"`
|
|
|
|
|
URL *string `json:"url,omitempty"`
|
|
|
|
|
|
|
|
|
|
// The User that generated this event.
|
|
|
|
|
Actor *User `json:"actor,omitempty"`
|
|
|
|
|
|
|
|
|
|
// Event identifies the actual type of Event that occurred. Possible
|
|
|
|
|
// values are:
|
|
|
|
|
//
|
|
|
|
|
// closed
|
|
|
|
|
// The Actor closed the issue.
|
|
|
|
|
// If the issue was closed by commit message, CommitID holds the SHA1 hash of the commit.
|
|
|
|
|
//
|
|
|
|
|
// merged
|
|
|
|
|
// The Actor merged into master a branch containing a commit mentioning the issue.
|
|
|
|
|
// CommitID holds the SHA1 of the merge commit.
|
|
|
|
|
//
|
|
|
|
|
// referenced
|
|
|
|
|
// The Actor committed to master a commit mentioning the issue in its commit message.
|
|
|
|
|
// CommitID holds the SHA1 of the commit.
|
|
|
|
|
//
|
|
|
|
|
// reopened, unlocked
|
|
|
|
|
// The Actor did that to the issue.
|
|
|
|
|
//
|
|
|
|
|
// locked
|
|
|
|
|
// The Actor locked the issue.
|
|
|
|
|
// LockReason holds the reason of locking the issue (if provided while locking).
|
|
|
|
|
//
|
|
|
|
|
// renamed
|
|
|
|
|
// The Actor changed the issue title from Rename.From to Rename.To.
|
|
|
|
|
//
|
|
|
|
|
// mentioned
|
|
|
|
|
// Someone unspecified @mentioned the Actor [sic] in an issue comment body.
|
|
|
|
|
//
|
|
|
|
|
// assigned, unassigned
|
|
|
|
|
// The Assigner assigned the issue to or removed the assignment from the Assignee.
|
|
|
|
|
//
|
|
|
|
|
// labeled, unlabeled
|
|
|
|
|
// The Actor added or removed the Label from the issue.
|
|
|
|
|
//
|
|
|
|
|
// milestoned, demilestoned
|
|
|
|
|
// The Actor added or removed the issue from the Milestone.
|
|
|
|
|
//
|
|
|
|
|
// subscribed, unsubscribed
|
|
|
|
|
// The Actor subscribed to or unsubscribed from notifications for an issue.
|
|
|
|
|
//
|
|
|
|
|
// head_ref_deleted, head_ref_restored
|
|
|
|
|
// The pull request’s branch was deleted or restored.
|
|
|
|
|
//
|
2020-07-31 16:22:34 +02:00
|
|
|
|
// review_dismissed
|
|
|
|
|
// The review was dismissed and `DismissedReview` will be populated below.
|
|
|
|
|
//
|
2019-05-07 03:12:51 +02:00
|
|
|
|
Event *string `json:"event,omitempty"`
|
|
|
|
|
|
|
|
|
|
CreatedAt *time.Time `json:"created_at,omitempty"`
|
|
|
|
|
Issue *Issue `json:"issue,omitempty"`
|
|
|
|
|
|
|
|
|
|
// Only present on certain events; see above.
|
2020-07-31 16:22:34 +02:00
|
|
|
|
Assignee *User `json:"assignee,omitempty"`
|
|
|
|
|
Assigner *User `json:"assigner,omitempty"`
|
|
|
|
|
CommitID *string `json:"commit_id,omitempty"`
|
|
|
|
|
Milestone *Milestone `json:"milestone,omitempty"`
|
|
|
|
|
Label *Label `json:"label,omitempty"`
|
|
|
|
|
Rename *Rename `json:"rename,omitempty"`
|
|
|
|
|
LockReason *string `json:"lock_reason,omitempty"`
|
|
|
|
|
ProjectCard *ProjectCard `json:"project_card,omitempty"`
|
|
|
|
|
DismissedReview *DismissedReview `json:"dismissed_review,omitempty"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// DismissedReview represents details for 'dismissed_review' events.
|
|
|
|
|
type DismissedReview struct {
|
|
|
|
|
// State represents the state of the dismissed review.
|
|
|
|
|
// Possible values are: "commented", "approved", and "changes_requested".
|
|
|
|
|
State *string `json:"state,omitempty"`
|
|
|
|
|
ReviewID *int64 `json:"review_id,omitempty"`
|
|
|
|
|
DismissalMessage *string `json:"dismissal_message,omitempty"`
|
|
|
|
|
DismissalCommitID *string `json:"dismissal_commit_id,omitempty"`
|
2019-05-07 03:12:51 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListIssueEvents lists events for the specified issue.
|
|
|
|
|
//
|
2020-07-31 16:22:34 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/events/#list-issue-events
|
|
|
|
|
func (s *IssuesService) ListIssueEvents(ctx context.Context, owner, repo string, number int, opts *ListOptions) ([]*IssueEvent, *Response, error) {
|
2019-05-07 03:12:51 +02:00
|
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/%v/events", owner, repo, number)
|
2020-07-31 16:22:34 +02:00
|
|
|
|
u, err := addOptions(u, opts)
|
2019-05-07 03:12:51 +02:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
acceptHeaders := []string{mediaTypeLockReasonPreview, mediaTypeProjectCardDetailsPreview}
|
|
|
|
|
req.Header.Set("Accept", strings.Join(acceptHeaders, ", "))
|
|
|
|
|
|
|
|
|
|
var events []*IssueEvent
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return events, resp, nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListRepositoryEvents lists events for the specified repository.
|
|
|
|
|
//
|
2020-07-31 16:22:34 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/events/#list-issue-events-for-a-repository
|
|
|
|
|
func (s *IssuesService) ListRepositoryEvents(ctx context.Context, owner, repo string, opts *ListOptions) ([]*IssueEvent, *Response, error) {
|
2019-05-07 03:12:51 +02:00
|
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/events", owner, repo)
|
2020-07-31 16:22:34 +02:00
|
|
|
|
u, err := addOptions(u, opts)
|
2019-05-07 03:12:51 +02:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var events []*IssueEvent
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return events, resp, nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// GetEvent returns the specified issue event.
|
|
|
|
|
//
|
2020-07-31 16:22:34 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/events/#get-an-issue-event
|
2019-05-07 03:12:51 +02:00
|
|
|
|
func (s *IssuesService) GetEvent(ctx context.Context, owner, repo string, id int64) (*IssueEvent, *Response, error) {
|
|
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/events/%v", owner, repo, id)
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
event := new(IssueEvent)
|
|
|
|
|
resp, err := s.client.Do(ctx, req, event)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return event, resp, nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Rename contains details for 'renamed' events.
|
|
|
|
|
type Rename struct {
|
|
|
|
|
From *string `json:"from,omitempty"`
|
|
|
|
|
To *string `json:"to,omitempty"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (r Rename) String() string {
|
|
|
|
|
return Stringify(r)
|
|
|
|
|
}
|