代码拉取完成,页面将自动刷新
// Copyright 2013 The StudyGolang Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// http://studygolang.com
// Author:polaris polaris@studygolang.com
package logic
import (
"global"
"model"
"net/url"
"strconv"
. "db"
"github.com/polaris1119/logger"
"golang.org/x/net/context"
)
type AuthorityLogic struct{}
var DefaultAuthority = AuthorityLogic{}
// GetUserMenu 获取用户菜单
func (self AuthorityLogic) GetUserMenu(ctx context.Context, user *model.Me, uri string) ([]*model.Authority, map[int][]*model.Authority, int) {
var (
aidMap = make(map[int]bool)
err error
)
if !user.IsRoot {
aidMap, err = self.userAuthority(user)
if err != nil {
return nil, nil, 0
}
}
authLocker.RLock()
defer authLocker.RUnlock()
userMenu1 := make([]*model.Authority, 0, 4)
userMenu2 := make(map[int][]*model.Authority)
curMenu1 := 0
for _, authority := range Authorities {
if _, ok := aidMap[authority.Aid]; ok || user.IsRoot {
if authority.Menu1 == 0 {
userMenu1 = append(userMenu1, authority)
userMenu2[authority.Aid] = make([]*model.Authority, 0, 4)
} else if authority.Menu2 == 0 {
userMenu2[authority.Menu1] = append(userMenu2[authority.Menu1], authority)
}
if authority.Route == uri {
curMenu1 = authority.Menu1
}
}
}
return userMenu1, userMenu2, curMenu1
}
// 获取整个菜单
func (AuthorityLogic) GetMenus() ([]*model.Authority, map[string][][]string) {
var (
menu1 = make([]*model.Authority, 0, 10)
menu2 = make(map[string][][]string)
)
for _, authority := range Authorities {
if authority.Menu1 == 0 {
menu1 = append(menu1, authority)
aid := strconv.Itoa(authority.Aid)
menu2[aid] = make([][]string, 0, 4)
} else if authority.Menu2 == 0 {
m := strconv.Itoa(authority.Menu1)
oneMenu2 := []string{strconv.Itoa(authority.Aid), authority.Name}
menu2[m] = append(menu2[m], oneMenu2)
}
}
return menu1, menu2
}
// 除了一级、二级菜单之外的权限(路由)
func (AuthorityLogic) GeneralAuthorities() map[int][]*model.Authority {
auths := make(map[int][]*model.Authority)
for _, authority := range Authorities {
if authority.Menu1 == 0 {
auths[authority.Aid] = make([]*model.Authority, 0, 8)
} else if authority.Menu2 != 0 {
auths[authority.Menu1] = append(auths[authority.Menu1], authority)
}
}
return auths
}
// 判断用户是否有某个权限
func (self AuthorityLogic) HasAuthority(user *model.Me, route string) bool {
if user.IsRoot {
return true
}
aidMap, err := self.userAuthority(user)
if err != nil {
logger.Errorln("HasAuthority:Read user authority error:", err)
return false
}
authLocker.RLock()
defer authLocker.RUnlock()
for _, authority := range Authorities {
if _, ok := aidMap[authority.Aid]; ok {
if route == authority.Route {
return true
}
}
}
return false
}
func (AuthorityLogic) FindAuthoritiesByPage(ctx context.Context, conds map[string]string, curPage, limit int) ([]*model.Authority, int) {
objLog := GetLogger(ctx)
session := MasterDB.NewSession()
for k, v := range conds {
session.And(k+"=?", v)
}
totalSession := session.Clone()
offset := (curPage - 1) * limit
auhtorities := make([]*model.Authority, 0)
err := session.Limit(limit, offset).Find(&auhtorities)
if err != nil {
objLog.Errorln("find error:", err)
return nil, 0
}
total, err := totalSession.Count(new(model.Authority))
if err != nil {
objLog.Errorln("find count error:", err)
return nil, 0
}
return auhtorities, int(total)
}
func (AuthorityLogic) FindById(ctx context.Context, aid int) *model.Authority {
objLog := GetLogger(ctx)
if aid == 0 {
return nil
}
authority := &model.Authority{}
_, err := MasterDB.Id(aid).Get(authority)
if err != nil {
objLog.Errorln("authority FindById error:", err)
return nil
}
return authority
}
func (AuthorityLogic) Save(ctx context.Context, form url.Values, opUser string) (errMsg string, err error) {
objLog := GetLogger(ctx)
authority := &model.Authority{}
err = schemaDecoder.Decode(authority, form)
if err != nil {
objLog.Errorln("authority schema Decoder error", err)
errMsg = err.Error()
return
}
authority.OpUser = opUser
if authority.Aid != 0 {
_, err = MasterDB.Id(authority.Aid).Update(authority)
} else {
_, err = MasterDB.Insert(authority)
}
if err != nil {
errMsg = "内部服务器错误"
objLog.Errorln(errMsg, ":", err)
return
}
global.AuthorityChan <- struct{}{}
return
}
func (AuthorityLogic) Del(aid int) error {
_, err := MasterDB.Id(aid).Delete(new(model.Authority))
global.AuthorityChan <- struct{}{}
return err
}
func (AuthorityLogic) userAuthority(user *model.Me) (map[int]bool, error) {
userRoles := make([]*model.UserRole, 0)
err := MasterDB.Where("uid=?", user.Uid).Find(&userRoles)
if err != nil {
logger.Errorln("userAuthority userole read fail:", err)
return nil, err
}
roleAuthLocker.RLock()
aidMap := make(map[int]bool)
for _, userRole := range userRoles {
for _, aid := range RoleAuthorities[userRole.Roleid] {
aidMap[aid] = true
}
}
roleAuthLocker.RUnlock()
return aidMap, nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。