Переглянути джерело

Add AddCollaborator API Endpoint (#2780)

* Add AddCollaborator API Endpoint

* Add optional Permission to AddCollaborator endpoint

* Use APIContext
Robin Lambertz 8 роки тому
батько
коміт
b6c14f8b21
2 змінених файлів з 50 додано та 0 видалено
  1. 1 0
      routers/api/v1/api.go
  2. 49 0
      routers/api/v1/repo/collaborators.go

+ 1 - 0
routers/api/v1/api.go

@@ -234,6 +234,7 @@ func RegisterRoutes(m *macaron.Macaron) {
 					m.Combo("/:id").Patch(bind(api.EditHookOption{}), repo.EditHook).
 						Delete(repo.DeleteHook)
 				})
+				m.Put("/collaborators/:collaborator", bind(api.AddCollaboratorOption{}), repo.AddCollaborator)
 				m.Get("/raw/*", context.RepoRef(), repo.GetRawFile)
 				m.Get("/archive/*", repo.GetArchive)
 				m.Group("/branches", func() {

+ 49 - 0
routers/api/v1/repo/collaborators.go

@@ -0,0 +1,49 @@
+// Copyright 2014 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/modules/context"
+)
+
+func AddCollaborator(ctx *context.APIContext, form api.AddCollaboratorOption) {
+	collaborator, err := models.GetUserByName(ctx.Params(":collaborator"))
+
+	if err != nil {
+		if models.IsErrUserNotExist(err) {
+			ctx.Error(422, "", err)
+		} else {
+			ctx.Error(500, "GetUserByName", err)
+		}
+		return
+	}
+
+	if err := ctx.Repo.Repository.AddCollaborator(collaborator); err != nil {
+		ctx.Error(500, "AddCollaborator", err)
+		return
+	}
+
+	mode := models.ACCESS_MODE_WRITE
+	if form.Permission != nil && *form.Permission == "pull" {
+		mode = models.ACCESS_MODE_READ
+	} else if form.Permission != nil && *form.Permission == "push" {
+		mode = models.ACCESS_MODE_WRITE
+	} else if form.Permission != nil && *form.Permission == "admin" {
+		mode = models.ACCESS_MODE_ADMIN
+	} else if form.Permission != nil {
+		ctx.Error(500, "Permission", "Invalid permission type")
+		return
+	}
+	if err := ctx.Repo.Repository.ChangeCollaborationAccessMode(collaborator.Id, mode); err != nil {
+		ctx.Error(500, "ChangeCollaborationAccessMode", err)
+		return
+	}
+
+	ctx.Status(204)
+	return
+}