| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 | // 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 (	"net/http"	api "github.com/gogs/go-gogs-client"	log "unknwon.dev/clog/v2"	"gogs.io/gogs/internal/conf"	"gogs.io/gogs/internal/context"	"gogs.io/gogs/internal/db"	"gogs.io/gogs/internal/email"	"gogs.io/gogs/internal/route/api/v1/user")func parseLoginSource(c *context.APIContext, u *db.User, sourceID int64, loginName string) {	if sourceID == 0 {		return	}	source, err := db.LoginSources.GetByID(sourceID)	if err != nil {		if db.IsErrLoginSourceNotExist(err) {			c.ErrorStatus(http.StatusUnprocessableEntity, err)		} else {			c.Error(err, "get login source by ID")		}		return	}	u.LoginType = source.Type	u.LoginSource = source.ID	u.LoginName = loginName}func CreateUser(c *context.APIContext, form api.CreateUserOption) {	u := &db.User{		Name:      form.Username,		FullName:  form.FullName,		Email:     form.Email,		Passwd:    form.Password,		IsActive:  true,		LoginType: db.LoginPlain,	}	parseLoginSource(c, u, form.SourceID, form.LoginName)	if c.Written() {		return	}	if err := db.CreateUser(u); err != nil {		if db.IsErrUserAlreadyExist(err) ||			db.IsErrEmailAlreadyUsed(err) ||			db.IsErrNameNotAllowed(err) {			c.ErrorStatus(http.StatusUnprocessableEntity, err)		} else {			c.Error(err, "create user")		}		return	}	log.Trace("Account created by admin %q: %s", c.User.Name, u.Name)	// Send email notification.	if form.SendNotify && conf.Email.Enabled {		email.SendRegisterNotifyMail(c.Context.Context, db.NewMailerUser(u))	}	c.JSON(http.StatusCreated, u.APIFormat())}func EditUser(c *context.APIContext, form api.EditUserOption) {	u := user.GetUserByParams(c)	if c.Written() {		return	}	parseLoginSource(c, u, form.SourceID, form.LoginName)	if c.Written() {		return	}	if len(form.Password) > 0 {		u.Passwd = form.Password		var err error		if u.Salt, err = db.GetUserSalt(); err != nil {			c.Error(err, "get user salt")			return		}		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 form.MaxRepoCreation != nil {		u.MaxRepoCreation = *form.MaxRepoCreation	}	if err := db.UpdateUser(u); err != nil {		if db.IsErrEmailAlreadyUsed(err) {			c.ErrorStatus(http.StatusUnprocessableEntity, err)		} else {			c.Error(err, "update user")		}		return	}	log.Trace("Account profile updated by admin %q: %s", c.User.Name, u.Name)	c.JSONSuccess(u.APIFormat())}func DeleteUser(c *context.APIContext) {	u := user.GetUserByParams(c)	if c.Written() {		return	}	if err := db.DeleteUser(u); err != nil {		if db.IsErrUserOwnRepos(err) ||			db.IsErrUserHasOrgs(err) {			c.ErrorStatus(http.StatusUnprocessableEntity, err)		} else {			c.Error(err, "delete user")		}		return	}	log.Trace("Account deleted by admin(%s): %s", c.User.Name, u.Name)	c.NoContent()}func CreatePublicKey(c *context.APIContext, form api.CreateKeyOption) {	u := user.GetUserByParams(c)	if c.Written() {		return	}	user.CreateUserPublicKey(c, form, u.ID)}
 |