package com.ruoyi.common.core.domain.entity; import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; import com.alibaba.excel.annotation.ExcelProperty; import com.baomidou.mybatisplus.annotation.*; import com.ruoyi.common.annotation.ExcelDictFormat; import com.ruoyi.common.convert.ExcelDictConvert; import lombok.Data; import lombok.NoArgsConstructor; import lombok.experimental.Accessors; import javax.validation.constraints.NotBlank; import javax.validation.constraints.Size; import java.io.Serializable; import java.util.Date; import java.util.HashMap; import java.util.Map; /** * 角色表 sys_role * * @author ruoyi */ @Data @NoArgsConstructor @Accessors(chain = true) @TableName("sys_role") @ExcelIgnoreUnannotated public class SysRole implements Serializable { private static final long serialVersionUID = 1L; /** * 角色ID */ @ExcelProperty(value = "角色序号") @TableId(value = "role_id", type = IdType.AUTO) private Long roleId; /** * 角色名称 */ @ExcelProperty(value = "角色名称") @NotBlank(message = "角色名称不能为空") @Size(min = 0, max = 30, message = "角色名称长度不能超过30个字符") private String roleName; /** * 角色权限 */ @ExcelProperty(value = "角色权限") @NotBlank(message = "权限字符不能为空") @Size(min = 0, max = 100, message = "权限字符长度不能超过100个字符") private String roleKey; /** * 角色排序 */ @ExcelProperty(value = "角色排序") @NotBlank(message = "显示顺序不能为空") private String roleSort; /** * 数据范围(1:所有数据权限;2:自定义数据权限;3:本部门数据权限;4:本部门及以下数据权限;5:仅本人数据权限) */ @ExcelProperty(value = "数据范围", converter = ExcelDictConvert.class) @ExcelDictFormat(readConverterExp = "1=所有数据权限,2=自定义数据权限,3=本部门数据权限,4=本部门及以下数据权限,5=仅本人数据权限") private String dataScope; /** * 菜单树选择项是否关联显示( 0:父子不互相关联显示 1:父子互相关联显示) */ private boolean menuCheckStrictly; /** * 部门树选择项是否关联显示(0:父子不互相关联显示 1:父子互相关联显示 ) */ private boolean deptCheckStrictly; /** * 角色状态(0正常 1停用) */ @ExcelProperty(value = "角色状态", converter = ExcelDictConvert.class) @ExcelDictFormat(dictType = "sys_common_status") private String status; /** * 删除标志(0代表存在 2代表删除) */ @TableLogic private String delFlag; /** * 创建者 */ @TableField(fill = FieldFill.INSERT) private String createBy; /** * 创建时间 */ @TableField(fill = FieldFill.INSERT) private Date createTime; /** * 更新者 */ @TableField(fill = FieldFill.INSERT_UPDATE) private String updateBy; /** * 更新时间 */ @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime; /** * 备注 */ private String remark; /** * 请求参数 */ @TableField(exist = false) private Map params = new HashMap<>(); /** * 用户是否存在此角色标识 默认不存在 */ @TableField(exist = false) private boolean flag = false; /** * 菜单组 */ @TableField(exist = false) private Long[] menuIds; /** * 部门组(数据权限) */ @TableField(exist = false) private Long[] deptIds; public SysRole(Long roleId) { this.roleId = roleId; } public boolean isAdmin() { return isAdmin(this.roleId); } public static boolean isAdmin(Long roleId) { return roleId != null && 1L == roleId; } }