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 }