diff options
author | Robin Lambertz <robinlambertz+dev@gmail.com> | 2016-08-11 20:23:25 +0200 |
---|---|---|
committer | 无闻 <u@gogs.io> | 2016-08-11 11:23:25 -0700 |
commit | b6c14f8b21a277576a882061fb772a76e3d4511b (patch) | |
tree | 0a17655aca072c55e43d8b654d162a5d88adbc5c /routers | |
parent | 5077408d78971463a94f2037d78fa68f201bda48 (diff) | |
download | gitea-b6c14f8b21a277576a882061fb772a76e3d4511b.tar.gz gitea-b6c14f8b21a277576a882061fb772a76e3d4511b.zip |
Add AddCollaborator API Endpoint (#2780)
* Add AddCollaborator API Endpoint
* Add optional Permission to AddCollaborator endpoint
* Use APIContext
Diffstat (limited to 'routers')
-rw-r--r-- | routers/api/v1/api.go | 1 | ||||
-rw-r--r-- | routers/api/v1/repo/collaborators.go | 49 |
2 files changed, 50 insertions, 0 deletions
diff --git a/routers/api/v1/api.go b/routers/api/v1/api.go index f43afd6e06..198036207d 100644 --- a/routers/api/v1/api.go +++ b/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() { diff --git a/routers/api/v1/repo/collaborators.go b/routers/api/v1/repo/collaborators.go new file mode 100644 index 0000000000..83c27aecef --- /dev/null +++ b/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 +} |