Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

org.go 4.6KB

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