2014-08-29 11:32:52 +04:00
// Copyright 2014 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 (
"strings"
"github.com/Unknwon/com"
2015-09-12 03:42:26 +03:00
"github.com/Unknwon/paginater"
2014-08-29 11:32:52 +04:00
"github.com/gogits/gogs/models"
"github.com/gogits/gogs/modules/auth"
"github.com/gogits/gogs/modules/base"
"github.com/gogits/gogs/modules/log"
2015-09-26 02:45:44 +03:00
"github.com/gogits/gogs/modules/mailer"
2014-08-29 11:32:52 +04:00
"github.com/gogits/gogs/modules/middleware"
2014-09-14 21:35:22 +04:00
"github.com/gogits/gogs/modules/setting"
2014-08-29 11:32:52 +04:00
)
const (
USERS base . TplName = "admin/user/list"
USER_NEW base . TplName = "admin/user/new"
USER_EDIT base . TplName = "admin/user/edit"
)
2014-08-29 16:50:43 +04:00
func Users ( ctx * middleware . Context ) {
ctx . Data [ "Title" ] = ctx . Tr ( "admin.users" )
ctx . Data [ "PageIsAdmin" ] = true
ctx . Data [ "PageIsAdminUsers" ] = true
2015-09-12 03:42:26 +03:00
total := models . CountUsers ( )
page := ctx . QueryInt ( "page" )
if page <= 1 {
page = 1
}
ctx . Data [ "Page" ] = paginater . New ( int ( total ) , setting . AdminUserPagingNum , page , 5 )
2014-08-29 11:32:52 +04:00
2015-09-12 03:42:26 +03:00
users , err := models . Users ( page , setting . AdminUserPagingNum )
2014-08-29 11:32:52 +04:00
if err != nil {
2015-09-12 03:42:26 +03:00
ctx . Handle ( 500 , "Users" , err )
2014-08-29 11:32:52 +04:00
return
}
2014-10-09 02:29:18 +04:00
ctx . Data [ "Users" ] = users
2015-09-12 03:42:26 +03:00
ctx . Data [ "Total" ] = total
2014-08-29 11:32:52 +04:00
ctx . HTML ( 200 , USERS )
}
func NewUser ( ctx * middleware . Context ) {
ctx . Data [ "Title" ] = ctx . Tr ( "admin.users.new_account" )
ctx . Data [ "PageIsAdmin" ] = true
ctx . Data [ "PageIsAdminUsers" ] = true
2015-09-13 16:51:51 +03:00
ctx . Data [ "login_type" ] = "0-0"
sources , err := models . LoginSources ( )
2014-08-29 11:32:52 +04:00
if err != nil {
2015-09-13 16:51:51 +03:00
ctx . Handle ( 500 , "LoginSources" , err )
2014-08-29 11:32:52 +04:00
return
}
2015-09-13 16:51:51 +03:00
ctx . Data [ "Sources" ] = sources
2015-09-26 02:45:44 +03:00
ctx . Data [ "CanSendEmail" ] = setting . MailService != nil
2014-08-29 11:32:52 +04:00
ctx . HTML ( 200 , USER_NEW )
}
2015-09-13 17:05:18 +03:00
func NewUserPost ( ctx * middleware . Context , form auth . AdminCrateUserForm ) {
2014-08-29 11:32:52 +04:00
ctx . Data [ "Title" ] = ctx . Tr ( "admin.users.new_account" )
ctx . Data [ "PageIsAdmin" ] = true
ctx . Data [ "PageIsAdminUsers" ] = true
2015-09-13 16:51:51 +03:00
sources , err := models . LoginSources ( )
if err != nil {
ctx . Handle ( 500 , "LoginSources" , err )
2014-08-29 11:32:52 +04:00
return
}
2015-09-13 16:51:51 +03:00
ctx . Data [ "Sources" ] = sources
2014-08-29 11:32:52 +04:00
2015-09-26 02:45:44 +03:00
ctx . Data [ "CanSendEmail" ] = setting . MailService != nil
2015-09-13 16:51:51 +03:00
if ctx . HasError ( ) {
ctx . HTML ( 200 , USER_NEW )
2014-08-29 11:32:52 +04:00
return
}
u := & models . User {
Name : form . UserName ,
Email : form . Email ,
Passwd : form . Password ,
IsActive : true ,
2015-12-11 03:02:57 +03:00
LoginType : models . LOGIN_PLAIN ,
2014-08-29 11:32:52 +04:00
}
if len ( form . LoginType ) > 0 {
fields := strings . Split ( form . LoginType , "-" )
2015-09-13 16:51:51 +03:00
if len ( fields ) == 2 {
u . LoginType = models . LoginType ( com . StrTo ( fields [ 0 ] ) . MustInt ( ) )
u . LoginSource = com . StrTo ( fields [ 1 ] ) . MustInt64 ( )
u . LoginName = form . LoginName
}
2014-08-29 11:32:52 +04:00
}
if err := models . CreateUser ( u ) ; err != nil {
2015-03-27 00:11:47 +03:00
switch {
case models . IsErrUserAlreadyExist ( err ) :
2014-08-29 11:32:52 +04:00
ctx . Data [ "Err_UserName" ] = true
ctx . RenderWithErr ( ctx . Tr ( "form.username_been_taken" ) , USER_NEW , & form )
2015-03-27 00:11:47 +03:00
case models . IsErrEmailAlreadyUsed ( err ) :
2014-08-29 11:32:52 +04:00
ctx . Data [ "Err_Email" ] = true
ctx . RenderWithErr ( ctx . Tr ( "form.email_been_used" ) , USER_NEW , & form )
2015-03-27 00:11:47 +03:00
case models . IsErrNameReserved ( err ) :
2014-08-29 11:32:52 +04:00
ctx . Data [ "Err_UserName" ] = true
2015-03-27 00:11:47 +03:00
ctx . RenderWithErr ( ctx . Tr ( "user.form.name_reserved" , err . ( models . ErrNameReserved ) . Name ) , USER_NEW , & form )
case models . IsErrNamePatternNotAllowed ( err ) :
ctx . Data [ "Err_UserName" ] = true
ctx . RenderWithErr ( ctx . Tr ( "user.form.name_pattern_not_allowed" , err . ( models . ErrNamePatternNotAllowed ) . Pattern ) , USER_NEW , & form )
2014-08-29 11:32:52 +04:00
default :
ctx . Handle ( 500 , "CreateUser" , err )
}
return
}
2015-12-06 01:13:13 +03:00
log . Trace ( "Account created by admin (%s): %s" , ctx . User . Name , u . Name )
2015-09-13 16:51:51 +03:00
2015-09-26 02:45:44 +03:00
// Send e-mail notification.
if form . SendNotify && setting . MailService != nil {
mailer . SendRegisterNotifyMail ( ctx . Context , u )
}
2015-09-13 16:51:51 +03:00
ctx . Flash . Success ( ctx . Tr ( "admin.users.new_success" , u . Name ) )
ctx . Redirect ( setting . AppSubUrl + "/admin/users/" + com . ToStr ( u . Id ) )
2014-08-29 11:32:52 +04:00
}
2015-09-13 18:07:21 +03:00
func prepareUserInfo ( ctx * middleware . Context ) * models . User {
u , err := models . GetUserByID ( ctx . ParamsInt64 ( ":userid" ) )
2014-08-29 11:32:52 +04:00
if err != nil {
2015-08-08 17:43:14 +03:00
ctx . Handle ( 500 , "GetUserByID" , err )
2015-09-13 18:07:21 +03:00
return nil
2014-08-29 11:32:52 +04:00
}
ctx . Data [ "User" ] = u
2015-09-13 16:51:51 +03:00
2015-09-13 18:07:21 +03:00
if u . LoginSource > 0 {
ctx . Data [ "LoginSource" ] , err = models . GetLoginSourceByID ( u . LoginSource )
if err != nil {
ctx . Handle ( 500 , "GetLoginSourceByID" , err )
return nil
}
} else {
ctx . Data [ "LoginSource" ] = & models . LoginSource { }
}
2015-09-13 16:51:51 +03:00
sources , err := models . LoginSources ( )
2014-08-29 11:32:52 +04:00
if err != nil {
2015-09-13 16:51:51 +03:00
ctx . Handle ( 500 , "LoginSources" , err )
2015-09-13 18:07:21 +03:00
return nil
2014-08-29 11:32:52 +04:00
}
2015-09-13 18:07:21 +03:00
ctx . Data [ "Sources" ] = sources
return u
2014-08-29 11:32:52 +04:00
}
2015-09-13 18:07:21 +03:00
func EditUser ( ctx * middleware . Context ) {
2014-08-29 11:32:52 +04:00
ctx . Data [ "Title" ] = ctx . Tr ( "admin.users.edit_account" )
ctx . Data [ "PageIsAdmin" ] = true
ctx . Data [ "PageIsAdminUsers" ] = true
2015-09-13 18:07:21 +03:00
prepareUserInfo ( ctx )
if ctx . Written ( ) {
2014-08-29 11:32:52 +04:00
return
}
2015-09-13 18:07:21 +03:00
ctx . HTML ( 200 , USER_EDIT )
}
func EditUserPost ( ctx * middleware . Context , form auth . AdminEditUserForm ) {
ctx . Data [ "Title" ] = ctx . Tr ( "admin.users.edit_account" )
ctx . Data [ "PageIsAdmin" ] = true
ctx . Data [ "PageIsAdminUsers" ] = true
u := prepareUserInfo ( ctx )
if ctx . Written ( ) {
2014-08-29 11:32:52 +04:00
return
}
if ctx . HasError ( ) {
ctx . HTML ( 200 , USER_EDIT )
return
}
2015-09-13 18:07:21 +03:00
fields := strings . Split ( form . LoginType , "-" )
if len ( fields ) == 2 {
loginType := models . LoginType ( com . StrTo ( fields [ 0 ] ) . MustInt ( ) )
loginSource := com . StrTo ( fields [ 1 ] ) . MustInt64 ( )
if u . LoginSource != loginSource {
u . LoginSource = loginSource
u . LoginType = loginType
}
}
2015-03-17 10:21:58 +03:00
if len ( form . Password ) > 0 {
u . Passwd = form . Password
2014-08-29 11:32:52 +04:00
u . Salt = models . GetUserSalt ( )
u . EncodePasswd ( )
}
2015-09-13 18:26:25 +03:00
u . LoginName = form . LoginName
2015-04-28 18:59:05 +03:00
u . FullName = form . FullName
2014-08-29 11:32:52 +04:00
u . Email = form . Email
u . Website = form . Website
u . Location = form . Location
2015-12-10 20:37:53 +03:00
u . MaxRepoCreation = form . MaxRepoCreation
2014-08-29 11:32:52 +04:00
u . IsActive = form . Active
u . IsAdmin = form . Admin
2014-11-17 22:53:41 +03:00
u . AllowGitHook = form . AllowGitHook
2015-11-04 02:40:52 +03:00
u . AllowImportLocal = form . AllowImportLocal
2014-12-01 02:29:16 +03:00
2014-08-29 11:32:52 +04:00
if err := models . UpdateUser ( u ) ; err != nil {
2015-03-27 00:11:47 +03:00
if models . IsErrEmailAlreadyUsed ( err ) {
2014-12-01 02:29:16 +03:00
ctx . Data [ "Err_Email" ] = true
ctx . RenderWithErr ( ctx . Tr ( "form.email_been_used" ) , USER_EDIT , & form )
} else {
ctx . Handle ( 500 , "UpdateUser" , err )
}
2014-08-29 11:32:52 +04:00
return
}
2015-12-06 01:13:13 +03:00
log . Trace ( "Account profile updated by admin (%s): %s" , ctx . User . Name , u . Name )
2015-09-13 18:07:21 +03:00
2014-08-29 11:32:52 +04:00
ctx . Flash . Success ( ctx . Tr ( "admin.users.update_profile_success" ) )
2014-09-20 04:11:34 +04:00
ctx . Redirect ( setting . AppSubUrl + "/admin/users/" + ctx . Params ( ":userid" ) )
2014-08-29 11:32:52 +04:00
}
func DeleteUser ( ctx * middleware . Context ) {
2015-09-13 20:26:20 +03:00
u , err := models . GetUserByID ( ctx . ParamsInt64 ( ":userid" ) )
2014-08-29 11:32:52 +04:00
if err != nil {
2015-08-08 17:43:14 +03:00
ctx . Handle ( 500 , "GetUserByID" , err )
2014-08-29 11:32:52 +04:00
return
}
if err = models . DeleteUser ( u ) ; err != nil {
2015-03-18 04:51:39 +03:00
switch {
case models . IsErrUserOwnRepos ( err ) :
2014-08-29 11:32:52 +04:00
ctx . Flash . Error ( ctx . Tr ( "admin.users.still_own_repo" ) )
2015-09-13 20:26:20 +03:00
ctx . JSON ( 200 , map [ string ] interface { } {
"redirect" : setting . AppSubUrl + "/admin/users/" + ctx . Params ( ":userid" ) ,
} )
2015-03-18 04:51:39 +03:00
case models . IsErrUserHasOrgs ( err ) :
2014-11-13 13:27:01 +03:00
ctx . Flash . Error ( ctx . Tr ( "admin.users.still_has_org" ) )
2015-09-13 20:26:20 +03:00
ctx . JSON ( 200 , map [ string ] interface { } {
"redirect" : setting . AppSubUrl + "/admin/users/" + ctx . Params ( ":userid" ) ,
} )
2014-08-29 11:32:52 +04:00
default :
ctx . Handle ( 500 , "DeleteUser" , err )
}
return
}
2015-12-06 01:13:13 +03:00
log . Trace ( "Account deleted by admin (%s): %s" , ctx . User . Name , u . Name )
2015-09-13 20:26:20 +03:00
ctx . Flash . Success ( ctx . Tr ( "admin.users.deletion_success" ) )
ctx . JSON ( 200 , map [ string ] interface { } {
"redirect" : setting . AppSubUrl + "/admin/users" ,
} )
2014-08-29 11:32:52 +04:00
}