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

org.go 5.3KB

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