aboutsummaryrefslogtreecommitdiff
path: root/routers/api/v1/admin/users.go
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2016-03-21 12:47:54 -0400
committerUnknwon <u@gogs.io>2016-03-21 12:47:54 -0400
commite6f927f61af927156798390e64f17dd6755697e7 (patch)
treec97f90dfb0f4ae96534c13f98352907fb42d177b /routers/api/v1/admin/users.go
parent60ae8ac3d2995d46156ead8ad93004801daad4ce (diff)
#1692 api: admin list and create team under organization
Diffstat (limited to 'routers/api/v1/admin/users.go')
-rw-r--r--routers/api/v1/admin/users.go152
1 files changed, 0 insertions, 152 deletions
diff --git a/routers/api/v1/admin/users.go b/routers/api/v1/admin/users.go
deleted file mode 100644
index ce13804f..00000000
--- a/routers/api/v1/admin/users.go
+++ /dev/null
@@ -1,152 +0,0 @@
-// Copyright 2015 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 "github.com/gogits/go-gogs-client"
-
- "github.com/gogits/gogs/models"
- "github.com/gogits/gogs/modules/context"
- "github.com/gogits/gogs/modules/log"
- "github.com/gogits/gogs/modules/mailer"
- "github.com/gogits/gogs/modules/setting"
- "github.com/gogits/gogs/routers/api/v1/convert"
- "github.com/gogits/gogs/routers/api/v1/user"
-)
-
-func parseLoginSource(ctx *context.APIContext, u *models.User, sourceID int64, loginName string) {
- if sourceID == 0 {
- return
- }
-
- source, err := models.GetLoginSourceByID(sourceID)
- if err != nil {
- if models.IsErrAuthenticationNotExist(err) {
- ctx.Error(422, "", err)
- } else {
- ctx.Error(500, "GetLoginSourceByID", err)
- }
- return
- }
-
- u.LoginType = source.Type
- u.LoginSource = source.ID
- u.LoginName = loginName
-}
-
-// https://github.com/gogits/go-gogs-client/wiki/Administration-Users#create-a-new-user
-func CreateUser(ctx *context.APIContext, form api.CreateUserOption) {
- u := &models.User{
- Name: form.Username,
- Email: form.Email,
- Passwd: form.Password,
- IsActive: true,
- LoginType: models.LOGIN_PLAIN,
- }
-
- parseLoginSource(ctx, u, form.SourceID, form.LoginName)
- if ctx.Written() {
- return
- }
-
- if err := models.CreateUser(u); err != nil {
- if models.IsErrUserAlreadyExist(err) ||
- models.IsErrEmailAlreadyUsed(err) ||
- models.IsErrNameReserved(err) ||
- models.IsErrNamePatternNotAllowed(err) {
- ctx.Error(422, "", err)
- } else {
- ctx.Error(500, "CreateUser", err)
- }
- return
- }
- log.Trace("Account created by admin (%s): %s", ctx.User.Name, u.Name)
-
- // Send e-mail notification.
- if form.SendNotify && setting.MailService != nil {
- mailer.SendRegisterNotifyMail(ctx.Context.Context, u)
- }
-
- ctx.JSON(201, convert.ToUser(u))
-}
-
-// https://github.com/gogits/go-gogs-client/wiki/Administration-Users#edit-an-existing-user
-func EditUser(ctx *context.APIContext, form api.EditUserOption) {
- u := user.GetUserByParams(ctx)
- if ctx.Written() {
- return
- }
-
- parseLoginSource(ctx, u, form.SourceID, form.LoginName)
- if ctx.Written() {
- return
- }
-
- if len(form.Password) > 0 {
- u.Passwd = form.Password
- u.Salt = models.GetUserSalt()
- u.EncodePasswd()
- }
-
- u.LoginName = form.LoginName
- u.FullName = form.FullName
- u.Email = form.Email
- u.Website = form.Website
- u.Location = form.Location
- if form.Active != nil {
- u.IsActive = *form.Active
- }
- if form.Admin != nil {
- u.IsAdmin = *form.Admin
- }
- if form.AllowGitHook != nil {
- u.AllowGitHook = *form.AllowGitHook
- }
- if form.AllowImportLocal != nil {
- u.AllowImportLocal = *form.AllowImportLocal
- }
-
- if err := models.UpdateUser(u); err != nil {
- if models.IsErrEmailAlreadyUsed(err) {
- ctx.Error(422, "", err)
- } else {
- ctx.Error(500, "UpdateUser", err)
- }
- return
- }
- log.Trace("Account profile updated by admin (%s): %s", ctx.User.Name, u.Name)
-
- ctx.JSON(200, convert.ToUser(u))
-}
-
-// https://github.com/gogits/go-gogs-client/wiki/Administration-Users#delete-a-user
-func DeleteUser(ctx *context.APIContext) {
- u := user.GetUserByParams(ctx)
- if ctx.Written() {
- return
- }
-
- if err := models.DeleteUser(u); err != nil {
- if models.IsErrUserOwnRepos(err) ||
- models.IsErrUserHasOrgs(err) {
- ctx.Error(422, "", err)
- } else {
- ctx.Error(500, "DeleteUser", err)
- }
- return
- }
- log.Trace("Account deleted by admin(%s): %s", ctx.User.Name, u.Name)
-
- ctx.Status(204)
-}
-
-// https://github.com/gogits/go-gogs-client/wiki/Administration-Users#create-a-public-key-for-user
-func CreatePublicKey(ctx *context.APIContext, form api.CreateKeyOption) {
- u := user.GetUserByParams(ctx)
- if ctx.Written() {
- return
- }
- user.CreateUserPublicKey(ctx, form, u.Id)
-}