235 lines
5.7 KiB
Go
235 lines
5.7 KiB
Go
package models
|
||
|
||
import (
|
||
"fmt"
|
||
|
||
orm "go-admin/common/global"
|
||
"go-admin/tools"
|
||
)
|
||
|
||
type RoleMenu struct {
|
||
RoleId int `gorm:""`
|
||
MenuId int `gorm:""`
|
||
RoleName string `gorm:"size:128)"`
|
||
CreateBy string `gorm:"size:128)"`
|
||
UpdateBy string `gorm:"size:128)"`
|
||
}
|
||
|
||
func (RoleMenu) TableName() string {
|
||
return "sys_role_menu"
|
||
}
|
||
|
||
type MenuPath struct {
|
||
Path string `json:"path"`
|
||
}
|
||
|
||
func (rm *RoleMenu) Get() ([]RoleMenu, error) {
|
||
var r []RoleMenu
|
||
table := orm.Eloquent.Table("sys_role_menu")
|
||
if rm.RoleId != 0 {
|
||
table = table.Where("role_id = ?", rm.RoleId)
|
||
|
||
}
|
||
if err := table.Find(&r).Error; err != nil {
|
||
return nil, err
|
||
}
|
||
return r, nil
|
||
}
|
||
|
||
func (rm *RoleMenu) GetPermis() ([]string, error) {
|
||
var r []Menu
|
||
table := orm.Eloquent.Select("sys_menu.permission").Table("sys_menu").Joins("left join sys_role_menu on sys_menu.menu_id = sys_role_menu.menu_id")
|
||
|
||
table = table.Where("role_id = ?", rm.RoleId)
|
||
|
||
table = table.Where("sys_menu.menu_type in('F','C')")
|
||
if err := table.Find(&r).Error; err != nil {
|
||
return nil, err
|
||
}
|
||
var list []string
|
||
for i := 0; i < len(r); i++ {
|
||
list = append(list, r[i].Permission)
|
||
}
|
||
return list, nil
|
||
}
|
||
|
||
func (rm *RoleMenu) GetIDS() ([]MenuPath, error) {
|
||
var r []MenuPath
|
||
table := orm.Eloquent.Select("sys_menu.path").Table("sys_role_menu")
|
||
table = table.Joins("left join sys_role on sys_role.role_id=sys_role_menu.role_id")
|
||
table = table.Joins("left join sys_menu on sys_menu.id=sys_role_menu.menu_id")
|
||
table = table.Where("sys_role.role_name = ? and sys_menu.type=1", rm.RoleName)
|
||
if err := table.Find(&r).Error; err != nil {
|
||
return nil, err
|
||
}
|
||
return r, nil
|
||
}
|
||
|
||
func (rm *RoleMenu) DeleteRoleMenu(roleId int) (bool, error) {
|
||
tx := orm.Eloquent.Begin()
|
||
defer func() {
|
||
if r := recover(); r != nil {
|
||
tx.Rollback()
|
||
}
|
||
}()
|
||
|
||
if err := tx.Error; err != nil {
|
||
return false, err
|
||
}
|
||
|
||
if err := tx.Table("sys_role_dept").Where("role_id = ?", roleId).Delete(&rm).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
if err := tx.Table("sys_role_menu").Where("role_id = ?", roleId).Delete(&rm).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
var role SysRole
|
||
if err := tx.Table("sys_role").Where("role_id = ?", roleId).First(&role).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
sql3 := "delete from sys_casbin_rule where v0= '" + role.RoleKey + "';"
|
||
if err := tx.Exec(sql3).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
if err := tx.Commit().Error; err != nil {
|
||
return false, err
|
||
}
|
||
|
||
return true, nil
|
||
|
||
}
|
||
|
||
// 该方法即将弃用
|
||
func (rm *RoleMenu) BatchDeleteRoleMenu(roleIds []int) (bool, error) {
|
||
tx := orm.Eloquent.Begin()
|
||
defer func() {
|
||
if r := recover(); r != nil {
|
||
tx.Rollback()
|
||
}
|
||
}()
|
||
|
||
if err := tx.Error; err != nil {
|
||
return false, err
|
||
}
|
||
|
||
if err := tx.Table("sys_role_menu").Where("role_id in (?)", roleIds).Delete(&rm).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
var role []SysRole
|
||
if err := tx.Table("sys_role").Where("role_id in (?)", roleIds).Find(&role).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
sql := ""
|
||
for i := 0; i < len(role); i++ {
|
||
sql += "delete from sys_casbin_rule where v0= '" + role[i].RoleName + "';"
|
||
}
|
||
if err := tx.Exec(sql).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
if err := tx.Commit().Error; err != nil {
|
||
return false, err
|
||
}
|
||
return true, nil
|
||
|
||
}
|
||
|
||
func (rm *RoleMenu) Insert(roleId int, menuId []int) (bool, error) {
|
||
var (
|
||
role SysRole
|
||
menu []Menu
|
||
casbinRuleQueue []CasbinRule // casbinRule 待插入队列
|
||
)
|
||
|
||
// 开始事务
|
||
tx := orm.Eloquent.Begin()
|
||
defer func() {
|
||
if r := recover(); r != nil {
|
||
tx.Rollback()
|
||
}
|
||
}()
|
||
|
||
if err := tx.Error; err != nil {
|
||
return false, err
|
||
}
|
||
|
||
// 在事务中做一些数据库操作(从这一点使用'tx',而不是'db')
|
||
if err := tx.Table("sys_role").Where("role_id = ?", roleId).First(&role).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
if err := tx.Table("sys_menu").Where("menu_id in (?)", menuId).Find(&menu).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
//ORM不支持批量插入所以需要拼接 sql 串
|
||
sysRoleMenuSql := "INSERT INTO `sys_role_menu` (`role_id`,`menu_id`,`role_name`) VALUES "
|
||
casbinRuleSql := "INSERT INTO `sys_casbin_rule` (`p_type`,`v0`,`v1`,`v2`) VALUES "
|
||
|
||
for i, m := range menu {
|
||
// 拼装'role_menu'表批量插入SQL语句
|
||
sysRoleMenuSql += fmt.Sprintf("(%d,%d,'%s')", role.RoleId, m.MenuId, role.RoleKey)
|
||
if i == len(menu)-1 {
|
||
sysRoleMenuSql += ";" //最后一条数据 以分号结尾
|
||
} else {
|
||
sysRoleMenuSql += ","
|
||
}
|
||
if m.MenuType == "A" {
|
||
// 加入队列
|
||
casbinRuleQueue = append(casbinRuleQueue,
|
||
CasbinRule{
|
||
V0: role.RoleKey,
|
||
V1: m.Path,
|
||
V2: m.Action,
|
||
})
|
||
}
|
||
}
|
||
// 执行批量插入sys_role_menu
|
||
if err := tx.Exec(sysRoleMenuSql).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
|
||
// 拼装'sys_casbin_rule'批量插入SQL语句
|
||
// TODO: casbinRuleQueue队列不为空时才会拼装,否则直接忽略不执行'for'循环
|
||
for i, v := range casbinRuleQueue {
|
||
casbinRuleSql += fmt.Sprintf("('p','%s','%s','%s')", v.V0, v.V1, v.V2)
|
||
if i == len(casbinRuleQueue)-1 {
|
||
casbinRuleSql += ";"
|
||
} else {
|
||
casbinRuleSql += ","
|
||
}
|
||
}
|
||
// 执行批量插入sys_casbin_rule
|
||
if len(casbinRuleQueue) > 0 {
|
||
if err := tx.Exec(casbinRuleSql).Error; err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
}
|
||
|
||
if err := tx.Commit().Error; err != nil {
|
||
return false, err
|
||
}
|
||
return true, nil
|
||
}
|
||
|
||
func (rm *RoleMenu) Delete(RoleId string, MenuID string) (bool, error) {
|
||
rm.RoleId, _ = tools.StringToInt(RoleId)
|
||
table := orm.Eloquent.Table("sys_role_menu").Where("role_id = ?", RoleId)
|
||
if MenuID != "" {
|
||
table = table.Where("menu_id = ?", MenuID)
|
||
}
|
||
if err := table.Delete(&rm).Error; err != nil {
|
||
return false, err
|
||
}
|
||
return true, nil
|
||
|
||
}
|