123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- // 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 (
- "context"
- "fmt"
- )
- // ListCollaboratorsOptions specifies the optional parameters to the
- // RepositoriesService.ListCollaborators method.
- type ListCollaboratorsOptions struct {
- // Affiliation specifies how collaborators should be filtered by their affiliation.
- // Possible values are:
- // outside - All outside collaborators of an organization-owned repository
- // direct - All collaborators with permissions to an organization-owned repository,
- // regardless of organization membership status
- // all - All collaborators the authenticated user can see
- //
- // Default value is "all".
- Affiliation string `url:"affiliation,omitempty"`
- ListOptions
- }
- // ListCollaborators lists the GitHub users that have access to the repository.
- //
- // GitHub API docs: https://developer.github.com/v3/repos/collaborators/#list-collaborators
- func (s *RepositoriesService) ListCollaborators(ctx context.Context, owner, repo string, opt *ListCollaboratorsOptions) ([]*User, *Response, error) {
- u := fmt.Sprintf("repos/%v/%v/collaborators", 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
- }
- req.Header.Set("Accept", mediaTypeNestedTeamsPreview)
- var users []*User
- resp, err := s.client.Do(ctx, req, &users)
- if err != nil {
- return nil, resp, err
- }
- return users, resp, nil
- }
- // IsCollaborator checks whether the specified GitHub user has collaborator
- // access to the given repo.
- // Note: This will return false if the user is not a collaborator OR the user
- // is not a GitHub user.
- //
- // GitHub API docs: https://developer.github.com/v3/repos/collaborators/#get
- func (s *RepositoriesService) IsCollaborator(ctx context.Context, owner, repo, user string) (bool, *Response, error) {
- u := fmt.Sprintf("repos/%v/%v/collaborators/%v", owner, repo, user)
- req, err := s.client.NewRequest("GET", u, nil)
- if err != nil {
- return false, nil, err
- }
- resp, err := s.client.Do(ctx, req, nil)
- isCollab, err := parseBoolResponse(err)
- return isCollab, resp, err
- }
- // RepositoryPermissionLevel represents the permission level an organization
- // member has for a given repository.
- type RepositoryPermissionLevel struct {
- // Possible values: "admin", "write", "read", "none"
- Permission *string `json:"permission,omitempty"`
- User *User `json:"user,omitempty"`
- }
- // GetPermissionLevel retrieves the specific permission level a collaborator has for a given repository.
- // GitHub API docs: https://developer.github.com/v3/repos/collaborators/#review-a-users-permission-level
- func (s *RepositoriesService) GetPermissionLevel(ctx context.Context, owner, repo, user string) (*RepositoryPermissionLevel, *Response, error) {
- u := fmt.Sprintf("repos/%v/%v/collaborators/%v/permission", owner, repo, user)
- req, err := s.client.NewRequest("GET", u, nil)
- if err != nil {
- return nil, nil, err
- }
- rpl := new(RepositoryPermissionLevel)
- resp, err := s.client.Do(ctx, req, rpl)
- if err != nil {
- return nil, resp, err
- }
- return rpl, resp, nil
- }
- // RepositoryAddCollaboratorOptions specifies the optional parameters to the
- // RepositoriesService.AddCollaborator method.
- type RepositoryAddCollaboratorOptions struct {
- // Permission specifies the permission to grant the user on this repository.
- // Possible values are:
- // pull - team members can pull, but not push to or administer this repository
- // push - team members can pull and push, but not administer this repository
- // admin - team members can pull, push and administer this repository
- //
- // Default value is "push". This option is only valid for organization-owned repositories.
- Permission string `json:"permission,omitempty"`
- }
- // AddCollaborator sends an invitation to the specified GitHub user
- // to become a collaborator to the given repo.
- //
- // GitHub API docs: https://developer.github.com/v3/repos/collaborators/#add-user-as-a-collaborator
- func (s *RepositoriesService) AddCollaborator(ctx context.Context, owner, repo, user string, opt *RepositoryAddCollaboratorOptions) (*Response, error) {
- u := fmt.Sprintf("repos/%v/%v/collaborators/%v", owner, repo, user)
- req, err := s.client.NewRequest("PUT", u, opt)
- 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)
- }
- // RemoveCollaborator removes the specified GitHub user as collaborator from the given repo.
- // Note: Does not return error if a valid user that is not a collaborator is removed.
- //
- // GitHub API docs: https://developer.github.com/v3/repos/collaborators/#remove-collaborator
- func (s *RepositoriesService) RemoveCollaborator(ctx context.Context, owner, repo, user string) (*Response, error) {
- u := fmt.Sprintf("repos/%v/%v/collaborators/%v", owner, repo, user)
- req, err := s.client.NewRequest("DELETE", u, nil)
- if err != nil {
- return nil, err
- }
- return s.client.Do(ctx, req, nil)
- }
|