| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 | // 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 adminimport (	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/convert"	"github.com/gogits/gogs/routers/api/v1/user")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}// https://github.com/gogits/go-gogs-client/wiki/Administration-Users#create-a-new-userfunc CreateUser(ctx *middleware.Context, 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.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, convert.ToApiUser(u))}// https://github.com/gogits/go-gogs-client/wiki/Administration-Users#edit-an-existing-userfunc 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, convert.ToApiUser(u))}// https://github.com/gogits/go-gogs-client/wiki/Administration-Users#delete-a-userfunc 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)}// https://github.com/gogits/go-gogs-client/wiki/Administration-Users#create-a-public-key-for-userfunc CreatePublicKey(ctx *middleware.Context, form api.CreateKeyOption) {	u := user.GetUserByParams(ctx)	if ctx.Written() {		return	}	user.CreateUserPublicKey(ctx, form, u.Id)}
 |