aboutsummaryrefslogtreecommitdiff
path: root/routes/api/v1/repo/collaborators.go
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2017-06-11 00:34:14 -0400
committerUnknwon <u@gogs.io>2017-06-11 00:34:14 -0400
commit4400d2fdd933204044aeb18ce7d8613c53aa87c0 (patch)
tree841e91d5294c49b7335170fbc4b9ff79e882f91a /routes/api/v1/repo/collaborators.go
parent6197a7639a88f7fb0fee8927e1d501504ae770ff (diff)
Refactoring: rename package routers -> routes
Diffstat (limited to 'routes/api/v1/repo/collaborators.go')
-rw-r--r--routes/api/v1/repo/collaborators.go94
1 files changed, 94 insertions, 0 deletions
diff --git a/routes/api/v1/repo/collaborators.go b/routes/api/v1/repo/collaborators.go
new file mode 100644
index 00000000..d295ac0f
--- /dev/null
+++ b/routes/api/v1/repo/collaborators.go
@@ -0,0 +1,94 @@
+// Copyright 2016 The Gogs Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package repo
+
+import (
+ api "github.com/gogits/go-gogs-client"
+
+ "github.com/gogits/gogs/models"
+ "github.com/gogits/gogs/models/errors"
+ "github.com/gogits/gogs/pkg/context"
+)
+
+func ListCollaborators(c *context.APIContext) {
+ collaborators, err := c.Repo.Repository.GetCollaborators()
+ if err != nil {
+ if errors.IsUserNotExist(err) {
+ c.Error(422, "", err)
+ } else {
+ c.Error(500, "GetCollaborators", err)
+ }
+ return
+ }
+
+ apiCollaborators := make([]*api.Collaborator, len(collaborators))
+ for i := range collaborators {
+ apiCollaborators[i] = collaborators[i].APIFormat()
+ }
+ c.JSON(200, &apiCollaborators)
+}
+
+func AddCollaborator(c *context.APIContext, form api.AddCollaboratorOption) {
+ collaborator, err := models.GetUserByName(c.Params(":collaborator"))
+ if err != nil {
+ if errors.IsUserNotExist(err) {
+ c.Error(422, "", err)
+ } else {
+ c.Error(500, "GetUserByName", err)
+ }
+ return
+ }
+
+ if err := c.Repo.Repository.AddCollaborator(collaborator); err != nil {
+ c.Error(500, "AddCollaborator", err)
+ return
+ }
+
+ if form.Permission != nil {
+ if err := c.Repo.Repository.ChangeCollaborationAccessMode(collaborator.ID, models.ParseAccessMode(*form.Permission)); err != nil {
+ c.Error(500, "ChangeCollaborationAccessMode", err)
+ return
+ }
+ }
+
+ c.Status(204)
+}
+
+func IsCollaborator(c *context.APIContext) {
+ collaborator, err := models.GetUserByName(c.Params(":collaborator"))
+ if err != nil {
+ if errors.IsUserNotExist(err) {
+ c.Error(422, "", err)
+ } else {
+ c.Error(500, "GetUserByName", err)
+ }
+ return
+ }
+
+ if !c.Repo.Repository.IsCollaborator(collaborator.ID) {
+ c.Status(404)
+ } else {
+ c.Status(204)
+ }
+}
+
+func DeleteCollaborator(c *context.APIContext) {
+ collaborator, err := models.GetUserByName(c.Params(":collaborator"))
+ if err != nil {
+ if errors.IsUserNotExist(err) {
+ c.Error(422, "", err)
+ } else {
+ c.Error(500, "GetUserByName", err)
+ }
+ return
+ }
+
+ if err := c.Repo.Repository.DeleteCollaboration(collaborator.ID); err != nil {
+ c.Error(500, "DeleteCollaboration", err)
+ return
+ }
+
+ c.Status(204)
+}