|
|
|
@ -10,10 +10,20 @@ import (
|
|
|
|
|
"fmt" |
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
type Collaborator struct { |
|
|
|
|
*User |
|
|
|
|
Permissions Permission `json:"permissions"` |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
type AddCollaboratorOption struct { |
|
|
|
|
Permission *string `json:"permission"` |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
func (c *Client) ListCollaborator(user, repo string) ([]*Collaborator, error) { |
|
|
|
|
collabs := make([]*Collaborator, 0, 10) |
|
|
|
|
return collabs, c.getParsedResponse("GET", fmt.Sprintf("/repos/%s/%s/collaborators", user, repo), nil, nil, &collabs) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
func (c *Client) AddCollaborator(user, repo, collaborator string, opt AddCollaboratorOption) error { |
|
|
|
|
body, err := json.Marshal(&opt) |
|
|
|
|
if err != nil { |
|
|
|
@ -22,3 +32,13 @@ func (c *Client) AddCollaborator(user, repo, collaborator string, opt AddCollabo
|
|
|
|
|
_, err = c.getResponse("PUT", fmt.Sprintf("/repos/%s/%s/collaborators/%s", user, repo, collaborator), nil, bytes.NewReader(body)) |
|
|
|
|
return err |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
func (c *Client) DeleteCollaborator(user, repo, collaborator string) error { |
|
|
|
|
_, err := c.getResponse("DELETE", fmt.Sprintf("/repos/%s/%s/collaborators/%s", user, repo, collaborator), nil, nil) |
|
|
|
|
return err |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
func (c *Client) IsCollaborator(user, repo, collaborator string) error { |
|
|
|
|
_, err := c.getResponse("GET", fmt.Sprintf("/repos/%s/%s/collaborators/%s", user, repo, collaborator), nil, nil) |
|
|
|
|
return err |
|
|
|
|
} |
|
|
|
|