1
0

BaseController.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. package controllers
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "io"
  6. "strings"
  7. "time"
  8. "github.com/astaxie/beego"
  9. "github.com/lifei6671/mindoc/conf"
  10. "github.com/lifei6671/mindoc/models"
  11. "github.com/lifei6671/mindoc/utils"
  12. "github.com/lifei6671/mindoc/acl"
  13. )
  14. type BaseController struct {
  15. beego.Controller
  16. Member *models.Member
  17. Option map[string]string
  18. EnableAnonymous bool
  19. EnableDocumentHistory bool
  20. }
  21. type CookieRemember struct {
  22. MemberId int
  23. Account string
  24. Time time.Time
  25. }
  26. // Prepare 预处理.
  27. func (c *BaseController) Prepare() {
  28. c.Data["SiteName"] = "MinDoc"
  29. c.Data["Member"] = models.NewMember()
  30. controller, action := c.GetControllerAndAction()
  31. c.Data["ActionName"] = action
  32. c.Data["ControllerName"] = controller
  33. c.EnableAnonymous = false
  34. c.EnableDocumentHistory = false
  35. if member, ok := c.GetSession(conf.LoginSessionName).(models.Member); ok && member.MemberId > 0 {
  36. c.Member = &member
  37. c.Data["Member"] = c.Member
  38. } else {
  39. var remember CookieRemember
  40. // //如果Cookie中存在登录信息,从cookie中获取用户信息
  41. if cookie, ok := c.GetSecureCookie(conf.GetAppKey(), "login"); ok {
  42. if err := utils.Decode(cookie, &remember); err == nil {
  43. if member, err := models.NewMember().Find(remember.MemberId); err == nil {
  44. c.Member = member
  45. c.Data["Member"] = member
  46. c.SetMember(*member)
  47. }
  48. }
  49. }
  50. //c.Member = models.NewMember()
  51. //c.Member.Find(1)
  52. //c.Data["Member"] = *c.Member
  53. }
  54. conf.BaseUrl = c.BaseUrl()
  55. c.Data["BaseUrl"] = c.BaseUrl()
  56. if options, err := models.NewOption().All(); err == nil {
  57. c.Option = make(map[string]string, len(options))
  58. for _, item := range options {
  59. c.Data[item.OptionName] = item.OptionValue
  60. c.Option[item.OptionName] = item.OptionValue
  61. if strings.EqualFold(item.OptionName, "ENABLE_ANONYMOUS") && item.OptionValue == "true" {
  62. c.EnableAnonymous = true
  63. }
  64. if strings.EqualFold(item.OptionName, "ENABLE_DOCUMENT_HISTORY") && item.OptionValue == "true" {
  65. c.EnableDocumentHistory = true
  66. }
  67. }
  68. }
  69. //如果没有访问权限
  70. if !(acl.IsAllow("anonymous",strings.TrimSuffix(controller,"Controller"),action,c.Ctx.Input.Method()) ||
  71. (c.Member != nil && c.Member.Role > 0 && acl.IsAllow(c.Member.Account,strings.TrimSuffix(controller,"Controller"),action,c.Ctx.Input.Method()))) {
  72. c.ShowErrorPage(403,"权限不足")
  73. }
  74. }
  75. // SetMember 获取或设置当前登录用户信息,如果 MemberId 小于 0 则标识删除 Session
  76. func (c *BaseController) SetMember(member models.Member) {
  77. if member.MemberId <= 0 {
  78. c.DelSession(conf.LoginSessionName)
  79. c.DelSession("uid")
  80. c.DestroySession()
  81. } else {
  82. c.SetSession(conf.LoginSessionName, member)
  83. c.SetSession("uid", member.MemberId)
  84. for _,resource := range acl.Modules["MemberCommon"].Resources {
  85. acl.AddMemberPermission(member.Account,*resource)
  86. }
  87. }
  88. }
  89. // JsonResult 响应 json 结果
  90. func (c *BaseController) JsonResult(errCode int, errMsg string, data ...interface{}) {
  91. jsonData := make(map[string]interface{}, 3)
  92. jsonData["errcode"] = errCode
  93. jsonData["message"] = errMsg
  94. if len(data) > 0 && data[0] != nil {
  95. jsonData["data"] = data[0]
  96. }
  97. returnJSON, err := json.Marshal(jsonData)
  98. if err != nil {
  99. beego.Error(err)
  100. }
  101. c.Ctx.ResponseWriter.Header().Set("Content-Type", "application/json; charset=utf-8")
  102. c.Ctx.ResponseWriter.Header().Set("Cache-Control", "no-cache, no-store")
  103. io.WriteString(c.Ctx.ResponseWriter, string(returnJSON))
  104. c.StopRun()
  105. }
  106. // ExecuteViewPathTemplate 执行指定的模板并返回执行结果.
  107. func (c *BaseController) ExecuteViewPathTemplate(tplName string, data interface{}) (string, error) {
  108. var buf bytes.Buffer
  109. viewPath := c.ViewPath
  110. if c.ViewPath == "" {
  111. viewPath = beego.BConfig.WebConfig.ViewsPath
  112. }
  113. if err := beego.ExecuteViewPathTemplate(&buf, tplName, viewPath, data); err != nil {
  114. return "", err
  115. }
  116. return buf.String(), nil
  117. }
  118. func (c *BaseController) BaseUrl() string {
  119. baseUrl := beego.AppConfig.DefaultString("baseurl", "")
  120. if baseUrl != "" {
  121. if strings.HasSuffix(baseUrl, "/") {
  122. baseUrl = strings.TrimSuffix(baseUrl, "/")
  123. }
  124. } else {
  125. baseUrl = c.Ctx.Input.Scheme() + "://" + c.Ctx.Request.Host
  126. }
  127. return baseUrl
  128. }
  129. //显示错误信息页面.
  130. func (c *BaseController) ShowErrorPage(errCode int, errMsg string) {
  131. c.TplName = "errors/error.tpl"
  132. c.Data["ErrorMessage"] = errMsg
  133. c.Data["ErrorCode"] = errCode
  134. var buf bytes.Buffer
  135. if err := beego.ExecuteViewPathTemplate(&buf, "errors/error.tpl", beego.BConfig.WebConfig.ViewsPath, map[string]interface{}{"ErrorMessage": errMsg, "errCode": errCode, "BaseUrl": conf.BaseUrl}); err != nil {
  136. c.Abort("500")
  137. }
  138. c.CustomAbort(200, buf.String())
  139. }