|
@@ -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
|
|
|
+}
|