2017-02-07 22:33:23 +01:00
|
|
|
|
// Copyright 2013 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 (
|
2017-04-11 17:10:46 +02:00
|
|
|
|
"context"
|
2017-02-07 22:33:23 +01:00
|
|
|
|
"encoding/json"
|
|
|
|
|
"fmt"
|
|
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// Event represents a GitHub event.
|
|
|
|
|
type Event struct {
|
|
|
|
|
Type *string `json:"type,omitempty"`
|
|
|
|
|
Public *bool `json:"public"`
|
|
|
|
|
RawPayload *json.RawMessage `json:"payload,omitempty"`
|
|
|
|
|
Repo *Repository `json:"repo,omitempty"`
|
|
|
|
|
Actor *User `json:"actor,omitempty"`
|
|
|
|
|
Org *Organization `json:"org,omitempty"`
|
|
|
|
|
CreatedAt *time.Time `json:"created_at,omitempty"`
|
|
|
|
|
ID *string `json:"id,omitempty"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (e Event) String() string {
|
|
|
|
|
return Stringify(e)
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// ParsePayload parses the event payload. For recognized event types,
|
2017-02-07 22:33:23 +01:00
|
|
|
|
// a value of the corresponding struct type will be returned.
|
2017-04-11 17:10:46 +02:00
|
|
|
|
func (e *Event) ParsePayload() (payload interface{}, err error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
switch *e.Type {
|
|
|
|
|
case "CommitCommentEvent":
|
|
|
|
|
payload = &CommitCommentEvent{}
|
|
|
|
|
case "CreateEvent":
|
|
|
|
|
payload = &CreateEvent{}
|
|
|
|
|
case "DeleteEvent":
|
|
|
|
|
payload = &DeleteEvent{}
|
|
|
|
|
case "DeploymentEvent":
|
|
|
|
|
payload = &DeploymentEvent{}
|
|
|
|
|
case "DeploymentStatusEvent":
|
|
|
|
|
payload = &DeploymentStatusEvent{}
|
|
|
|
|
case "ForkEvent":
|
|
|
|
|
payload = &ForkEvent{}
|
|
|
|
|
case "GollumEvent":
|
|
|
|
|
payload = &GollumEvent{}
|
|
|
|
|
case "IntegrationInstallationEvent":
|
|
|
|
|
payload = &IntegrationInstallationEvent{}
|
|
|
|
|
case "IntegrationInstallationRepositoriesEvent":
|
|
|
|
|
payload = &IntegrationInstallationRepositoriesEvent{}
|
|
|
|
|
case "IssueCommentEvent":
|
|
|
|
|
payload = &IssueCommentEvent{}
|
|
|
|
|
case "IssuesEvent":
|
|
|
|
|
payload = &IssuesEvent{}
|
|
|
|
|
case "LabelEvent":
|
|
|
|
|
payload = &LabelEvent{}
|
|
|
|
|
case "MemberEvent":
|
|
|
|
|
payload = &MemberEvent{}
|
|
|
|
|
case "MembershipEvent":
|
|
|
|
|
payload = &MembershipEvent{}
|
|
|
|
|
case "MilestoneEvent":
|
|
|
|
|
payload = &MilestoneEvent{}
|
2017-04-11 17:10:46 +02:00
|
|
|
|
case "OrganizationEvent":
|
|
|
|
|
payload = &OrganizationEvent{}
|
2017-02-07 22:33:23 +01:00
|
|
|
|
case "PageBuildEvent":
|
|
|
|
|
payload = &PageBuildEvent{}
|
|
|
|
|
case "PingEvent":
|
|
|
|
|
payload = &PingEvent{}
|
2017-04-11 17:10:46 +02:00
|
|
|
|
case "ProjectEvent":
|
|
|
|
|
payload = &ProjectEvent{}
|
|
|
|
|
case "ProjectCardEvent":
|
|
|
|
|
payload = &ProjectCardEvent{}
|
|
|
|
|
case "ProjectColumnEvent":
|
|
|
|
|
payload = &ProjectColumnEvent{}
|
2017-02-07 22:33:23 +01:00
|
|
|
|
case "PublicEvent":
|
|
|
|
|
payload = &PublicEvent{}
|
|
|
|
|
case "PullRequestEvent":
|
|
|
|
|
payload = &PullRequestEvent{}
|
|
|
|
|
case "PullRequestReviewEvent":
|
|
|
|
|
payload = &PullRequestReviewEvent{}
|
|
|
|
|
case "PullRequestReviewCommentEvent":
|
|
|
|
|
payload = &PullRequestReviewCommentEvent{}
|
|
|
|
|
case "PushEvent":
|
|
|
|
|
payload = &PushEvent{}
|
|
|
|
|
case "ReleaseEvent":
|
|
|
|
|
payload = &ReleaseEvent{}
|
|
|
|
|
case "RepositoryEvent":
|
|
|
|
|
payload = &RepositoryEvent{}
|
|
|
|
|
case "StatusEvent":
|
|
|
|
|
payload = &StatusEvent{}
|
|
|
|
|
case "TeamAddEvent":
|
|
|
|
|
payload = &TeamAddEvent{}
|
|
|
|
|
case "WatchEvent":
|
|
|
|
|
payload = &WatchEvent{}
|
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
|
err = json.Unmarshal(*e.RawPayload, &payload)
|
|
|
|
|
return payload, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Payload returns the parsed event payload. For recognized event types,
|
|
|
|
|
// a value of the corresponding struct type will be returned.
|
|
|
|
|
//
|
|
|
|
|
// Deprecated: Use ParsePayload instead, which returns an error
|
|
|
|
|
// rather than panics if JSON unmarshaling raw payload fails.
|
|
|
|
|
func (e *Event) Payload() (payload interface{}) {
|
|
|
|
|
var err error
|
|
|
|
|
payload, err = e.ParsePayload()
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|
|
|
|
|
return payload
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListEvents drinks from the firehose of all public events across GitHub.
|
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/activity/events/#list-public-events
|
|
|
|
|
func (s *ActivityService) ListEvents(ctx context.Context, opt *ListOptions) ([]*Event, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
u, err := addOptions("events", opt)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
var events []*Event
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
return events, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListRepositoryEvents lists events for a repository.
|
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/activity/events/#list-repository-events
|
|
|
|
|
func (s *ActivityService) ListRepositoryEvents(ctx context.Context, owner, repo string, opt *ListOptions) ([]*Event, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
u := fmt.Sprintf("repos/%v/%v/events", owner, repo)
|
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
var events []*Event
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
return events, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListIssueEventsForRepository lists issue events for a repository.
|
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/activity/events/#list-issue-events-for-a-repository
|
|
|
|
|
func (s *ActivityService) ListIssueEventsForRepository(ctx context.Context, owner, repo string, opt *ListOptions) ([]*IssueEvent, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/events", owner, repo)
|
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
var events []*IssueEvent
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
return events, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListEventsForRepoNetwork lists public events for a network of repositories.
|
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/activity/events/#list-public-events-for-a-network-of-repositories
|
|
|
|
|
func (s *ActivityService) ListEventsForRepoNetwork(ctx context.Context, owner, repo string, opt *ListOptions) ([]*Event, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
u := fmt.Sprintf("networks/%v/%v/events", owner, repo)
|
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
var events []*Event
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
return events, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListEventsForOrganization lists public events for an organization.
|
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/activity/events/#list-public-events-for-an-organization
|
|
|
|
|
func (s *ActivityService) ListEventsForOrganization(ctx context.Context, org string, opt *ListOptions) ([]*Event, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
u := fmt.Sprintf("orgs/%v/events", org)
|
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
var events []*Event
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
return events, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListEventsPerformedByUser lists the events performed by a user. If publicOnly is
|
|
|
|
|
// true, only public events will be returned.
|
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/activity/events/#list-events-performed-by-a-user
|
|
|
|
|
func (s *ActivityService) ListEventsPerformedByUser(ctx context.Context, user string, publicOnly bool, opt *ListOptions) ([]*Event, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
var u string
|
|
|
|
|
if publicOnly {
|
|
|
|
|
u = fmt.Sprintf("users/%v/events/public", user)
|
|
|
|
|
} else {
|
|
|
|
|
u = fmt.Sprintf("users/%v/events", user)
|
|
|
|
|
}
|
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
var events []*Event
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
return events, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListEventsReceivedByUser lists the events received by a user. If publicOnly is
|
|
|
|
|
// true, only public events will be returned.
|
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/activity/events/#list-events-that-a-user-has-received
|
|
|
|
|
func (s *ActivityService) ListEventsReceivedByUser(ctx context.Context, user string, publicOnly bool, opt *ListOptions) ([]*Event, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
var u string
|
|
|
|
|
if publicOnly {
|
|
|
|
|
u = fmt.Sprintf("users/%v/received_events/public", user)
|
|
|
|
|
} else {
|
|
|
|
|
u = fmt.Sprintf("users/%v/received_events", user)
|
|
|
|
|
}
|
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
var events []*Event
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
return events, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ListUserEventsForOrganization provides the user’s organization dashboard. You
|
|
|
|
|
// must be authenticated as the user to view this.
|
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
|
// GitHub API docs: https://developer.github.com/v3/activity/events/#list-events-for-an-organization
|
|
|
|
|
func (s *ActivityService) ListUserEventsForOrganization(ctx context.Context, org, user string, opt *ListOptions) ([]*Event, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
|
u := fmt.Sprintf("users/%v/events/orgs/%v", user, org)
|
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
var events []*Event
|
|
|
|
|
resp, err := s.client.Do(ctx, req, &events)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, resp, err
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
|
return events, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
|
}
|