BaseController.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  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. )
  13. type BaseController struct {
  14. beego.Controller
  15. Member *models.Member
  16. MemberResourceList []*models.Resource
  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. roleId := 4
  70. if c.Member != nil && c.Member.MemberId > 0 {
  71. roleId = c.Member.Role
  72. }
  73. resourceList,err := models.NewMemberGroup().FindMemberGroupResourceList(roleId)
  74. if err != nil {
  75. beego.Error("获取用户许可资源时出错 =>", err)
  76. c.ShowErrorPage(500,"获取用户许可资源时出错")
  77. }
  78. c.MemberResourceList = resourceList
  79. c.Data["MemberResource"] = resourceList
  80. for _,resource := range resourceList {
  81. if resource.ControllerName == controller && resource.ActionName == action && resource.HttpMethod == c.Ctx.Input.Method() {
  82. return
  83. }
  84. }
  85. c.ShowErrorPage(403,"权限不足")
  86. }
  87. // SetMember 获取或设置当前登录用户信息,如果 MemberId 小于 0 则标识删除 Session
  88. func (c *BaseController) SetMember(member models.Member) {
  89. if member.MemberId <= 0 {
  90. c.DelSession(conf.LoginSessionName)
  91. c.DelSession("uid")
  92. c.DestroySession()
  93. } else {
  94. c.SetSession(conf.LoginSessionName, member)
  95. c.SetSession("uid", member.MemberId)
  96. }
  97. }
  98. // JsonResult 响应 json 结果
  99. func (c *BaseController) JsonResult(errCode int, errMsg string, data ...interface{}) {
  100. jsonData := make(map[string]interface{}, 3)
  101. jsonData["errcode"] = errCode
  102. jsonData["message"] = errMsg
  103. if len(data) > 0 && data[0] != nil {
  104. jsonData["data"] = data[0]
  105. }
  106. returnJSON, err := json.Marshal(jsonData)
  107. if err != nil {
  108. beego.Error(err)
  109. }
  110. c.Ctx.ResponseWriter.Header().Set("Content-Type", "application/json; charset=utf-8")
  111. c.Ctx.ResponseWriter.Header().Set("Cache-Control", "no-cache, no-store")
  112. io.WriteString(c.Ctx.ResponseWriter, string(returnJSON))
  113. c.StopRun()
  114. }
  115. // ExecuteViewPathTemplate 执行指定的模板并返回执行结果.
  116. func (c *BaseController) ExecuteViewPathTemplate(tplName string, data interface{}) (string, error) {
  117. var buf bytes.Buffer
  118. viewPath := c.ViewPath
  119. if c.ViewPath == "" {
  120. viewPath = beego.BConfig.WebConfig.ViewsPath
  121. }
  122. if err := beego.ExecuteViewPathTemplate(&buf, tplName, viewPath, data); err != nil {
  123. return "", err
  124. }
  125. return buf.String(), nil
  126. }
  127. func (c *BaseController) BaseUrl() string {
  128. baseUrl := beego.AppConfig.DefaultString("baseurl", "")
  129. if baseUrl != "" {
  130. if strings.HasSuffix(baseUrl, "/") {
  131. baseUrl = strings.TrimSuffix(baseUrl, "/")
  132. }
  133. } else {
  134. baseUrl = c.Ctx.Input.Scheme() + "://" + c.Ctx.Request.Host
  135. }
  136. return baseUrl
  137. }
  138. //显示错误信息页面.
  139. func (c *BaseController) ShowErrorPage(errCode int, errMsg string) {
  140. c.TplName = "errors/error.tpl"
  141. c.Data["ErrorMessage"] = errMsg
  142. c.Data["ErrorCode"] = errCode
  143. var buf bytes.Buffer
  144. if err := beego.ExecuteViewPathTemplate(&buf, "errors/error.tpl", beego.BConfig.WebConfig.ViewsPath, map[string]interface{}{"ErrorMessage": errMsg, "errCode": errCode, "BaseUrl": conf.BaseUrl}); err != nil {
  145. c.Abort("500")
  146. }
  147. c.CustomAbort(200, buf.String())
  148. }