org.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  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 org
  5. import (
  6. "github.com/gogits/gogs/models"
  7. "github.com/gogits/gogs/modules/auth"
  8. "github.com/gogits/gogs/modules/base"
  9. "github.com/gogits/gogs/modules/log"
  10. "github.com/gogits/gogs/modules/middleware"
  11. )
  12. const (
  13. HOME base.TplName = "org/home"
  14. CREATE base.TplName = "org/create"
  15. SETTINGS base.TplName = "org/settings"
  16. )
  17. func Home(ctx *middleware.Context) {
  18. ctx.Data["Title"] = "Organization " + ctx.Params(":org")
  19. org, err := models.GetUserByName(ctx.Params(":org"))
  20. if err != nil {
  21. if err == models.ErrUserNotExist {
  22. ctx.Handle(404, "org.Home(GetUserByName)", err)
  23. } else {
  24. ctx.Handle(500, "org.Home(GetUserByName)", err)
  25. }
  26. return
  27. }
  28. ctx.Data["Org"] = org
  29. ctx.Data["Repos"], err = models.GetRepositories(org.Id,
  30. ctx.IsSigned && org.IsOrgMember(ctx.User.Id))
  31. if err != nil {
  32. ctx.Handle(500, "org.Home(GetRepositories)", err)
  33. return
  34. }
  35. if err = org.GetMembers(); err != nil {
  36. ctx.Handle(500, "org.Home(GetMembers)", err)
  37. return
  38. }
  39. ctx.Data["Members"] = org.Members
  40. if err = org.GetTeams(); err != nil {
  41. ctx.Handle(500, "org.Home(GetTeams)", err)
  42. return
  43. }
  44. ctx.Data["Teams"] = org.Teams
  45. ctx.HTML(200, HOME)
  46. }
  47. func Create(ctx *middleware.Context) {
  48. ctx.Data["Title"] = ctx.Tr("new_org")
  49. ctx.HTML(200, CREATE)
  50. }
  51. func CreatePost(ctx *middleware.Context, form auth.CreateOrgForm) {
  52. ctx.Data["Title"] = ctx.Tr("new_org")
  53. if ctx.HasError() {
  54. ctx.HTML(200, CREATE)
  55. return
  56. }
  57. org := &models.User{
  58. Name: form.OrgName,
  59. Email: form.Email,
  60. IsActive: true,
  61. Type: models.ORGANIZATION,
  62. }
  63. var err error
  64. if org, err = models.CreateOrganization(org, ctx.User); err != nil {
  65. switch err {
  66. case models.ErrUserAlreadyExist:
  67. ctx.Data["Err_OrgName"] = true
  68. ctx.RenderWithErr(ctx.Tr("form.org_name_been_taken"), CREATE, &form)
  69. case models.ErrEmailAlreadyUsed:
  70. ctx.Data["Err_Email"] = true
  71. ctx.RenderWithErr(ctx.Tr("form.email_been_used"), CREATE, &form)
  72. case models.ErrUserNameIllegal:
  73. ctx.Data["Err_OrgName"] = true
  74. ctx.RenderWithErr(ctx.Tr("form.illegal_org_name"), CREATE, &form)
  75. default:
  76. ctx.Handle(500, "CreateUser", err)
  77. }
  78. return
  79. }
  80. log.Trace("Organization created: %s", org.Name)
  81. ctx.Redirect("/org/" + form.OrgName + "/dashboard")
  82. }
  83. func Settings(ctx *middleware.Context) {
  84. ctx.Data["Title"] = "Settings"
  85. org, err := models.GetUserByName(ctx.Params(":org"))
  86. if err != nil {
  87. if err == models.ErrUserNotExist {
  88. ctx.Handle(404, "org.Settings(GetUserByName)", err)
  89. } else {
  90. ctx.Handle(500, "org.Settings(GetUserByName)", err)
  91. }
  92. return
  93. }
  94. ctx.Data["Org"] = org
  95. ctx.HTML(200, SETTINGS)
  96. }
  97. func SettingsPost(ctx *middleware.Context, form auth.OrgSettingForm) {
  98. ctx.Data["Title"] = "Settings"
  99. org, err := models.GetUserByName(ctx.Params(":org"))
  100. if err != nil {
  101. if err == models.ErrUserNotExist {
  102. ctx.Handle(404, "org.SettingsPost(GetUserByName)", err)
  103. } else {
  104. ctx.Handle(500, "org.SettingsPost(GetUserByName)", err)
  105. }
  106. return
  107. }
  108. ctx.Data["Org"] = org
  109. if ctx.HasError() {
  110. ctx.HTML(200, SETTINGS)
  111. return
  112. }
  113. org.FullName = form.DisplayName
  114. org.Email = form.Email
  115. org.Description = form.Description
  116. org.Website = form.Website
  117. org.Location = form.Location
  118. if err = models.UpdateUser(org); err != nil {
  119. ctx.Handle(500, "org.SettingsPost(UpdateUser)", err)
  120. return
  121. }
  122. log.Trace("%s Organization setting updated: %s", ctx.Req.RequestURI, org.LowerName)
  123. ctx.Flash.Success("Organization profile has been successfully updated.")
  124. ctx.Redirect("/org/" + org.Name + "/settings")
  125. }
  126. func DeletePost(ctx *middleware.Context) {
  127. ctx.Data["Title"] = "Settings"
  128. org, err := models.GetUserByName(ctx.Params(":org"))
  129. if err != nil {
  130. if err == models.ErrUserNotExist {
  131. ctx.Handle(404, "org.DeletePost(GetUserByName)", err)
  132. } else {
  133. ctx.Handle(500, "org.DeletePost(GetUserByName)", err)
  134. }
  135. return
  136. }
  137. ctx.Data["Org"] = org
  138. if !org.IsOrgOwner(ctx.User.Id) {
  139. ctx.Error(403)
  140. return
  141. }
  142. tmpUser := models.User{
  143. Passwd: ctx.Query("password"),
  144. Salt: ctx.User.Salt,
  145. }
  146. tmpUser.EncodePasswd()
  147. if tmpUser.Passwd != ctx.User.Passwd {
  148. ctx.Flash.Error("Password is not correct. Make sure you are owner of this account.")
  149. } else {
  150. if err := models.DeleteOrganization(org); err != nil {
  151. switch err {
  152. case models.ErrUserOwnRepos:
  153. ctx.Flash.Error("This organization still have ownership of repository, you have to delete or transfer them first.")
  154. default:
  155. ctx.Handle(500, "org.DeletePost(DeleteOrganization)", err)
  156. return
  157. }
  158. } else {
  159. ctx.Redirect("/")
  160. return
  161. }
  162. }
  163. ctx.Redirect("/org/" + org.Name + "/settings")
  164. }