mirror of https://github.com/gogits/gogs.git
Unknwon
9 years ago
8 changed files with 207 additions and 32 deletions
@ -0,0 +1,148 @@
|
||||
// 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/log" |
||||
"github.com/gogits/gogs/modules/mailer" |
||||
"github.com/gogits/gogs/modules/middleware" |
||||
"github.com/gogits/gogs/modules/setting" |
||||
"github.com/gogits/gogs/routers/api/v1/user" |
||||
to "github.com/gogits/gogs/routers/api/v1/utils" |
||||
) |
||||
|
||||
func parseLoginSource(ctx *middleware.Context, u *models.User, sourceID int64, loginName string) { |
||||
if sourceID == 0 { |
||||
return |
||||
} |
||||
|
||||
source, err := models.GetLoginSourceByID(sourceID) |
||||
if err != nil { |
||||
if models.IsErrAuthenticationNotExist(err) { |
||||
ctx.APIError(422, "", err) |
||||
} else { |
||||
ctx.APIError(500, "GetLoginSourceByID", err) |
||||
} |
||||
return |
||||
} |
||||
|
||||
u.LoginType = source.Type |
||||
u.LoginSource = source.ID |
||||
u.LoginName = loginName |
||||
} |
||||
|
||||
func CreateUser(ctx *middleware.Context, form api.CreateUserOption) { |
||||
u := &models.User{ |
||||
Name: form.Username, |
||||
Email: form.Email, |
||||
Passwd: form.Password, |
||||
IsActive: true, |
||||
LoginType: models.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.APIError(422, "", err) |
||||
} else { |
||||
ctx.APIError(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, u) |
||||
} |
||||
|
||||
ctx.JSON(201, to.ApiUser(u)) |
||||
} |
||||
|
||||
func EditUser(ctx *middleware.Context, 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.APIError(422, "", err) |
||||
} else { |
||||
ctx.APIError(500, "UpdateUser", err) |
||||
} |
||||
return |
||||
} |
||||
log.Trace("Account profile updated by admin (%s): %s", ctx.User.Name, u.Name) |
||||
|
||||
ctx.JSON(200, to.ApiUser(u)) |
||||
} |
||||
|
||||
func DeleteUser(ctx *middleware.Context) { |
||||
u := user.GetUserByParams(ctx) |
||||
if ctx.Written() { |
||||
return |
||||
} |
||||
|
||||
if err := models.DeleteUser(u); err != nil { |
||||
if models.IsErrUserOwnRepos(err) || |
||||
models.IsErrUserHasOrgs(err) { |
||||
ctx.APIError(422, "", err) |
||||
} else { |
||||
ctx.APIError(500, "DeleteUser", err) |
||||
} |
||||
return |
||||
} |
||||
log.Trace("Account deleted by admin(%s): %s", ctx.User.Name, u.Name) |
||||
|
||||
ctx.Status(204) |
||||
} |
||||
|
||||
func CreatePublicKey(ctx *middleware.Context, form api.CreateKeyOption) { |
||||
u := user.GetUserByParams(ctx) |
||||
if ctx.Written() { |
||||
return |
||||
} |
||||
user.CreateUserPublicKey(ctx, form, u.Id) |
||||
} |
Loading…
Reference in new issue