org.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  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. "github.com/gogits/gogs/routers/user"
  12. )
  13. const (
  14. HOME base.TplName = "org/home"
  15. NEW base.TplName = "org/new"
  16. SETTINGS base.TplName = "org/settings"
  17. )
  18. func Home(ctx *middleware.Context) {
  19. ctx.Data["Title"] = "Organization " + ctx.Params(":org")
  20. org, err := models.GetUserByName(ctx.Params(":org"))
  21. if err != nil {
  22. if err == models.ErrUserNotExist {
  23. ctx.Handle(404, "org.Home(GetUserByName)", err)
  24. } else {
  25. ctx.Handle(500, "org.Home(GetUserByName)", err)
  26. }
  27. return
  28. }
  29. ctx.Data["Org"] = org
  30. ctx.Data["Repos"], err = models.GetRepositories(org.Id,
  31. ctx.IsSigned && org.IsOrgMember(ctx.User.Id))
  32. if err != nil {
  33. ctx.Handle(500, "org.Home(GetRepositories)", err)
  34. return
  35. }
  36. if err = org.GetMembers(); err != nil {
  37. ctx.Handle(500, "org.Home(GetMembers)", err)
  38. return
  39. }
  40. ctx.Data["Members"] = org.Members
  41. if err = org.GetTeams(); err != nil {
  42. ctx.Handle(500, "org.Home(GetTeams)", err)
  43. return
  44. }
  45. ctx.Data["Teams"] = org.Teams
  46. ctx.HTML(200, HOME)
  47. }
  48. func New(ctx *middleware.Context) {
  49. ctx.Data["Title"] = "Create An Organization"
  50. ctx.HTML(200, NEW)
  51. }
  52. func NewPost(ctx *middleware.Context, form auth.CreateOrgForm) {
  53. ctx.Data["Title"] = "Create An Organization"
  54. if ctx.HasError() {
  55. ctx.HTML(200, NEW)
  56. return
  57. }
  58. org := &models.User{
  59. Name: form.OrgName,
  60. Email: form.Email,
  61. IsActive: true, // NOTE: may need to set false when require e-mail confirmation.
  62. Type: models.ORGANIZATION,
  63. }
  64. var err error
  65. if org, err = models.CreateOrganization(org, ctx.User); err != nil {
  66. switch err {
  67. case models.ErrUserAlreadyExist:
  68. ctx.Data["Err_OrgName"] = true
  69. ctx.RenderWithErr("Organization name has been already taken", NEW, &form)
  70. case models.ErrEmailAlreadyUsed:
  71. ctx.Data["Err_Email"] = true
  72. ctx.RenderWithErr("E-mail address has been already used", NEW, &form)
  73. case models.ErrUserNameIllegal:
  74. ctx.Data["Err_OrgName"] = true
  75. ctx.RenderWithErr(models.ErrRepoNameIllegal.Error(), NEW, &form)
  76. default:
  77. ctx.Handle(500, "org.NewPost(CreateUser)", err)
  78. }
  79. return
  80. }
  81. log.Trace("%s Organization created: %s", ctx.Req.RequestURI, org.Name)
  82. ctx.Redirect("/org/" + form.OrgName + "/dashboard")
  83. }
  84. func Dashboard(ctx *middleware.Context) {
  85. ctx.Data["Title"] = "Dashboard"
  86. ctx.Data["PageIsUserDashboard"] = true
  87. ctx.Data["PageIsOrgDashboard"] = true
  88. org, err := models.GetUserByName(ctx.Params(":org"))
  89. if err != nil {
  90. if err == models.ErrUserNotExist {
  91. ctx.Handle(404, "org.Dashboard(GetUserByName)", err)
  92. } else {
  93. ctx.Handle(500, "org.Dashboard(GetUserByName)", err)
  94. }
  95. return
  96. }
  97. if err := ctx.User.GetOrganizations(); err != nil {
  98. ctx.Handle(500, "home.Dashboard(GetOrganizations)", err)
  99. return
  100. }
  101. ctx.Data["Orgs"] = ctx.User.Orgs
  102. ctx.Data["ContextUser"] = org
  103. ctx.Data["MyRepos"], err = models.GetRepositories(org.Id, true)
  104. if err != nil {
  105. ctx.Handle(500, "org.Dashboard(GetRepositories)", err)
  106. return
  107. }
  108. actions, err := models.GetFeeds(org.Id, 0, false)
  109. if err != nil {
  110. ctx.Handle(500, "org.Dashboard(GetFeeds)", err)
  111. return
  112. }
  113. ctx.Data["Feeds"] = actions
  114. ctx.HTML(200, user.DASHBOARD)
  115. }
  116. func Settings(ctx *middleware.Context) {
  117. ctx.Data["Title"] = "Settings"
  118. org, err := models.GetUserByName(ctx.Params(":org"))
  119. if err != nil {
  120. if err == models.ErrUserNotExist {
  121. ctx.Handle(404, "org.Settings(GetUserByName)", err)
  122. } else {
  123. ctx.Handle(500, "org.Settings(GetUserByName)", err)
  124. }
  125. return
  126. }
  127. ctx.Data["Org"] = org
  128. ctx.HTML(200, SETTINGS)
  129. }
  130. func SettingsPost(ctx *middleware.Context, form auth.OrgSettingForm) {
  131. ctx.Data["Title"] = "Settings"
  132. org, err := models.GetUserByName(ctx.Params(":org"))
  133. if err != nil {
  134. if err == models.ErrUserNotExist {
  135. ctx.Handle(404, "org.SettingsPost(GetUserByName)", err)
  136. } else {
  137. ctx.Handle(500, "org.SettingsPost(GetUserByName)", err)
  138. }
  139. return
  140. }
  141. ctx.Data["Org"] = org
  142. if ctx.HasError() {
  143. ctx.HTML(200, SETTINGS)
  144. return
  145. }
  146. org.FullName = form.DisplayName
  147. org.Email = form.Email
  148. org.Description = form.Description
  149. org.Website = form.Website
  150. org.Location = form.Location
  151. if err = models.UpdateUser(org); err != nil {
  152. ctx.Handle(500, "org.SettingsPost(UpdateUser)", err)
  153. return
  154. }
  155. log.Trace("%s Organization setting updated: %s", ctx.Req.RequestURI, org.LowerName)
  156. ctx.Flash.Success("Organization profile has been successfully updated.")
  157. ctx.Redirect("/org/" + org.Name + "/settings")
  158. }
  159. func DeletePost(ctx *middleware.Context) {
  160. ctx.Data["Title"] = "Settings"
  161. org, err := models.GetUserByName(ctx.Params(":org"))
  162. if err != nil {
  163. if err == models.ErrUserNotExist {
  164. ctx.Handle(404, "org.DeletePost(GetUserByName)", err)
  165. } else {
  166. ctx.Handle(500, "org.DeletePost(GetUserByName)", err)
  167. }
  168. return
  169. }
  170. ctx.Data["Org"] = org
  171. if !org.IsOrgOwner(ctx.User.Id) {
  172. ctx.Error(403)
  173. return
  174. }
  175. tmpUser := models.User{
  176. Passwd: ctx.Query("password"),
  177. Salt: ctx.User.Salt,
  178. }
  179. tmpUser.EncodePasswd()
  180. if tmpUser.Passwd != ctx.User.Passwd {
  181. ctx.Flash.Error("Password is not correct. Make sure you are owner of this account.")
  182. } else {
  183. if err := models.DeleteOrganization(org); err != nil {
  184. switch err {
  185. case models.ErrUserOwnRepos:
  186. ctx.Flash.Error("This organization still have ownership of repository, you have to delete or transfer them first.")
  187. default:
  188. ctx.Handle(500, "org.DeletePost(DeleteOrganization)", err)
  189. return
  190. }
  191. } else {
  192. ctx.Redirect("/")
  193. return
  194. }
  195. }
  196. ctx.Redirect("/org/" + org.Name + "/settings")
  197. }