mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-16 07:56:33 +03:00
Add AddCollaborator API Endpoint (#2780)
* Add AddCollaborator API Endpoint * Add optional Permission to AddCollaborator endpoint * Use APIContext
This commit is contained in:
parent
5077408d78
commit
b6c14f8b21
2 changed files with 50 additions and 0 deletions
|
@ -234,6 +234,7 @@ func RegisterRoutes(m *macaron.Macaron) {
|
||||||
m.Combo("/:id").Patch(bind(api.EditHookOption{}), repo.EditHook).
|
m.Combo("/:id").Patch(bind(api.EditHookOption{}), repo.EditHook).
|
||||||
Delete(repo.DeleteHook)
|
Delete(repo.DeleteHook)
|
||||||
})
|
})
|
||||||
|
m.Put("/collaborators/:collaborator", bind(api.AddCollaboratorOption{}), repo.AddCollaborator)
|
||||||
m.Get("/raw/*", context.RepoRef(), repo.GetRawFile)
|
m.Get("/raw/*", context.RepoRef(), repo.GetRawFile)
|
||||||
m.Get("/archive/*", repo.GetArchive)
|
m.Get("/archive/*", repo.GetArchive)
|
||||||
m.Group("/branches", func() {
|
m.Group("/branches", func() {
|
||||||
|
|
49
routers/api/v1/repo/collaborators.go
Normal file
49
routers/api/v1/repo/collaborators.go
Normal file
|
@ -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
|
||||||
|
}
|
Loading…
Reference in a new issue