Fix permission bugs in team API (#647)
parent
fcf02e4961
commit
74bbec3bf9
@ -1,88 +0,0 @@
|
|||||||
// 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 admin
|
|
||||||
|
|
||||||
import (
|
|
||||||
api "code.gitea.io/sdk/gitea"
|
|
||||||
|
|
||||||
"code.gitea.io/gitea/models"
|
|
||||||
"code.gitea.io/gitea/modules/context"
|
|
||||||
"code.gitea.io/gitea/routers/api/v1/convert"
|
|
||||||
"code.gitea.io/gitea/routers/api/v1/user"
|
|
||||||
)
|
|
||||||
|
|
||||||
// CreateTeam api for create a team
|
|
||||||
func CreateTeam(ctx *context.APIContext, form api.CreateTeamOption) {
|
|
||||||
team := &models.Team{
|
|
||||||
OrgID: ctx.Org.Organization.ID,
|
|
||||||
Name: form.Name,
|
|
||||||
Description: form.Description,
|
|
||||||
Authorize: models.ParseAccessMode(form.Permission),
|
|
||||||
}
|
|
||||||
if err := models.NewTeam(team); err != nil {
|
|
||||||
if models.IsErrTeamAlreadyExist(err) {
|
|
||||||
ctx.Error(422, "", err)
|
|
||||||
} else {
|
|
||||||
ctx.Error(500, "NewTeam", err)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.JSON(201, convert.ToTeam(team))
|
|
||||||
}
|
|
||||||
|
|
||||||
// EditTeam api for edit a team
|
|
||||||
func EditTeam(ctx *context.APIContext, form api.EditTeamOption) {
|
|
||||||
team := &models.Team{
|
|
||||||
ID: ctx.Org.Team.ID,
|
|
||||||
OrgID: ctx.Org.Team.OrgID,
|
|
||||||
Name: form.Name,
|
|
||||||
Description: form.Description,
|
|
||||||
Authorize: models.ParseAccessMode(form.Permission),
|
|
||||||
}
|
|
||||||
if err := models.UpdateTeam(team, true); err != nil {
|
|
||||||
ctx.Error(500, "EditTeam", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
ctx.JSON(200, convert.ToTeam(team))
|
|
||||||
}
|
|
||||||
|
|
||||||
// DeleteTeam api for delete a team
|
|
||||||
func DeleteTeam(ctx *context.APIContext) {
|
|
||||||
if err := models.DeleteTeam(ctx.Org.Team); err != nil {
|
|
||||||
ctx.Error(500, "DeleteTeam", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
ctx.Status(204)
|
|
||||||
}
|
|
||||||
|
|
||||||
// AddTeamMember api for add a member to a team
|
|
||||||
func AddTeamMember(ctx *context.APIContext) {
|
|
||||||
u := user.GetUserByParams(ctx)
|
|
||||||
if ctx.Written() {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if err := ctx.Org.Team.AddMember(u.ID); err != nil {
|
|
||||||
ctx.Error(500, "AddMember", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.Status(204)
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveTeamMember api for remove one member from a team
|
|
||||||
func RemoveTeamMember(ctx *context.APIContext) {
|
|
||||||
u := user.GetUserByParams(ctx)
|
|
||||||
if ctx.Written() {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := ctx.Org.Team.RemoveMember(u.ID); err != nil {
|
|
||||||
ctx.Error(500, "RemoveMember", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.Status(204)
|
|
||||||
}
|
|
Loading…
Reference in New Issue