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.

members.go 3.1 kB

12 years ago
12 years ago
Better logging (#6038) (#6095) * Panic don't fatal on create new logger Fixes #5854 Signed-off-by: Andrew Thornton <art27@cantab.net> * partial broken * Update the logging infrastrcture Signed-off-by: Andrew Thornton <art27@cantab.net> * Reset the skip levels for Fatal and Error Signed-off-by: Andrew Thornton <art27@cantab.net> * broken ncsa * More log.Error fixes Signed-off-by: Andrew Thornton <art27@cantab.net> * Remove nal * set log-levels to lowercase * Make console_test test all levels * switch to lowercased levels * OK now working * Fix vetting issues * Fix lint * Fix tests * change default logging to match current gitea * Improve log testing Signed-off-by: Andrew Thornton <art27@cantab.net> * reset error skip levels to 0 * Update documentation and access logger configuration * Redirect the router log back to gitea if redirect macaron log but also allow setting the log level - i.e. TRACE * Fix broken level caching * Refactor the router log * Add Router logger * Add colorizing options * Adjust router colors * Only create logger if they will be used * update app.ini.sample * rename Attribute ColorAttribute * Change from white to green for function * Set fatal/error levels * Restore initial trace logger * Fix Trace arguments in modules/auth/auth.go * Properly handle XORMLogger * Improve admin/config page * fix fmt * Add auto-compression of old logs * Update error log levels * Remove the unnecessary skip argument from Error, Fatal and Critical * Add stacktrace support * Fix tests * Remove x/sync from vendors? * Add stderr option to console logger * Use filepath.ToSlash to protect against Windows in tests * Remove prefixed underscores from names in colors.go * Remove not implemented database logger This was removed from Gogs on 4 Mar 2016 but left in the configuration since then. * Ensure that log paths are relative to ROOT_PATH * use path.Join * rename jsonConfig to logConfig * Rename "config" to "jsonConfig" to make it clearer * Requested changes * Requested changes: XormLogger * Try to color the windows terminal If successful default to colorizing the console logs * fixup * Colorize initially too * update vendor * Colorize logs on default and remove if this is not a colorizing logger * Fix documentation * fix test * Use go-isatty to detect if on windows we are on msys or cygwin * Fix spelling mistake * Add missing vendors * More changes * Rationalise the ANSI writer protection * Adjust colors on advice from @0x5c * Make Flags a comma separated list * Move to use the windows constant for ENABLE_VIRTUAL_TERMINAL_PROCESSING * Ensure matching is done on the non-colored message - to simpify EXPRESSION
7 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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. "code.gitea.io/gitea/models"
  7. "code.gitea.io/gitea/modules/base"
  8. "code.gitea.io/gitea/modules/context"
  9. "code.gitea.io/gitea/modules/log"
  10. "code.gitea.io/gitea/modules/setting"
  11. "github.com/unknwon/com"
  12. )
  13. const (
  14. // tplMembers template for organization members page
  15. tplMembers base.TplName = "org/member/members"
  16. )
  17. // Members render organization users page
  18. func Members(ctx *context.Context) {
  19. org := ctx.Org.Organization
  20. ctx.Data["Title"] = org.FullName
  21. ctx.Data["PageIsOrgMembers"] = true
  22. page := ctx.QueryInt("page")
  23. if page <= 1 {
  24. page = 1
  25. }
  26. var opts = models.FindOrgMembersOpts{
  27. OrgID: org.ID,
  28. PublicOnly: true,
  29. }
  30. if ctx.User != nil {
  31. isMember, err := ctx.Org.Organization.IsOrgMember(ctx.User.ID)
  32. if err != nil {
  33. ctx.Error(500, "IsOrgMember")
  34. return
  35. }
  36. opts.PublicOnly = !isMember && !ctx.User.IsAdmin
  37. }
  38. total, err := models.CountOrgMembers(opts)
  39. if err != nil {
  40. ctx.Error(500, "CountOrgMembers")
  41. return
  42. }
  43. pager := context.NewPagination(int(total), setting.UI.MembersPagingNum, page, 5)
  44. opts.Start = (page - 1) * setting.UI.MembersPagingNum
  45. opts.Limit = setting.UI.MembersPagingNum
  46. members, membersIsPublic, err := models.FindOrgMembers(opts)
  47. if err != nil {
  48. ctx.ServerError("GetMembers", err)
  49. return
  50. }
  51. ctx.Data["Page"] = pager
  52. ctx.Data["Members"] = members
  53. ctx.Data["MembersIsPublicMember"] = membersIsPublic
  54. ctx.Data["MembersIsUserOrgOwner"] = members.IsUserOrgOwner(org.ID)
  55. ctx.Data["MembersTwoFaStatus"] = members.GetTwoFaStatus()
  56. ctx.HTML(200, tplMembers)
  57. }
  58. // MembersAction response for operation to a member of organization
  59. func MembersAction(ctx *context.Context) {
  60. uid := com.StrTo(ctx.Query("uid")).MustInt64()
  61. if uid == 0 {
  62. ctx.Redirect(ctx.Org.OrgLink + "/members")
  63. return
  64. }
  65. org := ctx.Org.Organization
  66. var err error
  67. switch ctx.Params(":action") {
  68. case "private":
  69. if ctx.User.ID != uid && !ctx.Org.IsOwner {
  70. ctx.Error(404)
  71. return
  72. }
  73. err = models.ChangeOrgUserStatus(org.ID, uid, false)
  74. case "public":
  75. if ctx.User.ID != uid && !ctx.Org.IsOwner {
  76. ctx.Error(404)
  77. return
  78. }
  79. err = models.ChangeOrgUserStatus(org.ID, uid, true)
  80. case "remove":
  81. if !ctx.Org.IsOwner {
  82. ctx.Error(404)
  83. return
  84. }
  85. err = org.RemoveMember(uid)
  86. if models.IsErrLastOrgOwner(err) {
  87. ctx.Flash.Error(ctx.Tr("form.last_org_owner"))
  88. ctx.Redirect(ctx.Org.OrgLink + "/members")
  89. return
  90. }
  91. case "leave":
  92. err = org.RemoveMember(ctx.User.ID)
  93. if models.IsErrLastOrgOwner(err) {
  94. ctx.Flash.Error(ctx.Tr("form.last_org_owner"))
  95. ctx.Redirect(ctx.Org.OrgLink + "/members")
  96. return
  97. }
  98. }
  99. if err != nil {
  100. log.Error("Action(%s): %v", ctx.Params(":action"), err)
  101. ctx.JSON(200, map[string]interface{}{
  102. "ok": false,
  103. "err": err.Error(),
  104. })
  105. return
  106. }
  107. if ctx.Params(":action") != "leave" {
  108. ctx.Redirect(ctx.Org.OrgLink + "/members")
  109. } else {
  110. ctx.Redirect(setting.AppSubURL + "/")
  111. }
  112. }