111 lines
3.1 KiB
Go
111 lines
3.1 KiB
Go
package service
|
||
|
||
import (
|
||
"github.com/go-admin-team/go-admin-core/sdk/service"
|
||
)
|
||
|
||
// SysRoleMenu 即将弃用结构体
|
||
type SysRoleMenu struct {
|
||
service.Service
|
||
}
|
||
|
||
//func (e *SysRoleMenu) ReloadRule(tx *gorm.DB, roleId int, menuId []int) (err error) {
|
||
// var role models.SysRole
|
||
//
|
||
// msgID := e.MsgID
|
||
//
|
||
// menu := make([]models.Menu, 0)
|
||
// roleMenu := make([]models.RoleMenu, len(menuId))
|
||
// casbinRule := make([]models.CasbinRule, 0)
|
||
// //先删除所有的
|
||
// err = e.DeleteRoleMenu(tx, roleId)
|
||
// if err != nil {
|
||
// return
|
||
// }
|
||
//
|
||
// // 在事务中做一些数据库操作(从这一点使用'tx',而不是'db')
|
||
// err = tx.Where("role_id = ?", roleId).First(&role).Error
|
||
// if err != nil {
|
||
// log.Errorf("msgID[%s] get role error, %s", msgID, err.Error())
|
||
// return
|
||
// }
|
||
// err = tx.Where("menu_id in (?)", menuId).
|
||
// //Select("path, action, menu_id, menu_type").
|
||
// Find(&menu).Error
|
||
// if err != nil {
|
||
// log.Errorf("msgID[%s] get menu error, %s", msgID, err.Error())
|
||
// return
|
||
// }
|
||
// for i := range menu {
|
||
// roleMenu[i] = models.RoleMenu{
|
||
// RoleId: role.RoleId,
|
||
// MenuId: menu[i].MenuId,
|
||
// RoleName: role.RoleKey,
|
||
// }
|
||
// if menu[i].MenuType == "A" {
|
||
// casbinRule = append(casbinRule, models.CasbinRule{
|
||
// PType: "p",
|
||
// V0: role.RoleKey,
|
||
// V1: menu[i].Path,
|
||
// V2: menu[i].Action,
|
||
// })
|
||
// }
|
||
// }
|
||
// err = tx.Create(&roleMenu).Error
|
||
// if err != nil {
|
||
// log.Errorf("msgID[%s] batch create role's menu error, %s", msgID, err.Error())
|
||
// return
|
||
// }
|
||
// if len(casbinRule) > 0 {
|
||
// err = tx.Create(&casbinRule).Error
|
||
// if err != nil {
|
||
// log.Errorf("msgID[%s] batch create casbin rule error, %s", msgID, err.Error())
|
||
// return
|
||
// }
|
||
// }
|
||
//
|
||
// return
|
||
//}
|
||
|
||
//func (e *SysRoleMenu) DeleteRoleMenu(tx *gorm.DB, roleId int) (err error) {
|
||
// msgID := e.MsgID
|
||
// err = tx.Where("role_id = ?", roleId).
|
||
// Delete(&models.SysRoleDept{}).Error
|
||
// if err != nil {
|
||
// log.Errorf("msgID[%s] delete role's dept error, %s", msgID, err.Error())
|
||
// return
|
||
// }
|
||
// err = tx.Where("role_id = ?", roleId).
|
||
// Delete(&models.RoleMenu{}).Error
|
||
// if err != nil {
|
||
// log.Errorf("msgID[%s] delete role's menu error, %s", msgID, err.Error())
|
||
// return
|
||
// }
|
||
// var role models.SysRole
|
||
// err = tx.Where("role_id = ?", roleId).
|
||
// First(&role).Error
|
||
// if err != nil {
|
||
// log.Errorf("msgID[%s] get role error, %s", msgID, err.Error())
|
||
// return
|
||
// }
|
||
// err = tx.Where("v0 = ?", role.RoleKey).
|
||
// Delete(&models.CasbinRule{}).Error
|
||
// if err != nil {
|
||
// log.Errorf("msgID[%s] delete casbin rule error, %s", msgID, err.Error())
|
||
// return
|
||
// }
|
||
// return
|
||
//}
|
||
//
|
||
//func (e *SysRoleMenu) GetIDS(tx *gorm.DB, roleName string) ([]models.MenuPath, error) {
|
||
// var r []models.MenuPath
|
||
// table := tx.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", roleName)
|
||
// if err := table.Find(&r).Error; err != nil {
|
||
// return nil, err
|
||
// }
|
||
// return r, nil
|
||
//}
|