1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- // 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
- import (
- "context"
- "fmt"
- )
- // RepositoryInvitation represents an invitation to collaborate on a repo.
- type RepositoryInvitation struct {
- ID *int64 `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
- func (s *RepositoriesService) ListInvitations(ctx context.Context, owner, repo string, opt *ListOptions) ([]*RepositoryInvitation, *Response, error) {
- u := fmt.Sprintf("repos/%v/%v/invitations", 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
- }
- // TODO: remove custom Accept header when this API fully launches.
- req.Header.Set("Accept", mediaTypeRepositoryInvitationsPreview)
- invites := []*RepositoryInvitation{}
- resp, err := s.client.Do(ctx, req, &invites)
- if err != nil {
- return nil, resp, err
- }
- return invites, resp, nil
- }
- // DeleteInvitation deletes a repository invitation.
- //
- // GitHub API docs: https://developer.github.com/v3/repos/invitations/#delete-a-repository-invitation
- func (s *RepositoriesService) DeleteInvitation(ctx context.Context, owner, repo string, invitationID int64) (*Response, error) {
- u := fmt.Sprintf("repos/%v/%v/invitations/%v", owner, repo, invitationID)
- 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)
- return s.client.Do(ctx, req, nil)
- }
- // 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
- func (s *RepositoriesService) UpdateInvitation(ctx context.Context, owner, repo string, invitationID int64, permissions string) (*RepositoryInvitation, *Response, error) {
- opts := &struct {
- Permissions string `json:"permissions"`
- }{Permissions: permissions}
- u := fmt.Sprintf("repos/%v/%v/invitations/%v", owner, repo, invitationID)
- 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{}
- resp, err := s.client.Do(ctx, req, invite)
- if err != nil {
- return nil, resp, err
- }
- return invite, resp, nil
- }
|