初始化
This commit is contained in:
		
							
								
								
									
										28
									
								
								ruoyi-system/pom.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								ruoyi-system/pom.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,28 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project xmlns="http://maven.apache.org/POM/4.0.0" | ||||
|          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||||
|          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||||
|     <parent> | ||||
|         <artifactId>ruoyi-vue-plus</artifactId> | ||||
|         <groupId>com.ruoyi</groupId> | ||||
|         <version>${ruoyi-vue-plus.version}</version> | ||||
|     </parent> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
|  | ||||
|     <artifactId>ruoyi-system</artifactId> | ||||
|  | ||||
|     <description> | ||||
|         system系统模块 | ||||
|     </description> | ||||
|  | ||||
|     <dependencies> | ||||
|  | ||||
|         <!-- 通用工具--> | ||||
|         <dependency> | ||||
|             <groupId>com.ruoyi</groupId> | ||||
|             <artifactId>ruoyi-common</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|     </dependencies> | ||||
|  | ||||
| </project> | ||||
| @ -0,0 +1,105 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.fasterxml.jackson.annotation.JsonFormat; | ||||
| import com.ruoyi.common.annotation.Excel; | ||||
| import com.ruoyi.common.annotation.Excel.ColumnType; | ||||
| 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_config | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_config") | ||||
| public class SysConfig implements Serializable { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
|      * 参数主键 | ||||
|      */ | ||||
|     @Excel(name = "参数主键", cellType = ColumnType.NUMERIC) | ||||
|     @TableId(value = "config_id", type = IdType.AUTO) | ||||
|     private Long configId; | ||||
|  | ||||
|     /** | ||||
|      * 参数名称 | ||||
|      */ | ||||
|     @Excel(name = "参数名称") | ||||
|     @NotBlank(message = "参数名称不能为空") | ||||
|     @Size(min = 0, max = 100, message = "参数名称不能超过100个字符") | ||||
|     private String configName; | ||||
|  | ||||
|     /** | ||||
|      * 参数键名 | ||||
|      */ | ||||
|     @Excel(name = "参数键名") | ||||
|     @NotBlank(message = "参数键名长度不能为空") | ||||
|     @Size(min = 0, max = 100, message = "参数键名长度不能超过100个字符") | ||||
|     private String configKey; | ||||
|  | ||||
|     /** | ||||
|      * 参数键值 | ||||
|      */ | ||||
|     @Excel(name = "参数键值") | ||||
|     @NotBlank(message = "参数键值不能为空") | ||||
|     @Size(min = 0, max = 500, message = "参数键值长度不能超过500个字符") | ||||
|     private String configValue; | ||||
|  | ||||
|     /** | ||||
|      * 系统内置(Y是 N否) | ||||
|      */ | ||||
|     @Excel(name = "系统内置", readConverterExp = "Y=是,N=否") | ||||
|     private String configType; | ||||
|  | ||||
|     /** | ||||
|      * 创建者 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT) | ||||
|     private String createBy; | ||||
|  | ||||
|     /** | ||||
|      * 创建时间 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT) | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date createTime; | ||||
|  | ||||
|     /** | ||||
|      * 更新者 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT_UPDATE) | ||||
|     private String updateBy; | ||||
|  | ||||
|     /** | ||||
|      * 更新时间 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT_UPDATE) | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date updateTime; | ||||
|  | ||||
|     /** | ||||
|      * 备注 | ||||
|      */ | ||||
|     private String remark; | ||||
|  | ||||
|     /** | ||||
|      * 请求参数 | ||||
|      */ | ||||
|     @TableField(exist = false) | ||||
|     private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,94 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.IdType; | ||||
| import com.baomidou.mybatisplus.annotation.TableField; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import com.fasterxml.jackson.annotation.JsonFormat; | ||||
| import com.ruoyi.common.annotation.Excel; | ||||
| import com.ruoyi.common.annotation.Excel.ColumnType; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.io.Serializable; | ||||
| import java.util.Date; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 系统访问记录表 sys_logininfor | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_logininfor") | ||||
| public class SysLogininfor implements Serializable { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
|      * ID | ||||
|      */ | ||||
|     @Excel(name = "序号", cellType = ColumnType.NUMERIC) | ||||
|     @TableId(value = "info_id", type = IdType.AUTO) | ||||
|     private Long infoId; | ||||
|  | ||||
|     /** | ||||
|      * 用户账号 | ||||
|      */ | ||||
|     @Excel(name = "用户账号") | ||||
|     private String userName; | ||||
|  | ||||
|     /** | ||||
|      * 登录状态 0成功 1失败 | ||||
|      */ | ||||
|     @Excel(name = "登录状态", readConverterExp = "0=成功,1=失败") | ||||
|     private String status; | ||||
|  | ||||
|     /** | ||||
|      * 登录IP地址 | ||||
|      */ | ||||
|     @Excel(name = "登录地址") | ||||
|     private String ipaddr; | ||||
|  | ||||
|     /** | ||||
|      * 登录地点 | ||||
|      */ | ||||
|     @Excel(name = "登录地点") | ||||
|     private String loginLocation; | ||||
|  | ||||
|     /** | ||||
|      * 浏览器类型 | ||||
|      */ | ||||
|     @Excel(name = "浏览器") | ||||
|     private String browser; | ||||
|  | ||||
|     /** | ||||
|      * 操作系统 | ||||
|      */ | ||||
|     @Excel(name = "操作系统") | ||||
|     private String os; | ||||
|  | ||||
|     /** | ||||
|      * 提示消息 | ||||
|      */ | ||||
|     @Excel(name = "提示消息") | ||||
|     private String msg; | ||||
|  | ||||
|     /** | ||||
|      * 访问时间 | ||||
|      */ | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     @Excel(name = "访问时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date loginTime; | ||||
|  | ||||
|     /** | ||||
|      * 请求参数 | ||||
|      */ | ||||
|     @TableField(exist = false) | ||||
|     private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,93 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.fasterxml.jackson.annotation.JsonFormat; | ||||
| 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_notice | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_notice") | ||||
| public class SysNotice implements Serializable { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
|      * 公告ID | ||||
|      */ | ||||
|     @TableId(value = "notice_id", type = IdType.AUTO) | ||||
|     private Long noticeId; | ||||
|  | ||||
|     /** | ||||
|      * 公告标题 | ||||
|      */ | ||||
|     @NotBlank(message = "公告标题不能为空") | ||||
|     @Size(min = 0, max = 50, message = "公告标题不能超过50个字符") | ||||
|     private String noticeTitle; | ||||
|  | ||||
|     /** | ||||
|      * 公告类型(1通知 2公告) | ||||
|      */ | ||||
|     private String noticeType; | ||||
|  | ||||
|     /** | ||||
|      * 公告内容 | ||||
|      */ | ||||
|     private String noticeContent; | ||||
|  | ||||
|     /** | ||||
|      * 公告状态(0正常 1关闭) | ||||
|      */ | ||||
|     private String status; | ||||
|  | ||||
|     /** | ||||
|      * 创建者 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT) | ||||
|     private String createBy; | ||||
|  | ||||
|     /** | ||||
|      * 创建时间 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT) | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date createTime; | ||||
|  | ||||
|     /** | ||||
|      * 更新者 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT_UPDATE) | ||||
|     private String updateBy; | ||||
|  | ||||
|     /** | ||||
|      * 更新时间 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT_UPDATE) | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date updateTime; | ||||
|  | ||||
|     /** | ||||
|      * 备注 | ||||
|      */ | ||||
|     private String remark; | ||||
|  | ||||
|     /** | ||||
|      * 请求参数 | ||||
|      */ | ||||
|     @TableField(exist = false) | ||||
|     private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,142 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.IdType; | ||||
| import com.baomidou.mybatisplus.annotation.TableField; | ||||
| import com.baomidou.mybatisplus.annotation.TableId; | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import com.fasterxml.jackson.annotation.JsonFormat; | ||||
| import com.ruoyi.common.annotation.Excel; | ||||
| import com.ruoyi.common.annotation.Excel.ColumnType; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.io.Serializable; | ||||
| import java.util.Date; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 操作日志记录表 oper_log | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_oper_log") | ||||
| public class SysOperLog implements Serializable { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
|      * 日志主键 | ||||
|      */ | ||||
|     @Excel(name = "操作序号", cellType = ColumnType.NUMERIC) | ||||
|     @TableId(value = "oper_id", type = IdType.AUTO) | ||||
|     private Long operId; | ||||
|  | ||||
|     /** | ||||
|      * 操作模块 | ||||
|      */ | ||||
|     @Excel(name = "操作模块") | ||||
|     private String title; | ||||
|  | ||||
|     /** | ||||
|      * 业务类型(0其它 1新增 2修改 3删除) | ||||
|      */ | ||||
|     @Excel(name = "业务类型", readConverterExp = "0=其它,1=新增,2=修改,3=删除,4=授权,5=导出,6=导入,7=强退,8=生成代码,9=清空数据") | ||||
|     private Integer businessType; | ||||
|  | ||||
|     /** | ||||
|      * 业务类型数组 | ||||
|      */ | ||||
|     @TableField(exist = false) | ||||
|     private Integer[] businessTypes; | ||||
|  | ||||
|     /** | ||||
|      * 请求方法 | ||||
|      */ | ||||
|     @Excel(name = "请求方法") | ||||
|     private String method; | ||||
|  | ||||
|     /** | ||||
|      * 请求方式 | ||||
|      */ | ||||
|     @Excel(name = "请求方式") | ||||
|     private String requestMethod; | ||||
|  | ||||
|     /** | ||||
|      * 操作类别(0其它 1后台用户 2手机端用户) | ||||
|      */ | ||||
|     @Excel(name = "操作类别", readConverterExp = "0=其它,1=后台用户,2=手机端用户") | ||||
|     private Integer operatorType; | ||||
|  | ||||
|     /** | ||||
|      * 操作人员 | ||||
|      */ | ||||
|     @Excel(name = "操作人员") | ||||
|     private String operName; | ||||
|  | ||||
|     /** | ||||
|      * 部门名称 | ||||
|      */ | ||||
|     @Excel(name = "部门名称") | ||||
|     private String deptName; | ||||
|  | ||||
|     /** | ||||
|      * 请求url | ||||
|      */ | ||||
|     @Excel(name = "请求地址") | ||||
|     private String operUrl; | ||||
|  | ||||
|     /** | ||||
|      * 操作地址 | ||||
|      */ | ||||
|     @Excel(name = "操作地址") | ||||
|     private String operIp; | ||||
|  | ||||
|     /** | ||||
|      * 操作地点 | ||||
|      */ | ||||
|     @Excel(name = "操作地点") | ||||
|     private String operLocation; | ||||
|  | ||||
|     /** | ||||
|      * 请求参数 | ||||
|      */ | ||||
|     @Excel(name = "请求参数") | ||||
|     private String operParam; | ||||
|  | ||||
|     /** | ||||
|      * 返回参数 | ||||
|      */ | ||||
|     @Excel(name = "返回参数") | ||||
|     private String jsonResult; | ||||
|  | ||||
|     /** | ||||
|      * 操作状态(0正常 1异常) | ||||
|      */ | ||||
|     @Excel(name = "状态", readConverterExp = "0=正常,1=异常") | ||||
|     private Integer status; | ||||
|  | ||||
|     /** | ||||
|      * 错误消息 | ||||
|      */ | ||||
|     @Excel(name = "错误消息") | ||||
|     private String errorMsg; | ||||
|  | ||||
|     /** | ||||
|      * 操作时间 | ||||
|      */ | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     @Excel(name = "操作时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date operTime; | ||||
|  | ||||
|     /** | ||||
|      * 请求参数 | ||||
|      */ | ||||
|     @TableField(exist = false) | ||||
|     private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
| } | ||||
							
								
								
									
										110
									
								
								ruoyi-system/src/main/java/com/ruoyi/system/domain/SysPost.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								ruoyi-system/src/main/java/com/ruoyi/system/domain/SysPost.java
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,110 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.*; | ||||
| import com.fasterxml.jackson.annotation.JsonFormat; | ||||
| import com.ruoyi.common.annotation.Excel; | ||||
| import com.ruoyi.common.annotation.Excel.ColumnType; | ||||
| 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_post | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_post") | ||||
| public class SysPost implements Serializable { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** | ||||
|      * 岗位序号 | ||||
|      */ | ||||
|     @Excel(name = "岗位序号", cellType = ColumnType.NUMERIC) | ||||
|     @TableId(value = "post_id", type = IdType.AUTO) | ||||
|     private Long postId; | ||||
|  | ||||
|     /** | ||||
|      * 岗位编码 | ||||
|      */ | ||||
|     @Excel(name = "岗位编码") | ||||
|     @NotBlank(message = "岗位编码不能为空") | ||||
|     @Size(min = 0, max = 64, message = "岗位编码长度不能超过64个字符") | ||||
|     private String postCode; | ||||
|  | ||||
|     /** | ||||
|      * 岗位名称 | ||||
|      */ | ||||
|     @Excel(name = "岗位名称") | ||||
|     @NotBlank(message = "岗位名称不能为空") | ||||
|     @Size(min = 0, max = 50, message = "岗位名称长度不能超过50个字符") | ||||
|     private String postName; | ||||
|  | ||||
|     /** | ||||
|      * 岗位排序 | ||||
|      */ | ||||
|     @Excel(name = "岗位排序") | ||||
|     @NotBlank(message = "显示顺序不能为空") | ||||
|     private String postSort; | ||||
|  | ||||
|     /** | ||||
|      * 状态(0正常 1停用) | ||||
|      */ | ||||
|     @Excel(name = "状态", readConverterExp = "0=正常,1=停用") | ||||
|     private String status; | ||||
|  | ||||
|     /** | ||||
|      * 创建者 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT) | ||||
|     private String createBy; | ||||
|  | ||||
|     /** | ||||
|      * 创建时间 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT) | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date createTime; | ||||
|  | ||||
|     /** | ||||
|      * 更新者 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT_UPDATE) | ||||
|     private String updateBy; | ||||
|  | ||||
|     /** | ||||
|      * 更新时间 | ||||
|      */ | ||||
|     @TableField(fill = FieldFill.INSERT_UPDATE) | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date updateTime; | ||||
|  | ||||
|     /** | ||||
|      * 备注 | ||||
|      */ | ||||
|     private String remark; | ||||
|  | ||||
|     /** | ||||
|      * 请求参数 | ||||
|      */ | ||||
|     @TableField(exist = false) | ||||
|     private Map<String, Object> params = new HashMap<>(); | ||||
|  | ||||
|     /** | ||||
|      * 用户是否存在此岗位标识 默认不存在 | ||||
|      */ | ||||
|     @TableField(exist = false) | ||||
|     private boolean flag = false; | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,29 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| /** | ||||
|  * 角色和部门关联 sys_role_dept | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_role_dept") | ||||
| public class SysRoleDept { | ||||
|     /** | ||||
|      * 角色ID | ||||
|      */ | ||||
|     private Long roleId; | ||||
|  | ||||
|     /** | ||||
|      * 部门ID | ||||
|      */ | ||||
|     private Long deptId; | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,29 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| /** | ||||
|  * 角色和菜单关联 sys_role_menu | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_role_menu") | ||||
| public class SysRoleMenu { | ||||
|     /** | ||||
|      * 角色ID | ||||
|      */ | ||||
|     private Long roleId; | ||||
|  | ||||
|     /** | ||||
|      * 菜单ID | ||||
|      */ | ||||
|     private Long menuId; | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,56 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import lombok.*; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| /** | ||||
|  * 当前在线会话 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| public class SysUserOnline { | ||||
|     /** | ||||
|      * 会话编号 | ||||
|      */ | ||||
|     private String tokenId; | ||||
|  | ||||
|     /** | ||||
|      * 部门名称 | ||||
|      */ | ||||
|     private String deptName; | ||||
|  | ||||
|     /** | ||||
|      * 用户名称 | ||||
|      */ | ||||
|     private String userName; | ||||
|  | ||||
|     /** | ||||
|      * 登录IP地址 | ||||
|      */ | ||||
|     private String ipaddr; | ||||
|  | ||||
|     /** | ||||
|      * 登录地址 | ||||
|      */ | ||||
|     private String loginLocation; | ||||
|  | ||||
|     /** | ||||
|      * 浏览器类型 | ||||
|      */ | ||||
|     private String browser; | ||||
|  | ||||
|     /** | ||||
|      * 操作系统 | ||||
|      */ | ||||
|     private String os; | ||||
|  | ||||
|     /** | ||||
|      * 登录时间 | ||||
|      */ | ||||
|     private Long loginTime; | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,29 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| /** | ||||
|  * 用户和岗位关联 sys_user_post | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_user_post") | ||||
| public class SysUserPost { | ||||
|     /** | ||||
|      * 用户ID | ||||
|      */ | ||||
|     private Long userId; | ||||
|  | ||||
|     /** | ||||
|      * 岗位ID | ||||
|      */ | ||||
|     private Long postId; | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,29 @@ | ||||
| package com.ruoyi.system.domain; | ||||
|  | ||||
| import com.baomidou.mybatisplus.annotation.TableName; | ||||
| import lombok.Data; | ||||
| import lombok.NoArgsConstructor; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| /** | ||||
|  * 用户和角色关联 sys_user_role | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @TableName("sys_user_role") | ||||
| public class SysUserRole { | ||||
|     /** | ||||
|      * 用户ID | ||||
|      */ | ||||
|     private Long userId; | ||||
|  | ||||
|     /** | ||||
|      * 角色ID | ||||
|      */ | ||||
|     private Long roleId; | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,42 @@ | ||||
| package com.ruoyi.system.domain.vo; | ||||
|  | ||||
| import lombok.*; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| /** | ||||
|  * 路由显示信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
|  | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| public class MetaVo { | ||||
|     /** | ||||
|      * 设置该路由在侧边栏和面包屑中展示的名字 | ||||
|      */ | ||||
|     private String title; | ||||
|  | ||||
|     /** | ||||
|      * 设置该路由的图标,对应路径src/assets/icons/svg | ||||
|      */ | ||||
|     private String icon; | ||||
|  | ||||
|     /** | ||||
|      * 设置为true,则不会被 <keep-alive>缓存 | ||||
|      */ | ||||
|     private boolean noCache; | ||||
|  | ||||
|     public MetaVo(String title, String icon) { | ||||
|         this.title = title; | ||||
|         this.icon = icon; | ||||
|     } | ||||
|  | ||||
|     public MetaVo(String title, String icon, boolean noCache) { | ||||
|         this.title = title; | ||||
|         this.icon = icon; | ||||
|         this.noCache = noCache; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,59 @@ | ||||
| package com.ruoyi.system.domain.vo; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonInclude; | ||||
| import lombok.*; | ||||
| import lombok.experimental.Accessors; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 路由配置信息 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Data | ||||
| @NoArgsConstructor | ||||
| @Accessors(chain = true) | ||||
| @JsonInclude(JsonInclude.Include.NON_EMPTY) | ||||
| public class RouterVo { | ||||
|     /** | ||||
|      * 路由名字 | ||||
|      */ | ||||
|     private String name; | ||||
|  | ||||
|     /** | ||||
|      * 路由地址 | ||||
|      */ | ||||
|     private String path; | ||||
|  | ||||
|     /** | ||||
|      * 是否隐藏路由,当设置 true 的时候该路由不会再侧边栏出现 | ||||
|      */ | ||||
|     private boolean hidden; | ||||
|  | ||||
|     /** | ||||
|      * 重定向地址,当设置 noRedirect 的时候该路由在面包屑导航中不可被点击 | ||||
|      */ | ||||
|     private String redirect; | ||||
|  | ||||
|     /** | ||||
|      * 组件地址 | ||||
|      */ | ||||
|     private String component; | ||||
|  | ||||
|     /** | ||||
|      * 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式--如组件页面 | ||||
|      */ | ||||
|     private Boolean alwaysShow; | ||||
|  | ||||
|     /** | ||||
|      * 其他元素 | ||||
|      */ | ||||
|     private MetaVo meta; | ||||
|  | ||||
|     /** | ||||
|      * 子路由 | ||||
|      */ | ||||
|     private List<RouterVo> children; | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysConfig; | ||||
|  | ||||
| /** | ||||
|  * 参数配置 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysConfigMapper extends BaseMapperPlus<SysConfig> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,41 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.entity.SysDept; | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 部门管理 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysDeptMapper extends BaseMapperPlus<SysDept> { | ||||
|  | ||||
|     /** | ||||
|      * 查询部门管理数据 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 部门信息集合 | ||||
|      */ | ||||
|     public List<SysDept> selectDeptList(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询部门树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @param deptCheckStrictly 部门树选择项是否关联显示 | ||||
|      * @return 选中部门列表 | ||||
|      */ | ||||
|     public List<Integer> selectDeptListByRoleId(@Param("roleId") Long roleId, @Param("deptCheckStrictly") boolean deptCheckStrictly); | ||||
|  | ||||
| 	/** | ||||
| 	 * 修改子元素关系 | ||||
| 	 * | ||||
| 	 * @param depts 子元素 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	public int updateDeptChildren(@Param("depts") List<SysDept> depts); | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,23 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.core.domain.entity.SysDictData; | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 字典表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysDictDataMapper extends BaseMapperPlus<SysDictData> { | ||||
|  | ||||
| 	default List<SysDictData> selectDictDataByType(String dictType) { | ||||
| 		return selectList( | ||||
| 			new LambdaQueryWrapper<SysDictData>() | ||||
| 				.eq(SysDictData::getStatus, "0") | ||||
| 				.eq(SysDictData::getDictType, dictType) | ||||
| 				.orderByAsc(SysDictData::getDictSort)); | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.entity.SysDictType; | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
|  | ||||
| /** | ||||
|  * 字典表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysDictTypeMapper extends BaseMapperPlus<SysDictType> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysLogininfor; | ||||
|  | ||||
| /** | ||||
|  * 系统访问日志情况信息 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysLogininforMapper extends BaseMapperPlus<SysLogininfor> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,63 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.entity.SysMenu; | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 菜单表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysMenuMapper extends BaseMapperPlus<SysMenu> { | ||||
|  | ||||
|     /** | ||||
|      * 根据用户所有权限 | ||||
|      * | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public List<String> selectMenuPerms(); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户查询系统菜单列表 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuListByUserId(SysMenu menu); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询权限 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public List<String> selectMenuPermsByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询菜单 | ||||
|      * | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuTreeAll(); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询菜单 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuTreeByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询菜单树信息 | ||||
|      * | ||||
|      * @param roleId            角色ID | ||||
|      * @param menuCheckStrictly 菜单树选择项是否关联显示 | ||||
|      * @return 选中菜单列表 | ||||
|      */ | ||||
|     public List<Integer> selectMenuListByRoleId(@Param("roleId") Long roleId, @Param("menuCheckStrictly") boolean menuCheckStrictly); | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysNotice; | ||||
|  | ||||
| /** | ||||
|  * 通知公告表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysNoticeMapper extends BaseMapperPlus<SysNotice> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysOperLog; | ||||
|  | ||||
| /** | ||||
|  * 操作日志 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysOperLogMapper extends BaseMapperPlus<SysOperLog> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,31 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysPost; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 岗位信息 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysPostMapper extends BaseMapperPlus<SysPost> { | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取岗位选择框列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中岗位ID列表 | ||||
|      */ | ||||
|     public List<Integer> selectPostListByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 查询用户所属岗位组 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public List<SysPost> selectPostsByUserName(String userName); | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysRoleDept; | ||||
|  | ||||
| /** | ||||
|  * 角色与部门关联表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysRoleDeptMapper extends BaseMapperPlus<SysRoleDept> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,52 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 角色表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysRoleMapper extends BaseMapperPlus<SysRole> { | ||||
|  | ||||
|     Page<SysRole> selectPageRoleList(@Param("page") Page<SysRole> page, @Param("role") SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询角色数据 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 角色数据集合信息 | ||||
|      */ | ||||
|     public List<SysRole> selectRoleList(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询角色 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     public List<SysRole> selectRolePermissionByUserId(Long userId); | ||||
|  | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取角色选择框列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中角色ID列表 | ||||
|      */ | ||||
|     public List<Integer> selectRoleListByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询角色 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     public List<SysRole> selectRolesByUserName(String userName); | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysRoleMenu; | ||||
|  | ||||
| /** | ||||
|  * 角色与菜单关联表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysRoleMenuMapper extends BaseMapperPlus<SysRoleMenu> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,43 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 用户表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysUserMapper extends BaseMapperPlus<SysUser> { | ||||
|  | ||||
|     Page<SysUser> selectPageUserList(@Param("page") Page<SysUser> page, @Param("user") SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询用户列表 | ||||
|      * | ||||
|      * @param sysUser 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     public List<SysUser> selectUserList(SysUser sysUser); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名查询用户 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     public SysUser selectUserByUserName(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID查询用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     public SysUser selectUserById(Long userId); | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysUserPost; | ||||
|  | ||||
| /** | ||||
|  * 用户与岗位关联表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysUserPostMapper extends BaseMapperPlus<SysUserPost> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,13 @@ | ||||
| package com.ruoyi.system.mapper; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus; | ||||
| import com.ruoyi.system.domain.SysUserRole; | ||||
|  | ||||
| /** | ||||
|  * 用户与角色关联表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysUserRoleMapper extends BaseMapperPlus<SysUserRole> { | ||||
|  | ||||
| } | ||||
| @ -0,0 +1,89 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.system.domain.SysConfig; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 参数配置 服务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysConfigService extends IServicePlus<SysConfig> { | ||||
|  | ||||
|  | ||||
|     TableDataInfo<SysConfig> selectPageConfigList(SysConfig config); | ||||
|  | ||||
|     /** | ||||
|      * 查询参数配置信息 | ||||
|      * | ||||
|      * @param configId 参数配置ID | ||||
|      * @return 参数配置信息 | ||||
|      */ | ||||
|     public SysConfig selectConfigById(Long configId); | ||||
|  | ||||
|     /** | ||||
|      * 根据键名查询参数配置信息 | ||||
|      * | ||||
|      * @param configKey 参数键名 | ||||
|      * @return 参数键值 | ||||
|      */ | ||||
|     public String selectConfigByKey(String configKey); | ||||
|  | ||||
|     /** | ||||
|      * 查询参数配置列表 | ||||
|      * | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 参数配置集合 | ||||
|      */ | ||||
|     public List<SysConfig> selectConfigList(SysConfig config); | ||||
|  | ||||
|     /** | ||||
|      * 新增参数配置 | ||||
|      * | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertConfig(SysConfig config); | ||||
|  | ||||
|     /** | ||||
|      * 修改参数配置 | ||||
|      * | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateConfig(SysConfig config); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除参数信息 | ||||
|      * | ||||
|      * @param configIds 需要删除的参数ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public void deleteConfigByIds(Long[] configIds); | ||||
|  | ||||
|     /** | ||||
|      * 加载参数缓存数据 | ||||
|      */ | ||||
|     public void loadingConfigCache(); | ||||
|  | ||||
|     /** | ||||
|      * 清空参数缓存数据 | ||||
|      */ | ||||
|     public void clearConfigCache(); | ||||
|  | ||||
|     /** | ||||
|      * 重置参数缓存数据 | ||||
|      */ | ||||
|     public void resetConfigCache(); | ||||
|  | ||||
|     /** | ||||
|      * 校验参数键名是否唯一 | ||||
|      * | ||||
|      * @param config 参数信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkConfigKeyUnique(SysConfig config); | ||||
| } | ||||
| @ -0,0 +1,110 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.TreeSelect; | ||||
| import com.ruoyi.common.core.domain.entity.SysDept; | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 部门管理 服务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysDeptService extends IServicePlus<SysDept> { | ||||
|     /** | ||||
|      * 查询部门管理数据 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 部门信息集合 | ||||
|      */ | ||||
|     public List<SysDept> selectDeptList(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要树结构 | ||||
|      * | ||||
|      * @param depts 部门列表 | ||||
|      * @return 树结构列表 | ||||
|      */ | ||||
|     public List<SysDept> buildDeptTree(List<SysDept> depts); | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要下拉树结构 | ||||
|      * | ||||
|      * @param depts 部门列表 | ||||
|      * @return 下拉树结构列表 | ||||
|      */ | ||||
|     public List<TreeSelect> buildDeptTreeSelect(List<SysDept> depts); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询部门树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 选中部门列表 | ||||
|      */ | ||||
|     public List<Integer> selectDeptListByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 根据部门ID查询信息 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 部门信息 | ||||
|      */ | ||||
|     public SysDept selectDeptById(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 根据ID查询所有子部门(正常状态) | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 子部门数 | ||||
|      */ | ||||
|     public int selectNormalChildrenDeptById(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 是否存在部门子节点 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public boolean hasChildByDeptId(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 查询部门是否存在用户 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 true 存在 false 不存在 | ||||
|      */ | ||||
|     public boolean checkDeptExistUser(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 校验部门名称是否唯一 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkDeptNameUnique(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存部门信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertDept(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 修改保存部门信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDept(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 删除部门管理信息 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteDeptById(Long deptId); | ||||
| } | ||||
| @ -0,0 +1,67 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.entity.SysDictData; | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 字典 业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysDictDataService extends IServicePlus<SysDictData> { | ||||
|  | ||||
|  | ||||
|     TableDataInfo<SysDictData> selectPageDictDataList(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询字典数据 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     public List<SysDictData> selectDictDataList(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典键值查询字典数据信息 | ||||
|      * | ||||
|      * @param dictType  字典类型 | ||||
|      * @param dictValue 字典键值 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     public String selectDictLabel(String dictType, String dictValue); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典数据ID查询信息 | ||||
|      * | ||||
|      * @param dictCode 字典数据ID | ||||
|      * @return 字典数据 | ||||
|      */ | ||||
|     public SysDictData selectDictDataById(Long dictCode); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除字典数据信息 | ||||
|      * | ||||
|      * @param dictCodes 需要删除的字典数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public void deleteDictDataByIds(Long[] dictCodes); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存字典数据信息 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertDictData(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 修改保存字典数据信息 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDictData(SysDictData dictData); | ||||
| } | ||||
| @ -0,0 +1,105 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.entity.SysDictData; | ||||
| import com.ruoyi.common.core.domain.entity.SysDictType; | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 字典 业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysDictTypeService extends IServicePlus<SysDictType> { | ||||
|  | ||||
|  | ||||
|     TableDataInfo<SysDictType> selectPageDictTypeList(SysDictType dictType); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询字典类型 | ||||
|      * | ||||
|      * @param dictType 字典类型信息 | ||||
|      * @return 字典类型集合信息 | ||||
|      */ | ||||
|     public List<SysDictType> selectDictTypeList(SysDictType dictType); | ||||
|  | ||||
|     /** | ||||
|      * 根据所有字典类型 | ||||
|      * | ||||
|      * @return 字典类型集合信息 | ||||
|      */ | ||||
|     public List<SysDictType> selectDictTypeAll(); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型查询字典数据 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     public List<SysDictData> selectDictDataByType(String dictType); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型ID查询信息 | ||||
|      * | ||||
|      * @param dictId 字典类型ID | ||||
|      * @return 字典类型 | ||||
|      */ | ||||
|     public SysDictType selectDictTypeById(Long dictId); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型查询信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @return 字典类型 | ||||
|      */ | ||||
|     public SysDictType selectDictTypeByType(String dictType); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除字典信息 | ||||
|      * | ||||
|      * @param dictIds 需要删除的字典ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public void deleteDictTypeByIds(Long[] dictIds); | ||||
|  | ||||
|     /** | ||||
|      * 加载字典缓存数据 | ||||
|      */ | ||||
|     public void loadingDictCache(); | ||||
|  | ||||
|     /** | ||||
|      * 清空字典缓存数据 | ||||
|      */ | ||||
|     public void clearDictCache(); | ||||
|  | ||||
|     /** | ||||
|      * 重置字典缓存数据 | ||||
|      */ | ||||
|     public void resetDictCache(); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存字典类型信息 | ||||
|      * | ||||
|      * @param dictType 字典类型信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertDictType(SysDictType dictType); | ||||
|  | ||||
|     /** | ||||
|      * 修改保存字典类型信息 | ||||
|      * | ||||
|      * @param dictType 字典类型信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDictType(SysDictType dictType); | ||||
|  | ||||
|     /** | ||||
|      * 校验字典类型称是否唯一 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkDictTypeUnique(SysDictType dictType); | ||||
| } | ||||
| @ -0,0 +1,46 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.system.domain.SysLogininfor; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 系统访问日志情况信息 服务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysLogininforService extends IServicePlus<SysLogininfor> { | ||||
|  | ||||
|  | ||||
|     TableDataInfo<SysLogininfor> selectPageLogininforList(SysLogininfor logininfor); | ||||
|  | ||||
|     /** | ||||
|      * 新增系统登录日志 | ||||
|      * | ||||
|      * @param logininfor 访问日志对象 | ||||
|      */ | ||||
|     public void insertLogininfor(SysLogininfor logininfor); | ||||
|  | ||||
|     /** | ||||
|      * 查询系统登录日志集合 | ||||
|      * | ||||
|      * @param logininfor 访问日志对象 | ||||
|      * @return 登录记录集合 | ||||
|      */ | ||||
|     public List<SysLogininfor> selectLogininforList(SysLogininfor logininfor); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统登录日志 | ||||
|      * | ||||
|      * @param infoIds 需要删除的登录日志ID | ||||
|      * @return | ||||
|      */ | ||||
|     public int deleteLogininforByIds(Long[] infoIds); | ||||
|  | ||||
|     /** | ||||
|      * 清空系统登录日志 | ||||
|      */ | ||||
|     public void cleanLogininfor(); | ||||
| } | ||||
| @ -0,0 +1,137 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.TreeSelect; | ||||
| import com.ruoyi.common.core.domain.entity.SysMenu; | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.system.domain.vo.RouterVo; | ||||
|  | ||||
| import java.util.List; | ||||
| import java.util.Set; | ||||
|  | ||||
| /** | ||||
|  * 菜单 业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysMenuService extends IServicePlus<SysMenu> { | ||||
|     /** | ||||
|      * 根据用户查询系统菜单列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuList(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户查询系统菜单列表 | ||||
|      * | ||||
|      * @param menu   菜单信息 | ||||
|      * @param userId 用户ID | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuList(SysMenu menu, Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询权限 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public Set<String> selectMenuPermsByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询菜单树信息 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuTreeByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询菜单树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 选中菜单列表 | ||||
|      */ | ||||
|     public List<Integer> selectMenuListByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 构建前端路由所需要的菜单 | ||||
|      * | ||||
|      * @param menus 菜单列表 | ||||
|      * @return 路由列表 | ||||
|      */ | ||||
|     public List<RouterVo> buildMenus(List<SysMenu> menus); | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要树结构 | ||||
|      * | ||||
|      * @param menus 菜单列表 | ||||
|      * @return 树结构列表 | ||||
|      */ | ||||
|     public List<SysMenu> buildMenuTree(List<SysMenu> menus); | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要下拉树结构 | ||||
|      * | ||||
|      * @param menus 菜单列表 | ||||
|      * @return 下拉树结构列表 | ||||
|      */ | ||||
|     public List<TreeSelect> buildMenuTreeSelect(List<SysMenu> menus); | ||||
|  | ||||
|     /** | ||||
|      * 根据菜单ID查询信息 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 菜单信息 | ||||
|      */ | ||||
|     public SysMenu selectMenuById(Long menuId); | ||||
|  | ||||
|     /** | ||||
|      * 是否存在菜单子节点 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 true 存在 false 不存在 | ||||
|      */ | ||||
|     public boolean hasChildByMenuId(Long menuId); | ||||
|  | ||||
|     /** | ||||
|      * 查询菜单是否存在角色 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 true 存在 false 不存在 | ||||
|      */ | ||||
|     public boolean checkMenuExistRole(Long menuId); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存菜单信息 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertMenu(SysMenu menu); | ||||
|  | ||||
|     /** | ||||
|      * 修改保存菜单信息 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateMenu(SysMenu menu); | ||||
|  | ||||
|     /** | ||||
|      * 删除菜单管理信息 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteMenuById(Long menuId); | ||||
|  | ||||
|     /** | ||||
|      * 校验菜单名称是否唯一 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkMenuNameUnique(SysMenu menu); | ||||
| } | ||||
| @ -0,0 +1,66 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.system.domain.SysNotice; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 公告 服务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysNoticeService extends IServicePlus<SysNotice> { | ||||
|  | ||||
|  | ||||
|     TableDataInfo<SysNotice> selectPageNoticeList(SysNotice notice); | ||||
|  | ||||
|     /** | ||||
|      * 查询公告信息 | ||||
|      * | ||||
|      * @param noticeId 公告ID | ||||
|      * @return 公告信息 | ||||
|      */ | ||||
|     public SysNotice selectNoticeById(Long noticeId); | ||||
|  | ||||
|     /** | ||||
|      * 查询公告列表 | ||||
|      * | ||||
|      * @param notice 公告信息 | ||||
|      * @return 公告集合 | ||||
|      */ | ||||
|     public List<SysNotice> selectNoticeList(SysNotice notice); | ||||
|  | ||||
|     /** | ||||
|      * 新增公告 | ||||
|      * | ||||
|      * @param notice 公告信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertNotice(SysNotice notice); | ||||
|  | ||||
|     /** | ||||
|      * 修改公告 | ||||
|      * | ||||
|      * @param notice 公告信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateNotice(SysNotice notice); | ||||
|  | ||||
|     /** | ||||
|      * 删除公告信息 | ||||
|      * | ||||
|      * @param noticeId 公告ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteNoticeById(Long noticeId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除公告信息 | ||||
|      * | ||||
|      * @param noticeIds 需要删除的公告ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteNoticeByIds(Long[] noticeIds); | ||||
| } | ||||
| @ -0,0 +1,53 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.system.domain.SysOperLog; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 操作日志 服务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysOperLogService extends IServicePlus<SysOperLog> { | ||||
|  | ||||
|     TableDataInfo<SysOperLog> selectPageOperLogList(SysOperLog operLog); | ||||
|  | ||||
|     /** | ||||
|      * 新增操作日志 | ||||
|      * | ||||
|      * @param operLog 操作日志对象 | ||||
|      */ | ||||
|     public void insertOperlog(SysOperLog operLog); | ||||
|  | ||||
|     /** | ||||
|      * 查询系统操作日志集合 | ||||
|      * | ||||
|      * @param operLog 操作日志对象 | ||||
|      * @return 操作日志集合 | ||||
|      */ | ||||
|     public List<SysOperLog> selectOperLogList(SysOperLog operLog); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统操作日志 | ||||
|      * | ||||
|      * @param operIds 需要删除的操作日志ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteOperLogByIds(Long[] operIds); | ||||
|  | ||||
|     /** | ||||
|      * 查询操作日志详细 | ||||
|      * | ||||
|      * @param operId 操作ID | ||||
|      * @return 操作日志对象 | ||||
|      */ | ||||
|     public SysOperLog selectOperLogById(Long operId); | ||||
|  | ||||
|     /** | ||||
|      * 清空操作日志 | ||||
|      */ | ||||
|     public void cleanOperLog(); | ||||
| } | ||||
| @ -0,0 +1,106 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.system.domain.SysPost; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 岗位信息 服务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysPostService extends IServicePlus<SysPost> { | ||||
|  | ||||
|  | ||||
|     TableDataInfo<SysPost> selectPagePostList(SysPost post); | ||||
|  | ||||
|     /** | ||||
|      * 查询岗位信息集合 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 岗位列表 | ||||
|      */ | ||||
|     public List<SysPost> selectPostList(SysPost post); | ||||
|  | ||||
|     /** | ||||
|      * 查询所有岗位 | ||||
|      * | ||||
|      * @return 岗位列表 | ||||
|      */ | ||||
|     public List<SysPost> selectPostAll(); | ||||
|  | ||||
|     /** | ||||
|      * 通过岗位ID查询岗位信息 | ||||
|      * | ||||
|      * @param postId 岗位ID | ||||
|      * @return 角色对象信息 | ||||
|      */ | ||||
|     public SysPost selectPostById(Long postId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取岗位选择框列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中岗位ID列表 | ||||
|      */ | ||||
|     public List<Integer> selectPostListByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 校验岗位名称 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkPostNameUnique(SysPost post); | ||||
|  | ||||
|     /** | ||||
|      * 校验岗位编码 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkPostCodeUnique(SysPost post); | ||||
|  | ||||
|     /** | ||||
|      * 通过岗位ID查询岗位使用数量 | ||||
|      * | ||||
|      * @param postId 岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int countUserPostById(Long postId); | ||||
|  | ||||
|     /** | ||||
|      * 删除岗位信息 | ||||
|      * | ||||
|      * @param postId 岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deletePostById(Long postId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除岗位信息 | ||||
|      * | ||||
|      * @param postIds 需要删除的岗位ID | ||||
|      * @return 结果 | ||||
|      * @throws Exception 异常 | ||||
|      */ | ||||
|     public int deletePostByIds(Long[] postIds); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存岗位信息 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertPost(SysPost post); | ||||
|  | ||||
|     /** | ||||
|      * 修改保存岗位信息 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updatePost(SysPost post); | ||||
| } | ||||
| @ -0,0 +1,137 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
|  | ||||
| import java.util.List; | ||||
| import java.util.Set; | ||||
|  | ||||
| /** | ||||
|  * 角色业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysRoleService extends IServicePlus<SysRole> { | ||||
|  | ||||
|  | ||||
|     TableDataInfo<SysRole> selectPageRoleList(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询角色数据 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 角色数据集合信息 | ||||
|      */ | ||||
|     public List<SysRole> selectRoleList(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询角色 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public Set<String> selectRolePermissionByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 查询所有角色 | ||||
|      * | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     public List<SysRole> selectRoleAll(); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取角色选择框列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中角色ID列表 | ||||
|      */ | ||||
|     public List<Integer> selectRoleListByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID查询角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 角色对象信息 | ||||
|      */ | ||||
|     public SysRole selectRoleById(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 校验角色名称是否唯一 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkRoleNameUnique(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 校验角色权限是否唯一 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkRoleKeyUnique(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 校验角色是否允许操作 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      */ | ||||
|     public void checkRoleAllowed(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID查询角色使用数量 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int countUserRoleByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存角色信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertRole(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 修改保存角色信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateRole(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 修改角色状态 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateRoleStatus(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 修改数据权限信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int authDataScope(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID删除角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteRoleById(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除角色信息 | ||||
|      * | ||||
|      * @param roleIds 需要删除的角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteRoleByIds(Long[] roleIds); | ||||
| } | ||||
| @ -0,0 +1,47 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.model.LoginUser; | ||||
| import com.ruoyi.system.domain.SysUserOnline; | ||||
|  | ||||
| /** | ||||
|  * 在线用户 服务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysUserOnlineService { | ||||
|     /** | ||||
|      * 通过登录地址查询信息 | ||||
|      * | ||||
|      * @param ipaddr 登录地址 | ||||
|      * @param user   用户信息 | ||||
|      * @return 在线用户信息 | ||||
|      */ | ||||
|     public SysUserOnline selectOnlineByIpaddr(String ipaddr, LoginUser user); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名称查询信息 | ||||
|      * | ||||
|      * @param userName 用户名称 | ||||
|      * @param user     用户信息 | ||||
|      * @return 在线用户信息 | ||||
|      */ | ||||
|     public SysUserOnline selectOnlineByUserName(String userName, LoginUser user); | ||||
|  | ||||
|     /** | ||||
|      * 通过登录地址/用户名称查询信息 | ||||
|      * | ||||
|      * @param ipaddr   登录地址 | ||||
|      * @param userName 用户名称 | ||||
|      * @param user     用户信息 | ||||
|      * @return 在线用户信息 | ||||
|      */ | ||||
|     public SysUserOnline selectOnlineByInfo(String ipaddr, String userName, LoginUser user); | ||||
|  | ||||
|     /** | ||||
|      * 设置在线用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 在线用户 | ||||
|      */ | ||||
|     public SysUserOnline loginUserToUserOnline(LoginUser user); | ||||
| } | ||||
| @ -0,0 +1,173 @@ | ||||
| package com.ruoyi.system.service; | ||||
|  | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.mybatisplus.core.IServicePlus; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 用户 业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysUserService extends IServicePlus<SysUser> { | ||||
|  | ||||
|  | ||||
|     TableDataInfo<SysUser> selectPageUserList(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询用户列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     public List<SysUser> selectUserList(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名查询用户 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     public SysUser selectUserByUserName(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID查询用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     public SysUser selectUserById(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询用户所属角色组 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String selectUserRoleGroup(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询用户所属岗位组 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String selectUserPostGroup(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 校验用户名称是否唯一 | ||||
|      * | ||||
|      * @param userName 用户名称 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkUserNameUnique(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 校验手机号码是否唯一 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkPhoneUnique(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 校验email是否唯一 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkEmailUnique(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 校验用户是否允许操作 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      */ | ||||
|     public void checkUserAllowed(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 新增用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertUser(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 修改用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateUser(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 修改用户状态 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateUserStatus(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 修改用户基本信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateUserProfile(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 修改用户头像 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @param avatar   头像地址 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public boolean updateUserAvatar(String userName, String avatar); | ||||
|  | ||||
|     /** | ||||
|      * 重置用户密码 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int resetPwd(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 重置用户密码 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @param password 密码 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int resetUserPwd(String userName, String password); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID删除用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserById(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除用户信息 | ||||
|      * | ||||
|      * @param userIds 需要删除的用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserByIds(Long[] userIds); | ||||
|  | ||||
|     /** | ||||
|      * 导入用户数据 | ||||
|      * | ||||
|      * @param userList        用户数据列表 | ||||
|      * @param isUpdateSupport 是否更新支持,如果已存在,则进行更新数据 | ||||
|      * @param operName        操作用户 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String importUser(List<SysUser> userList, Boolean isUpdateSupport, String operName); | ||||
| } | ||||
| @ -0,0 +1,220 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.convert.Convert; | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.annotation.DataSource; | ||||
| import com.ruoyi.common.constant.Constants; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.core.redis.RedisCache; | ||||
| import com.ruoyi.common.enums.DataSourceType; | ||||
| import com.ruoyi.common.exception.CustomException; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.system.domain.SysConfig; | ||||
| import com.ruoyi.system.mapper.SysConfigMapper; | ||||
| import com.ruoyi.system.service.ISysConfigService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import javax.annotation.PostConstruct; | ||||
| import java.util.Arrays; | ||||
| import java.util.Collection; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 参数配置 服务层实现 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysConfigServiceImpl extends ServicePlusImpl<SysConfigMapper, SysConfig> implements ISysConfigService { | ||||
|  | ||||
| 	@Autowired | ||||
| 	private RedisCache redisCache; | ||||
|  | ||||
| 	/** | ||||
| 	 * 项目启动时,初始化参数到缓存 | ||||
| 	 */ | ||||
| 	@PostConstruct | ||||
| 	public void init() { | ||||
| 		loadingConfigCache(); | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public TableDataInfo<SysConfig> selectPageConfigList(SysConfig config) { | ||||
| 		Map<String, Object> params = config.getParams(); | ||||
| 		LambdaQueryWrapper<SysConfig> lqw = new LambdaQueryWrapper<SysConfig>() | ||||
| 			.like(StrUtil.isNotBlank(config.getConfigName()), SysConfig::getConfigName, config.getConfigName()) | ||||
| 			.eq(StrUtil.isNotBlank(config.getConfigType()), SysConfig::getConfigType, config.getConfigType()) | ||||
| 			.like(StrUtil.isNotBlank(config.getConfigKey()), SysConfig::getConfigKey, config.getConfigKey()) | ||||
| 			.apply(Validator.isNotEmpty(params.get("beginTime")), | ||||
| 				"date_format(create_time,'%y%m%d') >= date_format({0},'%y%m%d')", | ||||
| 				params.get("beginTime")) | ||||
| 			.apply(Validator.isNotEmpty(params.get("endTime")), | ||||
| 				"date_format(create_time,'%y%m%d') <= date_format({0},'%y%m%d')", | ||||
| 				params.get("endTime")); | ||||
| 		return PageUtils.buildDataInfo(page(PageUtils.buildPage(), lqw)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 查询参数配置信息 | ||||
| 	 * | ||||
| 	 * @param configId 参数配置ID | ||||
| 	 * @return 参数配置信息 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	@DataSource(DataSourceType.MASTER) | ||||
| 	public SysConfig selectConfigById(Long configId) { | ||||
| 		return baseMapper.selectById(configId); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据键名查询参数配置信息 | ||||
| 	 * | ||||
| 	 * @param configKey 参数key | ||||
| 	 * @return 参数键值 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public String selectConfigByKey(String configKey) { | ||||
| 		String configValue = Convert.toStr(redisCache.getCacheObject(getCacheKey(configKey))); | ||||
| 		if (Validator.isNotEmpty(configValue)) { | ||||
| 			return configValue; | ||||
| 		} | ||||
| 		SysConfig retConfig = baseMapper.selectOne(new LambdaQueryWrapper<SysConfig>() | ||||
| 			.eq(SysConfig::getConfigKey, configKey)); | ||||
| 		if (Validator.isNotNull(retConfig)) { | ||||
| 			redisCache.setCacheObject(getCacheKey(configKey), retConfig.getConfigValue()); | ||||
| 			return retConfig.getConfigValue(); | ||||
| 		} | ||||
| 		return StrUtil.EMPTY; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 查询参数配置列表 | ||||
| 	 * | ||||
| 	 * @param config 参数配置信息 | ||||
| 	 * @return 参数配置集合 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public List<SysConfig> selectConfigList(SysConfig config) { | ||||
| 		Map<String, Object> params = config.getParams(); | ||||
| 		LambdaQueryWrapper<SysConfig> lqw = new LambdaQueryWrapper<SysConfig>() | ||||
| 			.like(StrUtil.isNotBlank(config.getConfigName()), SysConfig::getConfigName, config.getConfigName()) | ||||
| 			.eq(StrUtil.isNotBlank(config.getConfigType()), SysConfig::getConfigType, config.getConfigType()) | ||||
| 			.like(StrUtil.isNotBlank(config.getConfigKey()), SysConfig::getConfigKey, config.getConfigKey()) | ||||
| 			.apply(Validator.isNotEmpty(params.get("beginTime")), | ||||
| 				"date_format(create_time,'%y%m%d') >= date_format({0},'%y%m%d')", | ||||
| 				params.get("beginTime")) | ||||
| 			.apply(Validator.isNotEmpty(params.get("endTime")), | ||||
| 				"date_format(create_time,'%y%m%d') <= date_format({0},'%y%m%d')", | ||||
| 				params.get("endTime")); | ||||
| 		return baseMapper.selectList(lqw); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 新增参数配置 | ||||
| 	 * | ||||
| 	 * @param config 参数配置信息 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public int insertConfig(SysConfig config) { | ||||
| 		int row = baseMapper.insert(config); | ||||
| 		if (row > 0) { | ||||
| 			redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); | ||||
| 		} | ||||
| 		return row; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 修改参数配置 | ||||
| 	 * | ||||
| 	 * @param config 参数配置信息 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public int updateConfig(SysConfig config) { | ||||
| 		int row = baseMapper.updateById(config); | ||||
| 		if (row > 0) { | ||||
| 			redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); | ||||
| 		} | ||||
| 		return row; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 批量删除参数信息 | ||||
| 	 * | ||||
| 	 * @param configIds 需要删除的参数ID | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void deleteConfigByIds(Long[] configIds) { | ||||
| 		for (Long configId : configIds) { | ||||
| 			SysConfig config = selectConfigById(configId); | ||||
| 			if (StrUtil.equals(UserConstants.YES, config.getConfigType())) { | ||||
| 				throw new CustomException(String.format("内置参数【%1$s】不能删除 ", config.getConfigKey())); | ||||
| 			} | ||||
| 			redisCache.deleteObject(getCacheKey(config.getConfigKey())); | ||||
| 		} | ||||
| 		baseMapper.deleteBatchIds(Arrays.asList(configIds)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 加载参数缓存数据 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void loadingConfigCache() { | ||||
| 		List<SysConfig> configsList = selectConfigList(new SysConfig()); | ||||
| 		for (SysConfig config : configsList) { | ||||
| 			redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 清空参数缓存数据 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void clearConfigCache() { | ||||
| 		Collection<String> keys = redisCache.keys(Constants.SYS_CONFIG_KEY + "*"); | ||||
| 		redisCache.deleteObject(keys); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 重置参数缓存数据 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void resetConfigCache() { | ||||
| 		clearConfigCache(); | ||||
| 		loadingConfigCache(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 校验参数键名是否唯一 | ||||
| 	 * | ||||
| 	 * @param config 参数配置信息 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public String checkConfigKeyUnique(SysConfig config) { | ||||
| 		Long configId = Validator.isNull(config.getConfigId()) ? -1L : config.getConfigId(); | ||||
| 		SysConfig info = baseMapper.selectOne(new LambdaQueryWrapper<SysConfig>().eq(SysConfig::getConfigKey, config.getConfigKey())); | ||||
| 		if (Validator.isNotNull(info) && info.getConfigId().longValue() != configId.longValue()) { | ||||
| 			return UserConstants.NOT_UNIQUE; | ||||
| 		} | ||||
| 		return UserConstants.UNIQUE; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 设置cache key | ||||
| 	 * | ||||
| 	 * @param configKey 参数键 | ||||
| 	 * @return 缓存键key | ||||
| 	 */ | ||||
| 	private String getCacheKey(String configKey) { | ||||
| 		return Constants.SYS_CONFIG_KEY + configKey; | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,289 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.convert.Convert; | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | ||||
| import com.ruoyi.common.annotation.DataScope; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.domain.TreeSelect; | ||||
| import com.ruoyi.common.core.domain.entity.SysDept; | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.exception.CustomException; | ||||
| import com.ruoyi.system.mapper.SysDeptMapper; | ||||
| import com.ruoyi.system.mapper.SysRoleMapper; | ||||
| import com.ruoyi.system.mapper.SysUserMapper; | ||||
| import com.ruoyi.system.service.ISysDeptService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.Arrays; | ||||
| import java.util.List; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| /** | ||||
|  * 部门管理 服务实现 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysDeptServiceImpl extends ServicePlusImpl<SysDeptMapper, SysDept> implements ISysDeptService { | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleMapper roleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserMapper userMapper; | ||||
|  | ||||
|     /** | ||||
|      * 查询部门管理数据 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 部门信息集合 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d") | ||||
|     public List<SysDept> selectDeptList(SysDept dept) { | ||||
|         return baseMapper.selectDeptList(dept); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要树结构 | ||||
|      * | ||||
|      * @param depts 部门列表 | ||||
|      * @return 树结构列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysDept> buildDeptTree(List<SysDept> depts) { | ||||
|         List<SysDept> returnList = new ArrayList<SysDept>(); | ||||
|         List<Long> tempList = new ArrayList<Long>(); | ||||
|         for (SysDept dept : depts) { | ||||
|             tempList.add(dept.getDeptId()); | ||||
|         } | ||||
| 		for (SysDept dept : depts) { | ||||
| 			// 如果是顶级节点, 遍历该父节点的所有子节点 | ||||
| 			if (!tempList.contains(dept.getParentId())) { | ||||
| 				recursionFn(depts, dept); | ||||
| 				returnList.add(dept); | ||||
| 			} | ||||
| 		} | ||||
|         if (returnList.isEmpty()) { | ||||
|             returnList = depts; | ||||
|         } | ||||
|         return returnList; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要下拉树结构 | ||||
|      * | ||||
|      * @param depts 部门列表 | ||||
|      * @return 下拉树结构列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<TreeSelect> buildDeptTreeSelect(List<SysDept> depts) { | ||||
|         List<SysDept> deptTrees = buildDeptTree(depts); | ||||
|         return deptTrees.stream().map(TreeSelect::new).collect(Collectors.toList()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询部门树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 选中部门列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<Integer> selectDeptListByRoleId(Long roleId) { | ||||
|         SysRole role = roleMapper.selectById(roleId); | ||||
|         return baseMapper.selectDeptListByRoleId(roleId, role.isDeptCheckStrictly()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据部门ID查询信息 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 部门信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysDept selectDeptById(Long deptId) { | ||||
|         return getById(deptId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据ID查询所有子部门(正常状态) | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 子部门数 | ||||
|      */ | ||||
|     @Override | ||||
|     public int selectNormalChildrenDeptById(Long deptId) { | ||||
|         return count(new LambdaQueryWrapper<SysDept>() | ||||
|                 .eq(SysDept::getStatus, 0) | ||||
|                 .apply("find_in_set({0}, ancestors)", deptId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否存在子节点 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean hasChildByDeptId(Long deptId) { | ||||
|         int result = count(new LambdaQueryWrapper<SysDept>() | ||||
|                 .eq(SysDept::getParentId, deptId) | ||||
|                 .last("limit 1")); | ||||
|         return result > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询部门是否存在用户 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 true 存在 false 不存在 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean checkDeptExistUser(Long deptId) { | ||||
|         int result = userMapper.selectCount(new LambdaQueryWrapper<SysUser>() | ||||
|                 .eq(SysUser::getDeptId, deptId)); | ||||
|         return result > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验部门名称是否唯一 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkDeptNameUnique(SysDept dept) { | ||||
|         Long deptId = Validator.isNull(dept.getDeptId()) ? -1L : dept.getDeptId(); | ||||
|         SysDept info = getOne(new LambdaQueryWrapper<SysDept>() | ||||
|                 .eq(SysDept::getDeptName, dept.getDeptName()) | ||||
|                 .eq(SysDept::getParentId, dept.getParentId()) | ||||
|                 .last("limit 1")); | ||||
|         if (Validator.isNotNull(info) && info.getDeptId().longValue() != deptId.longValue()) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存部门信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertDept(SysDept dept) { | ||||
|         SysDept info = getById(dept.getParentId()); | ||||
|         // 如果父节点不为正常状态,则不允许新增子节点 | ||||
|         if (!UserConstants.DEPT_NORMAL.equals(info.getStatus())) { | ||||
|             throw new CustomException("部门停用,不允许新增"); | ||||
|         } | ||||
|         dept.setAncestors(info.getAncestors() + "," + dept.getParentId()); | ||||
|         return baseMapper.insert(dept); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存部门信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateDept(SysDept dept) { | ||||
|         SysDept newParentDept = getById(dept.getParentId()); | ||||
|         SysDept oldDept = getById(dept.getDeptId()); | ||||
|         if (Validator.isNotNull(newParentDept) && Validator.isNotNull(oldDept)) { | ||||
|             String newAncestors = newParentDept.getAncestors() + "," + newParentDept.getDeptId(); | ||||
|             String oldAncestors = oldDept.getAncestors(); | ||||
|             dept.setAncestors(newAncestors); | ||||
|             updateDeptChildren(dept.getDeptId(), newAncestors, oldAncestors); | ||||
|         } | ||||
|         int result = baseMapper.updateById(dept); | ||||
|         if (UserConstants.DEPT_NORMAL.equals(dept.getStatus())) { | ||||
|             // 如果该部门是启用状态,则启用该部门的所有上级部门 | ||||
|             updateParentDeptStatusNormal(dept); | ||||
|         } | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改该部门的父级部门状态 | ||||
|      * | ||||
|      * @param dept 当前部门 | ||||
|      */ | ||||
|     private void updateParentDeptStatusNormal(SysDept dept) { | ||||
| 		String ancestors = dept.getAncestors(); | ||||
| 		Long[] deptIds = Convert.toLongArray(ancestors); | ||||
|         update(null, new LambdaUpdateWrapper<SysDept>() | ||||
|                 .set(SysDept::getStatus, "0") | ||||
|                 .in(SysDept::getDeptId, Arrays.asList(deptIds))); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改子元素关系 | ||||
|      * | ||||
|      * @param deptId 被修改的部门ID | ||||
|      * @param newAncestors 新的父ID集合 | ||||
|      * @param oldAncestors 旧的父ID集合 | ||||
|      */ | ||||
|     public void updateDeptChildren(Long deptId, String newAncestors, String oldAncestors) { | ||||
|         List<SysDept> children = list(new LambdaQueryWrapper<SysDept>() | ||||
|                 .apply("find_in_set({0},ancestors)",deptId)); | ||||
|         for (SysDept child : children) { | ||||
|             child.setAncestors(child.getAncestors().replaceFirst(oldAncestors, newAncestors)); | ||||
|         } | ||||
|         if (children.size() > 0) { | ||||
|             baseMapper.updateDeptChildren(children); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除部门管理信息 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteDeptById(Long deptId) { | ||||
|         return baseMapper.deleteById(deptId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 递归列表 | ||||
|      */ | ||||
|     private void recursionFn(List<SysDept> list, SysDept t) { | ||||
|         // 得到子节点列表 | ||||
|         List<SysDept> childList = getChildList(list, t); | ||||
|         t.setChildren(childList); | ||||
|         for (SysDept tChild : childList) { | ||||
|             if (hasChild(list, tChild)) { | ||||
|                 recursionFn(list, tChild); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 得到子节点列表 | ||||
|      */ | ||||
|     private List<SysDept> getChildList(List<SysDept> list, SysDept t) { | ||||
|         List<SysDept> tlist = new ArrayList<SysDept>(); | ||||
| 		for (SysDept n : list) { | ||||
| 			if (Validator.isNotNull(n.getParentId()) && n.getParentId().longValue() == t.getDeptId().longValue()) { | ||||
| 				tlist.add(n); | ||||
| 			} | ||||
| 		} | ||||
|         return tlist; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 判断是否有子节点 | ||||
|      */ | ||||
|     private boolean hasChild(List<SysDept> list, SysDept t) { | ||||
|         return getChildList(list, t).size() > 0; | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,124 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.core.domain.entity.SysDictData; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.utils.DictUtils; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.system.mapper.SysDictDataMapper; | ||||
| import com.ruoyi.system.service.ISysDictDataService; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.util.Arrays; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 字典 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysDictDataServiceImpl extends ServicePlusImpl<SysDictDataMapper, SysDictData> implements ISysDictDataService { | ||||
|  | ||||
| 	@Override | ||||
| 	public TableDataInfo<SysDictData> selectPageDictDataList(SysDictData dictData) { | ||||
| 		LambdaQueryWrapper<SysDictData> lqw = new LambdaQueryWrapper<SysDictData>() | ||||
| 			.eq(StrUtil.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType()) | ||||
| 			.like(StrUtil.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel()) | ||||
| 			.eq(StrUtil.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus()) | ||||
| 			.orderByAsc(SysDictData::getDictSort); | ||||
| 		return PageUtils.buildDataInfo(page(PageUtils.buildPage(), lqw)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据条件分页查询字典数据 | ||||
| 	 * | ||||
| 	 * @param dictData 字典数据信息 | ||||
| 	 * @return 字典数据集合信息 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public List<SysDictData> selectDictDataList(SysDictData dictData) { | ||||
| 		return list(new LambdaQueryWrapper<SysDictData>() | ||||
| 			.eq(StrUtil.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType()) | ||||
| 			.like(StrUtil.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel()) | ||||
| 			.eq(StrUtil.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus()) | ||||
| 			.orderByAsc(SysDictData::getDictSort)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据字典类型和字典键值查询字典数据信息 | ||||
| 	 * | ||||
| 	 * @param dictType  字典类型 | ||||
| 	 * @param dictValue 字典键值 | ||||
| 	 * @return 字典标签 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public String selectDictLabel(String dictType, String dictValue) { | ||||
| 		return getOne(new LambdaQueryWrapper<SysDictData>() | ||||
| 			.select(SysDictData::getDictLabel) | ||||
| 			.eq(SysDictData::getDictType, dictType) | ||||
| 			.eq(SysDictData::getDictValue, dictValue)) | ||||
| 			.getDictLabel(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据字典数据ID查询信息 | ||||
| 	 * | ||||
| 	 * @param dictCode 字典数据ID | ||||
| 	 * @return 字典数据 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public SysDictData selectDictDataById(Long dictCode) { | ||||
| 		return getById(dictCode); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 批量删除字典数据信息 | ||||
| 	 * | ||||
| 	 * @param dictCodes 需要删除的字典数据ID | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void deleteDictDataByIds(Long[] dictCodes) { | ||||
| 		for (Long dictCode : dictCodes) { | ||||
| 			SysDictData data = selectDictDataById(dictCode); | ||||
| 			List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType()); | ||||
| 			DictUtils.setDictCache(data.getDictType(), dictDatas); | ||||
| 		} | ||||
| 		baseMapper.deleteBatchIds(Arrays.asList(dictCodes)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 新增保存字典数据信息 | ||||
| 	 * | ||||
| 	 * @param data 字典数据信息 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public int insertDictData(SysDictData data) { | ||||
| 		int row = baseMapper.insert(data); | ||||
| 		if (row > 0) { | ||||
| 			List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType()); | ||||
| 			DictUtils.setDictCache(data.getDictType(), dictDatas); | ||||
| 		} | ||||
| 		return row; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 修改保存字典数据信息 | ||||
| 	 * | ||||
| 	 * @param data 字典数据信息 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public int updateDictData(SysDictData data) { | ||||
| 		int row = baseMapper.updateById(data); | ||||
| 		if (row > 0) { | ||||
| 			List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType()); | ||||
| 			DictUtils.setDictCache(data.getDictType(), dictDatas); | ||||
| 		} | ||||
| 		return row; | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,238 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.collection.CollUtil; | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.domain.entity.SysDictData; | ||||
| import com.ruoyi.common.core.domain.entity.SysDictType; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.exception.CustomException; | ||||
| import com.ruoyi.common.utils.DictUtils; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.system.mapper.SysDictDataMapper; | ||||
| import com.ruoyi.system.mapper.SysDictTypeMapper; | ||||
| import com.ruoyi.system.service.ISysDictTypeService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
|  | ||||
| import javax.annotation.PostConstruct; | ||||
| import javax.annotation.Resource; | ||||
| import java.util.Arrays; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 字典 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysDictTypeServiceImpl extends ServicePlusImpl<SysDictTypeMapper, SysDictType> implements ISysDictTypeService { | ||||
|  | ||||
| 	@Resource | ||||
| 	private SysDictDataMapper dictDataMapper; | ||||
|  | ||||
| 	/** | ||||
| 	 * 项目启动时,初始化字典到缓存 | ||||
| 	 */ | ||||
| 	@PostConstruct | ||||
| 	public void init() { | ||||
| 		loadingDictCache(); | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public TableDataInfo<SysDictType> selectPageDictTypeList(SysDictType dictType) { | ||||
| 		Map<String, Object> params = dictType.getParams(); | ||||
| 		LambdaQueryWrapper<SysDictType> lqw = new LambdaQueryWrapper<SysDictType>() | ||||
| 			.like(StrUtil.isNotBlank(dictType.getDictName()), SysDictType::getDictName, dictType.getDictName()) | ||||
| 			.eq(StrUtil.isNotBlank(dictType.getStatus()), SysDictType::getStatus, dictType.getStatus()) | ||||
| 			.like(StrUtil.isNotBlank(dictType.getDictType()), SysDictType::getDictType, dictType.getDictType()) | ||||
| 			.apply(Validator.isNotEmpty(params.get("beginTime")), | ||||
| 				"date_format(create_time,'%y%m%d') >= date_format({0},'%y%m%d')", | ||||
| 				params.get("beginTime")) | ||||
| 			.apply(Validator.isNotEmpty(params.get("endTime")), | ||||
| 				"date_format(create_time,'%y%m%d') <= date_format({0},'%y%m%d')", | ||||
| 				params.get("endTime")); | ||||
| 		return PageUtils.buildDataInfo(page(PageUtils.buildPage(), lqw)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据条件分页查询字典类型 | ||||
| 	 * | ||||
| 	 * @param dictType 字典类型信息 | ||||
| 	 * @return 字典类型集合信息 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public List<SysDictType> selectDictTypeList(SysDictType dictType) { | ||||
| 		Map<String, Object> params = dictType.getParams(); | ||||
| 		return list(new LambdaQueryWrapper<SysDictType>() | ||||
| 			.like(StrUtil.isNotBlank(dictType.getDictName()), SysDictType::getDictName, dictType.getDictName()) | ||||
| 			.eq(StrUtil.isNotBlank(dictType.getStatus()), SysDictType::getStatus, dictType.getStatus()) | ||||
| 			.like(StrUtil.isNotBlank(dictType.getDictType()), SysDictType::getDictType, dictType.getDictType()) | ||||
| 			.apply(Validator.isNotEmpty(params.get("beginTime")), | ||||
| 				"date_format(create_time,'%y%m%d') >= date_format({0},'%y%m%d')", | ||||
| 				params.get("beginTime")) | ||||
| 			.apply(Validator.isNotEmpty(params.get("endTime")), | ||||
| 				"date_format(create_time,'%y%m%d') <= date_format({0},'%y%m%d')", | ||||
| 				params.get("endTime"))); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据所有字典类型 | ||||
| 	 * | ||||
| 	 * @return 字典类型集合信息 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public List<SysDictType> selectDictTypeAll() { | ||||
| 		return list(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据字典类型查询字典数据 | ||||
| 	 * | ||||
| 	 * @param dictType 字典类型 | ||||
| 	 * @return 字典数据集合信息 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public List<SysDictData> selectDictDataByType(String dictType) { | ||||
| 		List<SysDictData> dictDatas = DictUtils.getDictCache(dictType); | ||||
| 		if (CollUtil.isNotEmpty(dictDatas)) { | ||||
| 			return dictDatas; | ||||
| 		} | ||||
| 		dictDatas = dictDataMapper.selectDictDataByType(dictType); | ||||
| 		if (CollUtil.isNotEmpty(dictDatas)) { | ||||
| 			DictUtils.setDictCache(dictType, dictDatas); | ||||
| 			return dictDatas; | ||||
| 		} | ||||
| 		return null; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据字典类型ID查询信息 | ||||
| 	 * | ||||
| 	 * @param dictId 字典类型ID | ||||
| 	 * @return 字典类型 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public SysDictType selectDictTypeById(Long dictId) { | ||||
| 		return getById(dictId); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 根据字典类型查询信息 | ||||
| 	 * | ||||
| 	 * @param dictType 字典类型 | ||||
| 	 * @return 字典类型 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public SysDictType selectDictTypeByType(String dictType) { | ||||
| 		return getOne(new LambdaQueryWrapper<SysDictType>().eq(SysDictType::getDictType, dictType)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 批量删除字典类型信息 | ||||
| 	 * | ||||
| 	 * @param dictIds 需要删除的字典ID | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void deleteDictTypeByIds(Long[] dictIds) { | ||||
| 		for (Long dictId : dictIds) { | ||||
| 			SysDictType dictType = selectDictTypeById(dictId); | ||||
| 			if (dictDataMapper.selectCount(new LambdaQueryWrapper<SysDictData>() | ||||
| 				.eq(SysDictData::getDictType, dictType.getDictType())) > 0) { | ||||
| 				throw new CustomException(String.format("%1$s已分配,不能删除", dictType.getDictName())); | ||||
| 			} | ||||
| 			DictUtils.removeDictCache(dictType.getDictType()); | ||||
| 		} | ||||
| 		baseMapper.deleteBatchIds(Arrays.asList(dictIds)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 加载字典缓存数据 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void loadingDictCache() { | ||||
| 		List<SysDictType> dictTypeList = list(); | ||||
| 		for (SysDictType dictType : dictTypeList) { | ||||
| 			List<SysDictData> dictDatas = dictDataMapper.selectDictDataByType(dictType.getDictType()); | ||||
| 			DictUtils.setDictCache(dictType.getDictType(), dictDatas); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 清空字典缓存数据 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void clearDictCache() { | ||||
| 		DictUtils.clearDictCache(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 重置字典缓存数据 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public void resetDictCache() { | ||||
| 		clearDictCache(); | ||||
| 		loadingDictCache(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 新增保存字典类型信息 | ||||
| 	 * | ||||
| 	 * @param dict 字典类型信息 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public int insertDictType(SysDictType dict) { | ||||
| 		int row = baseMapper.insert(dict); | ||||
| 		if (row > 0) { | ||||
| 			DictUtils.setDictCache(dict.getDictType(), null); | ||||
| 		} | ||||
| 		return row; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 修改保存字典类型信息 | ||||
| 	 * | ||||
| 	 * @param dict 字典类型信息 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	@Transactional | ||||
| 	public int updateDictType(SysDictType dict) { | ||||
| 		SysDictType oldDict = getById(dict.getDictId()); | ||||
| 		dictDataMapper.update(null, new LambdaUpdateWrapper<SysDictData>() | ||||
| 			.set(SysDictData::getDictType, dict.getDictType()) | ||||
| 			.eq(SysDictData::getDictType, oldDict.getDictType())); | ||||
| 		int row = baseMapper.updateById(dict); | ||||
| 		if (row > 0) { | ||||
| 			List<SysDictData> dictDatas = dictDataMapper.selectDictDataByType(dict.getDictType()); | ||||
| 			DictUtils.setDictCache(dict.getDictType(), dictDatas); | ||||
| 		} | ||||
| 		return row; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 校验字典类型称是否唯一 | ||||
| 	 * | ||||
| 	 * @param dict 字典类型 | ||||
| 	 * @return 结果 | ||||
| 	 */ | ||||
| 	@Override | ||||
| 	public String checkDictTypeUnique(SysDictType dict) { | ||||
| 		Long dictId = Validator.isNull(dict.getDictId()) ? -1L : dict.getDictId(); | ||||
| 		SysDictType dictType = getOne(new LambdaQueryWrapper<SysDictType>() | ||||
| 			.eq(SysDictType::getDictType, dict.getDictType()) | ||||
| 			.last("limit 1")); | ||||
| 		if (Validator.isNotNull(dictType) && dictType.getDictId().longValue() != dictId.longValue()) { | ||||
| 			return UserConstants.NOT_UNIQUE; | ||||
| 		} | ||||
| 		return UserConstants.UNIQUE; | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,94 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.system.domain.SysLogininfor; | ||||
| import com.ruoyi.system.mapper.SysLogininforMapper; | ||||
| import com.ruoyi.system.service.ISysLogininforService; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.util.Arrays; | ||||
| import java.util.Date; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 系统访问日志情况信息 服务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysLogininforServiceImpl extends ServicePlusImpl<SysLogininforMapper, SysLogininfor> implements ISysLogininforService { | ||||
|  | ||||
|     @Override | ||||
|     public TableDataInfo<SysLogininfor> selectPageLogininforList(SysLogininfor logininfor) { | ||||
|         Map<String, Object> params = logininfor.getParams(); | ||||
|         LambdaQueryWrapper<SysLogininfor> lqw = new LambdaQueryWrapper<SysLogininfor>() | ||||
|                 .like(StrUtil.isNotBlank(logininfor.getIpaddr()), SysLogininfor::getIpaddr, logininfor.getIpaddr()) | ||||
|                 .eq(StrUtil.isNotBlank(logininfor.getStatus()), SysLogininfor::getStatus, logininfor.getStatus()) | ||||
|                 .like(StrUtil.isNotBlank(logininfor.getUserName()), SysLogininfor::getUserName, logininfor.getUserName()) | ||||
|                 .apply(Validator.isNotEmpty(params.get("beginTime")), | ||||
|                         "date_format(login_time,'%y%m%d') >= date_format({0},'%y%m%d')", | ||||
|                         params.get("beginTime")) | ||||
|                 .apply(Validator.isNotEmpty(params.get("endTime")), | ||||
|                         "date_format(login_time,'%y%m%d') <= date_format({0},'%y%m%d')", | ||||
|                         params.get("endTime")); | ||||
|         return PageUtils.buildDataInfo(page(PageUtils.buildPage("info_id","desc"), lqw)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增系统登录日志 | ||||
|      * | ||||
|      * @param logininfor 访问日志对象 | ||||
|      */ | ||||
|     @Override | ||||
|     public void insertLogininfor(SysLogininfor logininfor) { | ||||
|         logininfor.setLoginTime(new Date()); | ||||
|         save(logininfor); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询系统登录日志集合 | ||||
|      * | ||||
|      * @param logininfor 访问日志对象 | ||||
|      * @return 登录记录集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysLogininfor> selectLogininforList(SysLogininfor logininfor) { | ||||
|         Map<String, Object> params = logininfor.getParams(); | ||||
|         return list(new LambdaQueryWrapper<SysLogininfor>() | ||||
|                 .like(StrUtil.isNotBlank(logininfor.getIpaddr()),SysLogininfor::getIpaddr,logininfor.getIpaddr()) | ||||
|                 .eq(StrUtil.isNotBlank(logininfor.getStatus()),SysLogininfor::getStatus,logininfor.getStatus()) | ||||
|                 .like(StrUtil.isNotBlank(logininfor.getUserName()),SysLogininfor::getUserName,logininfor.getUserName()) | ||||
|                 .apply(Validator.isNotEmpty(params.get("beginTime")), | ||||
|                         "date_format(login_time,'%y%m%d') >= date_format({0},'%y%m%d')", | ||||
|                         params.get("beginTime")) | ||||
|                 .apply(Validator.isNotEmpty(params.get("endTime")), | ||||
|                         "date_format(login_time,'%y%m%d') <= date_format({0},'%y%m%d')", | ||||
|                         params.get("endTime")) | ||||
|                 .orderByDesc(SysLogininfor::getInfoId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统登录日志 | ||||
|      * | ||||
|      * @param infoIds 需要删除的登录日志ID | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteLogininforByIds(Long[] infoIds) { | ||||
|         return baseMapper.deleteBatchIds(Arrays.asList(infoIds)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 清空系统登录日志 | ||||
|      */ | ||||
|     @Override | ||||
|     public void cleanLogininfor() { | ||||
|         remove(new LambdaQueryWrapper<>()); | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,412 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.domain.TreeSelect; | ||||
| import com.ruoyi.common.core.domain.entity.SysMenu; | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.utils.SecurityUtils; | ||||
| import com.ruoyi.system.domain.SysRoleMenu; | ||||
| import com.ruoyi.system.domain.vo.MetaVo; | ||||
| import com.ruoyi.system.domain.vo.RouterVo; | ||||
| import com.ruoyi.system.mapper.SysMenuMapper; | ||||
| import com.ruoyi.system.mapper.SysRoleMapper; | ||||
| import com.ruoyi.system.mapper.SysRoleMenuMapper; | ||||
| import com.ruoyi.system.service.ISysMenuService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.util.*; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| /** | ||||
|  * 菜单 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysMenuServiceImpl extends ServicePlusImpl<SysMenuMapper, SysMenu> implements ISysMenuService { | ||||
|     public static final String PREMISSION_STRING = "perms[\"{0}\"]"; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleMapper roleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleMenuMapper roleMenuMapper; | ||||
|  | ||||
|     /** | ||||
|      * 根据用户查询系统菜单列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysMenu> selectMenuList(Long userId) { | ||||
|         return selectMenuList(new SysMenu(), userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询系统菜单列表 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysMenu> selectMenuList(SysMenu menu, Long userId) { | ||||
|         List<SysMenu> menuList = null; | ||||
|         // 管理员显示所有菜单信息 | ||||
|         if (SysUser.isAdmin(userId)) { | ||||
|             menuList = list(new LambdaQueryWrapper<SysMenu>() | ||||
|                     .like(StrUtil.isNotBlank(menu.getMenuName()),SysMenu::getMenuName,menu.getMenuName()) | ||||
|                     .eq(StrUtil.isNotBlank(menu.getVisible()),SysMenu::getVisible,menu.getVisible()) | ||||
|                     .eq(StrUtil.isNotBlank(menu.getStatus()),SysMenu::getStatus,menu.getStatus()) | ||||
|                     .orderByAsc(SysMenu::getParentId) | ||||
|                     .orderByAsc(SysMenu::getOrderNum)); | ||||
|         } else { | ||||
|             menu.getParams().put("userId", userId); | ||||
|             menuList = baseMapper.selectMenuListByUserId(menu); | ||||
|         } | ||||
|         return menuList; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询权限 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public Set<String> selectMenuPermsByUserId(Long userId) { | ||||
|         List<String> perms = baseMapper.selectMenuPermsByUserId(userId); | ||||
|         Set<String> permsSet = new HashSet<>(); | ||||
|         for (String perm : perms) { | ||||
|             if (Validator.isNotEmpty(perm)) { | ||||
|                 permsSet.addAll(Arrays.asList(perm.trim().split(","))); | ||||
|             } | ||||
|         } | ||||
|         return permsSet; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询菜单 | ||||
|      * | ||||
|      * @param userId 用户名称 | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysMenu> selectMenuTreeByUserId(Long userId) { | ||||
|         List<SysMenu> menus = null; | ||||
|         if (SecurityUtils.isAdmin(userId)) { | ||||
|             menus = baseMapper.selectMenuTreeAll(); | ||||
|         } else { | ||||
|             menus = baseMapper.selectMenuTreeByUserId(userId); | ||||
|         } | ||||
|         return getChildPerms(menus, 0); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询菜单树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 选中菜单列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<Integer> selectMenuListByRoleId(Long roleId) { | ||||
|         SysRole role = roleMapper.selectById(roleId); | ||||
|         return baseMapper.selectMenuListByRoleId(roleId, role.isMenuCheckStrictly()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 构建前端路由所需要的菜单 | ||||
|      * | ||||
|      * @param menus 菜单列表 | ||||
|      * @return 路由列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<RouterVo> buildMenus(List<SysMenu> menus) { | ||||
|         List<RouterVo> routers = new LinkedList<RouterVo>(); | ||||
|         for (SysMenu menu : menus) { | ||||
|             RouterVo router = new RouterVo(); | ||||
|             router.setHidden("1".equals(menu.getVisible())); | ||||
|             router.setName(getRouteName(menu)); | ||||
|             router.setPath(getRouterPath(menu)); | ||||
|             router.setComponent(getComponent(menu)); | ||||
|             router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StrUtil.equals("1", menu.getIsCache()))); | ||||
|             List<SysMenu> cMenus = menu.getChildren(); | ||||
|             if (!cMenus.isEmpty() && UserConstants.TYPE_DIR.equals(menu.getMenuType())) { | ||||
|                 router.setAlwaysShow(true); | ||||
|                 router.setRedirect("noRedirect"); | ||||
|                 router.setChildren(buildMenus(cMenus)); | ||||
|             } else if (isMenuFrame(menu)) { | ||||
|                 router.setMeta(null); | ||||
|                 List<RouterVo> childrenList = new ArrayList<RouterVo>(); | ||||
|                 RouterVo children = new RouterVo(); | ||||
|                 children.setPath(menu.getPath()); | ||||
|                 children.setComponent(menu.getComponent()); | ||||
|                 children.setName(StrUtil.upperFirst(menu.getPath())); | ||||
|                 children.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StrUtil.equals("1", menu.getIsCache()))); | ||||
|                 childrenList.add(children); | ||||
|                 router.setChildren(childrenList); | ||||
|             } | ||||
|             routers.add(router); | ||||
|         } | ||||
|         return routers; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要树结构 | ||||
|      * | ||||
|      * @param menus 菜单列表 | ||||
|      * @return 树结构列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysMenu> buildMenuTree(List<SysMenu> menus) { | ||||
|         List<SysMenu> returnList = new ArrayList<SysMenu>(); | ||||
|         List<Long> tempList = new ArrayList<Long>(); | ||||
|         for (SysMenu dept : menus) { | ||||
|             tempList.add(dept.getMenuId()); | ||||
|         } | ||||
| 		for (SysMenu menu : menus) { | ||||
| 			// 如果是顶级节点, 遍历该父节点的所有子节点 | ||||
| 			if (!tempList.contains(menu.getParentId())) { | ||||
| 				recursionFn(menus, menu); | ||||
| 				returnList.add(menu); | ||||
| 			} | ||||
| 		} | ||||
|         if (returnList.isEmpty()) { | ||||
|             returnList = menus; | ||||
|         } | ||||
|         return returnList; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要下拉树结构 | ||||
|      * | ||||
|      * @param menus 菜单列表 | ||||
|      * @return 下拉树结构列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<TreeSelect> buildMenuTreeSelect(List<SysMenu> menus) { | ||||
|         List<SysMenu> menuTrees = buildMenuTree(menus); | ||||
|         return menuTrees.stream().map(TreeSelect::new).collect(Collectors.toList()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据菜单ID查询信息 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 菜单信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysMenu selectMenuById(Long menuId) { | ||||
|         return getById(menuId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否存在菜单子节点 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean hasChildByMenuId(Long menuId) { | ||||
|         int result = count(new LambdaQueryWrapper<SysMenu>().eq(SysMenu::getParentId,menuId)); | ||||
|         return result > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询菜单使用数量 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean checkMenuExistRole(Long menuId) { | ||||
|         int result = roleMenuMapper.selectCount(new LambdaQueryWrapper<SysRoleMenu>().eq(SysRoleMenu::getMenuId,menuId)); | ||||
|         return result > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存菜单信息 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertMenu(SysMenu menu) { | ||||
|         return baseMapper.insert(menu); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存菜单信息 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateMenu(SysMenu menu) { | ||||
|         return baseMapper.updateById(menu); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除菜单管理信息 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteMenuById(Long menuId) { | ||||
|         return baseMapper.deleteById(menuId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验菜单名称是否唯一 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkMenuNameUnique(SysMenu menu) { | ||||
|         Long menuId = Validator.isNull(menu.getMenuId()) ? -1L : menu.getMenuId(); | ||||
|         SysMenu info = getOne(new LambdaQueryWrapper<SysMenu>() | ||||
|                 .eq(SysMenu::getMenuName,menu.getMenuName()) | ||||
|                 .eq(SysMenu::getParentId,menu.getParentId()) | ||||
|                 .last("limit 1")); | ||||
|         if (Validator.isNotNull(info) && info.getMenuId().longValue() != menuId.longValue()) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取路由名称 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 路由名称 | ||||
|      */ | ||||
|     public String getRouteName(SysMenu menu) { | ||||
|         String routerName = StrUtil.upperFirst(menu.getPath()); | ||||
|         // 非外链并且是一级目录(类型为目录) | ||||
|         if (isMenuFrame(menu)) { | ||||
|             routerName = StrUtil.EMPTY; | ||||
|         } | ||||
|         return routerName; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取路由地址 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 路由地址 | ||||
|      */ | ||||
|     public String getRouterPath(SysMenu menu) { | ||||
|         String routerPath = menu.getPath(); | ||||
|         // 非外链并且是一级目录(类型为目录) | ||||
|         if (0 == menu.getParentId().intValue() && UserConstants.TYPE_DIR.equals(menu.getMenuType()) | ||||
|                 && UserConstants.NO_FRAME.equals(menu.getIsFrame())) { | ||||
|             routerPath = "/" + menu.getPath(); | ||||
|         } | ||||
|         // 非外链并且是一级目录(类型为菜单) | ||||
|         else if (isMenuFrame(menu)) { | ||||
|             routerPath = "/"; | ||||
|         } | ||||
|         return routerPath; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取组件信息 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 组件信息 | ||||
|      */ | ||||
|     public String getComponent(SysMenu menu) { | ||||
|         String component = UserConstants.LAYOUT; | ||||
|         if (StrUtil.isNotEmpty(menu.getComponent()) && !isMenuFrame(menu)) { | ||||
|             component = menu.getComponent(); | ||||
|         } else if (StrUtil.isEmpty(menu.getComponent()) && isParentView(menu)) { | ||||
|             component = UserConstants.PARENT_VIEW; | ||||
|         } | ||||
|         return component; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否为菜单内部跳转 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public boolean isMenuFrame(SysMenu menu) { | ||||
|         return menu.getParentId().intValue() == 0 && UserConstants.TYPE_MENU.equals(menu.getMenuType()) | ||||
|                 && menu.getIsFrame().equals(UserConstants.NO_FRAME); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否为parent_view组件 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public boolean isParentView(SysMenu menu) { | ||||
|         return menu.getParentId().intValue() != 0 && UserConstants.TYPE_DIR.equals(menu.getMenuType()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据父节点的ID获取所有子节点 | ||||
|      * | ||||
|      * @param list     分类表 | ||||
|      * @param parentId 传入的父节点ID | ||||
|      * @return String | ||||
|      */ | ||||
|     public List<SysMenu> getChildPerms(List<SysMenu> list, int parentId) { | ||||
|         List<SysMenu> returnList = new ArrayList<SysMenu>(); | ||||
| 		for (SysMenu t : list) { | ||||
| 			// 一、根据传入的某个父节点ID,遍历该父节点的所有子节点 | ||||
| 			if (t.getParentId() == parentId) { | ||||
| 				recursionFn(list, t); | ||||
| 				returnList.add(t); | ||||
| 			} | ||||
| 		} | ||||
|         return returnList; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 递归列表 | ||||
|      * | ||||
|      * @param list | ||||
|      * @param t | ||||
|      */ | ||||
|     private void recursionFn(List<SysMenu> list, SysMenu t) { | ||||
|         // 得到子节点列表 | ||||
|         List<SysMenu> childList = getChildList(list, t); | ||||
|         t.setChildren(childList); | ||||
|         for (SysMenu tChild : childList) { | ||||
|             if (hasChild(list, tChild)) { | ||||
|                 recursionFn(list, tChild); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 得到子节点列表 | ||||
|      */ | ||||
|     private List<SysMenu> getChildList(List<SysMenu> list, SysMenu t) { | ||||
|         List<SysMenu> tlist = new ArrayList<SysMenu>(); | ||||
| 		for (SysMenu n : list) { | ||||
| 			if (n.getParentId().longValue() == t.getMenuId().longValue()) { | ||||
| 				tlist.add(n); | ||||
| 			} | ||||
| 		} | ||||
|         return tlist; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 判断是否有子节点 | ||||
|      */ | ||||
|     private boolean hasChild(List<SysMenu> list, SysMenu t) { | ||||
|         return getChildList(list, t).size() > 0; | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,101 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.system.domain.SysNotice; | ||||
| import com.ruoyi.system.mapper.SysNoticeMapper; | ||||
| import com.ruoyi.system.service.ISysNoticeService; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.util.Arrays; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 公告 服务层实现 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysNoticeServiceImpl extends ServicePlusImpl<SysNoticeMapper, SysNotice> implements ISysNoticeService { | ||||
|  | ||||
|     @Override | ||||
|     public TableDataInfo<SysNotice> selectPageNoticeList(SysNotice notice) { | ||||
|         LambdaQueryWrapper<SysNotice> lqw = new LambdaQueryWrapper<SysNotice>() | ||||
|                 .like(StrUtil.isNotBlank(notice.getNoticeTitle()), SysNotice::getNoticeTitle, notice.getNoticeTitle()) | ||||
|                 .eq(StrUtil.isNotBlank(notice.getNoticeType()), SysNotice::getNoticeType, notice.getNoticeType()) | ||||
|                 .like(StrUtil.isNotBlank(notice.getCreateBy()), SysNotice::getCreateBy, notice.getCreateBy()); | ||||
|         return PageUtils.buildDataInfo(page(PageUtils.buildPage(),lqw)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询公告信息 | ||||
|      * | ||||
|      * @param noticeId 公告ID | ||||
|      * @return 公告信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysNotice selectNoticeById(Long noticeId) { | ||||
|         return getById(noticeId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询公告列表 | ||||
|      * | ||||
|      * @param notice 公告信息 | ||||
|      * @return 公告集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysNotice> selectNoticeList(SysNotice notice) { | ||||
|         return list(new LambdaQueryWrapper<SysNotice>() | ||||
|                 .like(StrUtil.isNotBlank(notice.getNoticeTitle()),SysNotice::getNoticeTitle,notice.getNoticeTitle()) | ||||
|                 .eq(StrUtil.isNotBlank(notice.getNoticeType()),SysNotice::getNoticeType,notice.getNoticeType()) | ||||
|                 .like(StrUtil.isNotBlank(notice.getCreateBy()),SysNotice::getCreateBy,notice.getCreateBy())); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增公告 | ||||
|      * | ||||
|      * @param notice 公告信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertNotice(SysNotice notice) { | ||||
|         return baseMapper.insert(notice); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改公告 | ||||
|      * | ||||
|      * @param notice 公告信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateNotice(SysNotice notice) { | ||||
|         return baseMapper.updateById(notice); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除公告对象 | ||||
|      * | ||||
|      * @param noticeId 公告ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteNoticeById(Long noticeId) { | ||||
|         return baseMapper.deleteById(noticeId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除公告信息 | ||||
|      * | ||||
|      * @param noticeIds 需要删除的公告ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteNoticeByIds(Long[] noticeIds) { | ||||
|         return baseMapper.deleteBatchIds(Arrays.asList(noticeIds)); | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,122 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import cn.hutool.core.util.ArrayUtil; | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.system.domain.SysOperLog; | ||||
| import com.ruoyi.system.mapper.SysOperLogMapper; | ||||
| import com.ruoyi.system.service.ISysOperLogService; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.util.Arrays; | ||||
| import java.util.Date; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
|  | ||||
| /** | ||||
|  * 操作日志 服务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysOperLogServiceImpl extends ServicePlusImpl<SysOperLogMapper, SysOperLog> implements ISysOperLogService { | ||||
|  | ||||
|     @Override | ||||
|     public TableDataInfo<SysOperLog> selectPageOperLogList(SysOperLog operLog) { | ||||
|         Map<String, Object> params = operLog.getParams(); | ||||
|         LambdaQueryWrapper<SysOperLog> lqw = new LambdaQueryWrapper<SysOperLog>() | ||||
|                 .like(StrUtil.isNotBlank(operLog.getTitle()), SysOperLog::getTitle, operLog.getTitle()) | ||||
|                 .eq(operLog.getBusinessType() != null && operLog.getBusinessType() > 0, | ||||
|                         SysOperLog::getBusinessType, operLog.getBusinessType()) | ||||
|                 .func(f -> { | ||||
|                     if (ArrayUtil.isNotEmpty(operLog.getBusinessTypes())) { | ||||
|                         f.in(SysOperLog::getBusinessType, Arrays.asList(operLog.getBusinessTypes())); | ||||
|                     } | ||||
|                 }) | ||||
|                 .eq(operLog.getStatus() != null && operLog.getStatus() > 0, | ||||
|                         SysOperLog::getStatus, operLog.getStatus()) | ||||
|                 .like(StrUtil.isNotBlank(operLog.getOperName()), SysOperLog::getOperName, operLog.getOperName()) | ||||
|                 .apply(Validator.isNotEmpty(params.get("beginTime")), | ||||
|                         "date_format(oper_time,'%y%m%d') >= date_format({0},'%y%m%d')", | ||||
|                         params.get("beginTime")) | ||||
|                 .apply(Validator.isNotEmpty(params.get("endTime")), | ||||
|                         "date_format(oper_time,'%y%m%d') <= date_format({0},'%y%m%d')", | ||||
|                         params.get("endTime")); | ||||
|         return PageUtils.buildDataInfo(page(PageUtils.buildPage("oper_id","desc"), lqw)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增操作日志 | ||||
|      * | ||||
|      * @param operLog 操作日志对象 | ||||
|      */ | ||||
|     @Override | ||||
|     public void insertOperlog(SysOperLog operLog) { | ||||
|         operLog.setOperTime(new Date()); | ||||
|         save(operLog); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询系统操作日志集合 | ||||
|      * | ||||
|      * @param operLog 操作日志对象 | ||||
|      * @return 操作日志集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysOperLog> selectOperLogList(SysOperLog operLog) { | ||||
|         Map<String, Object> params = operLog.getParams(); | ||||
|         return list(new LambdaQueryWrapper<SysOperLog>() | ||||
|                 .like(StrUtil.isNotBlank(operLog.getTitle()),SysOperLog::getTitle,operLog.getTitle()) | ||||
|                 .eq(operLog.getBusinessType() != null && operLog.getBusinessType() > 0, | ||||
|                         SysOperLog::getBusinessType,operLog.getBusinessType()) | ||||
|                 .func(f -> { | ||||
|                     if (ArrayUtil.isNotEmpty(operLog.getBusinessTypes())){ | ||||
|                         f.in(SysOperLog::getBusinessType, Arrays.asList(operLog.getBusinessTypes())); | ||||
|                     } | ||||
|                 }) | ||||
|                 .eq(operLog.getStatus() != null && operLog.getStatus() > 0, | ||||
|                         SysOperLog::getStatus,operLog.getStatus()) | ||||
|                 .like(StrUtil.isNotBlank(operLog.getOperName()),SysOperLog::getOperName,operLog.getOperName()) | ||||
|                 .apply(Validator.isNotEmpty(params.get("beginTime")), | ||||
|                         "date_format(oper_time,'%y%m%d') >= date_format({0},'%y%m%d')", | ||||
|                         params.get("beginTime")) | ||||
|                 .apply(Validator.isNotEmpty(params.get("endTime")), | ||||
|                         "date_format(oper_time,'%y%m%d') <= date_format({0},'%y%m%d')", | ||||
|                         params.get("endTime")) | ||||
|                 .orderByDesc(SysOperLog::getOperId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统操作日志 | ||||
|      * | ||||
|      * @param operIds 需要删除的操作日志ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteOperLogByIds(Long[] operIds) { | ||||
|         return baseMapper.deleteBatchIds(Arrays.asList(operIds)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询操作日志详细 | ||||
|      * | ||||
|      * @param operId 操作ID | ||||
|      * @return 操作日志对象 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysOperLog selectOperLogById(Long operId) { | ||||
|         return getById(operId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 清空操作日志 | ||||
|      */ | ||||
|     @Override | ||||
|     public void cleanOperLog() { | ||||
|         remove(new LambdaQueryWrapper<>()); | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,183 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.exception.CustomException; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.system.domain.SysPost; | ||||
| import com.ruoyi.system.domain.SysUserPost; | ||||
| import com.ruoyi.system.mapper.SysPostMapper; | ||||
| import com.ruoyi.system.mapper.SysUserPostMapper; | ||||
| import com.ruoyi.system.service.ISysPostService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.util.Arrays; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 岗位信息 服务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysPostServiceImpl extends ServicePlusImpl<SysPostMapper, SysPost> implements ISysPostService { | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserPostMapper userPostMapper; | ||||
|  | ||||
|     @Override | ||||
|     public TableDataInfo<SysPost> selectPagePostList(SysPost post) { | ||||
|         LambdaQueryWrapper<SysPost> lqw = new LambdaQueryWrapper<SysPost>() | ||||
|                 .like(StrUtil.isNotBlank(post.getPostCode()), SysPost::getPostCode, post.getPostCode()) | ||||
|                 .eq(StrUtil.isNotBlank(post.getStatus()), SysPost::getStatus, post.getStatus()) | ||||
|                 .like(StrUtil.isNotBlank(post.getPostName()), SysPost::getPostName, post.getPostName()); | ||||
|         return PageUtils.buildDataInfo(page(PageUtils.buildPage(),lqw)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询岗位信息集合 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 岗位信息集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysPost> selectPostList(SysPost post) { | ||||
|         return list(new LambdaQueryWrapper<SysPost>() | ||||
|                 .like(StrUtil.isNotBlank(post.getPostCode()), SysPost::getPostCode, post.getPostCode()) | ||||
|                 .eq(StrUtil.isNotBlank(post.getStatus()), SysPost::getStatus, post.getStatus()) | ||||
|                 .like(StrUtil.isNotBlank(post.getPostName()), SysPost::getPostName, post.getPostName())); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询所有岗位 | ||||
|      * | ||||
|      * @return 岗位列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysPost> selectPostAll() { | ||||
|         return list(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过岗位ID查询岗位信息 | ||||
|      * | ||||
|      * @param postId 岗位ID | ||||
|      * @return 角色对象信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysPost selectPostById(Long postId) { | ||||
|         return getById(postId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取岗位选择框列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中岗位ID列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<Integer> selectPostListByUserId(Long userId) { | ||||
|         return baseMapper.selectPostListByUserId(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验岗位名称是否唯一 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkPostNameUnique(SysPost post) { | ||||
|         Long postId = Validator.isNull(post.getPostId()) ? -1L : post.getPostId(); | ||||
|         SysPost info = getOne(new LambdaQueryWrapper<SysPost>() | ||||
|                 .eq(SysPost::getPostName, post.getPostName()).last("limit 1")); | ||||
|         if (Validator.isNotNull(info) && info.getPostId().longValue() != postId.longValue()) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验岗位编码是否唯一 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkPostCodeUnique(SysPost post) { | ||||
|         Long postId = Validator.isNull(post.getPostId()) ? -1L : post.getPostId(); | ||||
|         SysPost info = getOne(new LambdaQueryWrapper<SysPost>() | ||||
|                 .eq(SysPost::getPostCode, post.getPostCode()).last("limit 1")); | ||||
|         if (Validator.isNotNull(info) && info.getPostId().longValue() != postId.longValue()) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过岗位ID查询岗位使用数量 | ||||
|      * | ||||
|      * @param postId 岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int countUserPostById(Long postId) { | ||||
|         return userPostMapper.selectCount(new LambdaQueryWrapper<SysUserPost>().eq(SysUserPost::getPostId,postId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除岗位信息 | ||||
|      * | ||||
|      * @param postId 岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deletePostById(Long postId) { | ||||
|         return baseMapper.deleteById(postId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除岗位信息 | ||||
|      * | ||||
|      * @param postIds 需要删除的岗位ID | ||||
|      * @return 结果 | ||||
|      * @throws Exception 异常 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deletePostByIds(Long[] postIds) { | ||||
|         for (Long postId : postIds) { | ||||
|             SysPost post = selectPostById(postId); | ||||
|             if (countUserPostById(postId) > 0) { | ||||
|                 throw new CustomException(String.format("%1$s已分配,不能删除", post.getPostName())); | ||||
|             } | ||||
|         } | ||||
|         return baseMapper.deleteBatchIds(Arrays.asList(postIds)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存岗位信息 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertPost(SysPost post) { | ||||
|         return baseMapper.insert(post); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存岗位信息 | ||||
|      * | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updatePost(SysPost post) { | ||||
|         return baseMapper.updateById(post); | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,308 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.ruoyi.common.annotation.DataScope; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.exception.CustomException; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.common.utils.spring.SpringUtils; | ||||
| import com.ruoyi.system.domain.SysRoleDept; | ||||
| import com.ruoyi.system.domain.SysRoleMenu; | ||||
| import com.ruoyi.system.domain.SysUserRole; | ||||
| import com.ruoyi.system.mapper.SysRoleDeptMapper; | ||||
| import com.ruoyi.system.mapper.SysRoleMapper; | ||||
| import com.ruoyi.system.mapper.SysRoleMenuMapper; | ||||
| import com.ruoyi.system.mapper.SysUserRoleMapper; | ||||
| import com.ruoyi.system.service.ISysRoleService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
|  | ||||
| import java.util.*; | ||||
|  | ||||
| /** | ||||
|  * 角色 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysRoleServiceImpl extends ServicePlusImpl<SysRoleMapper, SysRole> implements ISysRoleService { | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleMenuMapper roleMenuMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserRoleMapper userRoleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleDeptMapper roleDeptMapper; | ||||
|  | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d") | ||||
|     public TableDataInfo<SysRole> selectPageRoleList(SysRole role) { | ||||
|         return PageUtils.buildDataInfo(baseMapper.selectPageRoleList(PageUtils.buildPage(), role)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询角色数据 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 角色数据集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d") | ||||
|     public List<SysRole> selectRoleList(SysRole role) { | ||||
|         return baseMapper.selectRoleList(role); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询权限 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public Set<String> selectRolePermissionByUserId(Long userId) { | ||||
|         List<SysRole> perms = baseMapper.selectRolePermissionByUserId(userId); | ||||
|         Set<String> permsSet = new HashSet<>(); | ||||
|         for (SysRole perm : perms) { | ||||
|             if (Validator.isNotNull(perm)) { | ||||
|                 permsSet.addAll(Arrays.asList(perm.getRoleKey().trim().split(","))); | ||||
|             } | ||||
|         } | ||||
|         return permsSet; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询所有角色 | ||||
|      * | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysRole> selectRoleAll() { | ||||
|         return SpringUtils.getAopProxy(this).selectRoleList(new SysRole()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取角色选择框列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中角色ID列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<Integer> selectRoleListByUserId(Long userId) { | ||||
|         return baseMapper.selectRoleListByUserId(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID查询角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 角色对象信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysRole selectRoleById(Long roleId) { | ||||
|         return getById(roleId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验角色名称是否唯一 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkRoleNameUnique(SysRole role) { | ||||
|         Long roleId = Validator.isNull(role.getRoleId()) ? -1L : role.getRoleId(); | ||||
|         SysRole info = getOne(new LambdaQueryWrapper<SysRole>() | ||||
|                 .eq(SysRole::getRoleName, role.getRoleName()).last("limit 1")); | ||||
|         if (Validator.isNotNull(info) && info.getRoleId().longValue() != roleId.longValue()) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验角色权限是否唯一 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkRoleKeyUnique(SysRole role) { | ||||
|         Long roleId = Validator.isNull(role.getRoleId()) ? -1L : role.getRoleId(); | ||||
|         SysRole info = getOne(new LambdaQueryWrapper<SysRole>() | ||||
|                 .eq(SysRole::getRoleKey, role.getRoleKey()).last("limit 1")); | ||||
|         if (Validator.isNotNull(info) && info.getRoleId().longValue() != roleId.longValue()) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验角色是否允许操作 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public void checkRoleAllowed(SysRole role) { | ||||
|         if (Validator.isNotNull(role.getRoleId()) && role.isAdmin()) { | ||||
|             throw new CustomException("不允许操作超级管理员角色"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID查询角色使用数量 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int countUserRoleByRoleId(Long roleId) { | ||||
|         return userRoleMapper.selectCount(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getRoleId, roleId)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存角色信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int insertRole(SysRole role) { | ||||
|         // 新增角色信息 | ||||
|         baseMapper.insert(role); | ||||
|         return insertRoleMenu(role); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存角色信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int updateRole(SysRole role) { | ||||
|         // 修改角色信息 | ||||
|         baseMapper.updateById(role); | ||||
|         // 删除角色与菜单关联 | ||||
|         roleMenuMapper.delete(new LambdaQueryWrapper<SysRoleMenu>().eq(SysRoleMenu::getRoleId, role.getRoleId())); | ||||
|         return insertRoleMenu(role); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改角色状态 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateRoleStatus(SysRole role) { | ||||
|         return baseMapper.updateById(role); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改数据权限信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int authDataScope(SysRole role) { | ||||
|         // 修改角色信息 | ||||
|         baseMapper.updateById(role); | ||||
|         // 删除角色与部门关联 | ||||
|         roleDeptMapper.delete(new LambdaQueryWrapper<SysRoleDept>().eq(SysRoleDept::getRoleId, role.getRoleId())); | ||||
|         // 新增角色和部门信息(数据权限) | ||||
|         return insertRoleDept(role); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增角色菜单信息 | ||||
|      * | ||||
|      * @param role 角色对象 | ||||
|      */ | ||||
|     public int insertRoleMenu(SysRole role) { | ||||
|         int rows = 1; | ||||
|         // 新增用户与角色管理 | ||||
|         List<SysRoleMenu> list = new ArrayList<SysRoleMenu>(); | ||||
|         for (Long menuId : role.getMenuIds()) { | ||||
|             SysRoleMenu rm = new SysRoleMenu(); | ||||
|             rm.setRoleId(role.getRoleId()); | ||||
|             rm.setMenuId(menuId); | ||||
|             list.add(rm); | ||||
|         } | ||||
|         if (list.size() > 0) { | ||||
| 			rows = roleMenuMapper.insertAll(list); | ||||
|         } | ||||
|         return rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增角色部门信息(数据权限) | ||||
|      * | ||||
|      * @param role 角色对象 | ||||
|      */ | ||||
|     public int insertRoleDept(SysRole role) { | ||||
|         int rows = 1; | ||||
|         // 新增角色与部门(数据权限)管理 | ||||
|         List<SysRoleDept> list = new ArrayList<SysRoleDept>(); | ||||
|         for (Long deptId : role.getDeptIds()) { | ||||
|             SysRoleDept rd = new SysRoleDept(); | ||||
|             rd.setRoleId(role.getRoleId()); | ||||
|             rd.setDeptId(deptId); | ||||
|             list.add(rd); | ||||
|         } | ||||
|         if (list.size() > 0) { | ||||
| 			rows = roleDeptMapper.insertAll(list); | ||||
|         } | ||||
|         return rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID删除角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int deleteRoleById(Long roleId) { | ||||
|         // 删除角色与菜单关联 | ||||
|         roleMenuMapper.delete(new LambdaQueryWrapper<SysRoleMenu>().eq(SysRoleMenu::getRoleId, roleId)); | ||||
|         // 删除角色与部门关联 | ||||
|         roleDeptMapper.delete(new LambdaQueryWrapper<SysRoleDept>().eq(SysRoleDept::getRoleId, roleId)); | ||||
|         return baseMapper.deleteById(roleId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除角色信息 | ||||
|      * | ||||
|      * @param roleIds 需要删除的角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int deleteRoleByIds(Long[] roleIds) { | ||||
|         for (Long roleId : roleIds) { | ||||
|             checkRoleAllowed(new SysRole(roleId)); | ||||
|             SysRole role = selectRoleById(roleId); | ||||
|             if (countUserRoleByRoleId(roleId) > 0) { | ||||
|                 throw new CustomException(String.format("%1$s已分配,不能删除", role.getRoleName())); | ||||
|             } | ||||
|         } | ||||
|         List<Long> ids = Arrays.asList(roleIds); | ||||
|         // 删除角色与菜单关联 | ||||
|         roleMenuMapper.delete(new LambdaQueryWrapper<SysRoleMenu>().in(SysRoleMenu::getRoleId, ids)); | ||||
|         // 删除角色与部门关联 | ||||
|         roleDeptMapper.delete(new LambdaQueryWrapper<SysRoleDept>().in(SysRoleDept::getRoleId, ids)); | ||||
|         return baseMapper.deleteBatchIds(ids); | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,87 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import cn.hutool.core.util.StrUtil; | ||||
| import com.ruoyi.common.core.domain.model.LoginUser; | ||||
| import com.ruoyi.system.domain.SysUserOnline; | ||||
| import com.ruoyi.system.service.ISysUserOnlineService; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| /** | ||||
|  * 在线用户 服务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysUserOnlineServiceImpl implements ISysUserOnlineService { | ||||
|     /** | ||||
|      * 通过登录地址查询信息 | ||||
|      * | ||||
|      * @param ipaddr 登录地址 | ||||
|      * @param user   用户信息 | ||||
|      * @return 在线用户信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUserOnline selectOnlineByIpaddr(String ipaddr, LoginUser user) { | ||||
|         if (StrUtil.equals(ipaddr, user.getIpaddr())) { | ||||
|             return loginUserToUserOnline(user); | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名称查询信息 | ||||
|      * | ||||
|      * @param userName 用户名称 | ||||
|      * @param user     用户信息 | ||||
|      * @return 在线用户信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUserOnline selectOnlineByUserName(String userName, LoginUser user) { | ||||
|         if (StrUtil.equals(userName, user.getUsername())) { | ||||
|             return loginUserToUserOnline(user); | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过登录地址/用户名称查询信息 | ||||
|      * | ||||
|      * @param ipaddr   登录地址 | ||||
|      * @param userName 用户名称 | ||||
|      * @param user     用户信息 | ||||
|      * @return 在线用户信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUserOnline selectOnlineByInfo(String ipaddr, String userName, LoginUser user) { | ||||
|         if (StrUtil.equals(ipaddr, user.getIpaddr()) && StrUtil.equals(userName, user.getUsername())) { | ||||
|             return loginUserToUserOnline(user); | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 设置在线用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 在线用户 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUserOnline loginUserToUserOnline(LoginUser user) { | ||||
|         if (Validator.isNull(user) || Validator.isNull(user.getUser())) { | ||||
|             return null; | ||||
|         } | ||||
|         SysUserOnline sysUserOnline = new SysUserOnline(); | ||||
|         sysUserOnline.setTokenId(user.getToken()); | ||||
|         sysUserOnline.setUserName(user.getUsername()); | ||||
|         sysUserOnline.setIpaddr(user.getIpaddr()); | ||||
|         sysUserOnline.setLoginLocation(user.getLoginLocation()); | ||||
|         sysUserOnline.setBrowser(user.getBrowser()); | ||||
|         sysUserOnline.setOs(user.getOs()); | ||||
|         sysUserOnline.setLoginTime(user.getLoginTime()); | ||||
|         if (Validator.isNotNull(user.getUser().getDept())) { | ||||
|             sysUserOnline.setDeptName(user.getUser().getDept().getDeptName()); | ||||
|         } | ||||
|         return sysUserOnline; | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,429 @@ | ||||
| package com.ruoyi.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.lang.Validator; | ||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||
| import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | ||||
| import com.ruoyi.common.annotation.DataScope; | ||||
| import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.domain.entity.SysUser; | ||||
| import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl; | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| import com.ruoyi.common.exception.CustomException; | ||||
| import com.ruoyi.common.utils.PageUtils; | ||||
| import com.ruoyi.common.utils.SecurityUtils; | ||||
| import com.ruoyi.system.domain.SysPost; | ||||
| import com.ruoyi.system.domain.SysUserPost; | ||||
| import com.ruoyi.system.domain.SysUserRole; | ||||
| import com.ruoyi.system.mapper.*; | ||||
| import com.ruoyi.system.service.ISysConfigService; | ||||
| import com.ruoyi.system.service.ISysUserService; | ||||
| import lombok.extern.slf4j.Slf4j; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.Arrays; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 用户 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Slf4j | ||||
| @Service | ||||
| public class SysUserServiceImpl extends ServicePlusImpl<SysUserMapper, SysUser> implements ISysUserService { | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleMapper roleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysPostMapper postMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserRoleMapper userRoleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserPostMapper userPostMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private ISysConfigService configService; | ||||
|  | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d", userAlias = "u", isUser = true) | ||||
|     public TableDataInfo<SysUser> selectPageUserList(SysUser user) { | ||||
|         return PageUtils.buildDataInfo(baseMapper.selectPageUserList(PageUtils.buildPage(), user)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询用户列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d", userAlias = "u", isUser = true) | ||||
|     public List<SysUser> selectUserList(SysUser user) { | ||||
|         return baseMapper.selectUserList(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名查询用户 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUser selectUserByUserName(String userName) { | ||||
|         return baseMapper.selectUserByUserName(userName); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID查询用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUser selectUserById(Long userId) { | ||||
|         return baseMapper.selectUserById(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询用户所属角色组 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String selectUserRoleGroup(String userName) { | ||||
|         List<SysRole> list = roleMapper.selectRolesByUserName(userName); | ||||
|         StringBuilder idsStr = new StringBuilder(); | ||||
|         for (SysRole role : list) { | ||||
|             idsStr.append(role.getRoleName()).append(","); | ||||
|         } | ||||
|         if (Validator.isNotEmpty(idsStr.toString())) { | ||||
|             return idsStr.substring(0, idsStr.length() - 1); | ||||
|         } | ||||
|         return idsStr.toString(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询用户所属岗位组 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String selectUserPostGroup(String userName) { | ||||
|         List<SysPost> list = postMapper.selectPostsByUserName(userName); | ||||
|         StringBuilder idsStr = new StringBuilder(); | ||||
|         for (SysPost post : list) { | ||||
|             idsStr.append(post.getPostName()).append(","); | ||||
|         } | ||||
|         if (Validator.isNotEmpty(idsStr.toString())) { | ||||
|             return idsStr.substring(0, idsStr.length() - 1); | ||||
|         } | ||||
|         return idsStr.toString(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验用户名称是否唯一 | ||||
|      * | ||||
|      * @param userName 用户名称 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkUserNameUnique(String userName) { | ||||
|         int count = count(new LambdaQueryWrapper<SysUser>().eq(SysUser::getUserName, userName).last("limit 1")); | ||||
|         if (count > 0) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验用户名称是否唯一 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkPhoneUnique(SysUser user) { | ||||
|         Long userId = Validator.isNull(user.getUserId()) ? -1L : user.getUserId(); | ||||
|         SysUser info = getOne(new LambdaQueryWrapper<SysUser>() | ||||
|                 .select(SysUser::getUserId, SysUser::getPhonenumber) | ||||
|                 .eq(SysUser::getPhonenumber, user.getPhonenumber()).last("limit 1")); | ||||
|         if (Validator.isNotNull(info) && info.getUserId().longValue() != userId.longValue()) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验email是否唯一 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkEmailUnique(SysUser user) { | ||||
|         Long userId = Validator.isNull(user.getUserId()) ? -1L : user.getUserId(); | ||||
|         SysUser info = getOne(new LambdaQueryWrapper<SysUser>() | ||||
|                 .select(SysUser::getUserId, SysUser::getEmail) | ||||
|                 .eq(SysUser::getEmail, user.getEmail()).last("limit 1")); | ||||
|         if (Validator.isNotNull(info) && info.getUserId().longValue() != userId.longValue()) { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验用户是否允许操作 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public void checkUserAllowed(SysUser user) { | ||||
|         if (Validator.isNotNull(user.getUserId()) && user.isAdmin()) { | ||||
|             throw new CustomException("不允许操作超级管理员用户"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int insertUser(SysUser user) { | ||||
|         // 新增用户信息 | ||||
|         int rows = baseMapper.insert(user); | ||||
|         // 新增用户岗位关联 | ||||
|         insertUserPost(user); | ||||
|         // 新增用户与角色管理 | ||||
|         insertUserRole(user); | ||||
|         return rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int updateUser(SysUser user) { | ||||
|         Long userId = user.getUserId(); | ||||
|         // 删除用户与角色关联 | ||||
|         userRoleMapper.delete(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getUserId,userId)); | ||||
|         // 新增用户与角色管理 | ||||
|         insertUserRole(user); | ||||
|         // 删除用户与岗位关联 | ||||
|         userPostMapper.delete(new LambdaQueryWrapper<SysUserPost>().eq(SysUserPost::getUserId,userId)); | ||||
|         // 新增用户与岗位管理 | ||||
|         insertUserPost(user); | ||||
|         return baseMapper.updateById(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改用户状态 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateUserStatus(SysUser user) { | ||||
|         return baseMapper.updateById(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改用户基本信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateUserProfile(SysUser user) { | ||||
|         return baseMapper.updateById(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改用户头像 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @param avatar   头像地址 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean updateUserAvatar(String userName, String avatar) { | ||||
|         return baseMapper.update(null, | ||||
|                 new LambdaUpdateWrapper<SysUser>() | ||||
|                         .set(SysUser::getAvatar,avatar) | ||||
|                         .eq(SysUser::getUserName,userName)) > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 重置用户密码 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int resetPwd(SysUser user) { | ||||
|         return baseMapper.updateById(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 重置用户密码 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @param password 密码 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int resetUserPwd(String userName, String password) { | ||||
|         return baseMapper.update(null, | ||||
|                 new LambdaUpdateWrapper<SysUser>() | ||||
|                         .set(SysUser::getPassword,password) | ||||
|                         .eq(SysUser::getUserName,userName)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增用户角色信息 | ||||
|      * | ||||
|      * @param user 用户对象 | ||||
|      */ | ||||
|     public void insertUserRole(SysUser user) { | ||||
|         Long[] roles = user.getRoleIds(); | ||||
|         if (Validator.isNotNull(roles)) { | ||||
|             // 新增用户与角色管理 | ||||
|             List<SysUserRole> list = new ArrayList<SysUserRole>(); | ||||
|             for (Long roleId : roles) { | ||||
|                 SysUserRole ur = new SysUserRole(); | ||||
|                 ur.setUserId(user.getUserId()); | ||||
|                 ur.setRoleId(roleId); | ||||
|                 list.add(ur); | ||||
|             } | ||||
|             if (list.size() > 0) { | ||||
| 				userRoleMapper.insertAll(list); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增用户岗位信息 | ||||
|      * | ||||
|      * @param user 用户对象 | ||||
|      */ | ||||
|     public void insertUserPost(SysUser user) { | ||||
|         Long[] posts = user.getPostIds(); | ||||
|         if (Validator.isNotNull(posts)) { | ||||
|             // 新增用户与岗位管理 | ||||
|             List<SysUserPost> list = new ArrayList<SysUserPost>(); | ||||
|             for (Long postId : posts) { | ||||
|                 SysUserPost up = new SysUserPost(); | ||||
|                 up.setUserId(user.getUserId()); | ||||
|                 up.setPostId(postId); | ||||
|                 list.add(up); | ||||
|             } | ||||
|             if (list.size() > 0) { | ||||
| 				userPostMapper.insertAll(list); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID删除用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int deleteUserById(Long userId) { | ||||
|         // 删除用户与角色关联 | ||||
|         userRoleMapper.delete(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getUserId,userId)); | ||||
|         // 删除用户与岗位表 | ||||
|         userPostMapper.delete(new LambdaQueryWrapper<SysUserPost>().eq(SysUserPost::getUserId,userId)); | ||||
|         return baseMapper.deleteById(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除用户信息 | ||||
|      * | ||||
|      * @param userIds 需要删除的用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int deleteUserByIds(Long[] userIds) { | ||||
|         for (Long userId : userIds) { | ||||
|             checkUserAllowed(new SysUser(userId)); | ||||
|         } | ||||
|         List<Long> ids = Arrays.asList(userIds); | ||||
|         // 删除用户与角色关联 | ||||
|         userRoleMapper.delete(new LambdaQueryWrapper<SysUserRole>().in(SysUserRole::getUserId,ids)); | ||||
|         // 删除用户与岗位表 | ||||
|         userPostMapper.delete(new LambdaQueryWrapper<SysUserPost>().in(SysUserPost::getUserId,ids)); | ||||
|         return baseMapper.deleteBatchIds(ids); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 导入用户数据 | ||||
|      * | ||||
|      * @param userList        用户数据列表 | ||||
|      * @param isUpdateSupport 是否更新支持,如果已存在,则进行更新数据 | ||||
|      * @param operName        操作用户 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String importUser(List<SysUser> userList, Boolean isUpdateSupport, String operName) { | ||||
|         if (Validator.isNull(userList) || userList.size() == 0) { | ||||
|             throw new CustomException("导入用户数据不能为空!"); | ||||
|         } | ||||
|         int successNum = 0; | ||||
|         int failureNum = 0; | ||||
|         StringBuilder successMsg = new StringBuilder(); | ||||
|         StringBuilder failureMsg = new StringBuilder(); | ||||
|         String password = configService.selectConfigByKey("sys.user.initPassword"); | ||||
|         for (SysUser user : userList) { | ||||
|             try { | ||||
|                 // 验证是否存在这个用户 | ||||
|                 SysUser u = baseMapper.selectUserByUserName(user.getUserName()); | ||||
|                 if (Validator.isNull(u)) { | ||||
|                     user.setPassword(SecurityUtils.encryptPassword(password)); | ||||
|                     user.setCreateBy(operName); | ||||
|                     this.insertUser(user); | ||||
|                     successNum++; | ||||
|                     successMsg.append("<br/>" + successNum + "、账号 " + user.getUserName() + " 导入成功"); | ||||
|                 } else if (isUpdateSupport) { | ||||
|                     user.setUpdateBy(operName); | ||||
|                     this.updateUser(user); | ||||
|                     successNum++; | ||||
|                     successMsg.append("<br/>" + successNum + "、账号 " + user.getUserName() + " 更新成功"); | ||||
|                 } else { | ||||
|                     failureNum++; | ||||
|                     failureMsg.append("<br/>" + failureNum + "、账号 " + user.getUserName() + " 已存在"); | ||||
|                 } | ||||
|             } catch (Exception e) { | ||||
|                 failureNum++; | ||||
|                 String msg = "<br/>" + failureNum + "、账号 " + user.getUserName() + " 导入失败:"; | ||||
|                 failureMsg.append(msg + e.getMessage()); | ||||
|                 log.error(msg, e); | ||||
|             } | ||||
|         } | ||||
|         if (failureNum > 0) { | ||||
|             failureMsg.insert(0, "很抱歉,导入失败!共 " + failureNum + " 条数据格式不正确,错误如下:"); | ||||
|             throw new CustomException(failureMsg.toString()); | ||||
|         } else { | ||||
|             successMsg.insert(0, "恭喜您,数据已全部导入成功!共 " + successNum + " 条,数据如下:"); | ||||
|         } | ||||
|         return successMsg.toString(); | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,19 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysConfigMapper"> | ||||
|  | ||||
|     <resultMap type="SysConfig" id="SysConfigResult"> | ||||
|         <id property="configId" column="config_id"/> | ||||
|         <result property="configName" column="config_name"/> | ||||
|         <result property="configKey" column="config_key"/> | ||||
|         <result property="configValue" column="config_value"/> | ||||
|         <result property="configType" column="config_type"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper> | ||||
| @ -0,0 +1,73 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysDeptMapper"> | ||||
|  | ||||
|     <resultMap type="SysDept" id="SysDeptResult"> | ||||
|         <id property="deptId" column="dept_id"/> | ||||
|         <result property="parentId" column="parent_id"/> | ||||
|         <result property="ancestors" column="ancestors"/> | ||||
|         <result property="deptName" column="dept_name"/> | ||||
|         <result property="orderNum" column="order_num"/> | ||||
|         <result property="leader" column="leader"/> | ||||
|         <result property="phone" column="phone"/> | ||||
|         <result property="email" column="email"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="delFlag" column="del_flag"/> | ||||
|         <result property="parentName" column="parent_name"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|     </resultMap> | ||||
|  | ||||
|     <sql id="selectDeptVo"> | ||||
|         select d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.phone, d.email, d.status, d.del_flag, d.create_by, d.create_time | ||||
|         from sys_dept d | ||||
|     </sql> | ||||
|  | ||||
|     <select id="selectDeptList" parameterType="SysDept" resultMap="SysDeptResult"> | ||||
|         <include refid="selectDeptVo"/> | ||||
|         where d.del_flag = '0' | ||||
|         <if test="parentId != null and parentId != 0"> | ||||
|             AND parent_id = #{parentId} | ||||
|         </if> | ||||
|         <if test="deptName != null and deptName != ''"> | ||||
|             AND dept_name like concat('%', #{deptName}, '%') | ||||
|         </if> | ||||
|         <if test="status != null and status != ''"> | ||||
|             AND status = #{status} | ||||
|         </if> | ||||
|         <!-- 数据范围过滤 --> | ||||
|         <if test="params.dataScope != null and params.dataScope != ''"> | ||||
|             AND ( ${params.dataScope} ) | ||||
|         </if> | ||||
|         order by d.parent_id, d.order_num | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectDeptListByRoleId" resultType="Integer"> | ||||
|         select d.dept_id | ||||
|         from sys_dept d | ||||
|         left join sys_role_dept rd on d.dept_id = rd.dept_id | ||||
|         where rd.role_id = #{roleId} | ||||
|             <if test="deptCheckStrictly"> | ||||
|                 and d.dept_id not in (select d.parent_id from sys_dept d inner join sys_role_dept rd on d.dept_id = rd.dept_id and rd.role_id = #{roleId}) | ||||
|             </if> | ||||
|         order by d.parent_id, d.order_num | ||||
|     </select> | ||||
|  | ||||
|     <update id="updateDeptChildren" parameterType="java.util.List"> | ||||
|         update sys_dept set ancestors = | ||||
|         <foreach collection="depts" item="item" index="index" | ||||
|                  separator=" " open="case dept_id" close="end"> | ||||
|             when #{item.deptId} then #{item.ancestors} | ||||
|         </foreach> | ||||
|         where dept_id in | ||||
|         <foreach collection="depts" item="item" index="index" | ||||
|                  separator="," open="(" close=")"> | ||||
|             #{item.deptId} | ||||
|         </foreach> | ||||
|     </update> | ||||
|  | ||||
| </mapper> | ||||
| @ -0,0 +1,23 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysDictDataMapper"> | ||||
|  | ||||
|     <resultMap type="SysDictData" id="SysDictDataResult"> | ||||
|         <id property="dictCode" column="dict_code"/> | ||||
|         <result property="dictSort" column="dict_sort"/> | ||||
|         <result property="dictLabel" column="dict_label"/> | ||||
|         <result property="dictValue" column="dict_value"/> | ||||
|         <result property="dictType" column="dict_type"/> | ||||
|         <result property="cssClass" column="css_class"/> | ||||
|         <result property="listClass" column="list_class"/> | ||||
|         <result property="isDefault" column="is_default"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper>  | ||||
| @ -0,0 +1,18 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysDictTypeMapper"> | ||||
|  | ||||
|     <resultMap type="SysDictType" id="SysDictTypeResult"> | ||||
|         <id property="dictId" column="dict_id"/> | ||||
|         <result property="dictName" column="dict_name"/> | ||||
|         <result property="dictType" column="dict_type"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper>  | ||||
| @ -0,0 +1,19 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysLogininforMapper"> | ||||
|  | ||||
|     <resultMap type="SysLogininfor" id="SysLogininforResult"> | ||||
|         <id property="infoId" column="info_id"/> | ||||
|         <result property="userName" column="user_name"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="ipaddr" column="ipaddr"/> | ||||
|         <result property="loginLocation" column="login_location"/> | ||||
|         <result property="browser" column="browser"/> | ||||
|         <result property="os" column="os"/> | ||||
|         <result property="msg" column="msg"/> | ||||
|         <result property="loginTime" column="login_time"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper>  | ||||
							
								
								
									
										146
									
								
								ruoyi-system/src/main/resources/mapper/system/SysMenuMapper.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								ruoyi-system/src/main/resources/mapper/system/SysMenuMapper.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,146 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysMenuMapper"> | ||||
|  | ||||
|     <resultMap type="SysMenu" id="SysMenuResult"> | ||||
|         <id property="menuId" column="menu_id"/> | ||||
|         <result property="menuName" column="menu_name"/> | ||||
|         <result property="parentName" column="parent_name"/> | ||||
|         <result property="parentId" column="parent_id"/> | ||||
|         <result property="orderNum" column="order_num"/> | ||||
|         <result property="path" column="path"/> | ||||
|         <result property="component" column="component"/> | ||||
|         <result property="isFrame" column="is_frame"/> | ||||
|         <result property="isCache" column="is_cache"/> | ||||
|         <result property="menuType" column="menu_type"/> | ||||
|         <result property="visible" column="visible"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="perms" column="perms"/> | ||||
|         <result property="icon" column="icon"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="remark" column="remark"/> | ||||
|     </resultMap> | ||||
|  | ||||
|     <sql id="selectMenuVo"> | ||||
|         select menu_id, | ||||
|                menu_name, | ||||
|                parent_id, | ||||
|                order_num, | ||||
|                path, | ||||
|                component, | ||||
|                is_frame, | ||||
|                is_cache, | ||||
|                menu_type, | ||||
|                visible, | ||||
|                status, | ||||
|                ifnull(perms, '') as perms, | ||||
|                icon, | ||||
|                create_time | ||||
|         from sys_menu | ||||
|     </sql> | ||||
|  | ||||
|  | ||||
|     <select id="selectMenuTreeAll" resultMap="SysMenuResult"> | ||||
|         select distinct m.menu_id, | ||||
|                         m.parent_id, | ||||
|                         m.menu_name, | ||||
|                         m.path, | ||||
|                         m.component, | ||||
|                         m.visible, | ||||
|                         m.status, | ||||
|                         ifnull(m.perms, '') as perms, | ||||
|                         m.is_frame, | ||||
|                         m.is_cache, | ||||
|                         m.menu_type, | ||||
|                         m.icon, | ||||
|                         m.order_num, | ||||
|                         m.create_time | ||||
|         from sys_menu m | ||||
|         where m.menu_type in ('M', 'C') | ||||
|           and m.status = 0 | ||||
|         order by m.parent_id, m.order_num | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectMenuListByUserId" parameterType="SysMenu" resultMap="SysMenuResult"> | ||||
|         select distinct m.menu_id, m.parent_id, m.menu_name, m.path, m.component, m.visible, m.status, | ||||
|         ifnull(m.perms,'') as perms, m.is_frame, m.is_cache, m.menu_type, m.icon, m.order_num, m.create_time | ||||
|         from sys_menu m | ||||
|         left join sys_role_menu rm on m.menu_id = rm.menu_id | ||||
|         left join sys_user_role ur on rm.role_id = ur.role_id | ||||
|         left join sys_role ro on ur.role_id = ro.role_id | ||||
|         where ur.user_id = #{params.userId} | ||||
|         <if test="menuName != null and menuName != ''"> | ||||
|             AND menu_name like concat('%', #{menuName}, '%') | ||||
|         </if> | ||||
|         <if test="visible != null and visible != ''"> | ||||
|             AND visible = #{visible} | ||||
|         </if> | ||||
|         <if test="status != null and status != ''"> | ||||
|             AND status = #{status} | ||||
|         </if> | ||||
|         order by m.parent_id, m.order_num | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectMenuTreeByUserId" parameterType="Long" resultMap="SysMenuResult"> | ||||
|         select distinct m.menu_id, | ||||
|                         m.parent_id, | ||||
|                         m.menu_name, | ||||
|                         m.path, | ||||
|                         m.component, | ||||
|                         m.visible, | ||||
|                         m.status, | ||||
|                         ifnull(m.perms, '') as perms, | ||||
|                         m.is_frame, | ||||
|                         m.is_cache, | ||||
|                         m.menu_type, | ||||
|                         m.icon, | ||||
|                         m.order_num, | ||||
|                         m.create_time | ||||
|         from sys_menu m | ||||
|                  left join sys_role_menu rm on m.menu_id = rm.menu_id | ||||
|                  left join sys_user_role ur on rm.role_id = ur.role_id | ||||
|                  left join sys_role ro on ur.role_id = ro.role_id | ||||
|                  left join sys_user u on ur.user_id = u.user_id | ||||
|         where u.user_id = #{userId} | ||||
|           and m.menu_type in ('M', 'C') | ||||
|           and m.status = 0 | ||||
|           AND ro.status = 0 | ||||
|         order by m.parent_id, m.order_num | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectMenuListByRoleId" resultType="Integer"> | ||||
|         select m.menu_id | ||||
|         from sys_menu m | ||||
|         left join sys_role_menu rm on m.menu_id = rm.menu_id | ||||
|         where rm.role_id = #{roleId} | ||||
|         <if test="menuCheckStrictly"> | ||||
|             and m.menu_id not in (select m.parent_id from sys_menu m inner join sys_role_menu rm on m.menu_id = | ||||
|             rm.menu_id and rm.role_id = #{roleId}) | ||||
|         </if> | ||||
|         order by m.parent_id, m.order_num | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectMenuPerms" resultType="String"> | ||||
|         select distinct m.perms | ||||
|         from sys_menu m | ||||
|                  left join sys_role_menu rm on m.menu_id = rm.menu_id | ||||
|                  left join sys_user_role ur on rm.role_id = ur.role_id | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectMenuPermsByUserId" parameterType="Long" resultType="String"> | ||||
|         select distinct m.perms | ||||
|         from sys_menu m | ||||
|                  left join sys_role_menu rm on m.menu_id = rm.menu_id | ||||
|                  left join sys_user_role ur on rm.role_id = ur.role_id | ||||
|                  left join sys_role r on r.role_id = ur.role_id | ||||
|         where m.status = '0' | ||||
|           and r.status = '0' | ||||
|           and ur.user_id = #{userId} | ||||
|     </select> | ||||
|  | ||||
| </mapper>  | ||||
| @ -0,0 +1,20 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysNoticeMapper"> | ||||
|  | ||||
|     <resultMap type="SysNotice" id="SysNoticeResult"> | ||||
|         <result property="noticeId" column="notice_id"/> | ||||
|         <result property="noticeTitle" column="notice_title"/> | ||||
|         <result property="noticeType" column="notice_type"/> | ||||
|         <result property="noticeContent" column="notice_content"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|         <result property="remark" column="remark"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper> | ||||
| @ -0,0 +1,26 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysOperLogMapper"> | ||||
|  | ||||
|     <resultMap type="SysOperLog" id="SysOperLogResult"> | ||||
|         <id property="operId" column="oper_id"/> | ||||
|         <result property="title" column="title"/> | ||||
|         <result property="businessType" column="business_type"/> | ||||
|         <result property="method" column="method"/> | ||||
|         <result property="requestMethod" column="request_method"/> | ||||
|         <result property="operatorType" column="operator_type"/> | ||||
|         <result property="operName" column="oper_name"/> | ||||
|         <result property="deptName" column="dept_name"/> | ||||
|         <result property="operUrl" column="oper_url"/> | ||||
|         <result property="operIp" column="oper_ip"/> | ||||
|         <result property="operLocation" column="oper_location"/> | ||||
|         <result property="operParam" column="oper_param"/> | ||||
|         <result property="jsonResult" column="json_result"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="errorMsg" column="error_msg"/> | ||||
|         <result property="operTime" column="oper_time"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper>  | ||||
| @ -0,0 +1,48 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysPostMapper"> | ||||
|  | ||||
|     <resultMap type="SysPost" id="SysPostResult"> | ||||
|         <id property="postId" column="post_id"/> | ||||
|         <result property="postCode" column="post_code"/> | ||||
|         <result property="postName" column="post_name"/> | ||||
|         <result property="postSort" column="post_sort"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|         <result property="remark" column="remark"/> | ||||
|     </resultMap> | ||||
|  | ||||
|     <sql id="selectPostVo"> | ||||
|         select post_id, | ||||
|                post_code, | ||||
|                post_name, | ||||
|                post_sort, | ||||
|                status, | ||||
|                create_by, | ||||
|                create_time, | ||||
|                remark | ||||
|         from sys_post | ||||
|     </sql> | ||||
|  | ||||
|     <select id="selectPostListByUserId" parameterType="Long" resultType="Integer"> | ||||
|         select p.post_id | ||||
|         from sys_post p | ||||
|                  left join sys_user_post up on up.post_id = p.post_id | ||||
|                  left join sys_user u on u.user_id = up.user_id | ||||
|         where u.user_id = #{userId} | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectPostsByUserName" parameterType="String" resultMap="SysPostResult"> | ||||
|         select p.post_id, p.post_name, p.post_code | ||||
|         from sys_post p | ||||
|                  left join sys_user_post up on up.post_id = p.post_id | ||||
|                  left join sys_user u on u.user_id = up.user_id | ||||
|         where u.user_name = #{userName} | ||||
|     </select> | ||||
|  | ||||
| </mapper>  | ||||
| @ -0,0 +1,12 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysRoleDeptMapper"> | ||||
|  | ||||
|     <resultMap type="SysRoleDept" id="SysRoleDeptResult"> | ||||
|         <result property="roleId" column="role_id"/> | ||||
|         <result property="deptId" column="dept_id"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper> | ||||
							
								
								
									
										110
									
								
								ruoyi-system/src/main/resources/mapper/system/SysRoleMapper.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								ruoyi-system/src/main/resources/mapper/system/SysRoleMapper.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,110 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysRoleMapper"> | ||||
|  | ||||
|     <resultMap type="SysRole" id="SysRoleResult"> | ||||
|         <id property="roleId" column="role_id"/> | ||||
|         <result property="roleName" column="role_name"/> | ||||
|         <result property="roleKey" column="role_key"/> | ||||
|         <result property="roleSort" column="role_sort"/> | ||||
|         <result property="dataScope" column="data_scope"/> | ||||
|         <result property="menuCheckStrictly" column="menu_check_strictly"/> | ||||
|         <result property="deptCheckStrictly" column="dept_check_strictly"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="delFlag" column="del_flag"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|         <result property="remark" column="remark"/> | ||||
|     </resultMap> | ||||
|  | ||||
|     <sql id="selectRoleVo"> | ||||
|         select distinct r.role_id, | ||||
|                         r.role_name, | ||||
|                         r.role_key, | ||||
|                         r.role_sort, | ||||
|                         r.data_scope, | ||||
|                         r.menu_check_strictly, | ||||
|                         r.dept_check_strictly, | ||||
|                         r.status, | ||||
|                         r.del_flag, | ||||
|                         r.create_time, | ||||
|                         r.remark | ||||
|         from sys_role r | ||||
|                  left join sys_user_role ur on ur.role_id = r.role_id | ||||
|                  left join sys_user u on u.user_id = ur.user_id | ||||
|                  left join sys_dept d on u.dept_id = d.dept_id | ||||
|     </sql> | ||||
|  | ||||
|     <select id="selectPageRoleList" parameterType="SysRole" resultMap="SysRoleResult"> | ||||
|         <include refid="selectRoleVo"/> | ||||
|         where r.del_flag = '0' | ||||
|         <if test="role.roleName != null and role.roleName != ''"> | ||||
|             AND r.role_name like concat('%', #{role.roleName}, '%') | ||||
|         </if> | ||||
|         <if test="role.status != null and role.status != ''"> | ||||
|             AND r.status = #{role.status} | ||||
|         </if> | ||||
|         <if test="role.roleKey != null and role.roleKey != ''"> | ||||
|             AND r.role_key like concat('%', #{role.roleKey}, '%') | ||||
|         </if> | ||||
|         <if test="role.params.beginTime != null and role.params.beginTime != ''"><!-- 开始时间检索 --> | ||||
|             and date_format(r.create_time,'%y%m%d') >= date_format(#{role.params.beginTime},'%y%m%d') | ||||
|         </if> | ||||
|         <if test="role.params.endTime != null and role.params.endTime != ''"><!-- 结束时间检索 --> | ||||
|             and date_format(r.create_time,'%y%m%d') <= date_format(#{role.params.endTime},'%y%m%d') | ||||
|         </if> | ||||
|         <!-- 数据范围过滤 --> | ||||
|         <if test="role.params.dataScope != null and role.params.dataScope != ''"> | ||||
|             AND ( ${role.params.dataScope} ) | ||||
|         </if> | ||||
|         order by r.role_sort | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectRoleList" parameterType="SysRole" resultMap="SysRoleResult"> | ||||
|         <include refid="selectRoleVo"/> | ||||
|         where r.del_flag = '0' | ||||
|         <if test="roleName != null and roleName != ''"> | ||||
|             AND r.role_name like concat('%', #{roleName}, '%') | ||||
|         </if> | ||||
|         <if test="status != null and status != ''"> | ||||
|             AND r.status = #{status} | ||||
|         </if> | ||||
|         <if test="roleKey != null and roleKey != ''"> | ||||
|             AND r.role_key like concat('%', #{roleKey}, '%') | ||||
|         </if> | ||||
|         <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> | ||||
|             and date_format(r.create_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d') | ||||
|         </if> | ||||
|         <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> | ||||
|             and date_format(r.create_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d') | ||||
|         </if> | ||||
|         <!-- 数据范围过滤 --> | ||||
|         <if test="params.dataScope != null and params.dataScope != ''"> | ||||
|             AND ( ${params.dataScope} ) | ||||
|         </if> | ||||
|         order by r.role_sort | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectRolePermissionByUserId" parameterType="Long" resultMap="SysRoleResult"> | ||||
|         <include refid="selectRoleVo"/> | ||||
|         WHERE r.del_flag = '0' and ur.user_id = #{userId} | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectRoleListByUserId" parameterType="Long" resultType="Integer"> | ||||
|         select r.role_id | ||||
|         from sys_role r | ||||
|                  left join sys_user_role ur on ur.role_id = r.role_id | ||||
|                  left join sys_user u on u.user_id = ur.user_id | ||||
|         where u.user_id = #{userId} | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectRolesByUserName" parameterType="String" resultMap="SysRoleResult"> | ||||
|         <include refid="selectRoleVo"/> | ||||
|         WHERE r.del_flag = '0' and u.user_name = #{userName} | ||||
|     </select> | ||||
|  | ||||
| </mapper> | ||||
| @ -0,0 +1,12 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysRoleMenuMapper"> | ||||
|  | ||||
|     <resultMap type="SysRoleMenu" id="SysRoleMenuResult"> | ||||
|         <result property="roleId" column="role_id"/> | ||||
|         <result property="menuId" column="menu_id"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper> | ||||
							
								
								
									
										156
									
								
								ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										156
									
								
								ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,156 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysUserMapper"> | ||||
|  | ||||
|     <resultMap type="SysUser" id="SysUserResult"> | ||||
|         <id property="userId" column="user_id"/> | ||||
|         <result property="deptId" column="dept_id"/> | ||||
|         <result property="userName" column="user_name"/> | ||||
|         <result property="nickName" column="nick_name"/> | ||||
|         <result property="email" column="email"/> | ||||
|         <result property="phonenumber" column="phonenumber"/> | ||||
|         <result property="sex" column="sex"/> | ||||
|         <result property="avatar" column="avatar"/> | ||||
|         <result property="password" column="password"/> | ||||
|         <result property="status" column="status"/> | ||||
|         <result property="delFlag" column="del_flag"/> | ||||
|         <result property="loginIp" column="login_ip"/> | ||||
|         <result property="loginDate" column="login_date"/> | ||||
|         <result property="createBy" column="create_by"/> | ||||
|         <result property="createTime" column="create_time"/> | ||||
|         <result property="updateBy" column="update_by"/> | ||||
|         <result property="updateTime" column="update_time"/> | ||||
|         <result property="remark" column="remark"/> | ||||
|         <association property="dept" column="dept_id" javaType="SysDept" resultMap="deptResult"/> | ||||
|         <collection property="roles" javaType="java.util.List" resultMap="RoleResult"/> | ||||
|     </resultMap> | ||||
|  | ||||
|     <resultMap id="deptResult" type="SysDept"> | ||||
|         <id property="deptId" column="dept_id"/> | ||||
|         <result property="parentId" column="parent_id"/> | ||||
|         <result property="deptName" column="dept_name"/> | ||||
|         <result property="orderNum" column="order_num"/> | ||||
|         <result property="leader" column="leader"/> | ||||
|         <result property="status" column="dept_status"/> | ||||
|     </resultMap> | ||||
|  | ||||
|     <resultMap id="RoleResult" type="SysRole"> | ||||
|         <id property="roleId" column="role_id"/> | ||||
|         <result property="roleName" column="role_name"/> | ||||
|         <result property="roleKey" column="role_key"/> | ||||
|         <result property="roleSort" column="role_sort"/> | ||||
|         <result property="dataScope" column="data_scope"/> | ||||
|         <result property="status" column="role_status"/> | ||||
|     </resultMap> | ||||
|  | ||||
|     <sql id="selectUserVo"> | ||||
|         select u.user_id, | ||||
|                u.dept_id, | ||||
|                u.user_name, | ||||
|                u.nick_name, | ||||
|                u.email, | ||||
|                u.avatar, | ||||
|                u.phonenumber, | ||||
|                u.password, | ||||
|                u.sex, | ||||
|                u.status, | ||||
|                u.del_flag, | ||||
|                u.login_ip, | ||||
|                u.login_date, | ||||
|                u.create_by, | ||||
|                u.create_time, | ||||
|                u.remark, | ||||
|                d.dept_id, | ||||
|                d.parent_id, | ||||
|                d.dept_name, | ||||
|                d.order_num, | ||||
|                d.leader, | ||||
|                d.status as dept_status, | ||||
|                r.role_id, | ||||
|                r.role_name, | ||||
|                r.role_key, | ||||
|                r.role_sort, | ||||
|                r.data_scope, | ||||
|                r.status as role_status | ||||
|         from sys_user u | ||||
|                  left join sys_dept d on u.dept_id = d.dept_id | ||||
|                  left join sys_user_role ur on u.user_id = ur.user_id | ||||
|                  left join sys_role r on r.role_id = ur.role_id | ||||
|     </sql> | ||||
|  | ||||
|     <select id="selectPageUserList" parameterType="SysUser" resultMap="SysUserResult"> | ||||
|         select u.user_id, u.dept_id, u.nick_name, u.user_name, u.email, u.avatar, u.phonenumber, u.password, u.sex, | ||||
|         u.status, u.del_flag, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark, d.dept_name, d.leader from | ||||
|         sys_user u | ||||
|         left join sys_dept d on u.dept_id = d.dept_id | ||||
|         where u.del_flag = '0' | ||||
|         <if test="user.userName != null and user.userName != ''"> | ||||
|             AND u.user_name like concat('%', #{user.userName}, '%') | ||||
|         </if> | ||||
|         <if test="user.status != null and user.status != ''"> | ||||
|             AND u.status = #{user.status} | ||||
|         </if> | ||||
|         <if test="user.phonenumber != null and user.phonenumber != ''"> | ||||
|             AND u.phonenumber like concat('%', #{user.phonenumber}, '%') | ||||
|         </if> | ||||
|         <if test="user.params.beginTime != null and user.params.beginTime != ''"><!-- 开始时间检索 --> | ||||
|             AND date_format(u.create_time,'%y%m%d') >= date_format(#{user.params.beginTime},'%y%m%d') | ||||
|         </if> | ||||
|         <if test="user.params.endTime != null and user.params.endTime != ''"><!-- 结束时间检索 --> | ||||
|             AND date_format(u.create_time,'%y%m%d') <= date_format(#{user.params.endTime},'%y%m%d') | ||||
|         </if> | ||||
|         <if test="user.deptId != null and user.deptId != 0"> | ||||
|             AND (u.dept_id = #{user.deptId} OR u.dept_id IN ( SELECT t.dept_id FROM sys_dept t WHERE find_in_set(#{user.deptId}, | ||||
|             ancestors) )) | ||||
|         </if> | ||||
|         <!-- 数据范围过滤 --> | ||||
|         <if test="user.params.dataScope != null and user.params.dataScope != ''"> | ||||
|             AND ( ${user.params.dataScope} ) | ||||
|         </if> | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectUserList" parameterType="SysUser" resultMap="SysUserResult"> | ||||
|         select u.user_id, u.dept_id, u.nick_name, u.user_name, u.email, u.avatar, u.phonenumber, u.password, u.sex, | ||||
|         u.status, u.del_flag, u.login_ip, u.login_date, u.create_by, u.create_time, u.remark, d.dept_name, d.leader from | ||||
|         sys_user u | ||||
|         left join sys_dept d on u.dept_id = d.dept_id | ||||
|         where u.del_flag = '0' | ||||
|         <if test="userName != null and userName != ''"> | ||||
|             AND u.user_name like concat('%', #{userName}, '%') | ||||
|         </if> | ||||
|         <if test="status != null and status != ''"> | ||||
|             AND u.status = #{status} | ||||
|         </if> | ||||
|         <if test="phonenumber != null and phonenumber != ''"> | ||||
|             AND u.phonenumber like concat('%', #{phonenumber}, '%') | ||||
|         </if> | ||||
|         <if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> | ||||
|             AND date_format(u.create_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d') | ||||
|         </if> | ||||
|         <if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> | ||||
|             AND date_format(u.create_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d') | ||||
|         </if> | ||||
|         <if test="deptId != null and deptId != 0"> | ||||
|             AND (u.dept_id = #{deptId} OR u.dept_id IN ( SELECT t.dept_id FROM sys_dept t WHERE find_in_set(#{deptId}, | ||||
|             ancestors) )) | ||||
|         </if> | ||||
|         <!-- 数据范围过滤 --> | ||||
|         <if test="params.dataScope != null and params.dataScope != ''"> | ||||
|             AND ( ${params.dataScope} ) | ||||
|         </if> | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectUserByUserName" parameterType="String" resultMap="SysUserResult"> | ||||
|         <include refid="selectUserVo"/> | ||||
|         where u.user_name = #{userName} | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectUserById" parameterType="Long" resultMap="SysUserResult"> | ||||
|         <include refid="selectUserVo"/> | ||||
|         where u.user_id = #{userId} | ||||
|     </select> | ||||
|  | ||||
|  | ||||
| </mapper> | ||||
| @ -0,0 +1,12 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysUserPostMapper"> | ||||
|  | ||||
|     <resultMap type="SysUserPost" id="SysUserPostResult"> | ||||
|         <result property="userId" column="user_id"/> | ||||
|         <result property="postId" column="post_id"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper> | ||||
| @ -0,0 +1,12 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <!DOCTYPE mapper | ||||
|         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||
| <mapper namespace="com.ruoyi.system.mapper.SysUserRoleMapper"> | ||||
|  | ||||
|     <resultMap type="SysUserRole" id="SysUserRoleResult"> | ||||
|         <result property="userId" column="user_id"/> | ||||
|         <result property="roleId" column="role_id"/> | ||||
|     </resultMap> | ||||
|  | ||||
| </mapper> | ||||
							
								
								
									
										16
									
								
								ruoyi-system/src/main/resources/rebel.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								ruoyi-system/src/main/resources/rebel.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
|  | ||||
| <!-- | ||||
|   This is the JRebel configuration file. It maps the running application to your IDE workspace, enabling JRebel reloading for this project. | ||||
|   Refer to https://manuals.jrebel.com/jrebel/standalone/config.html for more information. | ||||
| --> | ||||
| <application generated-by="intellij" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.zeroturnaround.com" xsi:schemaLocation="http://www.zeroturnaround.com http://update.zeroturnaround.com/jrebel/rebel-2_3.xsd"> | ||||
|  | ||||
| 	<id>ruoyi-system</id> | ||||
|  | ||||
| 	<classpath> | ||||
| 		<dir name="E:/intellijWork/old-tress-sys/ruoyi-system/target/classes"> | ||||
| 		</dir> | ||||
| 	</classpath> | ||||
|  | ||||
| </application> | ||||
		Reference in New Issue
	
	Block a user
	 zt
					zt