You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

users.go 7.3 kB

10 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
10 years ago
11 years ago
10 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package admin
  5. import (
  6. "strings"
  7. "code.gitea.io/gitea/models"
  8. "code.gitea.io/gitea/modules/auth"
  9. "code.gitea.io/gitea/modules/base"
  10. "code.gitea.io/gitea/modules/context"
  11. "code.gitea.io/gitea/modules/log"
  12. "code.gitea.io/gitea/modules/setting"
  13. "code.gitea.io/gitea/routers"
  14. "code.gitea.io/gitea/services/mailer"
  15. "github.com/unknwon/com"
  16. )
  17. const (
  18. tplUsers base.TplName = "admin/user/list"
  19. tplUserNew base.TplName = "admin/user/new"
  20. tplUserEdit base.TplName = "admin/user/edit"
  21. )
  22. // Users show all the users
  23. func Users(ctx *context.Context) {
  24. ctx.Data["Title"] = ctx.Tr("admin.users")
  25. ctx.Data["PageIsAdmin"] = true
  26. ctx.Data["PageIsAdminUsers"] = true
  27. routers.RenderUserSearch(ctx, &models.SearchUserOptions{
  28. Type: models.UserTypeIndividual,
  29. PageSize: setting.UI.Admin.UserPagingNum,
  30. SearchByEmail: true,
  31. }, tplUsers)
  32. }
  33. // NewUser render adding a new user page
  34. func NewUser(ctx *context.Context) {
  35. ctx.Data["Title"] = ctx.Tr("admin.users.new_account")
  36. ctx.Data["PageIsAdmin"] = true
  37. ctx.Data["PageIsAdminUsers"] = true
  38. ctx.Data["login_type"] = "0-0"
  39. sources, err := models.LoginSources()
  40. if err != nil {
  41. ctx.ServerError("LoginSources", err)
  42. return
  43. }
  44. ctx.Data["Sources"] = sources
  45. ctx.Data["CanSendEmail"] = setting.MailService != nil
  46. ctx.HTML(200, tplUserNew)
  47. }
  48. // NewUserPost response for adding a new user
  49. func NewUserPost(ctx *context.Context, form auth.AdminCreateUserForm) {
  50. ctx.Data["Title"] = ctx.Tr("admin.users.new_account")
  51. ctx.Data["PageIsAdmin"] = true
  52. ctx.Data["PageIsAdminUsers"] = true
  53. sources, err := models.LoginSources()
  54. if err != nil {
  55. ctx.ServerError("LoginSources", err)
  56. return
  57. }
  58. ctx.Data["Sources"] = sources
  59. ctx.Data["CanSendEmail"] = setting.MailService != nil
  60. if ctx.HasError() {
  61. ctx.HTML(200, tplUserNew)
  62. return
  63. }
  64. u := &models.User{
  65. Name: form.UserName,
  66. Email: form.Email,
  67. Passwd: form.Password,
  68. IsActive: true,
  69. LoginType: models.LoginPlain,
  70. MustChangePassword: form.MustChangePassword,
  71. }
  72. if len(form.LoginType) > 0 {
  73. fields := strings.Split(form.LoginType, "-")
  74. if len(fields) == 2 {
  75. u.LoginType = models.LoginType(com.StrTo(fields[0]).MustInt())
  76. u.LoginSource = com.StrTo(fields[1]).MustInt64()
  77. u.LoginName = form.LoginName
  78. }
  79. }
  80. if err := models.CreateUser(u); err != nil {
  81. switch {
  82. case models.IsErrUserAlreadyExist(err):
  83. ctx.Data["Err_UserName"] = true
  84. ctx.RenderWithErr(ctx.Tr("form.username_been_taken"), tplUserNew, &form)
  85. case models.IsErrEmailAlreadyUsed(err):
  86. ctx.Data["Err_Email"] = true
  87. ctx.RenderWithErr(ctx.Tr("form.email_been_used"), tplUserNew, &form)
  88. case models.IsErrNameReserved(err):
  89. ctx.Data["Err_UserName"] = true
  90. ctx.RenderWithErr(ctx.Tr("user.form.name_reserved", err.(models.ErrNameReserved).Name), tplUserNew, &form)
  91. case models.IsErrNamePatternNotAllowed(err):
  92. ctx.Data["Err_UserName"] = true
  93. ctx.RenderWithErr(ctx.Tr("user.form.name_pattern_not_allowed", err.(models.ErrNamePatternNotAllowed).Pattern), tplUserNew, &form)
  94. default:
  95. ctx.ServerError("CreateUser", err)
  96. }
  97. return
  98. }
  99. log.Trace("Account created by admin (%s): %s", ctx.User.Name, u.Name)
  100. // Send email notification.
  101. if form.SendNotify {
  102. mailer.SendRegisterNotifyMail(ctx.Locale, u)
  103. }
  104. ctx.Flash.Success(ctx.Tr("admin.users.new_success", u.Name))
  105. ctx.Redirect(setting.AppSubURL + "/admin/users/" + com.ToStr(u.ID))
  106. }
  107. func prepareUserInfo(ctx *context.Context) *models.User {
  108. u, err := models.GetUserByID(ctx.ParamsInt64(":userid"))
  109. if err != nil {
  110. ctx.ServerError("GetUserByID", err)
  111. return nil
  112. }
  113. ctx.Data["User"] = u
  114. if u.LoginSource > 0 {
  115. ctx.Data["LoginSource"], err = models.GetLoginSourceByID(u.LoginSource)
  116. if err != nil {
  117. ctx.ServerError("GetLoginSourceByID", err)
  118. return nil
  119. }
  120. } else {
  121. ctx.Data["LoginSource"] = &models.LoginSource{}
  122. }
  123. sources, err := models.LoginSources()
  124. if err != nil {
  125. ctx.ServerError("LoginSources", err)
  126. return nil
  127. }
  128. ctx.Data["Sources"] = sources
  129. return u
  130. }
  131. // EditUser show editting user page
  132. func EditUser(ctx *context.Context) {
  133. ctx.Data["Title"] = ctx.Tr("admin.users.edit_account")
  134. ctx.Data["PageIsAdmin"] = true
  135. ctx.Data["PageIsAdminUsers"] = true
  136. ctx.Data["DisableRegularOrgCreation"] = setting.Admin.DisableRegularOrgCreation
  137. prepareUserInfo(ctx)
  138. if ctx.Written() {
  139. return
  140. }
  141. ctx.HTML(200, tplUserEdit)
  142. }
  143. // EditUserPost response for editting user
  144. func EditUserPost(ctx *context.Context, form auth.AdminEditUserForm) {
  145. ctx.Data["Title"] = ctx.Tr("admin.users.edit_account")
  146. ctx.Data["PageIsAdmin"] = true
  147. ctx.Data["PageIsAdminUsers"] = true
  148. u := prepareUserInfo(ctx)
  149. if ctx.Written() {
  150. return
  151. }
  152. if ctx.HasError() {
  153. ctx.HTML(200, tplUserEdit)
  154. return
  155. }
  156. fields := strings.Split(form.LoginType, "-")
  157. if len(fields) == 2 {
  158. loginType := models.LoginType(com.StrTo(fields[0]).MustInt())
  159. loginSource := com.StrTo(fields[1]).MustInt64()
  160. if u.LoginSource != loginSource {
  161. u.LoginSource = loginSource
  162. u.LoginType = loginType
  163. }
  164. }
  165. if len(form.Password) > 0 {
  166. var err error
  167. if u.Salt, err = models.GetUserSalt(); err != nil {
  168. ctx.ServerError("UpdateUser", err)
  169. return
  170. }
  171. u.HashPassword(form.Password)
  172. }
  173. u.LoginName = form.LoginName
  174. u.FullName = form.FullName
  175. u.Email = form.Email
  176. u.Website = form.Website
  177. u.Location = form.Location
  178. u.MaxRepoCreation = form.MaxRepoCreation
  179. u.IsActive = form.Active
  180. u.IsAdmin = form.Admin
  181. u.AllowGitHook = form.AllowGitHook
  182. u.AllowImportLocal = form.AllowImportLocal
  183. u.AllowCreateOrganization = form.AllowCreateOrganization
  184. u.ProhibitLogin = form.ProhibitLogin
  185. if err := models.UpdateUser(u); err != nil {
  186. if models.IsErrEmailAlreadyUsed(err) {
  187. ctx.Data["Err_Email"] = true
  188. ctx.RenderWithErr(ctx.Tr("form.email_been_used"), tplUserEdit, &form)
  189. } else {
  190. ctx.ServerError("UpdateUser", err)
  191. }
  192. return
  193. }
  194. log.Trace("Account profile updated by admin (%s): %s", ctx.User.Name, u.Name)
  195. ctx.Flash.Success(ctx.Tr("admin.users.update_profile_success"))
  196. ctx.Redirect(setting.AppSubURL + "/admin/users/" + ctx.Params(":userid"))
  197. }
  198. // DeleteUser response for deleting a user
  199. func DeleteUser(ctx *context.Context) {
  200. u, err := models.GetUserByID(ctx.ParamsInt64(":userid"))
  201. if err != nil {
  202. ctx.ServerError("GetUserByID", err)
  203. return
  204. }
  205. if err = models.DeleteUser(u); err != nil {
  206. switch {
  207. case models.IsErrUserOwnRepos(err):
  208. ctx.Flash.Error(ctx.Tr("admin.users.still_own_repo"))
  209. ctx.JSON(200, map[string]interface{}{
  210. "redirect": setting.AppSubURL + "/admin/users/" + ctx.Params(":userid"),
  211. })
  212. case models.IsErrUserHasOrgs(err):
  213. ctx.Flash.Error(ctx.Tr("admin.users.still_has_org"))
  214. ctx.JSON(200, map[string]interface{}{
  215. "redirect": setting.AppSubURL + "/admin/users/" + ctx.Params(":userid"),
  216. })
  217. default:
  218. ctx.ServerError("DeleteUser", err)
  219. }
  220. return
  221. }
  222. log.Trace("Account deleted by admin (%s): %s", ctx.User.Name, u.Name)
  223. ctx.Flash.Success(ctx.Tr("admin.users.deletion_success"))
  224. ctx.JSON(200, map[string]interface{}{
  225. "redirect": setting.AppSubURL + "/admin/users",
  226. })
  227. }