package models import ( "github.com/pkg/errors" "gorm.io/gorm" orm "go-admin/common/global" "go-admin/tools" ) type SysRole struct { RoleId int `json:"roleId" gorm:"primary_key;AUTO_INCREMENT"` // 角色编码 RoleName string `json:"roleName" gorm:"size:128;"` // 角色名称 Status string `json:"status" gorm:"size:4;"` // RoleKey string `json:"roleKey" gorm:"size:128;"` //角色代码 RoleSort int `json:"roleSort" gorm:""` //角色排序 Flag string `json:"flag" gorm:"size:128;"` // CreateBy string `json:"createBy" gorm:"size:128;"` // UpdateBy string `json:"updateBy" gorm:"size:128;"` // Remark string `json:"remark" gorm:"size:255;"` //备注 Admin bool `json:"admin" gorm:"size:4;"` DataScope string `json:"dataScope" gorm:"size:128;"` BaseModel Params string `json:"params" gorm:"-"` MenuIds []int `json:"menuIds" gorm:"-"` DeptIds []int `json:"deptIds" gorm:"-"` } func (SysRole) TableName() string { return "sys_role" } type MenuIdList struct { MenuId int `json:"menuId"` } func (role *SysRole) GetById(tx *gorm.DB, id interface{}) error { return tx.First(role, id).Error } func (role *SysRole) GetPage(pageSize int, pageIndex int) ([]SysRole, int, error) { var doc []SysRole table := orm.Eloquent.Table("sys_role") if role.RoleId != 0 { table = table.Where("role_id = ?", role.RoleId) } if role.RoleName != "" { table = table.Where("role_name = ?", role.RoleName) } if role.Status != "" { table = table.Where("status = ?", role.Status) } if role.RoleKey != "" { table = table.Where("role_key = ?", role.RoleKey) } // 数据权限控制 dataPermission := new(DataPermission) dataPermission.UserId, _ = tools.StringToInt(role.DataScope) table, err := dataPermission.GetDataScope("sys_role", table) if err != nil { return nil, 0, err } var count int64 if err := table.Order("role_sort").Offset((pageIndex - 1) * pageSize).Limit(pageSize).Find(&doc).Offset(-1).Limit(-1).Count(&count).Error; err != nil { return nil, 0, err } //table.Where("`deleted_at` IS NULL").Total(&count) return doc, int(count), nil } func (role *SysRole) Get() (SysRole SysRole, err error) { table := orm.Eloquent.Table("sys_role") if role.RoleId != 0 { table = table.Where("role_id = ?", role.RoleId) } if role.RoleName != "" { table = table.Where("role_name = ?", role.RoleName) } if err = table.First(&SysRole).Error; err != nil { return } return } func (role *SysRole) GetList() (SysRole []SysRole, err error) { table := orm.Eloquent.Table("sys_role") if role.RoleId != 0 { table = table.Where("role_id = ?", role.RoleId) } if role.RoleName != "" { table = table.Where("role_name = ?", role.RoleName) } if err = table.Order("role_sort").Find(&SysRole).Error; err != nil { return } return } // 获取角色对应的菜单ids func (role *SysRole) GetRoleMeunId() ([]int, error) { menuIds := make([]int, 0) menuList := make([]MenuIdList, 0) if err := orm.Eloquent.Table("sys_role_menu").Select("sys_role_menu.menu_id").Where("role_id = ? ", role.RoleId).Where(" sys_role_menu.menu_id not in(select sys_menu.parent_id from sys_role_menu LEFT JOIN sys_menu on sys_menu.menu_id=sys_role_menu.menu_id where role_id =? and parent_id is not null)", role.RoleId).Find(&menuList).Error; err != nil { return nil, err } for i := 0; i < len(menuList); i++ { menuIds = append(menuIds, menuList[i].MenuId) } return menuIds, nil } func (role *SysRole) Insert() (id int, err error) { var i int64 orm.Eloquent.Table(role.TableName()).Where("role_name=? or role_key = ?", role.RoleName, role.RoleKey).Count(&i) if i > 0 { return 0, errors.New("角色名称或者角色标识已经存在!") } role.UpdateBy = "" result := orm.Eloquent.Table(role.TableName()).Create(&role) if result.Error != nil { err = result.Error return } id = role.RoleId return } type DeptIdList struct { DeptId int `json:"DeptId"` } func (role *SysRole) GetRoleDeptId() ([]int, error) { deptIds := make([]int, 0) deptList := make([]DeptIdList, 0) if err := orm.Eloquent.Table("sys_role_dept").Select("sys_role_dept.dept_id").Joins("LEFT JOIN sys_dept on sys_dept.dept_id=sys_role_dept.dept_id").Where("role_id = ? ", role.RoleId).Where(" sys_role_dept.dept_id not in(select sys_dept.parent_id from sys_role_dept LEFT JOIN sys_dept on sys_dept.dept_id=sys_role_dept.dept_id where role_id =? )", role.RoleId).Find(&deptList).Error; err != nil { return nil, err } for i := 0; i < len(deptList); i++ { deptIds = append(deptIds, deptList[i].DeptId) } return deptIds, nil } // 修改 func (role *SysRole) Update(id int) (update SysRole, err error) { if err = orm.Eloquent.Table(role.TableName()).First(&update, id).Error; err != nil { return } if role.RoleName != "" && role.RoleName != update.RoleName { return update, errors.New("角色名称不允许修改!") } if role.RoleKey != "" && role.RoleKey != update.RoleKey { return update, errors.New("角色标识不允许修改!") } //参数1:是要修改的数据 //参数2:是修改的数据 if err = orm.Eloquent.Table(role.TableName()).Model(&update).Updates(&role).Error; err != nil { return } return } // 批量删除 func (role *SysRole) BatchDelete(id []int) (Result bool, err error) { tx := orm.Eloquent.Begin() defer func() { if r := recover(); r != nil { tx.Rollback() } }() if err := tx.Error; err != nil { return false, err } // 查询角色 var roles []SysRole if err := tx.Table("sys_role").Where("role_id in (?)", id).Find(&roles).Error; err != nil { tx.Rollback() return false, err } var count int64 if err := tx.Table("sys_user").Where("role_id in (?)", id).Count(&count).Error; err != nil { tx.Rollback() return false, err } if count > 0 { tx.Rollback() return false, errors.New("存在绑定用户,请解绑后重试") } // 删除角色 if err = tx.Table(role.TableName()).Where("role_id in (?)", id).Unscoped().Delete(&SysRole{}).Error; err != nil { tx.Rollback() return false, err } // 删除角色菜单 if err := tx.Table("sys_role_menu").Where("role_id in (?)", id).Delete(&RoleMenu{}).Error; err != nil { tx.Rollback() return false, err } // 删除casbin配置 for i := 0; i < len(roles); i++ { if err := tx.Table("sys_casbin_rule").Where("v0 in (?)", roles[0].RoleKey).Delete(&CasbinRule{}).Error; err != nil { tx.Rollback() return false, err } } if err := tx.Commit().Error; err != nil { return false, err } return true, nil }