mirror of https://github.com/mindoc-org/mindoc.git
173 lines
4.6 KiB
Go
173 lines
4.6 KiB
Go
package controllers
|
||
|
||
import (
|
||
"bytes"
|
||
|
||
"encoding/json"
|
||
"io"
|
||
"strings"
|
||
"time"
|
||
|
||
"github.com/astaxie/beego"
|
||
"github.com/lifei6671/mindoc/conf"
|
||
"github.com/lifei6671/mindoc/models"
|
||
"github.com/lifei6671/mindoc/utils"
|
||
"github.com/lifei6671/mindoc/acl"
|
||
)
|
||
|
||
type BaseController struct {
|
||
beego.Controller
|
||
Member *models.Member
|
||
Option map[string]string
|
||
EnableAnonymous bool
|
||
EnableDocumentHistory bool
|
||
}
|
||
|
||
type CookieRemember struct {
|
||
MemberId int
|
||
Account string
|
||
Time time.Time
|
||
}
|
||
|
||
// Prepare 预处理.
|
||
func (c *BaseController) Prepare() {
|
||
c.Data["SiteName"] = "MinDoc"
|
||
c.Data["Member"] = models.NewMember()
|
||
controller, action := c.GetControllerAndAction()
|
||
|
||
c.Data["ActionName"] = action
|
||
c.Data["ControllerName"] = controller
|
||
|
||
c.EnableAnonymous = false
|
||
c.EnableDocumentHistory = false
|
||
|
||
if member, ok := c.GetSession(conf.LoginSessionName).(models.Member); ok && member.MemberId > 0 {
|
||
|
||
c.Member = &member
|
||
c.Data["Member"] = c.Member
|
||
} else {
|
||
var remember CookieRemember
|
||
// //如果Cookie中存在登录信息,从cookie中获取用户信息
|
||
if cookie, ok := c.GetSecureCookie(conf.GetAppKey(), "login"); ok {
|
||
if err := utils.Decode(cookie, &remember); err == nil {
|
||
if member, err := models.NewMember().Find(remember.MemberId); err == nil {
|
||
c.Member = member
|
||
c.Data["Member"] = member
|
||
c.SetMember(*member)
|
||
}
|
||
}
|
||
}
|
||
//c.Member = models.NewMember()
|
||
//c.Member.Find(1)
|
||
//c.Data["Member"] = *c.Member
|
||
}
|
||
conf.BaseUrl = c.BaseUrl()
|
||
c.Data["BaseUrl"] = c.BaseUrl()
|
||
|
||
if options, err := models.NewOption().All(); err == nil {
|
||
c.Option = make(map[string]string, len(options))
|
||
for _, item := range options {
|
||
c.Data[item.OptionName] = item.OptionValue
|
||
c.Option[item.OptionName] = item.OptionValue
|
||
|
||
if strings.EqualFold(item.OptionName, "ENABLE_ANONYMOUS") && item.OptionValue == "true" {
|
||
c.EnableAnonymous = true
|
||
}
|
||
if strings.EqualFold(item.OptionName, "ENABLE_DOCUMENT_HISTORY") && item.OptionValue == "true" {
|
||
c.EnableDocumentHistory = true
|
||
}
|
||
}
|
||
}
|
||
//如果没有访问权限
|
||
if !(acl.IsAllow("anonymous",strings.TrimSuffix(controller,"Controller"),action,c.Ctx.Input.Method()) ||
|
||
(c.Member != nil && c.Member.Role > 0 && acl.IsAllow(c.Member.Account,strings.TrimSuffix(controller,"Controller"),action,c.Ctx.Input.Method()))) {
|
||
|
||
c.ShowErrorPage(403,"权限不足")
|
||
}
|
||
}
|
||
|
||
// SetMember 获取或设置当前登录用户信息,如果 MemberId 小于 0 则标识删除 Session
|
||
func (c *BaseController) SetMember(member models.Member) {
|
||
|
||
if member.MemberId <= 0 {
|
||
c.DelSession(conf.LoginSessionName)
|
||
c.DelSession("uid")
|
||
c.DestroySession()
|
||
} else {
|
||
c.SetSession(conf.LoginSessionName, member)
|
||
c.SetSession("uid", member.MemberId)
|
||
for _,resource := range acl.Modules["MemberCommon"].Resources {
|
||
acl.AddMemberPermission(member.Account,*resource)
|
||
}
|
||
}
|
||
}
|
||
|
||
// JsonResult 响应 json 结果
|
||
func (c *BaseController) JsonResult(errCode int, errMsg string, data ...interface{}) {
|
||
jsonData := make(map[string]interface{}, 3)
|
||
|
||
jsonData["errcode"] = errCode
|
||
jsonData["message"] = errMsg
|
||
|
||
if len(data) > 0 && data[0] != nil {
|
||
jsonData["data"] = data[0]
|
||
}
|
||
|
||
returnJSON, err := json.Marshal(jsonData)
|
||
|
||
if err != nil {
|
||
beego.Error(err)
|
||
}
|
||
|
||
c.Ctx.ResponseWriter.Header().Set("Content-Type", "application/json; charset=utf-8")
|
||
c.Ctx.ResponseWriter.Header().Set("Cache-Control", "no-cache, no-store")
|
||
io.WriteString(c.Ctx.ResponseWriter, string(returnJSON))
|
||
|
||
c.StopRun()
|
||
}
|
||
|
||
// ExecuteViewPathTemplate 执行指定的模板并返回执行结果.
|
||
func (c *BaseController) ExecuteViewPathTemplate(tplName string, data interface{}) (string, error) {
|
||
var buf bytes.Buffer
|
||
|
||
viewPath := c.ViewPath
|
||
|
||
if c.ViewPath == "" {
|
||
viewPath = beego.BConfig.WebConfig.ViewsPath
|
||
|
||
}
|
||
|
||
if err := beego.ExecuteViewPathTemplate(&buf, tplName, viewPath, data); err != nil {
|
||
return "", err
|
||
}
|
||
return buf.String(), nil
|
||
}
|
||
|
||
func (c *BaseController) BaseUrl() string {
|
||
baseUrl := beego.AppConfig.DefaultString("baseurl", "")
|
||
if baseUrl != "" {
|
||
if strings.HasSuffix(baseUrl, "/") {
|
||
baseUrl = strings.TrimSuffix(baseUrl, "/")
|
||
}
|
||
} else {
|
||
baseUrl = c.Ctx.Input.Scheme() + "://" + c.Ctx.Request.Host
|
||
}
|
||
return baseUrl
|
||
}
|
||
|
||
//显示错误信息页面.
|
||
func (c *BaseController) ShowErrorPage(errCode int, errMsg string) {
|
||
c.TplName = "errors/error.tpl"
|
||
|
||
c.Data["ErrorMessage"] = errMsg
|
||
c.Data["ErrorCode"] = errCode
|
||
|
||
var buf bytes.Buffer
|
||
|
||
if err := beego.ExecuteViewPathTemplate(&buf, "errors/error.tpl", beego.BConfig.WebConfig.ViewsPath, map[string]interface{}{"ErrorMessage": errMsg, "errCode": errCode, "BaseUrl": conf.BaseUrl}); err != nil {
|
||
c.Abort("500")
|
||
}
|
||
|
||
c.CustomAbort(200, buf.String())
|
||
}
|