open-vault/vendor/github.com/google/go-github/github/repos_invitations.go

99 lines
3.3 KiB
Go
Raw Normal View History

2016-06-30 18:19:03 +00:00
// Copyright 2016 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
2017-02-24 19:36:54 +00:00
import (
"context"
"fmt"
)
2016-06-30 18:19:03 +00:00
// RepositoryInvitation represents an invitation to collaborate on a repo.
type RepositoryInvitation struct {
ID *int `json:"id,omitempty"`
Repo *Repository `json:"repository,omitempty"`
Invitee *User `json:"invitee,omitempty"`
Inviter *User `json:"inviter,omitempty"`
// Permissions represents the permissions that the associated user will have
// on the repository. Possible values are: "read", "write", "admin".
Permissions *string `json:"permissions,omitempty"`
CreatedAt *Timestamp `json:"created_at,omitempty"`
URL *string `json:"url,omitempty"`
HTMLURL *string `json:"html_url,omitempty"`
}
// ListInvitations lists all currently-open repository invitations.
//
// GitHub API docs: https://developer.github.com/v3/repos/invitations/#list-invitations-for-a-repository
2017-03-31 00:03:13 +00:00
func (s *RepositoriesService) ListInvitations(ctx context.Context, owner, repo string, opt *ListOptions) ([]*RepositoryInvitation, *Response, error) {
u := fmt.Sprintf("repos/%v/%v/invitations", owner, repo)
2016-06-30 18:19:03 +00:00
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
}
// TODO: remove custom Accept header when this API fully launches.
req.Header.Set("Accept", mediaTypeRepositoryInvitationsPreview)
invites := []*RepositoryInvitation{}
2017-02-24 19:36:54 +00:00
resp, err := s.client.Do(ctx, req, &invites)
2016-06-30 18:19:03 +00:00
if err != nil {
return nil, resp, err
}
return invites, resp, nil
2016-06-30 18:19:03 +00:00
}
// DeleteInvitation deletes a repository invitation.
//
// GitHub API docs: https://developer.github.com/v3/repos/invitations/#delete-a-repository-invitation
2017-03-31 00:03:13 +00:00
func (s *RepositoriesService) DeleteInvitation(ctx context.Context, owner, repo string, invitationID int) (*Response, error) {
u := fmt.Sprintf("repos/%v/%v/invitations/%v", owner, repo, invitationID)
2016-06-30 18:19:03 +00:00
req, err := s.client.NewRequest("DELETE", u, nil)
if err != nil {
return nil, err
}
// TODO: remove custom Accept header when this API fully launches.
req.Header.Set("Accept", mediaTypeRepositoryInvitationsPreview)
2017-02-24 19:36:54 +00:00
return s.client.Do(ctx, req, nil)
2016-06-30 18:19:03 +00:00
}
// UpdateInvitation updates the permissions associated with a repository
// invitation.
//
// permissions represents the permissions that the associated user will have
// on the repository. Possible values are: "read", "write", "admin".
//
// GitHub API docs: https://developer.github.com/v3/repos/invitations/#update-a-repository-invitation
2017-03-31 00:03:13 +00:00
func (s *RepositoriesService) UpdateInvitation(ctx context.Context, owner, repo string, invitationID int, permissions string) (*RepositoryInvitation, *Response, error) {
2016-06-30 18:19:03 +00:00
opts := &struct {
Permissions string `json:"permissions"`
}{Permissions: permissions}
2017-03-31 00:03:13 +00:00
u := fmt.Sprintf("repos/%v/%v/invitations/%v", owner, repo, invitationID)
2016-06-30 18:19:03 +00:00
req, err := s.client.NewRequest("PATCH", u, opts)
if err != nil {
return nil, nil, err
}
// TODO: remove custom Accept header when this API fully launches.
req.Header.Set("Accept", mediaTypeRepositoryInvitationsPreview)
invite := &RepositoryInvitation{}
2017-02-24 19:36:54 +00:00
resp, err := s.client.Do(ctx, req, invite)
2017-05-24 13:40:58 +00:00
if err != nil {
return nil, resp, err
}
return invite, resp, nil
2016-06-30 18:19:03 +00:00
}