第一次提交
This commit is contained in:
		
							
								
								
									
										28
									
								
								fastbee-service/fastbee-system-service/pom.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								fastbee-service/fastbee-system-service/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>fastbee-service</artifactId> | ||||
|         <groupId>com.fastbee</groupId> | ||||
|         <version>3.8.5</version> | ||||
|     </parent> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
|  | ||||
|     <artifactId>fastbee-system-service</artifactId> | ||||
|  | ||||
|     <description> | ||||
|         system系统模块 | ||||
|     </description> | ||||
|  | ||||
|     <dependencies> | ||||
|  | ||||
|         <!-- 通用工具--> | ||||
|         <dependency> | ||||
|             <groupId>com.fastbee</groupId> | ||||
|             <artifactId>fastbee-common</artifactId> | ||||
|         </dependency> | ||||
|  | ||||
|     </dependencies> | ||||
|  | ||||
| </project> | ||||
| @@ -0,0 +1,92 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import com.fastbee.common.core.domain.BaseEntity; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
|  | ||||
| /** | ||||
|  * app语言对象 app_language | ||||
|  */ | ||||
| public class AppLanguage extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** 主键ID */ | ||||
|     private Long id; | ||||
|  | ||||
|     /** 语言 */ | ||||
|     @ApiModelProperty(value = "语言") | ||||
|     private String language; | ||||
|  | ||||
|     /** 国家 */ | ||||
|     @ApiModelProperty(value = "国家") | ||||
|     private String country; | ||||
|  | ||||
|     /** 时区 */ | ||||
|     @ApiModelProperty(value = "时区") | ||||
|     private String timeZone; | ||||
|  | ||||
|     /** 语言名称 */ | ||||
|     @ApiModelProperty(value = "语言名称") | ||||
|     private String langName; | ||||
|  | ||||
|     public void setId(Long id) | ||||
|     { | ||||
|         this.id = id; | ||||
|     } | ||||
|  | ||||
|     public Long getId() | ||||
|     { | ||||
|         return id; | ||||
|     } | ||||
|     public void setLanguage(String language) | ||||
|     { | ||||
|         this.language = language; | ||||
|     } | ||||
|  | ||||
|     public String getLanguage() | ||||
|     { | ||||
|         return language; | ||||
|     } | ||||
|     public void setCountry(String country) | ||||
|     { | ||||
|         this.country = country; | ||||
|     } | ||||
|  | ||||
|     public String getCountry() | ||||
|     { | ||||
|         return country; | ||||
|     } | ||||
|     public void setTimeZone(String timeZone) | ||||
|     { | ||||
|         this.timeZone = timeZone; | ||||
|     } | ||||
|  | ||||
|     public String getTimeZone() | ||||
|     { | ||||
|         return timeZone; | ||||
|     } | ||||
|     public void setLangName(String langName) | ||||
|     { | ||||
|         this.langName = langName; | ||||
|     } | ||||
|  | ||||
|     public String getLangName() | ||||
|     { | ||||
|         return langName; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("id", getId()) | ||||
|             .append("language", getLanguage()) | ||||
|             .append("country", getCountry()) | ||||
|             .append("timeZone", getTimeZone()) | ||||
|             .append("createBy", getCreateBy()) | ||||
|             .append("createTime", getCreateTime()) | ||||
|             .append("langName", getLangName()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,82 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import com.fastbee.common.core.domain.BaseEntity; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * APP用户偏好设置对象 app_preferences | ||||
|  */ | ||||
| public class AppPreferences extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** 主键id */ | ||||
|     private Long id; | ||||
|  | ||||
|     /** 用户 */ | ||||
|     @ApiModelProperty(value = "用户") | ||||
|     private Long userId; | ||||
|  | ||||
|     /** 语言 */ | ||||
|     @ApiModelProperty(value = "语言") | ||||
|     private String language; | ||||
|  | ||||
|     /** 时区 */ | ||||
|     @ApiModelProperty(value = "时区") | ||||
|     private String timeZone; | ||||
|  | ||||
|     public void setId(Long id) | ||||
|     { | ||||
|         this.id = id; | ||||
|     } | ||||
|  | ||||
|     public Long getId() | ||||
|     { | ||||
|         return id; | ||||
|     } | ||||
|     public void setUserId(Long userId) | ||||
|     { | ||||
|         this.userId = userId; | ||||
|     } | ||||
|  | ||||
|     public Long getUserId() | ||||
|     { | ||||
|         return userId; | ||||
|     } | ||||
|     public void setLanguage(String language) | ||||
|     { | ||||
|         this.language = language; | ||||
|     } | ||||
|  | ||||
|     public String getLanguage() | ||||
|     { | ||||
|         return language; | ||||
|     } | ||||
|     public void setTimeZone(String timeZone) | ||||
|     { | ||||
|         this.timeZone = timeZone; | ||||
|     } | ||||
|  | ||||
|     public String getTimeZone() | ||||
|     { | ||||
|         return timeZone; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("id", getId()) | ||||
|             .append("userId", getUserId()) | ||||
|             .append("language", getLanguage()) | ||||
|             .append("timeZone", getTimeZone()) | ||||
|             .append("createBy", getCreateBy()) | ||||
|             .append("createTime", getCreateTime()) | ||||
|             .append("updateBy", getUpdateBy()) | ||||
|             .append("updateTime", getUpdateTime()) | ||||
|             .append("remark", getRemark()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,81 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
|  | ||||
| /** | ||||
|  * 缓存信息 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class SysCache | ||||
| { | ||||
|     /** 缓存名称 */ | ||||
|     private String cacheName = ""; | ||||
|  | ||||
|     /** 缓存键名 */ | ||||
|     private String cacheKey = ""; | ||||
|  | ||||
|     /** 缓存内容 */ | ||||
|     private String cacheValue = ""; | ||||
|  | ||||
|     /** 备注 */ | ||||
|     private String remark = ""; | ||||
|  | ||||
|     public SysCache() | ||||
|     { | ||||
|  | ||||
|     } | ||||
|  | ||||
|     public SysCache(String cacheName, String remark) | ||||
|     { | ||||
|         this.cacheName = cacheName; | ||||
|         this.remark = remark; | ||||
|     } | ||||
|  | ||||
|     public SysCache(String cacheName, String cacheKey, String cacheValue) | ||||
|     { | ||||
|         this.cacheName = StringUtils.replace(cacheName, ":", ""); | ||||
|         this.cacheKey = StringUtils.replace(cacheKey, cacheName, ""); | ||||
|         this.cacheValue = cacheValue; | ||||
|     } | ||||
|  | ||||
|     public String getCacheName() | ||||
|     { | ||||
|         return cacheName; | ||||
|     } | ||||
|  | ||||
|     public void setCacheName(String cacheName) | ||||
|     { | ||||
|         this.cacheName = cacheName; | ||||
|     } | ||||
|  | ||||
|     public String getCacheKey() | ||||
|     { | ||||
|         return cacheKey; | ||||
|     } | ||||
|  | ||||
|     public void setCacheKey(String cacheKey) | ||||
|     { | ||||
|         this.cacheKey = cacheKey; | ||||
|     } | ||||
|  | ||||
|     public String getCacheValue() | ||||
|     { | ||||
|         return cacheValue; | ||||
|     } | ||||
|  | ||||
|     public void setCacheValue(String cacheValue) | ||||
|     { | ||||
|         this.cacheValue = cacheValue; | ||||
|     } | ||||
|  | ||||
|     public String getRemark() | ||||
|     { | ||||
|         return remark; | ||||
|     } | ||||
|  | ||||
|     public void setRemark(String remark) | ||||
|     { | ||||
|         this.remark = remark; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,64 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import lombok.Data; | ||||
| import lombok.EqualsAndHashCode; | ||||
| import com.fastbee.common.annotation.Excel; | ||||
| import com.fastbee.common.core.domain.BaseEntity; | ||||
|  | ||||
| /** | ||||
|  * 系统授权对象 sys_client | ||||
|  * | ||||
|  * @author zhuangpeng.li | ||||
|  * @date 2024-07-26 | ||||
|  */ | ||||
| @ApiModel(value = "SysClient",description = "系统授权 sys_client") | ||||
| @Data | ||||
| @EqualsAndHashCode(callSuper = true) | ||||
| public class SysClient extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** id唯一标识 */ | ||||
|     private Long id; | ||||
|  | ||||
|     /** 客户端key */ | ||||
|     @Excel(name = "客户端key") | ||||
|     @ApiModelProperty("客户端key") | ||||
|     private String clientKey; | ||||
|  | ||||
|     /** 客户端秘钥 */ | ||||
|     @Excel(name = "客户端秘钥") | ||||
|     @ApiModelProperty("客户端秘钥") | ||||
|     private String clientSecret; | ||||
|  | ||||
|     /** 客户端token */ | ||||
|     @Excel(name = "客户端token") | ||||
|     @ApiModelProperty("客户端token") | ||||
|     private String token; | ||||
|  | ||||
|     /** 授权类型 */ | ||||
|     @Excel(name = "授权类型") | ||||
|     @ApiModelProperty("授权类型") | ||||
|     private String grantType; | ||||
|  | ||||
|     /** 设备类型 */ | ||||
|     @Excel(name = "设备类型") | ||||
|     @ApiModelProperty("设备类型") | ||||
|     private String deviceType; | ||||
|  | ||||
|     /** token固定超时 */ | ||||
|     @Excel(name = "token固定超时") | ||||
|     @ApiModelProperty("token固定超时") | ||||
|     private Long timeout; | ||||
|  | ||||
|     /** 是否生效(0-不生效,1-生效) */ | ||||
|     @Excel(name = "是否生效", readConverterExp = "0=-不生效,1-生效") | ||||
|     @ApiModelProperty("是否生效") | ||||
|     private String enable; | ||||
|  | ||||
|     /** 删除标志(0代表存在 2代表删除) */ | ||||
|     private String delFlag; | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,120 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.Size; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
| import com.fastbee.common.annotation.Excel; | ||||
| import com.fastbee.common.annotation.Excel.ColumnType; | ||||
| import com.fastbee.common.core.domain.BaseEntity; | ||||
|  | ||||
| /** | ||||
|  * 参数配置表 sys_config | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysConfig", description = "参数配置表 sys_config") | ||||
| public class SysConfig extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** 参数主键 */ | ||||
|     @ApiModelProperty("参数主键") | ||||
|     @Excel(name = "参数主键", cellType = ColumnType.NUMERIC) | ||||
|     private Long configId; | ||||
|  | ||||
|     /** 参数名称 */ | ||||
|     @ApiModelProperty("参数名称") | ||||
|     @Excel(name = "参数名称") | ||||
|     private String configName; | ||||
|  | ||||
|     /** 参数键名 */ | ||||
|     @ApiModelProperty("参数键名") | ||||
|     @Excel(name = "参数键名") | ||||
|     private String configKey; | ||||
|  | ||||
|     /** 参数键值 */ | ||||
|     @ApiModelProperty("参数键值") | ||||
|     @Excel(name = "参数键值") | ||||
|     private String configValue; | ||||
|  | ||||
|     /** 系统内置(Y是 N否) */ | ||||
|     @ApiModelProperty("系统内置(Y是 N否)") | ||||
|     @Excel(name = "系统内置", readConverterExp = "Y=是,N=否") | ||||
|     private String configType; | ||||
|  | ||||
|     public Long getConfigId() | ||||
|     { | ||||
|         return configId; | ||||
|     } | ||||
|  | ||||
|     public void setConfigId(Long configId) | ||||
|     { | ||||
|         this.configId = configId; | ||||
|     } | ||||
|  | ||||
|     @NotBlank(message = "参数名称不能为空") | ||||
|     @Size(min = 0, max = 100, message = "参数名称不能超过100个字符") | ||||
|     public String getConfigName() | ||||
|     { | ||||
|         return configName; | ||||
|     } | ||||
|  | ||||
|     public void setConfigName(String configName) | ||||
|     { | ||||
|         this.configName = configName; | ||||
|     } | ||||
|  | ||||
|     @NotBlank(message = "参数键名长度不能为空") | ||||
|     @Size(min = 0, max = 100, message = "参数键名长度不能超过100个字符") | ||||
|     public String getConfigKey() | ||||
|     { | ||||
|         return configKey; | ||||
|     } | ||||
|  | ||||
|     public void setConfigKey(String configKey) | ||||
|     { | ||||
|         this.configKey = configKey; | ||||
|     } | ||||
|  | ||||
|     @NotBlank(message = "参数键值不能为空") | ||||
|     @Size(min = 0, max = 500, message = "参数键值长度不能超过500个字符") | ||||
|     public String getConfigValue() | ||||
|     { | ||||
|         return configValue; | ||||
|     } | ||||
|  | ||||
|     public void setConfigValue(String configValue) | ||||
|     { | ||||
|         this.configValue = configValue; | ||||
|     } | ||||
|  | ||||
|     public String getConfigType() | ||||
|     { | ||||
|         return configType; | ||||
|     } | ||||
|  | ||||
|     public void setConfigType(String configType) | ||||
|     { | ||||
|         this.configType = configType; | ||||
|     } | ||||
|      | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("configId", getConfigId()) | ||||
|             .append("configName", getConfigName()) | ||||
|             .append("configKey", getConfigKey()) | ||||
|             .append("configValue", getConfigValue()) | ||||
|             .append("configType", getConfigType()) | ||||
|             .append("createBy", getCreateBy()) | ||||
|             .append("createTime", getCreateTime()) | ||||
|             .append("updateBy", getUpdateBy()) | ||||
|             .append("updateTime", getUpdateTime()) | ||||
|             .append("remark", getRemark()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,156 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import java.util.Date; | ||||
| import com.fasterxml.jackson.annotation.JsonFormat; | ||||
| import com.fastbee.common.annotation.Excel; | ||||
| import com.fastbee.common.annotation.Excel.ColumnType; | ||||
| import com.fastbee.common.core.domain.BaseEntity; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
|  | ||||
| /** | ||||
|  * 系统访问记录表 sys_logininfor | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysLogininfor", description = "系统访问记录表 sys_logininfor") | ||||
| public class SysLogininfor extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** ID */ | ||||
|     @ApiModelProperty("ID") | ||||
|     @Excel(name = "序号", cellType = ColumnType.NUMERIC) | ||||
|     private Long infoId; | ||||
|  | ||||
|     /** 用户账号 */ | ||||
|     @ApiModelProperty("用户账号") | ||||
|     @Excel(name = "用户账号") | ||||
|     private String userName; | ||||
|  | ||||
|     /** 登录状态 0成功 1失败 */ | ||||
|     @ApiModelProperty("登录状态 0成功 1失败") | ||||
|     @Excel(name = "登录状态", readConverterExp = "0=成功,1=失败") | ||||
|     private String status; | ||||
|  | ||||
|     /** 登录IP地址 */ | ||||
|     @ApiModelProperty("登录IP地址") | ||||
|     @Excel(name = "登录地址") | ||||
|     private String ipaddr; | ||||
|  | ||||
|     /** 登录地点 */ | ||||
|     @ApiModelProperty("登录地点") | ||||
|     @Excel(name = "登录地点") | ||||
|     private String loginLocation; | ||||
|  | ||||
|     /** 浏览器类型 */ | ||||
|     @ApiModelProperty("浏览器类型") | ||||
|     @Excel(name = "浏览器") | ||||
|     private String browser; | ||||
|  | ||||
|     /** 操作系统 */ | ||||
|     @ApiModelProperty("操作系统") | ||||
|     @Excel(name = "操作系统") | ||||
|     private String os; | ||||
|  | ||||
|     /** 提示消息 */ | ||||
|     @ApiModelProperty("提示消息") | ||||
|     @Excel(name = "提示消息") | ||||
|     private String msg; | ||||
|  | ||||
|     /** 访问时间 */ | ||||
|     @ApiModelProperty("访问时间") | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     @Excel(name = "访问时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date loginTime; | ||||
|  | ||||
|     public Long getInfoId() | ||||
|     { | ||||
|         return infoId; | ||||
|     } | ||||
|  | ||||
|     public void setInfoId(Long infoId) | ||||
|     { | ||||
|         this.infoId = infoId; | ||||
|     } | ||||
|  | ||||
|     public String getUserName() | ||||
|     { | ||||
|         return userName; | ||||
|     } | ||||
|  | ||||
|     public void setUserName(String userName) | ||||
|     { | ||||
|         this.userName = userName; | ||||
|     } | ||||
|  | ||||
|     public String getStatus() | ||||
|     { | ||||
|         return status; | ||||
|     } | ||||
|  | ||||
|     public void setStatus(String status) | ||||
|     { | ||||
|         this.status = status; | ||||
|     } | ||||
|  | ||||
|     public String getIpaddr() | ||||
|     { | ||||
|         return ipaddr; | ||||
|     } | ||||
|  | ||||
|     public void setIpaddr(String ipaddr) | ||||
|     { | ||||
|         this.ipaddr = ipaddr; | ||||
|     } | ||||
|  | ||||
|     public String getLoginLocation() | ||||
|     { | ||||
|         return loginLocation; | ||||
|     } | ||||
|  | ||||
|     public void setLoginLocation(String loginLocation) | ||||
|     { | ||||
|         this.loginLocation = loginLocation; | ||||
|     } | ||||
|  | ||||
|     public String getBrowser() | ||||
|     { | ||||
|         return browser; | ||||
|     } | ||||
|  | ||||
|     public void setBrowser(String browser) | ||||
|     { | ||||
|         this.browser = browser; | ||||
|     } | ||||
|  | ||||
|     public String getOs() | ||||
|     { | ||||
|         return os; | ||||
|     } | ||||
|  | ||||
|     public void setOs(String os) | ||||
|     { | ||||
|         this.os = os; | ||||
|     } | ||||
|  | ||||
|     public String getMsg() | ||||
|     { | ||||
|         return msg; | ||||
|     } | ||||
|  | ||||
|     public void setMsg(String msg) | ||||
|     { | ||||
|         this.msg = msg; | ||||
|     } | ||||
|  | ||||
|     public Date getLoginTime() | ||||
|     { | ||||
|         return loginTime; | ||||
|     } | ||||
|  | ||||
|     public void setLoginTime(Date loginTime) | ||||
|     { | ||||
|         this.loginTime = loginTime; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,111 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.Size; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
| import com.fastbee.common.core.domain.BaseEntity; | ||||
| import com.fastbee.common.xss.Xss; | ||||
|  | ||||
| /** | ||||
|  * 通知公告表 sys_notice | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysNotice", description = "通知公告表 sys_notice") | ||||
| public class SysNotice extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** 公告ID */ | ||||
|     @ApiModelProperty("公告ID") | ||||
|     private Long noticeId; | ||||
|  | ||||
|     /** 公告标题 */ | ||||
|     @ApiModelProperty("公告标题") | ||||
|     private String noticeTitle; | ||||
|  | ||||
|     /** 公告类型(1通知 2公告) */ | ||||
|     @ApiModelProperty("公告类型(1通知 2公告)") | ||||
|     private String noticeType; | ||||
|  | ||||
|     /** 公告内容 */ | ||||
|     @ApiModelProperty("公告内容") | ||||
|     private String noticeContent; | ||||
|  | ||||
|     /** 公告状态(0正常 1关闭) */ | ||||
|     @ApiModelProperty("公告状态(0正常 1关闭)") | ||||
|     private String status; | ||||
|  | ||||
|     public Long getNoticeId() | ||||
|     { | ||||
|         return noticeId; | ||||
|     } | ||||
|  | ||||
|     public void setNoticeId(Long noticeId) | ||||
|     { | ||||
|         this.noticeId = noticeId; | ||||
|     } | ||||
|  | ||||
|     public void setNoticeTitle(String noticeTitle) | ||||
|     { | ||||
|         this.noticeTitle = noticeTitle; | ||||
|     } | ||||
|  | ||||
|     @Xss(message = "公告标题不能包含脚本字符") | ||||
|     @NotBlank(message = "公告标题不能为空") | ||||
|     @Size(min = 0, max = 50, message = "公告标题不能超过50个字符") | ||||
|     public String getNoticeTitle() | ||||
|     { | ||||
|         return noticeTitle; | ||||
|     } | ||||
|  | ||||
|     public void setNoticeType(String noticeType) | ||||
|     { | ||||
|         this.noticeType = noticeType; | ||||
|     } | ||||
|  | ||||
|     public String getNoticeType() | ||||
|     { | ||||
|         return noticeType; | ||||
|     } | ||||
|  | ||||
|     public void setNoticeContent(String noticeContent) | ||||
|     { | ||||
|         this.noticeContent = noticeContent; | ||||
|     } | ||||
|  | ||||
|     public String getNoticeContent() | ||||
|     { | ||||
|         return noticeContent; | ||||
|     } | ||||
|  | ||||
|     public void setStatus(String status) | ||||
|     { | ||||
|         this.status = status; | ||||
|     } | ||||
|  | ||||
|     public String getStatus() | ||||
|     { | ||||
|         return status; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("noticeId", getNoticeId()) | ||||
|             .append("noticeTitle", getNoticeTitle()) | ||||
|             .append("noticeType", getNoticeType()) | ||||
|             .append("noticeContent", getNoticeContent()) | ||||
|             .append("status", getStatus()) | ||||
|             .append("createBy", getCreateBy()) | ||||
|             .append("createTime", getCreateTime()) | ||||
|             .append("updateBy", getUpdateBy()) | ||||
|             .append("updateTime", getUpdateTime()) | ||||
|             .append("remark", getRemark()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,275 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import java.util.Date; | ||||
| import com.fasterxml.jackson.annotation.JsonFormat; | ||||
| import com.fastbee.common.annotation.Excel; | ||||
| import com.fastbee.common.annotation.Excel.ColumnType; | ||||
| import com.fastbee.common.core.domain.BaseEntity; | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
|  | ||||
| /** | ||||
|  * 操作日志记录表 oper_log | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysOperLog", description = "操作日志记录表 oper_log") | ||||
| public class SysOperLog extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** 日志主键 */ | ||||
|     @ApiModelProperty("日志主键") | ||||
|     @Excel(name = "操作序号", cellType = ColumnType.NUMERIC) | ||||
|     private Long operId; | ||||
|  | ||||
|     /** 操作模块 */ | ||||
|     @ApiModelProperty("操作模块") | ||||
|     @Excel(name = "操作模块") | ||||
|     private String title; | ||||
|  | ||||
|     /** 业务类型(0其它 1新增 2修改 3删除) */ | ||||
|     @ApiModelProperty(value = "业务类型", notes = "0其它 1新增 2修改 3删除") | ||||
|     @Excel(name = "业务类型", readConverterExp = "0=其它,1=新增,2=修改,3=删除,4=授权,5=导出,6=导入,7=强退,8=生成代码,9=清空数据") | ||||
|     private Integer businessType; | ||||
|  | ||||
|     /** 业务类型数组 */ | ||||
|     @ApiModelProperty("业务类型数组") | ||||
|     private Integer[] businessTypes; | ||||
|  | ||||
|     /** 请求方法 */ | ||||
|     @ApiModelProperty("请求方法") | ||||
|     @Excel(name = "请求方法") | ||||
|     private String method; | ||||
|  | ||||
|     /** 请求方式 */ | ||||
|     @ApiModelProperty("请求方式") | ||||
|     @Excel(name = "请求方式") | ||||
|     private String requestMethod; | ||||
|  | ||||
|     /** 操作类别(0其它 1后台用户 2手机端用户) */ | ||||
|     @ApiModelProperty(value = "操作类别", notes = "(0其它 1后台用户 2手机端用户)") | ||||
|     @Excel(name = "操作类别", readConverterExp = "0=其它,1=后台用户,2=手机端用户") | ||||
|     private Integer operatorType; | ||||
|  | ||||
|     /** 操作人员 */ | ||||
|     @ApiModelProperty("操作人员") | ||||
|     @Excel(name = "操作人员") | ||||
|     private String operName; | ||||
|  | ||||
|     /** 部门名称 */ | ||||
|     @ApiModelProperty("部门名称") | ||||
|     @Excel(name = "部门名称") | ||||
|     private String deptName; | ||||
|  | ||||
|     /** 请求url */ | ||||
|     @ApiModelProperty("请求url") | ||||
|     @Excel(name = "请求地址") | ||||
|     private String operUrl; | ||||
|  | ||||
|     /** 操作地址 */ | ||||
|     @ApiModelProperty("操作地址") | ||||
|     @Excel(name = "操作地址") | ||||
|     private String operIp; | ||||
|  | ||||
|     /** 操作地点 */ | ||||
|     @ApiModelProperty("操作地点") | ||||
|     @Excel(name = "操作地点") | ||||
|     private String operLocation; | ||||
|  | ||||
|     /** 请求参数 */ | ||||
|     @ApiModelProperty("请求参数") | ||||
|     @Excel(name = "请求参数") | ||||
|     private String operParam; | ||||
|  | ||||
|     /** 返回参数 */ | ||||
|     @ApiModelProperty("返回参数") | ||||
|     @Excel(name = "返回参数") | ||||
|     private String jsonResult; | ||||
|  | ||||
|     /** 操作状态(0正常 1异常) */ | ||||
|     @ApiModelProperty("操作状态(0正常 1异常)") | ||||
|     @Excel(name = "状态", readConverterExp = "0=正常,1=异常") | ||||
|     private Integer status; | ||||
|  | ||||
|     /** 错误消息 */ | ||||
|     @ApiModelProperty("错误消息") | ||||
|     @Excel(name = "错误消息") | ||||
|     private String errorMsg; | ||||
|  | ||||
|     /** 操作时间 */ | ||||
|     @ApiModelProperty("操作时间") | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||
|     @Excel(name = "操作时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss") | ||||
|     private Date operTime; | ||||
|  | ||||
|     public Long getOperId() | ||||
|     { | ||||
|         return operId; | ||||
|     } | ||||
|  | ||||
|     public void setOperId(Long operId) | ||||
|     { | ||||
|         this.operId = operId; | ||||
|     } | ||||
|  | ||||
|     public String getTitle() | ||||
|     { | ||||
|         return title; | ||||
|     } | ||||
|  | ||||
|     public void setTitle(String title) | ||||
|     { | ||||
|         this.title = title; | ||||
|     } | ||||
|  | ||||
|     public Integer getBusinessType() | ||||
|     { | ||||
|         return businessType; | ||||
|     } | ||||
|  | ||||
|     public void setBusinessType(Integer businessType) | ||||
|     { | ||||
|         this.businessType = businessType; | ||||
|     } | ||||
|  | ||||
|     public Integer[] getBusinessTypes() | ||||
|     { | ||||
|         return businessTypes; | ||||
|     } | ||||
|  | ||||
|     public void setBusinessTypes(Integer[] businessTypes) | ||||
|     { | ||||
|         this.businessTypes = businessTypes; | ||||
|     } | ||||
|  | ||||
|     public String getMethod() | ||||
|     { | ||||
|         return method; | ||||
|     } | ||||
|  | ||||
|     public void setMethod(String method) | ||||
|     { | ||||
|         this.method = method; | ||||
|     } | ||||
|  | ||||
|     public String getRequestMethod() | ||||
|     { | ||||
|         return requestMethod; | ||||
|     } | ||||
|  | ||||
|     public void setRequestMethod(String requestMethod) | ||||
|     { | ||||
|         this.requestMethod = requestMethod; | ||||
|     } | ||||
|  | ||||
|     public Integer getOperatorType() | ||||
|     { | ||||
|         return operatorType; | ||||
|     } | ||||
|  | ||||
|     public void setOperatorType(Integer operatorType) | ||||
|     { | ||||
|         this.operatorType = operatorType; | ||||
|     } | ||||
|  | ||||
|     public String getOperName() | ||||
|     { | ||||
|         return operName; | ||||
|     } | ||||
|  | ||||
|     public void setOperName(String operName) | ||||
|     { | ||||
|         this.operName = operName; | ||||
|     } | ||||
|  | ||||
|     public String getDeptName() | ||||
|     { | ||||
|         return deptName; | ||||
|     } | ||||
|  | ||||
|     public void setDeptName(String deptName) | ||||
|     { | ||||
|         this.deptName = deptName; | ||||
|     } | ||||
|  | ||||
|     public String getOperUrl() | ||||
|     { | ||||
|         return operUrl; | ||||
|     } | ||||
|  | ||||
|     public void setOperUrl(String operUrl) | ||||
|     { | ||||
|         this.operUrl = operUrl; | ||||
|     } | ||||
|  | ||||
|     public String getOperIp() | ||||
|     { | ||||
|         return operIp; | ||||
|     } | ||||
|  | ||||
|     public void setOperIp(String operIp) | ||||
|     { | ||||
|         this.operIp = operIp; | ||||
|     } | ||||
|  | ||||
|     public String getOperLocation() | ||||
|     { | ||||
|         return operLocation; | ||||
|     } | ||||
|  | ||||
|     public void setOperLocation(String operLocation) | ||||
|     { | ||||
|         this.operLocation = operLocation; | ||||
|     } | ||||
|  | ||||
|     public String getOperParam() | ||||
|     { | ||||
|         return operParam; | ||||
|     } | ||||
|  | ||||
|     public void setOperParam(String operParam) | ||||
|     { | ||||
|         this.operParam = operParam; | ||||
|     } | ||||
|  | ||||
|     public String getJsonResult() | ||||
|     { | ||||
|         return jsonResult; | ||||
|     } | ||||
|  | ||||
|     public void setJsonResult(String jsonResult) | ||||
|     { | ||||
|         this.jsonResult = jsonResult; | ||||
|     } | ||||
|  | ||||
|     public Integer getStatus() | ||||
|     { | ||||
|         return status; | ||||
|     } | ||||
|  | ||||
|     public void setStatus(Integer status) | ||||
|     { | ||||
|         this.status = status; | ||||
|     } | ||||
|  | ||||
|     public String getErrorMsg() | ||||
|     { | ||||
|         return errorMsg; | ||||
|     } | ||||
|  | ||||
|     public void setErrorMsg(String errorMsg) | ||||
|     { | ||||
|         this.errorMsg = errorMsg; | ||||
|     } | ||||
|  | ||||
|     public Date getOperTime() | ||||
|     { | ||||
|         return operTime; | ||||
|     } | ||||
|  | ||||
|     public void setOperTime(Date operTime) | ||||
|     { | ||||
|         this.operTime = operTime; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,133 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import javax.validation.constraints.NotBlank; | ||||
| import javax.validation.constraints.NotNull; | ||||
| import javax.validation.constraints.Size; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
| import com.fastbee.common.annotation.Excel; | ||||
| import com.fastbee.common.annotation.Excel.ColumnType; | ||||
| import com.fastbee.common.core.domain.BaseEntity; | ||||
|  | ||||
| /** | ||||
|  * 岗位表 sys_post | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysPost", description = "岗位表 sys_post") | ||||
| public class SysPost extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
|     /** 岗位序号 */ | ||||
|     @ApiModelProperty("岗位序号") | ||||
|     @Excel(name = "岗位序号", cellType = ColumnType.NUMERIC) | ||||
|     private Long postId; | ||||
|  | ||||
|     /** 岗位编码 */ | ||||
|     @ApiModelProperty("岗位编码") | ||||
|     @Excel(name = "岗位编码") | ||||
|     private String postCode; | ||||
|  | ||||
|     /** 岗位名称 */ | ||||
|     @ApiModelProperty("岗位名称") | ||||
|     @Excel(name = "岗位名称") | ||||
|     private String postName; | ||||
|  | ||||
|     /** 岗位排序 */ | ||||
|     @ApiModelProperty("岗位排序") | ||||
|     @Excel(name = "岗位排序") | ||||
|     private Integer postSort; | ||||
|  | ||||
|     /** 状态(0正常 1停用) */ | ||||
|     @ApiModelProperty("状态(0正常 1停用)") | ||||
|     @Excel(name = "状态", readConverterExp = "0=正常,1=停用") | ||||
|     private String status; | ||||
|  | ||||
|     /** 用户是否存在此岗位标识 默认不存在 */ | ||||
|     private boolean flag = false; | ||||
|  | ||||
|     public Long getPostId() | ||||
|     { | ||||
|         return postId; | ||||
|     } | ||||
|  | ||||
|     public void setPostId(Long postId) | ||||
|     { | ||||
|         this.postId = postId; | ||||
|     } | ||||
|  | ||||
|     @NotBlank(message = "岗位编码不能为空") | ||||
|     @Size(min = 0, max = 64, message = "岗位编码长度不能超过64个字符") | ||||
|     public String getPostCode() | ||||
|     { | ||||
|         return postCode; | ||||
|     } | ||||
|  | ||||
|     public void setPostCode(String postCode) | ||||
|     { | ||||
|         this.postCode = postCode; | ||||
|     } | ||||
|  | ||||
|     @NotBlank(message = "岗位名称不能为空") | ||||
|     @Size(min = 0, max = 50, message = "岗位名称长度不能超过50个字符") | ||||
|     public String getPostName() | ||||
|     { | ||||
|         return postName; | ||||
|     } | ||||
|  | ||||
|     public void setPostName(String postName) | ||||
|     { | ||||
|         this.postName = postName; | ||||
|     } | ||||
|  | ||||
|     @NotNull(message = "显示顺序不能为空") | ||||
|     public Integer getPostSort() | ||||
|     { | ||||
|         return postSort; | ||||
|     } | ||||
|  | ||||
|     public void setPostSort(Integer postSort) | ||||
|     { | ||||
|         this.postSort = postSort; | ||||
|     } | ||||
|  | ||||
|     public String getStatus() | ||||
|     { | ||||
|         return status; | ||||
|     } | ||||
|  | ||||
|     public void setStatus(String status) | ||||
|     { | ||||
|         this.status = status; | ||||
|     } | ||||
|  | ||||
|     public boolean isFlag() | ||||
|     { | ||||
|         return flag; | ||||
|     } | ||||
|  | ||||
|     public void setFlag(boolean flag) | ||||
|     { | ||||
|         this.flag = flag; | ||||
|     } | ||||
|      | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("postId", getPostId()) | ||||
|             .append("postCode", getPostCode()) | ||||
|             .append("postName", getPostName()) | ||||
|             .append("postSort", getPostSort()) | ||||
|             .append("status", getStatus()) | ||||
|             .append("createBy", getCreateBy()) | ||||
|             .append("createTime", getCreateTime()) | ||||
|             .append("updateBy", getUpdateBy()) | ||||
|             .append("updateTime", getUpdateTime()) | ||||
|             .append("remark", getRemark()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,51 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
|  | ||||
| /** | ||||
|  * 角色和部门关联 sys_role_dept | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysRoleDept", description = "角色和部门关联 sys_role_dept") | ||||
| public class SysRoleDept | ||||
| { | ||||
|     /** 角色ID */ | ||||
|     @ApiModelProperty("角色ID") | ||||
|     private Long roleId; | ||||
|      | ||||
|     /** 部门ID */ | ||||
|     @ApiModelProperty("部门ID") | ||||
|     private Long deptId; | ||||
|  | ||||
|     public Long getRoleId() | ||||
|     { | ||||
|         return roleId; | ||||
|     } | ||||
|  | ||||
|     public void setRoleId(Long roleId) | ||||
|     { | ||||
|         this.roleId = roleId; | ||||
|     } | ||||
|  | ||||
|     public Long getDeptId() | ||||
|     { | ||||
|         return deptId; | ||||
|     } | ||||
|  | ||||
|     public void setDeptId(Long deptId) | ||||
|     { | ||||
|         this.deptId = deptId; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("roleId", getRoleId()) | ||||
|             .append("deptId", getDeptId()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,51 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
|  | ||||
| /** | ||||
|  * 角色和菜单关联 sys_role_menu | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysRoleMenu", description = "角色和菜单关联 sys_role_menu") | ||||
| public class SysRoleMenu | ||||
| { | ||||
|     /** 角色ID */ | ||||
|     @ApiModelProperty("角色ID") | ||||
|     private Long roleId; | ||||
|      | ||||
|     /** 菜单ID */ | ||||
|     @ApiModelProperty("菜单ID") | ||||
|     private Long menuId; | ||||
|  | ||||
|     public Long getRoleId() | ||||
|     { | ||||
|         return roleId; | ||||
|     } | ||||
|  | ||||
|     public void setRoleId(Long roleId) | ||||
|     { | ||||
|         this.roleId = roleId; | ||||
|     } | ||||
|  | ||||
|     public Long getMenuId() | ||||
|     { | ||||
|         return menuId; | ||||
|     } | ||||
|  | ||||
|     public void setMenuId(Long menuId) | ||||
|     { | ||||
|         this.menuId = menuId; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("roleId", getRoleId()) | ||||
|             .append("menuId", getMenuId()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,113 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| /** | ||||
|  * 当前在线会话 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| 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; | ||||
|  | ||||
|     public String getTokenId() | ||||
|     { | ||||
|         return tokenId; | ||||
|     } | ||||
|  | ||||
|     public void setTokenId(String tokenId) | ||||
|     { | ||||
|         this.tokenId = tokenId; | ||||
|     } | ||||
|  | ||||
|     public String getDeptName() | ||||
|     { | ||||
|         return deptName; | ||||
|     } | ||||
|  | ||||
|     public void setDeptName(String deptName) | ||||
|     { | ||||
|         this.deptName = deptName; | ||||
|     } | ||||
|  | ||||
|     public String getUserName() | ||||
|     { | ||||
|         return userName; | ||||
|     } | ||||
|  | ||||
|     public void setUserName(String userName) | ||||
|     { | ||||
|         this.userName = userName; | ||||
|     } | ||||
|  | ||||
|     public String getIpaddr() | ||||
|     { | ||||
|         return ipaddr; | ||||
|     } | ||||
|  | ||||
|     public void setIpaddr(String ipaddr) | ||||
|     { | ||||
|         this.ipaddr = ipaddr; | ||||
|     } | ||||
|  | ||||
|     public String getLoginLocation() | ||||
|     { | ||||
|         return loginLocation; | ||||
|     } | ||||
|  | ||||
|     public void setLoginLocation(String loginLocation) | ||||
|     { | ||||
|         this.loginLocation = loginLocation; | ||||
|     } | ||||
|  | ||||
|     public String getBrowser() | ||||
|     { | ||||
|         return browser; | ||||
|     } | ||||
|  | ||||
|     public void setBrowser(String browser) | ||||
|     { | ||||
|         this.browser = browser; | ||||
|     } | ||||
|  | ||||
|     public String getOs() | ||||
|     { | ||||
|         return os; | ||||
|     } | ||||
|  | ||||
|     public void setOs(String os) | ||||
|     { | ||||
|         this.os = os; | ||||
|     } | ||||
|  | ||||
|     public Long getLoginTime() | ||||
|     { | ||||
|         return loginTime; | ||||
|     } | ||||
|  | ||||
|     public void setLoginTime(Long loginTime) | ||||
|     { | ||||
|         this.loginTime = loginTime; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,51 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
|  | ||||
| /** | ||||
|  * 用户和岗位关联 sys_user_post | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysUserPost", description = "用户和岗位关联 sys_user_post") | ||||
| public class SysUserPost | ||||
| { | ||||
|     /** 用户ID */ | ||||
|     @ApiModelProperty("用户ID") | ||||
|     private Long userId; | ||||
|      | ||||
|     /** 岗位ID */ | ||||
|     @ApiModelProperty("岗位ID") | ||||
|     private Long postId; | ||||
|  | ||||
|     public Long getUserId() | ||||
|     { | ||||
|         return userId; | ||||
|     } | ||||
|  | ||||
|     public void setUserId(Long userId) | ||||
|     { | ||||
|         this.userId = userId; | ||||
|     } | ||||
|  | ||||
|     public Long getPostId() | ||||
|     { | ||||
|         return postId; | ||||
|     } | ||||
|  | ||||
|     public void setPostId(Long postId) | ||||
|     { | ||||
|         this.postId = postId; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("userId", getUserId()) | ||||
|             .append("postId", getPostId()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,51 @@ | ||||
| package com.fastbee.system.domain; | ||||
|  | ||||
| import io.swagger.annotations.ApiModel; | ||||
| import io.swagger.annotations.ApiModelProperty; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
|  | ||||
| /** | ||||
|  * 用户和角色关联 sys_user_role | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @ApiModel(value = "SysUserRole", description = "用户和角色关联 sys_user_role") | ||||
| public class SysUserRole | ||||
| { | ||||
|     /** 用户ID */ | ||||
|     @ApiModelProperty("用户ID") | ||||
|     private Long userId; | ||||
|      | ||||
|     /** 角色ID */ | ||||
|     @ApiModelProperty("角色ID") | ||||
|     private Long roleId; | ||||
|  | ||||
|     public Long getUserId() | ||||
|     { | ||||
|         return userId; | ||||
|     } | ||||
|  | ||||
|     public void setUserId(Long userId) | ||||
|     { | ||||
|         this.userId = userId; | ||||
|     } | ||||
|  | ||||
|     public Long getRoleId() | ||||
|     { | ||||
|         return roleId; | ||||
|     } | ||||
|  | ||||
|     public void setRoleId(Long roleId) | ||||
|     { | ||||
|         this.roleId = roleId; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
|             .append("userId", getUserId()) | ||||
|             .append("roleId", getRoleId()) | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,106 @@ | ||||
| package com.fastbee.system.domain.vo; | ||||
|  | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
|  | ||||
| /** | ||||
|  * 路由显示信息 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public class MetaVo | ||||
| { | ||||
|     /** | ||||
|      * 设置该路由在侧边栏和面包屑中展示的名字 | ||||
|      */ | ||||
|     private String title; | ||||
|  | ||||
|     /** | ||||
|      * 设置该路由的图标,对应路径src/assets/icons/svg | ||||
|      */ | ||||
|     private String icon; | ||||
|  | ||||
|     /** | ||||
|      * 设置为true,则不会被 <keep-alive>缓存 | ||||
|      */ | ||||
|     private boolean noCache; | ||||
|  | ||||
|     /** | ||||
|      * 内链地址(http(s)://开头) | ||||
|      */ | ||||
|     private String link; | ||||
|  | ||||
|     public MetaVo() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     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; | ||||
|     } | ||||
|  | ||||
|     public MetaVo(String title, String icon, String link) | ||||
|     { | ||||
|         this.title = title; | ||||
|         this.icon = icon; | ||||
|         this.link = link; | ||||
|     } | ||||
|  | ||||
|     public MetaVo(String title, String icon, boolean noCache, String link) | ||||
|     { | ||||
|         this.title = title; | ||||
|         this.icon = icon; | ||||
|         this.noCache = noCache; | ||||
|         if (StringUtils.ishttp(link)) | ||||
|         { | ||||
|             this.link = link; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public boolean isNoCache() | ||||
|     { | ||||
|         return noCache; | ||||
|     } | ||||
|  | ||||
|     public void setNoCache(boolean noCache) | ||||
|     { | ||||
|         this.noCache = noCache; | ||||
|     } | ||||
|  | ||||
|     public String getTitle() | ||||
|     { | ||||
|         return title; | ||||
|     } | ||||
|  | ||||
|     public void setTitle(String title) | ||||
|     { | ||||
|         this.title = title; | ||||
|     } | ||||
|  | ||||
|     public String getIcon() | ||||
|     { | ||||
|         return icon; | ||||
|     } | ||||
|  | ||||
|     public void setIcon(String icon) | ||||
|     { | ||||
|         this.icon = icon; | ||||
|     } | ||||
|  | ||||
|     public String getLink() | ||||
|     { | ||||
|         return link; | ||||
|     } | ||||
|  | ||||
|     public void setLink(String link) | ||||
|     { | ||||
|         this.link = link; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,148 @@ | ||||
| package com.fastbee.system.domain.vo; | ||||
|  | ||||
| import com.fasterxml.jackson.annotation.JsonInclude; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 路由配置信息 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @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; | ||||
|  | ||||
|     /** | ||||
|      * 路由参数:如 {"id": 1, "name": "ry"} | ||||
|      */ | ||||
|     private String query; | ||||
|  | ||||
|     /** | ||||
|      * 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式--如组件页面 | ||||
|      */ | ||||
|     private Boolean alwaysShow; | ||||
|  | ||||
|     /** | ||||
|      * 其他元素 | ||||
|      */ | ||||
|     private MetaVo meta; | ||||
|  | ||||
|     /** | ||||
|      * 子路由 | ||||
|      */ | ||||
|     private List<RouterVo> children; | ||||
|  | ||||
|     public String getName() | ||||
|     { | ||||
|         return name; | ||||
|     } | ||||
|  | ||||
|     public void setName(String name) | ||||
|     { | ||||
|         this.name = name; | ||||
|     } | ||||
|  | ||||
|     public String getPath() | ||||
|     { | ||||
|         return path; | ||||
|     } | ||||
|  | ||||
|     public void setPath(String path) | ||||
|     { | ||||
|         this.path = path; | ||||
|     } | ||||
|  | ||||
|     public boolean getHidden() | ||||
|     { | ||||
|         return hidden; | ||||
|     } | ||||
|  | ||||
|     public void setHidden(boolean hidden) | ||||
|     { | ||||
|         this.hidden = hidden; | ||||
|     } | ||||
|  | ||||
|     public String getRedirect() | ||||
|     { | ||||
|         return redirect; | ||||
|     } | ||||
|  | ||||
|     public void setRedirect(String redirect) | ||||
|     { | ||||
|         this.redirect = redirect; | ||||
|     } | ||||
|  | ||||
|     public String getComponent() | ||||
|     { | ||||
|         return component; | ||||
|     } | ||||
|  | ||||
|     public void setComponent(String component) | ||||
|     { | ||||
|         this.component = component; | ||||
|     } | ||||
|  | ||||
|     public String getQuery() | ||||
|     { | ||||
|         return query; | ||||
|     } | ||||
|  | ||||
|     public void setQuery(String query) | ||||
|     { | ||||
|         this.query = query; | ||||
|     } | ||||
|  | ||||
|     public Boolean getAlwaysShow() | ||||
|     { | ||||
|         return alwaysShow; | ||||
|     } | ||||
|  | ||||
|     public void setAlwaysShow(Boolean alwaysShow) | ||||
|     { | ||||
|         this.alwaysShow = alwaysShow; | ||||
|     } | ||||
|  | ||||
|     public MetaVo getMeta() | ||||
|     { | ||||
|         return meta; | ||||
|     } | ||||
|  | ||||
|     public void setMeta(MetaVo meta) | ||||
|     { | ||||
|         this.meta = meta; | ||||
|     } | ||||
|  | ||||
|     public List<RouterVo> getChildren() | ||||
|     { | ||||
|         return children; | ||||
|     } | ||||
|  | ||||
|     public void setChildren(List<RouterVo> children) | ||||
|     { | ||||
|         this.children = children; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,28 @@ | ||||
| package com.fastbee.system.domain.vo; | ||||
|  | ||||
| import lombok.Data; | ||||
|  | ||||
| /** | ||||
|  * @author fastb | ||||
|  * @version 1.0 | ||||
|  * @description: 机构类型VO | ||||
|  * @date 2024-03-12 16:37 | ||||
|  */ | ||||
| @Data | ||||
| public class SysDeptTypeVO { | ||||
|  | ||||
|     /** | ||||
|      * 机构类型 | ||||
|      */ | ||||
|     private Integer deptType; | ||||
|  | ||||
|     /** | ||||
|      * 机构类型名称 | ||||
|      */ | ||||
|     private String deptTypeName; | ||||
|  | ||||
|     /** | ||||
|      * 祖级列表 | ||||
|      */ | ||||
|     private String ancestors; | ||||
| } | ||||
| @@ -0,0 +1,25 @@ | ||||
| package com.fastbee.system.enums; | ||||
|  | ||||
| public enum Language { | ||||
|     ZH_CN("zh-CN"), | ||||
|     EN("en-US"), | ||||
|     DEFAULT("default"); | ||||
|  | ||||
|     private String value; | ||||
|  | ||||
|     Language(String value) { | ||||
|         this.value = value; | ||||
|     } | ||||
|  | ||||
|     public String getValue() { | ||||
|         return value; | ||||
|     } | ||||
|  | ||||
|     public static String matches(String language) { | ||||
|         if(language.equals("zh")){ | ||||
|             return Language.ZH_CN.value; | ||||
|         }else { | ||||
|             return Language.EN.value; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,60 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
|  | ||||
| import com.fastbee.system.domain.AppLanguage; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * app语言Mapper接口 | ||||
|  */ | ||||
| public interface AppLanguageMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询app语言 | ||||
|      * | ||||
|      * @param id app语言主键 | ||||
|      * @return app语言 | ||||
|      */ | ||||
|     public AppLanguage selectAppLanguageById(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 查询app语言列表 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return app语言集合 | ||||
|      */ | ||||
|     public List<AppLanguage> selectAppLanguageList(AppLanguage appLanguage); | ||||
|  | ||||
|     /** | ||||
|      * 新增app语言 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertAppLanguage(AppLanguage appLanguage); | ||||
|  | ||||
|     /** | ||||
|      * 修改app语言 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateAppLanguage(AppLanguage appLanguage); | ||||
|  | ||||
|     /** | ||||
|      * 删除app语言 | ||||
|      * | ||||
|      * @param id app语言主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAppLanguageById(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除app语言 | ||||
|      * | ||||
|      * @param ids 需要删除的数据主键集合 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAppLanguageByIds(Long[] ids); | ||||
| } | ||||
| @@ -0,0 +1,67 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
|  | ||||
| import com.fastbee.system.domain.AppPreferences; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * APP用户偏好设置Mapper接口 | ||||
|  */ | ||||
| public interface AppPreferencesMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询APP用户偏好设置 | ||||
|      * | ||||
|      * @param id APP用户偏好设置主键 | ||||
|      * @return APP用户偏好设置 | ||||
|      */ | ||||
|     public AppPreferences selectAppPreferencesById(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 查询APP用户偏好设置列表 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return APP用户偏好设置集合 | ||||
|      */ | ||||
|     public List<AppPreferences> selectAppPreferencesList(AppPreferences appPreferences); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID查询APP用户偏好设置 | ||||
|      * @param userId 用户ID | ||||
|      * @return | ||||
|      */ | ||||
|     public AppPreferences selectAppPreferencesByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 新增APP用户偏好设置 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertAppPreferences(AppPreferences appPreferences); | ||||
|  | ||||
|     /** | ||||
|      * 修改APP用户偏好设置 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateAppPreferences(AppPreferences appPreferences); | ||||
|  | ||||
|     /** | ||||
|      * 删除APP用户偏好设置 | ||||
|      * | ||||
|      * @param userId APP用户偏好设置主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAppPreferencesByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除APP用户偏好设置 | ||||
|      * | ||||
|      * @param userIds 需要删除的数据主键集合 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAppPreferencesByUserIds(Long[] userIds); | ||||
| } | ||||
| @@ -0,0 +1,61 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysClient; | ||||
|  | ||||
| /** | ||||
|  * 系统授权Mapper接口 | ||||
|  * | ||||
|  * @author zhuangpeng.li | ||||
|  * @date 2024-07-26 | ||||
|  */ | ||||
| public interface SysClientMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询系统授权 | ||||
|      * | ||||
|      * @param id 系统授权主键 | ||||
|      * @return 系统授权 | ||||
|      */ | ||||
|     public SysClient selectSysClientById(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 查询系统授权列表 | ||||
|      * | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 系统授权集合 | ||||
|      */ | ||||
|     public List<SysClient> selectSysClientList(SysClient sysClient); | ||||
|  | ||||
|     /** | ||||
|      * 新增系统授权 | ||||
|      * | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertSysClient(SysClient sysClient); | ||||
|  | ||||
|     /** | ||||
|      * 修改系统授权 | ||||
|      * | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateSysClient(SysClient sysClient); | ||||
|  | ||||
|     /** | ||||
|      * 删除系统授权 | ||||
|      * | ||||
|      * @param id 系统授权主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteSysClientById(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统授权 | ||||
|      * | ||||
|      * @param ids 需要删除的数据主键集合 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteSysClientByIds(Long[] ids); | ||||
| } | ||||
| @@ -0,0 +1,76 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysConfig; | ||||
|  | ||||
| /** | ||||
|  * 参数配置 数据层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysConfigMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询参数配置信息 | ||||
|      *  | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 参数配置信息 | ||||
|      */ | ||||
|     public SysConfig selectConfig(SysConfig config); | ||||
|  | ||||
|     /** | ||||
|      * 通过ID查询配置 | ||||
|      *  | ||||
|      * @param configId 参数ID | ||||
|      * @return 参数配置信息 | ||||
|      */ | ||||
|     public SysConfig selectConfigById(Long configId); | ||||
|  | ||||
|     /** | ||||
|      * 查询参数配置列表 | ||||
|      *  | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 参数配置集合 | ||||
|      */ | ||||
|     public List<SysConfig> selectConfigList(SysConfig config); | ||||
|  | ||||
|     /** | ||||
|      * 根据键名查询参数配置信息 | ||||
|      *  | ||||
|      * @param configKey 参数键名 | ||||
|      * @return 参数配置信息 | ||||
|      */ | ||||
|     public SysConfig checkConfigKeyUnique(String configKey); | ||||
|  | ||||
|     /** | ||||
|      * 新增参数配置 | ||||
|      *  | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertConfig(SysConfig config); | ||||
|  | ||||
|     /** | ||||
|      * 修改参数配置 | ||||
|      *  | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateConfig(SysConfig config); | ||||
|  | ||||
|     /** | ||||
|      * 删除参数配置 | ||||
|      *  | ||||
|      * @param configId 参数ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteConfigById(Long configId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除参数信息 | ||||
|      *  | ||||
|      * @param configIds 需要删除的参数ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteConfigByIds(Long[] configIds); | ||||
| } | ||||
| @@ -0,0 +1,156 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| import com.fastbee.system.domain.SysRoleDept; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
| import com.fastbee.common.core.domain.entity.SysDept; | ||||
|  | ||||
| /** | ||||
|  * 部门管理 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysDeptMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询部门管理数据 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 部门信息集合 | ||||
|      */ | ||||
|     public List<SysDept> selectDeptList(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询部门树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @param deptCheckStrictly 部门树选择项是否关联显示 | ||||
|      * @return 选中部门列表 | ||||
|      */ | ||||
|     public List<Long> selectDeptListByRoleId(@Param("roleId") Long roleId, @Param("deptCheckStrictly") boolean deptCheckStrictly); | ||||
|  | ||||
|     /** | ||||
|      * 根据部门ID查询信息 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 部门信息 | ||||
|      */ | ||||
|     public SysDept selectDeptById(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 根据ID查询所有子部门 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 部门列表 | ||||
|      */ | ||||
|     public List<SysDept> selectChildrenDeptById(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 根据ID查询所有子部门(正常状态) | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 子部门数 | ||||
|      */ | ||||
|     public int selectNormalChildrenDeptById(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 是否存在子节点 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int hasChildByDeptId(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 查询部门是否存在用户 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int checkDeptExistUser(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 校验部门名称是否唯一 | ||||
|      * | ||||
|      * @param deptName 部门名称 | ||||
|      * @param parentId 父部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public SysDept checkDeptNameUnique(@Param("deptName") String deptName, @Param("parentId") Long parentId); | ||||
|  | ||||
|     /** | ||||
|      * 新增部门信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertDept(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 修改部门信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDept(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 修改所在部门正常状态 | ||||
|      * | ||||
|      * @param deptIds 部门ID组 | ||||
|      */ | ||||
|     public void updateDeptStatusNormal(Long[] deptIds); | ||||
|  | ||||
|     /** | ||||
|      * 修改子元素关系 | ||||
|      * | ||||
|      * @param depts 子元素 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDeptChildren(@Param("depts") List<SysDept> depts); | ||||
|  | ||||
|     /** | ||||
|      * 删除部门管理信息 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteDeptById(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 更新部门管理员 | ||||
|      * @param deptId 部门id | ||||
|      * @param: sysUserId 用户id | ||||
|      * @return int | ||||
|      */ | ||||
|     int updateDeptUserId(@Param("deptId") Long deptId, @Param("deptUserId") Long deptUserId); | ||||
|  | ||||
|     /** | ||||
|      * 查询父子部门 | ||||
|      * @param dept 部门 | ||||
|      * @return java.util.List<com.fastbee.common.core.domain.entity.SysDept> | ||||
|      */ | ||||
|     List<SysDept> listDeptAndChild(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 查询部门信息 | ||||
|      * @param deptIdList 部门id集合 | ||||
|      * @return java.util.List<com.fastbee.common.core.domain.entity.SysDept> | ||||
|      */ | ||||
|     List<SysDept> selectDeptByIds(@Param("deptIdList") List<Long> deptIdList); | ||||
|  | ||||
|     /** | ||||
|      * 查询机构的所有上级绑定租户 | ||||
|      * @param deptId | ||||
|      * @return | ||||
|      */ | ||||
|     List<Long> selectSeniorDeptUser(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 查询web端注册用户机构角色id | ||||
|      * @param deptId | ||||
|      * @return java.lang.Long | ||||
|      */ | ||||
|     Long selectRoleIdByDeptId(Long deptId); | ||||
| } | ||||
| @@ -0,0 +1,134 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import com.fastbee.common.core.domain.entity.SysDictData; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 字典表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysDictDataMapper | ||||
| { | ||||
|     /** | ||||
|      * 根据条件分页查询字典数据 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     public List<SysDictData> selectDictDataList(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询字典数据--返回所有语言 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     public List<SysDictData> selectDictDataListAll(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型查询字典数据 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     public List<SysDictData> selectDictDataByType(@Param("dictType") String dictType); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典键值查询字典数据信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @param dictValue 字典键值 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     public String selectDictLabel(@Param("dictType") String dictType, @Param("dictValue") String dictValue); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典数据ID查询信息 | ||||
|      * | ||||
|      * @param dictCode 字典数据ID | ||||
|      * @param language 语言 | ||||
|      * @return 字典数据 | ||||
|      */ | ||||
|     public SysDictData selectDictDataById(@Param("dictCode") Long dictCode, @Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 查询字典数据 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @return 字典数据 | ||||
|      */ | ||||
|     public int countDictDataByType(String dictType); | ||||
|  | ||||
|     /** | ||||
|      * 通过字典ID删除字典数据信息 | ||||
|      * | ||||
|      * @param dictCode 字典数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteDictDataById(Long dictCode); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除字典数据信息 | ||||
|      * | ||||
|      * @param dictCodes 需要删除的字典数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteDictDataByIds(Long[] dictCodes); | ||||
|  | ||||
|     /** | ||||
|      * 新增字典数据信息 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertDictData(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 修改字典数据信息 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDictData(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 同步修改字典类型 | ||||
|      * | ||||
|      * @param oldDictType 旧字典类型 | ||||
|      * @param newDictType 新旧字典类型 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDictDataType(@Param("oldDictType") String oldDictType, @Param("newDictType") String newDictType); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典分类查询字典数据 | ||||
|      * | ||||
|      * @param dictTypeList 字典分类信息 | ||||
|      * @param language 语言 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     List<SysDictData> selectDictDataListByDictTypes(@Param("dictTypeList") List<String> dictTypeList, @Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典键值查询字典数据信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @param dictValue 字典键值 | ||||
|      * @param language 语言 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     SysDictData selectByDictTypeAndDictValue(@Param("dictType") String dictType, @Param("dictValue") String dictValue, @Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典键值集合查询字典数据信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @param dictValueList 字典键值集合 | ||||
|      * @param language 语言 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     List<SysDictData> listByDictTypeAndDictValue(@Param("dictType") String dictType, @Param("dictValueList") List<String> dictValueList, @Param("language") String language); | ||||
| } | ||||
| @@ -0,0 +1,88 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.common.core.domain.entity.SysDictType; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| /** | ||||
|  * 字典表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysDictTypeMapper | ||||
| { | ||||
|     /** | ||||
|      * 根据条件分页查询字典类型 | ||||
|      * | ||||
|      * @param dictType 字典类型信息 | ||||
|      * @return 字典类型集合信息 | ||||
|      */ | ||||
|     public List<SysDictType> selectDictTypeList(SysDictType dictType); | ||||
|  | ||||
|     /** | ||||
|      * 根据所有字典类型 | ||||
|      * | ||||
|      * @param language 语言 | ||||
|      * @return 字典类型集合信息 | ||||
|      */ | ||||
|     public List<SysDictType> selectDictTypeAll(@Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型ID查询信息 | ||||
|      * | ||||
|      * @param dictId 字典类型ID | ||||
|      * @param language 语言 | ||||
|      * @return 字典类型 | ||||
|      */ | ||||
|     public SysDictType selectDictTypeById(@Param("dictId") Long dictId, @Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型查询信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @param language 语言 | ||||
|      * @return 字典类型 | ||||
|      */ | ||||
|     public SysDictType selectDictTypeByType(@Param("dictType") String dictType, @Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 通过字典ID删除字典信息 | ||||
|      * | ||||
|      * @param dictId 字典ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteDictTypeById(Long dictId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除字典类型信息 | ||||
|      * | ||||
|      * @param dictIds 需要删除的字典ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteDictTypeByIds(Long[] dictIds); | ||||
|  | ||||
|     /** | ||||
|      * 新增字典类型信息 | ||||
|      * | ||||
|      * @param dictType 字典类型信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertDictType(SysDictType dictType); | ||||
|  | ||||
|     /** | ||||
|      * 修改字典类型信息 | ||||
|      * | ||||
|      * @param dictType 字典类型信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDictType(SysDictType dictType); | ||||
|  | ||||
|     /** | ||||
|      * 校验字典类型称是否唯一 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @param language 语言 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public SysDictType checkDictTypeUnique(@Param("dictType") String dictType, @Param("language") String language); | ||||
| } | ||||
| @@ -0,0 +1,42 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysLogininfor; | ||||
|  | ||||
| /** | ||||
|  * 系统访问日志情况信息 数据层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysLogininforMapper | ||||
| { | ||||
|     /** | ||||
|      * 新增系统登录日志 | ||||
|      *  | ||||
|      * @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); | ||||
|  | ||||
|     /** | ||||
|      * 清空系统登录日志 | ||||
|      *  | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int cleanLogininfor(); | ||||
| } | ||||
| @@ -0,0 +1,125 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
| import com.fastbee.common.core.domain.entity.SysMenu; | ||||
|  | ||||
| /** | ||||
|  * 菜单表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysMenuMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询系统菜单列表 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuList(SysMenu menu); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户所有权限 | ||||
|      * | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public List<String> selectMenuPerms(); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户查询系统菜单列表 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuListByUserId(SysMenu menu); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询权限 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public List<String> selectMenuPermsByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询权限 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public List<String> selectMenuPermsByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询菜单 | ||||
|      * | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuTreeAll(@Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询菜单 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuTreeByUserId(@Param("userId") Long userId, @Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询菜单树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @param menuCheckStrictly 菜单树选择项是否关联显示 | ||||
|      * @return 选中菜单列表 | ||||
|      */ | ||||
|     public List<Long> selectMenuListByRoleId(@Param("roleId") Long roleId, @Param("menuCheckStrictly") boolean menuCheckStrictly); | ||||
|  | ||||
|     /** | ||||
|      * 根据菜单ID查询信息 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 菜单信息 | ||||
|      */ | ||||
|     public SysMenu selectMenuById(@Param("menuId") Long menuId, @Param("language") String language); | ||||
|  | ||||
|     /** | ||||
|      * 是否存在菜单子节点 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int hasChildByMenuId(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 menuName 菜单名称 | ||||
|      * @param parentId 父菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public SysMenu checkMenuNameUnique(@Param("menuName") String menuName, @Param("parentId") Long parentId); | ||||
| } | ||||
| @@ -0,0 +1,60 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysNotice; | ||||
|  | ||||
| /** | ||||
|  * 通知公告表 数据层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysNoticeMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询公告信息 | ||||
|      *  | ||||
|      * @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,48 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysOperLog; | ||||
|  | ||||
| /** | ||||
|  * 操作日志 数据层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysOperLogMapper | ||||
| { | ||||
|     /** | ||||
|      * 新增操作日志 | ||||
|      *  | ||||
|      * @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,99 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysPost; | ||||
|  | ||||
| /** | ||||
|  * 岗位信息 数据层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysPostMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询岗位数据集合 | ||||
|      *  | ||||
|      * @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<Long> selectPostListByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 查询用户所属岗位组 | ||||
|      *  | ||||
|      * @param userName 用户名 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public List<SysPost> selectPostsByUserName(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 删除岗位信息 | ||||
|      *  | ||||
|      * @param postId 岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deletePostById(Long postId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除岗位信息 | ||||
|      *  | ||||
|      * @param postIds 需要删除的岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deletePostByIds(Long[] postIds); | ||||
|  | ||||
|     /** | ||||
|      * 修改岗位信息 | ||||
|      *  | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updatePost(SysPost post); | ||||
|  | ||||
|     /** | ||||
|      * 新增岗位信息 | ||||
|      *  | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertPost(SysPost post); | ||||
|  | ||||
|     /** | ||||
|      * 校验岗位名称 | ||||
|      *  | ||||
|      * @param postName 岗位名称 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public SysPost checkPostNameUnique(String postName); | ||||
|  | ||||
|     /** | ||||
|      * 校验岗位编码 | ||||
|      *  | ||||
|      * @param postCode 岗位编码 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public SysPost checkPostCodeUnique(String postCode); | ||||
| } | ||||
| @@ -0,0 +1,66 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysRoleDept; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| /** | ||||
|  * 角色与部门关联表 数据层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysRoleDeptMapper | ||||
| { | ||||
|     /** | ||||
|      * 通过角色ID删除角色和部门关联 | ||||
|      *  | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteRoleDeptByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除角色部门关联信息 | ||||
|      *  | ||||
|      * @param ids 需要删除的数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteRoleDept(Long[] ids); | ||||
|  | ||||
|     /** | ||||
|      * 查询部门使用数量 | ||||
|      *  | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int selectCountRoleDeptByDeptId(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 批量新增角色部门信息 | ||||
|      *  | ||||
|      * @param roleDeptList 角色部门列表 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int batchRoleDept(List<SysRoleDept> roleDeptList); | ||||
|  | ||||
|     /** | ||||
|      * 查询部门角色 | ||||
|      * @param deptIdList 部门id | ||||
|      * @return java.util.List<com.fastbee.system.domain.SysRoleDept> | ||||
|      */ | ||||
|     List<SysRoleDept> selectRoleDeptByDeptIds(@Param("deptIdList") List<Long> deptIdList); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色id查询关联部门 | ||||
|      * @param roleId 角色id | ||||
|      * @return com.fastbee.system.domain.SysRoleDept | ||||
|      */ | ||||
|     SysRoleDept selectByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 查询部门角色 | ||||
|      * @param deptId 部门id | ||||
|      * @return java.util.List<com.fastbee.common.core.domain.entity.SysRole> | ||||
|      */ | ||||
|     List<Long> selectByDeptId(Long deptId); | ||||
| } | ||||
| @@ -0,0 +1,115 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.common.core.domain.entity.SysRole; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| /** | ||||
|  * 角色表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysRoleMapper | ||||
| { | ||||
|     /** | ||||
|      * 根据条件分页查询角色数据 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 角色数据集合信息 | ||||
|      */ | ||||
|     public List<SysRole> selectRoleList(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询角色 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     public List<SysRole> selectRolePermissionByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 查询所有角色 | ||||
|      * | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     public List<SysRole> selectRoleAll(); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取角色选择框列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中角色ID列表 | ||||
|      */ | ||||
|     public List<Long> selectRoleListByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID查询角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 角色对象信息 | ||||
|      */ | ||||
|     public SysRole selectRoleById(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询角色 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     public List<SysRole> selectRolesByUserName(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 校验角色名称是否唯一 | ||||
|      * | ||||
|      * @param roleName 角色名称 | ||||
|      * @return 角色信息 | ||||
|      */ | ||||
|     public SysRole checkRoleNameUnique(String roleName); | ||||
|  | ||||
|     /** | ||||
|      * 校验角色权限是否唯一 | ||||
|      * | ||||
|      * @param roleKey 角色权限 | ||||
|      * @return 角色信息 | ||||
|      */ | ||||
|     public SysRole checkRoleKeyUnique(String roleKey); | ||||
|  | ||||
|     /** | ||||
|      * 修改角色信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateRole(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 新增角色信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertRole(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID删除角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteRoleById(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除角色信息 | ||||
|      * | ||||
|      * @param roleIds 需要删除的角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteRoleByIds(Long[] roleIds); | ||||
|  | ||||
|     /** | ||||
|      * 查询角色信息 | ||||
|      * @param roleIdList 角色id集合 | ||||
|      * @return java.util.List<com.fastbee.common.core.domain.entity.SysRole> | ||||
|      */ | ||||
|     List<SysRole> selectRoleByIds(@Param("roleIdList") List<Long> roleIdList, @Param("roleName") String roleName, @Param("status") String status); | ||||
| } | ||||
| @@ -0,0 +1,51 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysRoleMenu; | ||||
|  | ||||
| /** | ||||
|  * 角色与菜单关联表 数据层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysRoleMenuMapper | ||||
| { | ||||
|     /** | ||||
|      * 查询菜单使用数量 | ||||
|      *  | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int checkMenuExistRole(Long menuId); | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID删除角色和菜单关联 | ||||
|      *  | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteRoleMenuByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除角色菜单关联信息 | ||||
|      *  | ||||
|      * @param ids 需要删除的数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteRoleMenu(Long[] ids); | ||||
|  | ||||
|     /** | ||||
|      * 批量新增角色菜单信息 | ||||
|      *  | ||||
|      * @param roleMenuList 角色菜单列表 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int batchRoleMenu(List<SysRoleMenu> roleMenuList); | ||||
|  | ||||
|     /** | ||||
|      * 查询角色权限 | ||||
|      * @param roleId 角色id | ||||
|      * @return java.util.List<com.fastbee.system.domain.SysRoleMenu> | ||||
|      */ | ||||
|     List<SysRoleMenu> selectRoleMenuList(Long roleId); | ||||
| } | ||||
| @@ -0,0 +1,45 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import com.fastbee.common.core.domain.entity.SysTranslate; | ||||
| import org.apache.ibatis.annotations.Mapper; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 翻译Mapper接口 | ||||
|  * | ||||
|  * @author kerwincui | ||||
|  * @date 2024-05-29 | ||||
|  */ | ||||
| @Mapper | ||||
| public interface SysTranslateMapper | ||||
| { | ||||
|  | ||||
|     /** | ||||
|      * 新增或修改翻译 | ||||
|      * | ||||
|      * @param sysTranslate 翻译 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertSysTranslate(SysTranslate sysTranslate); | ||||
|  | ||||
|     /** | ||||
|      * 查询翻译列表 | ||||
|      * | ||||
|      * @param sysTranslate 翻译 | ||||
|      * @return 翻译集合 | ||||
|      */ | ||||
|     public List<SysTranslate> selectSysTranslateList(SysTranslate sysTranslate); | ||||
|  | ||||
|     /** | ||||
|      * 查询原表数据列表 | ||||
|      * | ||||
|      * @param tableName 表名 | ||||
|      * @param idColumn id列名 | ||||
|      * @param nameColumn 名称列名 | ||||
|      * @return 翻译集合 | ||||
|      */ | ||||
|     public List<SysTranslate> selectSourceList(@Param("tableName") String tableName, @Param("idColumn") String idColumn, @Param("nameColumn") String nameColumn, @Param("productId") Long productId); | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,186 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import com.fastbee.common.core.domain.entity.SysUser; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 用户表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysUserMapper | ||||
| { | ||||
|     /** | ||||
|      * 根据条件分页查询用户列表 | ||||
|      * | ||||
|      * @param sysUser 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     public List<SysUser> selectUserList(SysUser sysUser); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询已配用户角色列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     public List<SysUser> selectAllocatedList(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询未分配用户角色列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     public List<SysUser> selectUnallocatedList(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名查询用户 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     public SysUser selectUserByUserName(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID查询用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     public SysUser selectUserById(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 新增用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertUser(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 修改用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateUser(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 修改用户头像 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @param avatar 头像地址 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateUserAvatar(@Param("userName") String userName, @Param("avatar") String avatar); | ||||
|  | ||||
|     /** | ||||
|      * 重置用户密码 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @param password 密码 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int resetUserPwd(@Param("userName") String userName, @Param("password") String password); | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID删除用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserById(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除用户信息 | ||||
|      * | ||||
|      * @param userIds 需要删除的用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserByIds(Long[] userIds); | ||||
|  | ||||
|     /** | ||||
|      * 校验用户名称是否唯一 | ||||
|      * | ||||
|      * @param userName 用户名称 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public SysUser checkUserNameUnique(String userName); | ||||
|  | ||||
|     /** | ||||
|      * 校验手机号码是否唯一 | ||||
|      * | ||||
|      * @param phonenumber 手机号码 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public SysUser checkPhoneUnique(String phonenumber); | ||||
|  | ||||
|     /** | ||||
|      * 校验email是否唯一 | ||||
|      * | ||||
|      * @param email 用户邮箱 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public SysUser checkEmailUnique(String email); | ||||
|  | ||||
|     /** | ||||
|      * 通过手机号查询用户 | ||||
|      * | ||||
|      * @param phoneNumber 手机号 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     SysUser selectUserByPhoneNumber(String phoneNumber); | ||||
|     /** | ||||
|      * 取消三方登录相关信息 | ||||
|      * @param sysUserId 系统用户id | ||||
|      * @param sourceClientList 来源具体平台 | ||||
|      * @return | ||||
|      */ | ||||
|     int deleteBySysUserIdAndSourceClient(@Param("sysUserId") Long sysUserId, @Param("sourceClientList") List<String> sourceClientList); | ||||
|  | ||||
|     /** | ||||
|      * 取消三方登录相关信息 | ||||
|      * @param sysUserIds 系统用户id集合 | ||||
|      * @param sourceClientList 来源具体平台 | ||||
|      * @return | ||||
|      */ | ||||
|     int deleteBySysUserIdsAndSourceClient(@Param("sysUserIds") Long[] sysUserIds, @Param("sourceClientList") List<String> sourceClientList); | ||||
|  | ||||
|     /** | ||||
|      * 通过部门id删除用户 | ||||
|      * @param deptId 部门id | ||||
|      * @return int | ||||
|      */ | ||||
|     int deleteUserByDeptID(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 获取下级所有子节点用户 | ||||
|      * @param deptId | ||||
|      * @return | ||||
|      */ | ||||
|     List<SysUser> selectAllSubUser(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户id获取当前机构的管理员账号 | ||||
|      * @param userId | ||||
|      * @return | ||||
|      */ | ||||
|     SysUser getDeptUserByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 获取终端用户列表 | ||||
|      * @param user 用户信息 | ||||
|      * @return com.fastbee.common.core.page.TableDataInfo | ||||
|      */ | ||||
|     List<SysUser> listTerminal(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 根据机构id获取当前机构所有非管理用户 | ||||
|      * @return | ||||
|      */ | ||||
|     List<SysUser> selectByDeptId(Long deptId); | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,44 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysUserPost; | ||||
|  | ||||
| /** | ||||
|  * 用户与岗位关联表 数据层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysUserPostMapper | ||||
| { | ||||
|     /** | ||||
|      * 通过用户ID删除用户和岗位关联 | ||||
|      *  | ||||
|      * @param userId 用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserPostByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 通过岗位ID查询岗位使用数量 | ||||
|      *  | ||||
|      * @param postId 岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int countUserPostById(Long postId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除用户和岗位关联 | ||||
|      *  | ||||
|      * @param ids 需要删除的数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserPost(Long[] ids); | ||||
|  | ||||
|     /** | ||||
|      * 批量新增用户岗位信息 | ||||
|      *  | ||||
|      * @param userPostList 用户角色列表 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int batchUserPost(List<SysUserPost> userPostList); | ||||
| } | ||||
| @@ -0,0 +1,69 @@ | ||||
| package com.fastbee.system.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import org.apache.ibatis.annotations.Param; | ||||
| import com.fastbee.system.domain.SysUserRole; | ||||
|  | ||||
| /** | ||||
|  * 用户与角色关联表 数据层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface SysUserRoleMapper | ||||
| { | ||||
|     /** | ||||
|      * 通过用户ID删除用户和角色关联 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserRoleByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除用户和角色关联 | ||||
|      * | ||||
|      * @param ids 需要删除的数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserRole(Long[] ids); | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID查询角色使用数量 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int countUserRoleByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 批量新增用户角色信息 | ||||
|      * | ||||
|      * @param userRoleList 用户角色列表 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int batchUserRole(List<SysUserRole> userRoleList); | ||||
|  | ||||
|     /** | ||||
|      * 删除用户和角色关联信息 | ||||
|      * | ||||
|      * @param userRole 用户和角色关联信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserRoleInfo(SysUserRole userRole); | ||||
|  | ||||
|     /** | ||||
|      * 批量取消授权用户角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @param userIds 需要删除的用户数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteUserRoleInfos(@Param("roleId") Long roleId, @Param("userIds") Long[] userIds); | ||||
|  | ||||
|     /** | ||||
|      * 查询用户相关的角色 | ||||
|      * @param userId 用户id | ||||
|      * @return java.util.List<com.fastbee.system.domain.SysUserRole> | ||||
|      */ | ||||
|     List<SysUserRole> selectRoleByUserId(Long userId); | ||||
| } | ||||
| @@ -0,0 +1,60 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
|  | ||||
| import com.fastbee.system.domain.AppLanguage; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * app语言Service接口 | ||||
|  */ | ||||
| public interface IAppLanguageService | ||||
| { | ||||
|     /** | ||||
|      * 查询app语言 | ||||
|      * | ||||
|      * @param id app语言主键 | ||||
|      * @return app语言 | ||||
|      */ | ||||
|     public AppLanguage selectAppLanguageById(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 查询app语言列表 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return app语言集合 | ||||
|      */ | ||||
|     public List<AppLanguage> selectAppLanguageList(AppLanguage appLanguage); | ||||
|  | ||||
|     /** | ||||
|      * 新增app语言 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertAppLanguage(AppLanguage appLanguage); | ||||
|  | ||||
|     /** | ||||
|      * 修改app语言 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateAppLanguage(AppLanguage appLanguage); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除app语言 | ||||
|      * | ||||
|      * @param ids 需要删除的app语言主键集合 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAppLanguageByIds(Long[] ids); | ||||
|  | ||||
|     /** | ||||
|      * 删除app语言信息 | ||||
|      * | ||||
|      * @param id app语言主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAppLanguageById(Long id); | ||||
| } | ||||
| @@ -0,0 +1,74 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
|  | ||||
| import com.fastbee.system.domain.AppPreferences; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * APP用户偏好设置Service接口 | ||||
|  */ | ||||
| public interface IAppPreferencesService | ||||
| { | ||||
|     /** | ||||
|      * 查询APP用户偏好设置 | ||||
|      * | ||||
|      * @param userId APP用户偏好设置主键 | ||||
|      * @return APP用户偏好设置 | ||||
|      */ | ||||
|     public AppPreferences selectAppPreferencesByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 查询APP用户偏好设置列表 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return APP用户偏好设置集合 | ||||
|      */ | ||||
|     public List<AppPreferences> selectAppPreferencesList(AppPreferences appPreferences); | ||||
|  | ||||
|     /** | ||||
|      * 新增APP用户偏好设置 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertAppPreferences(AppPreferences appPreferences); | ||||
|  | ||||
|     /** | ||||
|      * 修改APP用户偏好设置 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateAppPreferences(AppPreferences appPreferences); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除APP用户偏好设置 | ||||
|      * | ||||
|      * @param userIds 需要删除的APP用户偏好设置主键集合 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAppPreferencesByUserIds(Long[] userIds); | ||||
|  | ||||
|     /** | ||||
|      * 删除APP用户偏好设置信息 | ||||
|      * | ||||
|      * @param userId APP用户偏好设置主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAppPreferencesByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 新增或者更新用户偏好设置 | ||||
|      * @param appPreferences | ||||
|      * @return | ||||
|      */ | ||||
|     public int addOrUpdate(AppPreferences appPreferences); | ||||
|  | ||||
|     /** | ||||
|      * 获取用户偏好语言 | ||||
|      * @param userId | ||||
|      * @return | ||||
|      */ | ||||
|     public String getLanguage(Long userId); | ||||
| } | ||||
| @@ -0,0 +1,61 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysClient; | ||||
|  | ||||
| /** | ||||
|  * 系统授权Service接口 | ||||
|  *  | ||||
|  * @author zhuangpeng.li | ||||
|  * @date 2024-07-26 | ||||
|  */ | ||||
| public interface ISysClientService  | ||||
| { | ||||
|     /** | ||||
|      * 查询系统授权 | ||||
|      *  | ||||
|      * @param id 系统授权主键 | ||||
|      * @return 系统授权 | ||||
|      */ | ||||
|     public SysClient selectSysClientById(Long id); | ||||
|  | ||||
|     /** | ||||
|      * 查询系统授权列表 | ||||
|      *  | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 系统授权集合 | ||||
|      */ | ||||
|     public List<SysClient> selectSysClientList(SysClient sysClient); | ||||
|  | ||||
|     /** | ||||
|      * 新增系统授权 | ||||
|      *  | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertSysClient(SysClient sysClient); | ||||
|  | ||||
|     /** | ||||
|      * 修改系统授权 | ||||
|      *  | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateSysClient(SysClient sysClient); | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统授权 | ||||
|      *  | ||||
|      * @param ids 需要删除的系统授权主键集合 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteSysClientByIds(Long[] ids); | ||||
|  | ||||
|     /** | ||||
|      * 删除系统授权信息 | ||||
|      *  | ||||
|      * @param id 系统授权主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteSysClientById(Long id); | ||||
| } | ||||
| @@ -0,0 +1,89 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysConfig; | ||||
|  | ||||
| /** | ||||
|  * 参数配置 服务层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysConfigService | ||||
| { | ||||
|     /** | ||||
|      * 查询参数配置信息 | ||||
|      *  | ||||
|      * @param configId 参数配置ID | ||||
|      * @return 参数配置信息 | ||||
|      */ | ||||
|     public SysConfig selectConfigById(Long configId); | ||||
|  | ||||
|     /** | ||||
|      * 根据键名查询参数配置信息 | ||||
|      *  | ||||
|      * @param configKey 参数键名 | ||||
|      * @return 参数键值 | ||||
|      */ | ||||
|     public String selectConfigByKey(String configKey); | ||||
|  | ||||
|     /** | ||||
|      * 获取验证码开关 | ||||
|      *  | ||||
|      * @return true开启,false关闭 | ||||
|      */ | ||||
|     public boolean selectCaptchaEnabled(); | ||||
|  | ||||
|     /** | ||||
|      * 查询参数配置列表 | ||||
|      *  | ||||
|      * @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 | ||||
|      */ | ||||
|     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,155 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import com.fastbee.common.core.domain.TreeSelect; | ||||
| import com.fastbee.common.core.domain.entity.SysDept; | ||||
| import com.fastbee.common.core.domain.entity.SysRole; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 部门管理 服务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysDeptService | ||||
| { | ||||
|     /** | ||||
|      * 查询部门管理数据 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 部门信息集合 | ||||
|      */ | ||||
|     public List<SysDept> selectDeptList(SysDept dept); | ||||
|  | ||||
|     /** | ||||
|      * 查询部门树结构信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 部门树信息集合 | ||||
|      */ | ||||
|     public List<TreeSelect> selectDeptTreeList(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<Long> 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 deptId 部门id | ||||
|      */ | ||||
|     public void checkDeptDataScope(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存部门信息 | ||||
|      * | ||||
|      * @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); | ||||
|  | ||||
|     /** | ||||
|      * 更新部门管理员 | ||||
|      * @param deptId 部门id | ||||
|      * @param: sysUserId 用户id | ||||
|      * @return int | ||||
|      */ | ||||
|     int updateDeptUserId(Long deptId, Long deptUserId); | ||||
|  | ||||
|     /** | ||||
|      * 查询部门角色 | ||||
|      * @param deptId 部门id | ||||
|      * @return java.util.List<com.fastbee.common.core.domain.entity.SysRole> | ||||
|      */ | ||||
|     List<SysRole> getRole(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 查询机构的所有上级绑定租户 | ||||
|      * @param deptId | ||||
|      * @return | ||||
|      */ | ||||
|     List<Long> selectSeniorDeptUser(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 查询web端注册用户机构角色id | ||||
|      * @param deptId | ||||
|      * @return java.lang.Long | ||||
|      */ | ||||
|     Long selectRoleIdByDeptId(Long deptId); | ||||
| } | ||||
| @@ -0,0 +1,87 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import com.fastbee.common.core.domain.entity.SysDictData; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 字典 业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysDictDataService | ||||
| { | ||||
|     /** | ||||
|      * 根据条件分页查询字典数据 | ||||
|      * | ||||
|      * @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 | ||||
|      */ | ||||
|     public void deleteDictDataByIds(Long[] dictCodes); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存字典数据信息 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertDictData(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 修改保存字典数据信息 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateDictData(SysDictData dictData); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典分类查询字典数据 | ||||
|      * | ||||
|      * @param dictTypeList 字典分类信息 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     public List<SysDictData> selectDictDataListByDictTypes(List<String> dictTypeList); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典键值查询字典数据信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @param dictValue 字典键值 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     SysDictData selectByDictTypeAndDictValue(String dictType, String dictValue); | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典键值集合查询字典数据信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @param dictValueList 字典键值集合 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     List<SysDictData> listByDictTypeAndDictValue(String dictType, List<String> dictValueList); | ||||
| } | ||||
| @@ -0,0 +1,98 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.common.core.domain.entity.SysDictData; | ||||
| import com.fastbee.common.core.domain.entity.SysDictType; | ||||
|  | ||||
| /** | ||||
|  * 字典 业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysDictTypeService | ||||
| { | ||||
|     /** | ||||
|      * 根据条件分页查询字典类型 | ||||
|      * | ||||
|      * @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 | ||||
|      */ | ||||
|     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,40 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysLogininfor; | ||||
|  | ||||
| /** | ||||
|  * 系统访问日志情况信息 服务层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysLogininforService | ||||
| { | ||||
|     /** | ||||
|      * 新增系统登录日志 | ||||
|      *  | ||||
|      * @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,149 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import java.util.Set; | ||||
| import com.fastbee.common.core.domain.TreeSelect; | ||||
| import com.fastbee.common.core.domain.entity.SysMenu; | ||||
| import com.fastbee.system.domain.vo.RouterVo; | ||||
|  | ||||
| /** | ||||
|  * 菜单 业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysMenuService | ||||
| { | ||||
|     /** | ||||
|      * 根据用户查询系统菜单列表 | ||||
|      * | ||||
|      * @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 roleId 角色ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public Set<String> selectMenuPermsByRoleId(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询菜单树信息 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @param language 语言 | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     public List<SysMenu> selectMenuTreeByUserId(Long userId, String language); | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询菜单树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 选中菜单列表 | ||||
|      */ | ||||
|     public List<Long> 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); | ||||
|  | ||||
|     List<SysMenu> deptMenuTreeselect(Long deptId); | ||||
|  | ||||
|     List<SysMenu> deptRoleMenuTreeselect(Long deptId, Long roleId); | ||||
| } | ||||
| @@ -0,0 +1,60 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysNotice; | ||||
|  | ||||
| /** | ||||
|  * 公告 服务层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysNoticeService | ||||
| { | ||||
|     /** | ||||
|      * 查询公告信息 | ||||
|      *  | ||||
|      * @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,48 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysOperLog; | ||||
|  | ||||
| /** | ||||
|  * 操作日志 服务层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysOperLogService | ||||
| { | ||||
|     /** | ||||
|      * 新增操作日志 | ||||
|      *  | ||||
|      * @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,99 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.system.domain.SysPost; | ||||
|  | ||||
| /** | ||||
|  * 岗位信息 服务层 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysPostService | ||||
| { | ||||
|     /** | ||||
|      * 查询岗位信息集合 | ||||
|      *  | ||||
|      * @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<Long> 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 结果 | ||||
|      */ | ||||
|     public int deletePostByIds(Long[] postIds); | ||||
|  | ||||
|     /** | ||||
|      * 新增保存岗位信息 | ||||
|      *  | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertPost(SysPost post); | ||||
|  | ||||
|     /** | ||||
|      * 修改保存岗位信息 | ||||
|      *  | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updatePost(SysPost post); | ||||
| } | ||||
| @@ -0,0 +1,174 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import java.util.List; | ||||
| import java.util.Set; | ||||
| import com.fastbee.common.core.domain.entity.SysRole; | ||||
| import com.fastbee.system.domain.SysUserRole; | ||||
|  | ||||
| /** | ||||
|  * 角色业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysRoleService | ||||
| { | ||||
|     /** | ||||
|      * 根据条件分页查询角色数据 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 角色数据集合信息 | ||||
|      */ | ||||
|     public List<SysRole> selectRoleList(SysRole role); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询角色列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     public List<SysRole> selectRolesByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询角色权限 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     public Set<String> selectRolePermissionByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 查询所有角色 | ||||
|      * | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     public List<SysRole> selectRoleAll(); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取角色选择框列表 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中角色ID列表 | ||||
|      */ | ||||
|     public List<Long> 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); | ||||
|  | ||||
|     /** | ||||
|      * 校验角色是否有数据权限 | ||||
|      * | ||||
|      * @param roleId 角色id | ||||
|      */ | ||||
|     public void checkRoleDataScope(Long roleId); | ||||
|  | ||||
|     /** | ||||
|      * 通过角色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); | ||||
|  | ||||
|     /** | ||||
|      * 取消授权用户角色 | ||||
|      * | ||||
|      * @param userRole 用户和角色关联信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAuthUser(SysUserRole userRole); | ||||
|  | ||||
|     /** | ||||
|      * 批量取消授权用户角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @param userIds 需要取消授权的用户数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int deleteAuthUsers(Long roleId, Long[] userIds); | ||||
|  | ||||
|     /** | ||||
|      * 批量选择授权用户角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @param userIds 需要删除的用户数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertAuthUsers(Long roleId, Long[] userIds); | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,36 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import com.fastbee.common.core.domain.entity.SysTranslate; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 翻译Service接口 | ||||
|  * | ||||
|  * @author kerwincui | ||||
|  * @date 2024-05-29 | ||||
|  */ | ||||
| public interface ISysTranslateService | ||||
| { | ||||
|     /** | ||||
|      * 导入翻译列表 | ||||
|      * @param list | ||||
|      * @return | ||||
|      */ | ||||
|     public void importSysTranslate(List<SysTranslate> list, String type, Long productId); | ||||
|  | ||||
|     /** | ||||
|      * 查询翻译列表 | ||||
|      * @param sysTranslate 翻译类 | ||||
|      * @return 翻译列表 | ||||
|      */ | ||||
|     public List<SysTranslate> selectSysTranslateList(SysTranslate sysTranslate, String type); | ||||
|  | ||||
|     /** | ||||
|      * 查询原表数据列表 | ||||
|      * @param type | ||||
|      * @return | ||||
|      */ | ||||
|     public List<SysTranslate> selectSourceList(String type, Long productId); | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,48 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import com.fastbee.common.core.domain.model.LoginUser; | ||||
| import com.fastbee.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,257 @@ | ||||
| package com.fastbee.system.service; | ||||
|  | ||||
| import com.fastbee.common.core.domain.entity.SysUser; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 用户 业务层 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| public interface ISysUserService | ||||
| { | ||||
|     /** | ||||
|      * 根据条件分页查询用户列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     public List<SysUser> selectUserList(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询已分配用户角色列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     public List<SysUser> selectAllocatedList(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询未分配用户角色列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     public List<SysUser> selectUnallocatedList(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 user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public String checkUserNameUnique(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 校验手机号码是否唯一 | ||||
|      * | ||||
|      * @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 userId 用户id | ||||
|      */ | ||||
|     public void checkUserDataScope(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 新增用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int insertUser(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 注册用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public boolean registerUser(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 修改用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int updateUser(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 用户授权角色 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @param roleIds 角色组 | ||||
|      */ | ||||
|     public void insertUserAuth(Long userId, Long[] roleIds); | ||||
|  | ||||
|     /** | ||||
|      * 修改用户状态 | ||||
|      * | ||||
|      * @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); | ||||
|  | ||||
|     /** | ||||
|      * 通过手机号查询用户 | ||||
|      * | ||||
|      * @param phoneNumber 手机号 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     SysUser selectUserByPhoneNumber(String phoneNumber); | ||||
|  | ||||
|     /** | ||||
|      * 验证用户密码 | ||||
|      * @param userPassword 用户原密码 | ||||
|      * @param inputPassword 用户输入密码 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     Boolean validatePassword(String userPassword, String inputPassword); | ||||
|  | ||||
|     /** | ||||
|      * 通过部门id删除用户 | ||||
|      * @param deptId | ||||
|      * @return void | ||||
|      */ | ||||
|     int deleteUserByDeptID(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 获取下级所有子节点用户 | ||||
|      * @param deptId | ||||
|      * @return | ||||
|      */ | ||||
|     List<SysUser> selectAllSubUser(Long deptId); | ||||
|  | ||||
|     /** | ||||
|      * 根据用户id获取当前机构的管理员账号 | ||||
|      * @param userId | ||||
|      * @return | ||||
|      */ | ||||
|     SysUser getDeptUserByUserId(Long userId); | ||||
|  | ||||
|     /** | ||||
|      * 获取终端用户列表 | ||||
|      * @param user 用户信息 | ||||
|      * @return com.fastbee.common.core.page.TableDataInfo | ||||
|      */ | ||||
|     List<SysUser> listTerminal(SysUser user); | ||||
|  | ||||
|     /** | ||||
|      * 根据机构id获取当前机构所有非管理用户 | ||||
|      * @return | ||||
|      */ | ||||
|     List<SysUser> selectByDeptId(); | ||||
| } | ||||
| @@ -0,0 +1,95 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
|  | ||||
|  | ||||
| import com.fastbee.common.utils.DateUtils; | ||||
| import com.fastbee.system.domain.AppLanguage; | ||||
| import com.fastbee.system.mapper.AppLanguageMapper; | ||||
| import com.fastbee.system.service.IAppLanguageService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * app语言Service业务层处理 | ||||
|  */ | ||||
| @Service | ||||
| public class AppLanguageServiceImpl implements IAppLanguageService | ||||
| { | ||||
|     @Autowired | ||||
|     private AppLanguageMapper appLanguageMapper; | ||||
|  | ||||
|     /** | ||||
|      * 查询app语言 | ||||
|      * | ||||
|      * @param id app语言主键 | ||||
|      * @return app语言 | ||||
|      */ | ||||
|     @Override | ||||
|     public AppLanguage selectAppLanguageById(Long id) | ||||
|     { | ||||
|         return appLanguageMapper.selectAppLanguageById(id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询app语言列表 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return app语言 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<AppLanguage> selectAppLanguageList(AppLanguage appLanguage) | ||||
|     { | ||||
|         return appLanguageMapper.selectAppLanguageList(appLanguage); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增app语言 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertAppLanguage(AppLanguage appLanguage) | ||||
|     { | ||||
|         appLanguage.setCreateTime(DateUtils.getNowDate()); | ||||
|         return appLanguageMapper.insertAppLanguage(appLanguage); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改app语言 | ||||
|      * | ||||
|      * @param appLanguage app语言 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateAppLanguage(AppLanguage appLanguage) | ||||
|     { | ||||
|         return appLanguageMapper.updateAppLanguage(appLanguage); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除app语言 | ||||
|      * | ||||
|      * @param ids 需要删除的app语言主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteAppLanguageByIds(Long[] ids) | ||||
|     { | ||||
|         return appLanguageMapper.deleteAppLanguageByIds(ids); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除app语言信息 | ||||
|      * | ||||
|      * @param id app语言主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteAppLanguageById(Long id) | ||||
|     { | ||||
|         return appLanguageMapper.deleteAppLanguageById(id); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,140 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
|  | ||||
| import com.fastbee.common.utils.DateUtils; | ||||
| import com.fastbee.common.utils.SecurityUtils; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.system.domain.AppPreferences; | ||||
|  | ||||
| import com.fastbee.system.enums.Language; | ||||
| import com.fastbee.system.mapper.AppPreferencesMapper; | ||||
| import com.fastbee.system.service.IAppPreferencesService; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import javax.annotation.Resource; | ||||
| import java.util.List; | ||||
| import java.util.Objects; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * APP用户偏好设置Service业务层处理 | ||||
|  */ | ||||
| @Service | ||||
| public class AppPreferencesServiceImpl implements IAppPreferencesService | ||||
| { | ||||
|     @Resource | ||||
|     private AppPreferencesMapper appPreferencesMapper; | ||||
|  | ||||
|     /** | ||||
|      * 查询APP用户偏好设置 | ||||
|      * | ||||
|      * @param userId APP用户偏好设置主键 | ||||
|      * @return APP用户偏好设置 | ||||
|      */ | ||||
|     @Override | ||||
|     public AppPreferences selectAppPreferencesByUserId(Long userId) | ||||
|     { | ||||
|         AppPreferences appPreferences = appPreferencesMapper.selectAppPreferencesByUserId(userId); | ||||
|         if (appPreferences == null){ | ||||
|             appPreferences = new AppPreferences(); | ||||
|         } | ||||
|         // 设置默认语言 | ||||
|         if (StringUtils.isEmpty(appPreferences.getLanguage())) { | ||||
|             appPreferences.setLanguage(Language.DEFAULT.getValue()); | ||||
|         } | ||||
|         return appPreferences; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询APP用户偏好设置列表 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return APP用户偏好设置 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<AppPreferences> selectAppPreferencesList(AppPreferences appPreferences) | ||||
|     { | ||||
|         return appPreferencesMapper.selectAppPreferencesList(appPreferences); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增APP用户偏好设置 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertAppPreferences(AppPreferences appPreferences) | ||||
|     { | ||||
|         appPreferences.setCreateTime(DateUtils.getNowDate()); | ||||
|         return appPreferencesMapper.insertAppPreferences(appPreferences); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改APP用户偏好设置 | ||||
|      * | ||||
|      * @param appPreferences APP用户偏好设置 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateAppPreferences(AppPreferences appPreferences) | ||||
|     { | ||||
|         appPreferences.setUpdateTime(DateUtils.getNowDate()); | ||||
|         return appPreferencesMapper.updateAppPreferences(appPreferences); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除APP用户偏好设置 | ||||
|      * | ||||
|      * @param userIds 需要删除的APP用户偏好设置主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteAppPreferencesByUserIds(Long[] userIds) | ||||
|     { | ||||
|         return appPreferencesMapper.deleteAppPreferencesByUserIds(userIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除APP用户偏好设置信息 | ||||
|      * | ||||
|      * @param userId APP用户偏好设置主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteAppPreferencesByUserId(Long userId) | ||||
|     { | ||||
|         return appPreferencesMapper.deleteAppPreferencesByUserId(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增或者更新用户偏好设置 | ||||
|      * @param appPreferences | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public int addOrUpdate(AppPreferences appPreferences) | ||||
|     { | ||||
|         if (Objects.isNull(appPreferences.getId())){ | ||||
|             appPreferences.setUserId(SecurityUtils.getUserId()); | ||||
|         } | ||||
|         AppPreferences preferences = this.selectAppPreferencesByUserId(SecurityUtils.getUserId()); | ||||
|         if (!Objects.isNull(preferences)){ | ||||
|             return appPreferencesMapper.updateAppPreferences(appPreferences); | ||||
|         } else { | ||||
|             return  appPreferencesMapper.insertAppPreferences(appPreferences); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取用户偏好语言 | ||||
|      * @param userId | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public String getLanguage(Long userId) { | ||||
|         AppPreferences appPreferences = selectAppPreferencesByUserId(userId); | ||||
|         return appPreferences.getLanguage(); | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,96 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.List; | ||||
| import com.fastbee.common.utils.DateUtils; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import com.fastbee.system.mapper.SysClientMapper; | ||||
| import com.fastbee.system.domain.SysClient; | ||||
| import com.fastbee.system.service.ISysClientService; | ||||
|  | ||||
| /** | ||||
|  * 系统授权Service业务层处理 | ||||
|  *  | ||||
|  * @author zhuangpeng.li | ||||
|  * @date 2024-07-26 | ||||
|  */ | ||||
| @Service | ||||
| public class SysClientServiceImpl implements ISysClientService  | ||||
| { | ||||
|     @Autowired | ||||
|     private SysClientMapper sysClientMapper; | ||||
|  | ||||
|     /** | ||||
|      * 查询系统授权 | ||||
|      *  | ||||
|      * @param id 系统授权主键 | ||||
|      * @return 系统授权 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysClient selectSysClientById(Long id) | ||||
|     { | ||||
|         return sysClientMapper.selectSysClientById(id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询系统授权列表 | ||||
|      *  | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 系统授权 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysClient> selectSysClientList(SysClient sysClient) | ||||
|     { | ||||
|         return sysClientMapper.selectSysClientList(sysClient); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增系统授权 | ||||
|      *  | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertSysClient(SysClient sysClient) | ||||
|     { | ||||
|         sysClient.setCreateTime(DateUtils.getNowDate()); | ||||
|         return sysClientMapper.insertSysClient(sysClient); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改系统授权 | ||||
|      *  | ||||
|      * @param sysClient 系统授权 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateSysClient(SysClient sysClient) | ||||
|     { | ||||
|         sysClient.setUpdateTime(DateUtils.getNowDate()); | ||||
|         return sysClientMapper.updateSysClient(sysClient); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统授权 | ||||
|      *  | ||||
|      * @param ids 需要删除的系统授权主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteSysClientByIds(Long[] ids) | ||||
|     { | ||||
|         return sysClientMapper.deleteSysClientByIds(ids); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除系统授权信息 | ||||
|      *  | ||||
|      * @param id 系统授权主键 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteSysClientById(Long id) | ||||
|     { | ||||
|         return sysClientMapper.deleteSysClientById(id); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,232 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.Collection; | ||||
| import java.util.List; | ||||
| import javax.annotation.PostConstruct; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import com.fastbee.common.annotation.DataSource; | ||||
| import com.fastbee.common.constant.CacheConstants; | ||||
| import com.fastbee.common.constant.UserConstants; | ||||
| import com.fastbee.common.core.redis.RedisCache; | ||||
| import com.fastbee.common.core.text.Convert; | ||||
| import com.fastbee.common.enums.DataSourceType; | ||||
| import com.fastbee.common.exception.ServiceException; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.system.domain.SysConfig; | ||||
| import com.fastbee.system.mapper.SysConfigMapper; | ||||
| import com.fastbee.system.service.ISysConfigService; | ||||
|  | ||||
| /** | ||||
|  * 参数配置 服务层实现 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysConfigServiceImpl implements ISysConfigService | ||||
| { | ||||
|     @Autowired | ||||
|     private SysConfigMapper configMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private RedisCache redisCache; | ||||
|  | ||||
|     /** | ||||
|      * 项目启动时,初始化参数到缓存 | ||||
|      */ | ||||
|     @PostConstruct | ||||
|     public void init() | ||||
|     { | ||||
|         loadingConfigCache(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询参数配置信息 | ||||
|      *  | ||||
|      * @param configId 参数配置ID | ||||
|      * @return 参数配置信息 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataSource(DataSourceType.MASTER) | ||||
|     public SysConfig selectConfigById(Long configId) | ||||
|     { | ||||
|         SysConfig config = new SysConfig(); | ||||
|         config.setConfigId(configId); | ||||
|         return configMapper.selectConfig(config); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据键名查询参数配置信息 | ||||
|      *  | ||||
|      * @param configKey 参数key | ||||
|      * @return 参数键值 | ||||
|      */ | ||||
|     @Override | ||||
|     public String selectConfigByKey(String configKey) | ||||
|     { | ||||
|         String configValue = Convert.toStr(redisCache.getCacheObject(getCacheKey(configKey))); | ||||
|         if (StringUtils.isNotEmpty(configValue)) | ||||
|         { | ||||
|             return configValue; | ||||
|         } | ||||
|         SysConfig config = new SysConfig(); | ||||
|         config.setConfigKey(configKey); | ||||
|         SysConfig retConfig = configMapper.selectConfig(config); | ||||
|         if (StringUtils.isNotNull(retConfig)) | ||||
|         { | ||||
|             redisCache.setCacheObject(getCacheKey(configKey), retConfig.getConfigValue()); | ||||
|             return retConfig.getConfigValue(); | ||||
|         } | ||||
|         return StringUtils.EMPTY; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取验证码开关 | ||||
|      *  | ||||
|      * @return true开启,false关闭 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean selectCaptchaEnabled() | ||||
|     { | ||||
|         String captchaEnabled = selectConfigByKey("sys.account.captchaEnabled"); | ||||
|         if (StringUtils.isEmpty(captchaEnabled)) | ||||
|         { | ||||
|             return true; | ||||
|         } | ||||
|         return Convert.toBool(captchaEnabled); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询参数配置列表 | ||||
|      *  | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 参数配置集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysConfig> selectConfigList(SysConfig config) | ||||
|     { | ||||
|         return configMapper.selectConfigList(config); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增参数配置 | ||||
|      *  | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertConfig(SysConfig config) | ||||
|     { | ||||
|         int row = configMapper.insertConfig(config); | ||||
|         if (row > 0) | ||||
|         { | ||||
|             redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); | ||||
|         } | ||||
|         return row; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改参数配置 | ||||
|      *  | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateConfig(SysConfig config) | ||||
|     { | ||||
|         SysConfig temp = configMapper.selectConfigById(config.getConfigId()); | ||||
|         if (!StringUtils.equals(temp.getConfigKey(), config.getConfigKey())) | ||||
|         { | ||||
|             redisCache.deleteObject(getCacheKey(temp.getConfigKey())); | ||||
|         } | ||||
|  | ||||
|         int row = configMapper.updateConfig(config); | ||||
|         if (row > 0) | ||||
|         { | ||||
|             redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); | ||||
|         } | ||||
|         return row; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除参数信息 | ||||
|      *  | ||||
|      * @param configIds 需要删除的参数ID | ||||
|      */ | ||||
|     @Override | ||||
|     public void deleteConfigByIds(Long[] configIds) | ||||
|     { | ||||
|         for (Long configId : configIds) | ||||
|         { | ||||
|             SysConfig config = selectConfigById(configId); | ||||
|             if (StringUtils.equals(UserConstants.YES, config.getConfigType())) | ||||
|             { | ||||
|                 throw new ServiceException(String.format("内置参数【%1$s】不能删除 ", config.getConfigKey())); | ||||
|             } | ||||
|             configMapper.deleteConfigById(configId); | ||||
|             redisCache.deleteObject(getCacheKey(config.getConfigKey())); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 加载参数缓存数据 | ||||
|      */ | ||||
|     @Override | ||||
|     public void loadingConfigCache() | ||||
|     { | ||||
|         List<SysConfig> configsList = configMapper.selectConfigList(new SysConfig()); | ||||
|         for (SysConfig config : configsList) | ||||
|         { | ||||
|             redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue()); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 清空参数缓存数据 | ||||
|      */ | ||||
|     @Override | ||||
|     public void clearConfigCache() | ||||
|     { | ||||
|         Collection<String> keys = redisCache.keys(CacheConstants.SYS_CONFIG_KEY + "*"); | ||||
|         redisCache.deleteObject(keys); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 重置参数缓存数据 | ||||
|      */ | ||||
|     @Override | ||||
|     public void resetConfigCache() | ||||
|     { | ||||
|         clearConfigCache(); | ||||
|         loadingConfigCache(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验参数键名是否唯一 | ||||
|      *  | ||||
|      * @param config 参数配置信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkConfigKeyUnique(SysConfig config) | ||||
|     { | ||||
|         Long configId = StringUtils.isNull(config.getConfigId()) ? -1L : config.getConfigId(); | ||||
|         SysConfig info = configMapper.checkConfigKeyUnique(config.getConfigKey()); | ||||
|         if (StringUtils.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 CacheConstants.SYS_CONFIG_KEY + configKey; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,404 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import com.fastbee.common.annotation.DataScope; | ||||
| import com.fastbee.common.constant.UserConstants; | ||||
| import com.fastbee.common.core.domain.TreeSelect; | ||||
| import com.fastbee.common.core.domain.entity.SysDept; | ||||
| import com.fastbee.common.core.domain.entity.SysRole; | ||||
| import com.fastbee.common.core.domain.entity.SysUser; | ||||
| import com.fastbee.common.core.domain.model.LoginUser; | ||||
| import com.fastbee.common.core.text.Convert; | ||||
| import com.fastbee.common.exception.ServiceException; | ||||
| import com.fastbee.common.utils.SecurityUtils; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.common.utils.spring.SpringUtils; | ||||
| import com.fastbee.system.mapper.SysDeptMapper; | ||||
| import com.fastbee.system.mapper.SysRoleDeptMapper; | ||||
| import com.fastbee.system.mapper.SysRoleMapper; | ||||
| import com.fastbee.system.service.ISysDeptService; | ||||
| import org.apache.commons.collections4.CollectionUtils; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.cache.annotation.CacheEvict; | ||||
| import org.springframework.cache.annotation.CachePut; | ||||
| import org.springframework.cache.annotation.Cacheable; | ||||
| import org.springframework.cache.annotation.Caching; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import javax.annotation.Resource; | ||||
| import java.util.ArrayList; | ||||
| import java.util.Iterator; | ||||
| import java.util.List; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| import static com.fastbee.common.utils.SecurityUtils.getLoginUser; | ||||
|  | ||||
| /** | ||||
|  * 部门管理 服务实现 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysDeptServiceImpl implements ISysDeptService | ||||
| { | ||||
|     @Autowired | ||||
|     private SysDeptMapper deptMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleMapper roleMapper; | ||||
|  | ||||
|     @Resource | ||||
|     private SysRoleDeptMapper sysRoleDeptMapper; | ||||
|  | ||||
|     /** | ||||
|      * 查询部门管理数据 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 部门信息集合 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d") | ||||
|     public List<SysDept> selectDeptList(SysDept dept) | ||||
|     { | ||||
|         LoginUser loginUser = getLoginUser(); | ||||
|         Long deptId = loginUser.getDeptId(); | ||||
|         List<SysDept> sysDeptList = new ArrayList<>(); | ||||
|         if (null != deptId) { | ||||
|             dept.setDeptId(deptId); | ||||
|             sysDeptList = deptMapper.listDeptAndChild(dept); | ||||
|         } | ||||
|         return sysDeptList; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询部门树结构信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 部门树信息集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<TreeSelect> selectDeptTreeList(SysDept dept) | ||||
|     { | ||||
|         List<SysDept> depts = SpringUtils.getAopProxy(this).selectDeptList(dept); | ||||
|         return buildDeptTreeSelect(depts); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 构建前端所需要树结构 | ||||
|      * | ||||
|      * @param depts 部门列表 | ||||
|      * @return 树结构列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysDept> buildDeptTree(List<SysDept> depts) | ||||
|     { | ||||
|         List<SysDept> returnList = new ArrayList<SysDept>(); | ||||
|         List<Long> tempList = depts.stream().map(SysDept::getDeptId).collect(Collectors.toList()); | ||||
|         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 选中部门列表 | ||||
|      */ | ||||
|     @Cacheable(value = "dept", key = "#root.methodName + '_' + #roleId", unless = "#result == null") | ||||
|     @Override | ||||
|     public List<Long> selectDeptListByRoleId(Long roleId) | ||||
|     { | ||||
|         SysRole role = roleMapper.selectRoleById(roleId); | ||||
|         return deptMapper.selectDeptListByRoleId(roleId, role.isDeptCheckStrictly()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据部门ID查询信息 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 部门信息 | ||||
|      */ | ||||
|     @Cacheable(value = "dept", key = "#root.methodName + '_' + #deptId", unless = "#result == null") | ||||
|     @Override | ||||
|     public SysDept selectDeptById(Long deptId) | ||||
|     { | ||||
|         return deptMapper.selectDeptById(deptId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据ID查询所有子部门(正常状态) | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 子部门数 | ||||
|      */ | ||||
|     @Cacheable(value = "dept", key = "#root.methodName + '_' + #deptId") | ||||
|     @Override | ||||
|     public int selectNormalChildrenDeptById(Long deptId) | ||||
|     { | ||||
|         return deptMapper.selectNormalChildrenDeptById(deptId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否存在子节点 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean hasChildByDeptId(Long deptId) | ||||
|     { | ||||
|         int result = deptMapper.hasChildByDeptId(deptId); | ||||
|         return result > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询部门是否存在用户 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 true 存在 false 不存在 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean checkDeptExistUser(Long deptId) | ||||
|     { | ||||
|         int result = deptMapper.checkDeptExistUser(deptId); | ||||
|         return result > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验部门名称是否唯一 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkDeptNameUnique(SysDept dept) | ||||
|     { | ||||
|         Long deptId = StringUtils.isNull(dept.getDeptId()) ? -1L : dept.getDeptId(); | ||||
|         SysDept info = deptMapper.checkDeptNameUnique(dept.getDeptName(), dept.getParentId()); | ||||
|         if (StringUtils.isNotNull(info) && info.getDeptId().longValue() != deptId.longValue()) | ||||
|         { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验部门是否有数据权限 | ||||
|      * | ||||
|      * @param deptId 部门id | ||||
|      */ | ||||
|     @Override | ||||
|     public void checkDeptDataScope(Long deptId) | ||||
|     { | ||||
|         if (!SysUser.isAdmin(SecurityUtils.getUserId())) | ||||
|         { | ||||
|             SysDept dept = new SysDept(); | ||||
|             dept.setDeptId(deptId); | ||||
|             List<SysDept> depts = SpringUtils.getAopProxy(this).selectDeptList(dept); | ||||
|             if (StringUtils.isEmpty(depts)) | ||||
|             { | ||||
|                 throw new ServiceException("没有权限访问部门数据!"); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存部门信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Caching(put = { | ||||
|             @CachePut(value = "dept", key = "'selectDeptById' + '_' + #dept.deptId"), | ||||
|             @CachePut(value = "dept", key = "'selectNormalChildrenDeptById' + '_' + #dept.deptId") | ||||
|     }) | ||||
|     @Override | ||||
|     public int insertDept(SysDept dept) | ||||
|     { | ||||
|         SysDept info = deptMapper.selectDeptById(dept.getParentId()); | ||||
|         // 如果父节点不为正常状态,则不允许新增子节点 | ||||
|         if (!UserConstants.DEPT_NORMAL.equals(info.getStatus())) | ||||
|         { | ||||
|             throw new ServiceException("部门停用,不允许新增"); | ||||
|         } | ||||
|         dept.setAncestors(info.getAncestors() + "," + dept.getParentId()); | ||||
|         return deptMapper.insertDept(dept); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存部门信息 | ||||
|      * | ||||
|      * @param dept 部门信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Caching(put = { | ||||
|             @CachePut(value = "dept", key = "'selectDeptById' + '_' + #dept.deptId"), | ||||
|             @CachePut(value = "dept", key = "'selectNormalChildrenDeptById' + '_' + #dept.deptId") | ||||
|     }) | ||||
|     @Override | ||||
|     public int updateDept(SysDept dept) | ||||
|     { | ||||
|         SysDept newParentDept = deptMapper.selectDeptById(dept.getParentId()); | ||||
|         SysDept oldDept = deptMapper.selectDeptById(dept.getDeptId()); | ||||
|         if (StringUtils.isNotNull(newParentDept) && StringUtils.isNotNull(oldDept)) | ||||
|         { | ||||
|             String newAncestors = newParentDept.getAncestors() + "," + newParentDept.getDeptId(); | ||||
|             String oldAncestors = oldDept.getAncestors(); | ||||
|             dept.setAncestors(newAncestors); | ||||
|             updateDeptChildren(dept.getDeptId(), newAncestors, oldAncestors); | ||||
|         } | ||||
|         int result = deptMapper.updateDept(dept); | ||||
|         if (UserConstants.DEPT_NORMAL.equals(dept.getStatus()) && StringUtils.isNotEmpty(dept.getAncestors()) | ||||
|                 && !StringUtils.equals("0", dept.getAncestors())) | ||||
|         { | ||||
|             // 如果该部门是启用状态,则启用该部门的所有上级部门 | ||||
|             updateParentDeptStatusNormal(dept); | ||||
|         } | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改该部门的父级部门状态 | ||||
|      * | ||||
|      * @param dept 当前部门 | ||||
|      */ | ||||
|     private void updateParentDeptStatusNormal(SysDept dept) | ||||
|     { | ||||
|         String ancestors = dept.getAncestors(); | ||||
|         Long[] deptIds = Convert.toLongArray(ancestors); | ||||
|         deptMapper.updateDeptStatusNormal(deptIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改子元素关系 | ||||
|      * | ||||
|      * @param deptId 被修改的部门ID | ||||
|      * @param newAncestors 新的父ID集合 | ||||
|      * @param oldAncestors 旧的父ID集合 | ||||
|      */ | ||||
|     public void updateDeptChildren(Long deptId, String newAncestors, String oldAncestors) | ||||
|     { | ||||
|         List<SysDept> children = deptMapper.selectChildrenDeptById(deptId); | ||||
|         for (SysDept child : children) | ||||
|         { | ||||
|             child.setAncestors(child.getAncestors().replaceFirst(oldAncestors, newAncestors)); | ||||
|         } | ||||
|         if (children.size() > 0) | ||||
|         { | ||||
|             deptMapper.updateDeptChildren(children); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除部门管理信息 | ||||
|      * | ||||
|      * @param deptId 部门ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @CacheEvict(value = "dept", allEntries = true) | ||||
|     @Override | ||||
|     public int deleteDeptById(Long deptId) | ||||
|     { | ||||
|         return deptMapper.deleteDeptById(deptId); | ||||
|     } | ||||
|  | ||||
|     @Caching(put = { | ||||
|             @CachePut(value = "dept", key = "'selectDeptById' + '_' + #deptId"), | ||||
|             @CachePut(value = "dept", key = "'selectNormalChildrenDeptById' + '_' + #deptId") | ||||
|     }) | ||||
|     @Override | ||||
|     public int updateDeptUserId(Long deptId, Long deptUserId) { | ||||
|         return deptMapper.updateDeptUserId(deptId, deptUserId); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public List<SysRole> getRole(Long deptId) { | ||||
|         List<Long> roleIdList = sysRoleDeptMapper.selectByDeptId(deptId); | ||||
|         if (CollectionUtils.isEmpty(roleIdList)) { | ||||
|             return new ArrayList<>(); | ||||
|         } | ||||
|         return roleMapper.selectRoleByIds(roleIdList, null, null); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询机构的所有上级绑定租户 | ||||
|      * @param deptId | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public List<Long> selectSeniorDeptUser(Long deptId){ | ||||
|        return deptMapper.selectSeniorDeptUser(deptId); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public Long selectRoleIdByDeptId(Long deptId) { | ||||
|         return deptMapper.selectRoleIdByDeptId(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>(); | ||||
|         Iterator<SysDept> it = list.iterator(); | ||||
|         while (it.hasNext()) | ||||
|         { | ||||
|             SysDept n = (SysDept) it.next(); | ||||
|             if (StringUtils.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,129 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import com.fastbee.common.core.domain.entity.SysDictData; | ||||
| import com.fastbee.common.utils.DictUtils; | ||||
| import com.fastbee.common.utils.SecurityUtils; | ||||
| import com.fastbee.system.mapper.SysDictDataMapper; | ||||
| import com.fastbee.system.service.ISysDictDataService; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import javax.annotation.Resource; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * 字典 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysDictDataServiceImpl implements ISysDictDataService | ||||
| { | ||||
|     @Resource | ||||
|     private SysDictDataMapper dictDataMapper; | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询字典数据 | ||||
|      * | ||||
|      * @param dictData 字典数据信息 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysDictData> selectDictDataList(SysDictData dictData) | ||||
|     { | ||||
|         dictData.setLanguage(SecurityUtils.getLanguage()); | ||||
|         return dictDataMapper.selectDictDataList(dictData); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型和字典键值查询字典数据信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @param dictValue 字典键值 | ||||
|      * @return 字典标签 | ||||
|      */ | ||||
|     @Override | ||||
|     public String selectDictLabel(String dictType, String dictValue) | ||||
|     { | ||||
|         return dictDataMapper.selectDictLabel(dictType, dictValue); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据字典数据ID查询信息 | ||||
|      * | ||||
|      * @param dictCode 字典数据ID | ||||
|      * @return 字典数据 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysDictData selectDictDataById(Long dictCode) | ||||
|     { | ||||
|         return dictDataMapper.selectDictDataById(dictCode, SecurityUtils.getLanguage()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除字典数据信息 | ||||
|      * | ||||
|      * @param dictCodes 需要删除的字典数据ID | ||||
|      */ | ||||
|     @Override | ||||
|     public void deleteDictDataByIds(Long[] dictCodes) | ||||
|     { | ||||
|         for (Long dictCode : dictCodes) | ||||
|         { | ||||
|             SysDictData data = selectDictDataById(dictCode); | ||||
|             dictDataMapper.deleteDictDataById(dictCode); | ||||
|             List<SysDictData> dictDatas = dictDataMapper.selectDictDataByType(data.getDictType()); | ||||
|             DictUtils.setDictCache(data.getDictType(), dictDatas); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存字典数据信息 | ||||
|      * | ||||
|      * @param data 字典数据信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertDictData(SysDictData data) | ||||
|     { | ||||
|         int row = dictDataMapper.insertDictData(data); | ||||
|         if (row > 0) | ||||
|         { | ||||
|             List<SysDictData> dictDatas = dictDataMapper.selectDictDataByType(data.getDictType()); | ||||
|             DictUtils.setDictCache(data.getDictType(), dictDatas); | ||||
|         } | ||||
|         return row; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存字典数据信息 | ||||
|      * | ||||
|      * @param data 字典数据信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateDictData(SysDictData data) | ||||
|     { | ||||
|         int row = dictDataMapper.updateDictData(data); | ||||
|         if (row > 0) | ||||
|         { | ||||
|             List<SysDictData> dictDatas = dictDataMapper.selectDictDataByType(data.getDictType()); | ||||
|             DictUtils.setDictCache(data.getDictType(), dictDatas); | ||||
|         } | ||||
|         return row; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public List<SysDictData> selectDictDataListByDictTypes(List<String> dictTypeList) { | ||||
|         return dictDataMapper.selectDictDataListByDictTypes(dictTypeList, SecurityUtils.getLanguage()); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public SysDictData selectByDictTypeAndDictValue(String dictType, String dictValue) { | ||||
|         return dictDataMapper.selectByDictTypeAndDictValue(dictType, dictValue, SecurityUtils.getLanguage()); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public List<SysDictData> listByDictTypeAndDictValue(String dictType, List<String> dictValueList) { | ||||
|         return dictDataMapper.listByDictTypeAndDictValue(dictType, dictValueList, SecurityUtils.getLanguage()); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,254 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.Comparator; | ||||
| import java.util.List; | ||||
| import java.util.Map; | ||||
| import java.util.stream.Collectors; | ||||
| import javax.annotation.PostConstruct; | ||||
| import javax.annotation.Resource; | ||||
|  | ||||
| import com.fastbee.common.utils.SecurityUtils; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
| import com.fastbee.common.constant.UserConstants; | ||||
| import com.fastbee.common.core.domain.entity.SysDictData; | ||||
| import com.fastbee.common.core.domain.entity.SysDictType; | ||||
| import com.fastbee.common.exception.ServiceException; | ||||
| import com.fastbee.common.utils.DictUtils; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.system.mapper.SysDictDataMapper; | ||||
| import com.fastbee.system.mapper.SysDictTypeMapper; | ||||
| import com.fastbee.system.service.ISysDictTypeService; | ||||
|  | ||||
| import static com.fastbee.common.constant.Constants.EN_US; | ||||
| import static com.fastbee.common.constant.Constants.ZH_CN; | ||||
|  | ||||
| /** | ||||
|  * 字典 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysDictTypeServiceImpl implements ISysDictTypeService | ||||
| { | ||||
|     @Resource | ||||
|     private SysDictTypeMapper dictTypeMapper; | ||||
|  | ||||
|     @Resource | ||||
|     private SysDictDataMapper dictDataMapper; | ||||
|  | ||||
|     /** | ||||
|      * 项目启动时,初始化字典到缓存 | ||||
|      */ | ||||
|     @PostConstruct | ||||
|     public void init() | ||||
|     { | ||||
|         loadingDictCache(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询字典类型 | ||||
|      * | ||||
|      * @param dictType 字典类型信息 | ||||
|      * @return 字典类型集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysDictType> selectDictTypeList(SysDictType dictType) | ||||
|     { | ||||
|         dictType.setLanguage(SecurityUtils.getLanguage()); | ||||
|         return dictTypeMapper.selectDictTypeList(dictType); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据所有字典类型 | ||||
|      * | ||||
|      * @return 字典类型集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysDictType> selectDictTypeAll() | ||||
|     { | ||||
|         return dictTypeMapper.selectDictTypeAll(SecurityUtils.getLanguage()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型查询字典数据 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @return 字典数据集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysDictData> selectDictDataByType(String dictType) | ||||
|     { | ||||
|         List<SysDictData> dictDatas = DictUtils.getDictCache(dictType); | ||||
|         if (StringUtils.isNotEmpty(dictDatas)) | ||||
|         { | ||||
|             convertDictLabel(dictDatas, SecurityUtils.getLanguage()); | ||||
|             return dictDatas; | ||||
|         } | ||||
|         dictDatas = dictDataMapper.selectDictDataByType(dictType); | ||||
|         if (StringUtils.isNotEmpty(dictDatas)) | ||||
|         { | ||||
|             DictUtils.setDictCache(dictType, dictDatas); | ||||
|             convertDictLabel(dictDatas, SecurityUtils.getLanguage()); | ||||
|             return dictDatas; | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型ID查询信息 | ||||
|      * | ||||
|      * @param dictId 字典类型ID | ||||
|      * @return 字典类型 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysDictType selectDictTypeById(Long dictId) | ||||
|     { | ||||
|         return dictTypeMapper.selectDictTypeById(dictId, SecurityUtils.getLanguage()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据字典类型查询信息 | ||||
|      * | ||||
|      * @param dictType 字典类型 | ||||
|      * @return 字典类型 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysDictType selectDictTypeByType(String dictType) | ||||
|     { | ||||
|         return dictTypeMapper.selectDictTypeByType(dictType, SecurityUtils.getLanguage()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除字典类型信息 | ||||
|      * | ||||
|      * @param dictIds 需要删除的字典ID | ||||
|      */ | ||||
|     @Override | ||||
|     public void deleteDictTypeByIds(Long[] dictIds) | ||||
|     { | ||||
|         for (Long dictId : dictIds) | ||||
|         { | ||||
|             SysDictType dictType = selectDictTypeById(dictId); | ||||
|             if (dictDataMapper.countDictDataByType(dictType.getDictType()) > 0) | ||||
|             { | ||||
|                 throw new ServiceException(String.format("%1$s已分配,不能删除", dictType.getDictName())); | ||||
|             } | ||||
|             dictTypeMapper.deleteDictTypeById(dictId); | ||||
|             DictUtils.removeDictCache(dictType.getDictType()); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 加载字典缓存数据 | ||||
|      * | ||||
|      */ | ||||
|     @Override | ||||
|     public void loadingDictCache() | ||||
|     { | ||||
|         SysDictData dictData = new SysDictData(); | ||||
|         dictData.setStatus("0"); | ||||
|         Map<String, List<SysDictData>> dictDataMap = dictDataMapper.selectDictDataListAll(dictData).stream().collect(Collectors.groupingBy(SysDictData::getDictType)); | ||||
|         for (Map.Entry<String, List<SysDictData>> entry : dictDataMap.entrySet()) | ||||
|         { | ||||
|             DictUtils.setDictCache(entry.getKey(), entry.getValue().stream().sorted(Comparator.comparing(SysDictData::getDictSort)).collect(Collectors.toList())); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 清空字典缓存数据 | ||||
|      */ | ||||
|     @Override | ||||
|     public void clearDictCache() | ||||
|     { | ||||
|         DictUtils.clearDictCache(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 重置字典缓存数据 | ||||
|      * | ||||
|      */ | ||||
|     @Override | ||||
|     public void resetDictCache() | ||||
|     { | ||||
|         clearDictCache(); | ||||
|         loadingDictCache(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存字典类型信息 | ||||
|      * | ||||
|      * @param dict 字典类型信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertDictType(SysDictType dict) | ||||
|     { | ||||
|         int row = dictTypeMapper.insertDictType(dict); | ||||
|         if (row > 0) | ||||
|         { | ||||
|             DictUtils.setDictCache(dict.getDictType(), null); | ||||
|         } | ||||
|         return row; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存字典类型信息 | ||||
|      * | ||||
|      * @param dict 字典类型信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int updateDictType(SysDictType dict) | ||||
|     { | ||||
|         SysDictType oldDict = dictTypeMapper.selectDictTypeById(dict.getDictId(), SecurityUtils.getLanguage()); | ||||
|         dictDataMapper.updateDictDataType(oldDict.getDictType(), dict.getDictType()); | ||||
|         int row = dictTypeMapper.updateDictType(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 = StringUtils.isNull(dict.getDictId()) ? -1L : dict.getDictId(); | ||||
|         SysDictType dictType = dictTypeMapper.checkDictTypeUnique(dict.getDictType(), SecurityUtils.getLanguage()); | ||||
|         if (StringUtils.isNotNull(dictType) && dictType.getDictId().longValue() != dictId.longValue()) | ||||
|         { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 多语言转换 | ||||
|      * @param list | ||||
|      * @param language | ||||
|      * @return | ||||
|      */ | ||||
|     public static void convertDictLabel(List<SysDictData> list, String language) { | ||||
|         switch (language) { | ||||
|             case EN_US: | ||||
|                 for (SysDictData data : list) { | ||||
|                     data.setDictLabel(data.getDictLabel_en_US()); | ||||
|                 } | ||||
|                 break; | ||||
|             case ZH_CN: | ||||
|                 for (SysDictData data : list) { | ||||
|                     data.setDictLabel(data.getDictLabel_zh_CN()); | ||||
|                 } | ||||
|                 break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,65 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import com.fastbee.system.domain.SysLogininfor; | ||||
| import com.fastbee.system.mapper.SysLogininforMapper; | ||||
| import com.fastbee.system.service.ISysLogininforService; | ||||
|  | ||||
| /** | ||||
|  * 系统访问日志情况信息 服务层处理 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysLogininforServiceImpl implements ISysLogininforService | ||||
| { | ||||
|  | ||||
|     @Autowired | ||||
|     private SysLogininforMapper logininforMapper; | ||||
|  | ||||
|     /** | ||||
|      * 新增系统登录日志 | ||||
|      *  | ||||
|      * @param logininfor 访问日志对象 | ||||
|      */ | ||||
|     @Override | ||||
|     public void insertLogininfor(SysLogininfor logininfor) | ||||
|     { | ||||
|         logininforMapper.insertLogininfor(logininfor); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询系统登录日志集合 | ||||
|      *  | ||||
|      * @param logininfor 访问日志对象 | ||||
|      * @return 登录记录集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysLogininfor> selectLogininforList(SysLogininfor logininfor) | ||||
|     { | ||||
|         return logininforMapper.selectLogininforList(logininfor); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统登录日志 | ||||
|      *  | ||||
|      * @param infoIds 需要删除的登录日志ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteLogininforByIds(Long[] infoIds) | ||||
|     { | ||||
|         return logininforMapper.deleteLogininforByIds(infoIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 清空系统登录日志 | ||||
|      */ | ||||
|     @Override | ||||
|     public void cleanLogininfor() | ||||
|     { | ||||
|         logininforMapper.cleanLogininfor(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,575 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.Arrays; | ||||
| import java.util.HashSet; | ||||
| import java.util.Iterator; | ||||
| import java.util.LinkedList; | ||||
| import java.util.List; | ||||
| import java.util.Set; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import com.fastbee.common.core.domain.entity.SysDept; | ||||
| import com.fastbee.common.core.domain.model.LoginUser; | ||||
| import com.fastbee.common.core.redis.RedisCache; | ||||
| import com.fastbee.system.mapper.*; | ||||
| import com.fastbee.system.service.IAppPreferencesService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import com.fastbee.common.constant.Constants; | ||||
| import com.fastbee.common.constant.UserConstants; | ||||
| import com.fastbee.common.core.domain.TreeSelect; | ||||
| import com.fastbee.common.core.domain.entity.SysMenu; | ||||
| import com.fastbee.common.core.domain.entity.SysRole; | ||||
| import com.fastbee.common.core.domain.entity.SysUser; | ||||
| import com.fastbee.common.utils.SecurityUtils; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.system.domain.vo.MetaVo; | ||||
| import com.fastbee.system.domain.vo.RouterVo; | ||||
| import com.fastbee.system.service.ISysMenuService; | ||||
|  | ||||
| import javax.annotation.Resource; | ||||
| import static com.fastbee.common.utils.SecurityUtils.getLoginUser; | ||||
|  | ||||
| /** | ||||
|  * 菜单 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysMenuServiceImpl implements ISysMenuService | ||||
| { | ||||
|     public static final String PREMISSION_STRING = "perms[\"{0}\"]"; | ||||
|  | ||||
|     @Resource | ||||
|     private SysMenuMapper menuMapper; | ||||
|  | ||||
|     @Resource | ||||
|     private SysRoleMapper roleMapper; | ||||
|  | ||||
|     @Resource | ||||
|     private SysRoleMenuMapper roleMenuMapper; | ||||
|  | ||||
|     @Resource | ||||
|     private SysDeptMapper sysDeptMapper; | ||||
|  | ||||
|     /** | ||||
|      * 根据用户查询系统菜单列表 | ||||
|      * | ||||
|      * @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) | ||||
|     { | ||||
|         menu.setLanguage(SecurityUtils.getLanguage()); | ||||
|         List<SysMenu> menuList = null; | ||||
|         // 管理员显示所有菜单信息 | ||||
|         if (SysUser.isAdmin(userId)) | ||||
|         { | ||||
|             menuList = menuMapper.selectMenuList(menu); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             menu.getParams().put("userId", userId); | ||||
|             menuList = menuMapper.selectMenuListByUserId(menu); | ||||
|         } | ||||
|         return menuList; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询权限 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public Set<String> selectMenuPermsByUserId(Long userId) | ||||
|     { | ||||
|         List<String> perms = menuMapper.selectMenuPermsByUserId(userId); | ||||
|         Set<String> permsSet = new HashSet<>(); | ||||
|         for (String perm : perms) | ||||
|         { | ||||
|             if (StringUtils.isNotEmpty(perm)) | ||||
|             { | ||||
|                 permsSet.addAll(Arrays.asList(perm.trim().split(","))); | ||||
|             } | ||||
|         } | ||||
|         return permsSet; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询权限 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public Set<String> selectMenuPermsByRoleId(Long roleId) | ||||
|     { | ||||
|         List<String> perms = menuMapper.selectMenuPermsByRoleId(roleId); | ||||
|         Set<String> permsSet = new HashSet<>(); | ||||
|         for (String perm : perms) | ||||
|         { | ||||
|             if (StringUtils.isNotEmpty(perm)) | ||||
|             { | ||||
|                 permsSet.addAll(Arrays.asList(perm.trim().split(","))); | ||||
|             } | ||||
|         } | ||||
|         return permsSet; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询菜单 | ||||
|      * | ||||
|      * @param userId 用户名称 | ||||
|      * @param language 语言 | ||||
|      * @return 菜单列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysMenu> selectMenuTreeByUserId(Long userId, String language) | ||||
|     { | ||||
|         List<SysMenu> menus = null; | ||||
|         if (SecurityUtils.isAdmin(userId)) | ||||
|         { | ||||
|             menus = menuMapper.selectMenuTreeAll(language); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             menus = menuMapper.selectMenuTreeByUserId(userId, language); | ||||
|         } | ||||
|         return getChildPerms(menus, 0); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据角色ID查询菜单树信息 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 选中菜单列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<Long> selectMenuListByRoleId(Long roleId) | ||||
|     { | ||||
|         SysRole role = roleMapper.selectRoleById(roleId); | ||||
|         return menuMapper.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.setQuery(menu.getQuery()); | ||||
|             router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StringUtils.equals("1", menu.getIsCache()), menu.getPath())); | ||||
|             List<SysMenu> cMenus = menu.getChildren(); | ||||
|             if (!cMenus.isEmpty() && cMenus.size() > 0 && 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(StringUtils.capitalize(menu.getPath())); | ||||
|                 children.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StringUtils.equals("1", menu.getIsCache()), menu.getPath())); | ||||
|                 children.setQuery(menu.getQuery()); | ||||
|                 childrenList.add(children); | ||||
|                 router.setChildren(childrenList); | ||||
|             } | ||||
|             else if (menu.getParentId().intValue() == 0 && isInnerLink(menu)) | ||||
|             { | ||||
|                 router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon())); | ||||
|                 router.setPath("/"); | ||||
|                 List<RouterVo> childrenList = new ArrayList<RouterVo>(); | ||||
|                 RouterVo children = new RouterVo(); | ||||
|                 String routerPath = innerLinkReplaceEach(menu.getPath()); | ||||
|                 children.setPath(routerPath); | ||||
|                 children.setComponent(UserConstants.INNER_LINK); | ||||
|                 children.setName(StringUtils.capitalize(routerPath)); | ||||
|                 children.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), menu.getPath())); | ||||
|                 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 = menus.stream().map(SysMenu::getMenuId).collect(Collectors.toList()); | ||||
|         for (Iterator<SysMenu> iterator = menus.iterator(); iterator.hasNext();) | ||||
|         { | ||||
|             SysMenu menu = (SysMenu) iterator.next(); | ||||
|             // 如果是顶级节点, 遍历该父节点的所有子节点 | ||||
|             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 menuMapper.selectMenuById(menuId, SecurityUtils.getLanguage()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否存在菜单子节点 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean hasChildByMenuId(Long menuId) | ||||
|     { | ||||
|         int result = menuMapper.hasChildByMenuId(menuId); | ||||
|         return result > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询菜单使用数量 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean checkMenuExistRole(Long menuId) | ||||
|     { | ||||
|         int result = roleMenuMapper.checkMenuExistRole(menuId); | ||||
|         return result > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存菜单信息 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertMenu(SysMenu menu) | ||||
|     { | ||||
|         return menuMapper.insertMenu(menu); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存菜单信息 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateMenu(SysMenu menu) | ||||
|     { | ||||
|         return menuMapper.updateMenu(menu); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除菜单管理信息 | ||||
|      * | ||||
|      * @param menuId 菜单ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteMenuById(Long menuId) | ||||
|     { | ||||
|         return menuMapper.deleteMenuById(menuId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验菜单名称是否唯一 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkMenuNameUnique(SysMenu menu) | ||||
|     { | ||||
|         Long menuId = StringUtils.isNull(menu.getMenuId()) ? -1L : menu.getMenuId(); | ||||
|         // 仅匹配菜单表存储的菜单名称,不匹配菜单翻译表存储的对应语言名称 | ||||
|         SysMenu info = menuMapper.checkMenuNameUnique(menu.getMenuName(), menu.getParentId()); | ||||
|         if (StringUtils.isNotNull(info) && info.getMenuId().longValue() != menuId.longValue()) | ||||
|         { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public List<SysMenu> deptMenuTreeselect(Long deptId) { | ||||
|         SysDept sysDept = sysDeptMapper.selectDeptById(deptId); | ||||
|         if (ObjectUtil.isNull(sysDept) && null == sysDept.getDeptUserId()) { | ||||
|             return new ArrayList<>(); | ||||
|         } | ||||
|         return this.selectMenuList(sysDept.getDeptUserId()); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public List<SysMenu> deptRoleMenuTreeselect(Long deptId, Long roleId) { | ||||
|         LoginUser loginUser = getLoginUser(); | ||||
|         Long userDeptId = loginUser.getDeptId(); | ||||
|         Long deptUserId = loginUser.getUser().getDept().getDeptUserId(); | ||||
|         SysRole sysRole = roleMapper.selectRoleById(roleId); | ||||
| //        List<SysUserRole> sysUserRoleList = sysUserRoleMapper.selectRoleByUserId(sysDept.getDeptUserId()); | ||||
| //        SysUserRole sysUserRole = sysUserRoleList.stream().filter(s -> roleId.equals(s.getRoleId())).findAny().orElse(null); | ||||
| //        if (ObjectUtil.isNotNull(sysUserRole)) { | ||||
| //            return menuMapper.selectMenuList(new SysMenu()); | ||||
| //        } | ||||
|         if (!deptId.equals(userDeptId) && "manager".equals(sysRole.getRoleKey())) { | ||||
|             return this.selectMenuList(deptUserId); | ||||
|         } | ||||
|         SysDept sysDept = sysDeptMapper.selectDeptById(deptId); | ||||
|         if (ObjectUtil.isNull(sysDept) && null == sysDept.getDeptUserId()) { | ||||
|             return new ArrayList<>(); | ||||
|         } | ||||
|         return this.selectMenuList(new SysMenu(), sysDept.getDeptUserId()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取路由名称 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 路由名称 | ||||
|      */ | ||||
|     public String getRouteName(SysMenu menu) | ||||
|     { | ||||
|         String routerName = StringUtils.capitalize(menu.getPath()); | ||||
|         // 非外链并且是一级目录(类型为目录) | ||||
|         if (isMenuFrame(menu)) | ||||
|         { | ||||
|             routerName = StringUtils.EMPTY; | ||||
|         } | ||||
|         return routerName; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取路由地址 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 路由地址 | ||||
|      */ | ||||
|     public String getRouterPath(SysMenu menu) | ||||
|     { | ||||
|         String routerPath = menu.getPath(); | ||||
|         // 内链打开外网方式 | ||||
|         if (menu.getParentId().intValue() != 0 && isInnerLink(menu)) | ||||
|         { | ||||
|             routerPath = innerLinkReplaceEach(routerPath); | ||||
|         } | ||||
|         // 非外链并且是一级目录(类型为目录) | ||||
|         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 (StringUtils.isNotEmpty(menu.getComponent()) && !isMenuFrame(menu)) | ||||
|         { | ||||
|             component = menu.getComponent(); | ||||
|         } | ||||
|         else if (StringUtils.isEmpty(menu.getComponent()) && menu.getParentId().intValue() != 0 && isInnerLink(menu)) | ||||
|         { | ||||
|             component = UserConstants.INNER_LINK; | ||||
|         } | ||||
|         else if (StringUtils.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); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否为内链组件 | ||||
|      * | ||||
|      * @param menu 菜单信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public boolean isInnerLink(SysMenu menu) | ||||
|     { | ||||
|         return menu.getIsFrame().equals(UserConstants.NO_FRAME) && StringUtils.ishttp(menu.getPath()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 是否为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 (Iterator<SysMenu> iterator = list.iterator(); iterator.hasNext();) | ||||
|         { | ||||
|             SysMenu t = (SysMenu) iterator.next(); | ||||
|             // 一、根据传入的某个父节点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>(); | ||||
|         Iterator<SysMenu> it = list.iterator(); | ||||
|         while (it.hasNext()) | ||||
|         { | ||||
|             SysMenu n = (SysMenu) it.next(); | ||||
|             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; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 内链域名特殊字符替换 | ||||
|      * | ||||
|      * @return 替换后的内链域名 | ||||
|      */ | ||||
|     public String innerLinkReplaceEach(String path) | ||||
|     { | ||||
|         return StringUtils.replaceEach(path, new String[] { Constants.HTTP, Constants.HTTPS, Constants.WWW, "." }, | ||||
|                 new String[] { "", "", "", "/" }); | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,92 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import com.fastbee.system.domain.SysNotice; | ||||
| import com.fastbee.system.mapper.SysNoticeMapper; | ||||
| import com.fastbee.system.service.ISysNoticeService; | ||||
|  | ||||
| /** | ||||
|  * 公告 服务层实现 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysNoticeServiceImpl implements ISysNoticeService | ||||
| { | ||||
|     @Autowired | ||||
|     private SysNoticeMapper noticeMapper; | ||||
|  | ||||
|     /** | ||||
|      * 查询公告信息 | ||||
|      *  | ||||
|      * @param noticeId 公告ID | ||||
|      * @return 公告信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysNotice selectNoticeById(Long noticeId) | ||||
|     { | ||||
|         return noticeMapper.selectNoticeById(noticeId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询公告列表 | ||||
|      *  | ||||
|      * @param notice 公告信息 | ||||
|      * @return 公告集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysNotice> selectNoticeList(SysNotice notice) | ||||
|     { | ||||
|         return noticeMapper.selectNoticeList(notice); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增公告 | ||||
|      *  | ||||
|      * @param notice 公告信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertNotice(SysNotice notice) | ||||
|     { | ||||
|         return noticeMapper.insertNotice(notice); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改公告 | ||||
|      *  | ||||
|      * @param notice 公告信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateNotice(SysNotice notice) | ||||
|     { | ||||
|         return noticeMapper.updateNotice(notice); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除公告对象 | ||||
|      *  | ||||
|      * @param noticeId 公告ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteNoticeById(Long noticeId) | ||||
|     { | ||||
|         return noticeMapper.deleteNoticeById(noticeId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除公告信息 | ||||
|      *  | ||||
|      * @param noticeIds 需要删除的公告ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteNoticeByIds(Long[] noticeIds) | ||||
|     { | ||||
|         return noticeMapper.deleteNoticeByIds(noticeIds); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,76 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import com.fastbee.system.domain.SysOperLog; | ||||
| import com.fastbee.system.mapper.SysOperLogMapper; | ||||
| import com.fastbee.system.service.ISysOperLogService; | ||||
|  | ||||
| /** | ||||
|  * 操作日志 服务层处理 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysOperLogServiceImpl implements ISysOperLogService | ||||
| { | ||||
|     @Autowired | ||||
|     private SysOperLogMapper operLogMapper; | ||||
|  | ||||
|     /** | ||||
|      * 新增操作日志 | ||||
|      *  | ||||
|      * @param operLog 操作日志对象 | ||||
|      */ | ||||
|     @Override | ||||
|     public void insertOperlog(SysOperLog operLog) | ||||
|     { | ||||
|         operLogMapper.insertOperlog(operLog); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询系统操作日志集合 | ||||
|      *  | ||||
|      * @param operLog 操作日志对象 | ||||
|      * @return 操作日志集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysOperLog> selectOperLogList(SysOperLog operLog) | ||||
|     { | ||||
|         return operLogMapper.selectOperLogList(operLog); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除系统操作日志 | ||||
|      *  | ||||
|      * @param operIds 需要删除的操作日志ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deleteOperLogByIds(Long[] operIds) | ||||
|     { | ||||
|         return operLogMapper.deleteOperLogByIds(operIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询操作日志详细 | ||||
|      *  | ||||
|      * @param operId 操作ID | ||||
|      * @return 操作日志对象 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysOperLog selectOperLogById(Long operId) | ||||
|     { | ||||
|         return operLogMapper.selectOperLogById(operId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 清空操作日志 | ||||
|      */ | ||||
|     @Override | ||||
|     public void cleanOperLog() | ||||
|     { | ||||
|         operLogMapper.cleanOperLog(); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,178 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.List; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| import com.fastbee.common.constant.UserConstants; | ||||
| import com.fastbee.common.exception.ServiceException; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.system.domain.SysPost; | ||||
| import com.fastbee.system.mapper.SysPostMapper; | ||||
| import com.fastbee.system.mapper.SysUserPostMapper; | ||||
| import com.fastbee.system.service.ISysPostService; | ||||
|  | ||||
| /** | ||||
|  * 岗位信息 服务层处理 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysPostServiceImpl implements ISysPostService | ||||
| { | ||||
|     @Autowired | ||||
|     private SysPostMapper postMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserPostMapper userPostMapper; | ||||
|  | ||||
|     /** | ||||
|      * 查询岗位信息集合 | ||||
|      *  | ||||
|      * @param post 岗位信息 | ||||
|      * @return 岗位信息集合 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysPost> selectPostList(SysPost post) | ||||
|     { | ||||
|         return postMapper.selectPostList(post); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询所有岗位 | ||||
|      *  | ||||
|      * @return 岗位列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysPost> selectPostAll() | ||||
|     { | ||||
|         return postMapper.selectPostAll(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过岗位ID查询岗位信息 | ||||
|      *  | ||||
|      * @param postId 岗位ID | ||||
|      * @return 角色对象信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysPost selectPostById(Long postId) | ||||
|     { | ||||
|         return postMapper.selectPostById(postId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID获取岗位选择框列表 | ||||
|      *  | ||||
|      * @param userId 用户ID | ||||
|      * @return 选中岗位ID列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<Long> selectPostListByUserId(Long userId) | ||||
|     { | ||||
|         return postMapper.selectPostListByUserId(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验岗位名称是否唯一 | ||||
|      *  | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkPostNameUnique(SysPost post) | ||||
|     { | ||||
|         Long postId = StringUtils.isNull(post.getPostId()) ? -1L : post.getPostId(); | ||||
|         SysPost info = postMapper.checkPostNameUnique(post.getPostName()); | ||||
|         if (StringUtils.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 = StringUtils.isNull(post.getPostId()) ? -1L : post.getPostId(); | ||||
|         SysPost info = postMapper.checkPostCodeUnique(post.getPostCode()); | ||||
|         if (StringUtils.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.countUserPostById(postId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 删除岗位信息 | ||||
|      *  | ||||
|      * @param postId 岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deletePostById(Long postId) | ||||
|     { | ||||
|         return postMapper.deletePostById(postId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除岗位信息 | ||||
|      *  | ||||
|      * @param postIds 需要删除的岗位ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int deletePostByIds(Long[] postIds) | ||||
|     { | ||||
|         for (Long postId : postIds) | ||||
|         { | ||||
|             SysPost post = selectPostById(postId); | ||||
|             if (countUserPostById(postId) > 0) | ||||
|             { | ||||
|                 throw new ServiceException(String.format("%1$s已分配,不能删除", post.getPostName())); | ||||
|             } | ||||
|         } | ||||
|         return postMapper.deletePostByIds(postIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存岗位信息 | ||||
|      *  | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertPost(SysPost post) | ||||
|     { | ||||
|         return postMapper.insertPost(post); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存岗位信息 | ||||
|      *  | ||||
|      * @param post 岗位信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updatePost(SysPost post) | ||||
|     { | ||||
|         return postMapper.updatePost(post); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,528 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import java.util.*; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import com.fastbee.common.core.domain.entity.SysDept; | ||||
| import com.fastbee.common.core.domain.model.LoginUser; | ||||
| import com.fastbee.system.mapper.*; | ||||
| import org.apache.commons.collections4.CollectionUtils; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.cache.annotation.CacheEvict; | ||||
| import org.springframework.cache.annotation.CachePut; | ||||
| import org.springframework.cache.annotation.Cacheable; | ||||
| import org.springframework.cache.annotation.Caching; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
| import com.fastbee.common.annotation.DataScope; | ||||
| import com.fastbee.common.constant.UserConstants; | ||||
| import com.fastbee.common.core.domain.entity.SysRole; | ||||
| import com.fastbee.common.core.domain.entity.SysUser; | ||||
| import com.fastbee.common.exception.ServiceException; | ||||
| import com.fastbee.common.utils.SecurityUtils; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.common.utils.spring.SpringUtils; | ||||
| import com.fastbee.system.domain.SysRoleDept; | ||||
| import com.fastbee.system.domain.SysRoleMenu; | ||||
| import com.fastbee.system.domain.SysUserRole; | ||||
| import com.fastbee.system.service.ISysRoleService; | ||||
|  | ||||
| import javax.annotation.Resource; | ||||
|  | ||||
| import static com.fastbee.common.utils.SecurityUtils.getLoginUser; | ||||
| import static com.fastbee.common.utils.SecurityUtils.isAdmin; | ||||
|  | ||||
| /** | ||||
|  * 角色 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysRoleServiceImpl implements ISysRoleService | ||||
| { | ||||
|     @Autowired | ||||
|     private SysRoleMapper roleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleMenuMapper roleMenuMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserRoleMapper userRoleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleDeptMapper roleDeptMapper; | ||||
|  | ||||
|     @Resource | ||||
|     private SysDeptMapper sysDeptMapper; | ||||
|     @Resource | ||||
|     private SysUserMapper sysUserMapper; | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询角色数据 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 角色数据集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d") | ||||
|     public List<SysRole> selectRoleList(SysRole role) | ||||
|     { | ||||
|         LoginUser loginUser = getLoginUser(); | ||||
|         Long userId = loginUser.getUserId(); | ||||
|         Long userDeptId = loginUser.getDeptId(); | ||||
|         Long deptId; | ||||
|         if (null != role.getDeptId()) { | ||||
|             deptId = role.getDeptId(); | ||||
|         } else { | ||||
|             deptId = loginUser.getDeptId(); | ||||
|         } | ||||
|         List<SysDept> sysDeptList; | ||||
|         SysDept sysDept = new SysDept(); | ||||
|         sysDept.setDeptId(deptId); | ||||
|         if (null != role.getShowChild() && role.getShowChild()) { | ||||
|             sysDeptList = sysDeptMapper.listDeptAndChild(sysDept); | ||||
|         } else { | ||||
|             sysDeptList = sysDeptMapper.selectDeptList(sysDept); | ||||
|         } | ||||
| //        List<SysDept> sysDeptList = new ArrayList<>(); | ||||
| //        if (null != role.getDeptIds()) { | ||||
| //            sysDeptList = sysDeptMapper.selectDeptByIds(Arrays.asList(role.getDeptIds())); | ||||
| //        } else { | ||||
| //            LoginUser loginUser = getLoginUser(); | ||||
| //            Long deptId = loginUser.getDeptId(); | ||||
| //            if (null != deptId) { | ||||
| //                SysDept sysDept = new SysDept(); | ||||
| //                sysDept.setDeptId(deptId); | ||||
| //                sysDeptList = sysDeptMapper.selectDeptList(sysDept); | ||||
| //            } | ||||
| //        } | ||||
|         if (CollectionUtils.isNotEmpty(sysDeptList)) { | ||||
|             Map<Long, String> deptMap = sysDeptList.stream().collect(Collectors.toMap(SysDept::getDeptId, SysDept::getDeptName)); | ||||
|             List<Long> deptIdList = sysDeptList.stream().map(SysDept::getDeptId).collect(Collectors.toList()); | ||||
|             List<SysRoleDept> sysRoleDeptList = roleDeptMapper.selectRoleDeptByDeptIds(deptIdList); | ||||
|             Map<Long, Long> roleDeptMap = sysRoleDeptList.stream().collect(Collectors.toMap(SysRoleDept::getRoleId, SysRoleDept::getDeptId)); | ||||
|             if (CollectionUtils.isEmpty(sysRoleDeptList)) { | ||||
|                 return new ArrayList<>(); | ||||
|             } | ||||
|             List<Long> roleIdList = sysRoleDeptList.stream().map(SysRoleDept::getRoleId).collect(Collectors.toList()); | ||||
|             if (CollectionUtils.isEmpty(roleIdList)) { | ||||
|                 return new ArrayList<>(); | ||||
|             } | ||||
|             List<SysRole> sysRoleList = roleMapper.selectRoleByIds(roleIdList, role.getRoleName(), role.getStatus()); | ||||
|             for (SysRole sysRole : sysRoleList) { | ||||
|                 Long deptId1 = roleDeptMap.get(sysRole.getRoleId()); | ||||
|                 String deptName = deptMap.get(deptId1); | ||||
|                 sysRole.setDeptId(deptId1); | ||||
|                 sysRole.setDeptName(deptName); | ||||
| //                if (userDeptId.equals(deptId1) && "manager".equals(sysRole.getRoleKey())) { | ||||
| //                    sysRole.setCanEditRole(false); | ||||
| //                } else { | ||||
| //                    sysRole.setCanEditRole(true); | ||||
| //                } | ||||
|                 sysRole.setCanEditRole(!(userDeptId.equals(deptId1) && "manager".equals(sysRole.getRoleKey()) && !isAdmin(userId))); | ||||
|                 sysRole.setManager("manager".equals(sysRole.getRoleKey())); | ||||
|             } | ||||
|             return sysRoleList; | ||||
|         } else { | ||||
|             return new ArrayList<>(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询角色 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 角色列表 | ||||
|      */ | ||||
|     @Cacheable(value = "role", key = "#root.methodName + '_' + #userId", unless = "#result == null or #result.size() == 0") | ||||
|     @Override | ||||
|     public List<SysRole> selectRolesByUserId(Long userId) | ||||
|     { | ||||
|         List<SysRole> userRoles = roleMapper.selectRolePermissionByUserId(userId); | ||||
|         List<SysRole> roles = selectRoleAll(); | ||||
|         for (SysRole role : roles) | ||||
|         { | ||||
|             for (SysRole userRole : userRoles) | ||||
|             { | ||||
|                 if (role.getRoleId().longValue() == userRole.getRoleId().longValue()) | ||||
|                 { | ||||
|                     role.setFlag(true); | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return roles; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户ID查询权限 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 权限列表 | ||||
|      */ | ||||
|     @Cacheable(value = "role", key = "#root.methodName + '_' + #userId", unless = "#result == null or #result.size() == 0") | ||||
|     @Override | ||||
|     public Set<String> selectRolePermissionByUserId(Long userId) | ||||
|     { | ||||
|         List<SysRole> perms = roleMapper.selectRolePermissionByUserId(userId); | ||||
|         Set<String> permsSet = new HashSet<>(); | ||||
|         for (SysRole perm : perms) | ||||
|         { | ||||
|             if (StringUtils.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<Long> selectRoleListByUserId(Long userId) | ||||
|     { | ||||
|         return roleMapper.selectRoleListByUserId(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID查询角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 角色对象信息 | ||||
|      */ | ||||
|     @Cacheable(value = "role", key = "#root.methodName + '_' + #roleId", unless = "#result == null") | ||||
|     @Override | ||||
|     public SysRole selectRoleById(Long roleId) | ||||
|     { | ||||
|         SysRole sysRole = roleMapper.selectRoleById(roleId); | ||||
|         if (ObjectUtil.isNotNull(sysRole)) { | ||||
|             SysRoleDept sysRoleDept = roleDeptMapper.selectByRoleId(sysRole.getRoleId()); | ||||
|             if (ObjectUtil.isNotNull(sysRoleDept)) { | ||||
|                 sysRole.setDeptId(sysRoleDept.getDeptId()); | ||||
|             } | ||||
|         } | ||||
|         return sysRole; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验角色名称是否唯一 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkRoleNameUnique(SysRole role) | ||||
|     { | ||||
|         Long roleId = StringUtils.isNull(role.getRoleId()) ? -1L : role.getRoleId(); | ||||
|         SysRole info = roleMapper.checkRoleNameUnique(role.getRoleName()); | ||||
|         if (StringUtils.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 = StringUtils.isNull(role.getRoleId()) ? -1L : role.getRoleId(); | ||||
|         SysRole info = roleMapper.checkRoleKeyUnique(role.getRoleKey()); | ||||
|         if (StringUtils.isNotNull(info) && info.getRoleId().longValue() != roleId.longValue()) | ||||
|         { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验角色是否允许操作 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public void checkRoleAllowed(SysRole role) | ||||
|     { | ||||
|         if (StringUtils.isNotNull(role.getRoleId()) && role.isAdmin()) | ||||
|         { | ||||
|             throw new ServiceException("不允许操作超级管理员角色"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验角色是否有数据权限 | ||||
|      * | ||||
|      * @param roleId 角色id | ||||
|      */ | ||||
|     @Override | ||||
|     public void checkRoleDataScope(Long roleId) | ||||
|     { | ||||
|         if (!SysUser.isAdmin(SecurityUtils.getUserId())) | ||||
|         { | ||||
|             SysRole role = new SysRole(); | ||||
|             role.setRoleId(roleId); | ||||
|             List<SysRole> roles = SpringUtils.getAopProxy(this).selectRoleList(role); | ||||
|             if (StringUtils.isEmpty(roles)) | ||||
|             { | ||||
|                 throw new ServiceException("没有权限访问角色数据!"); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID查询角色使用数量 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Cacheable(value = "role", key = "#root.methodName + '_' + #roleId", unless = "#result == null") | ||||
|     @Override | ||||
|     public int countUserRoleByRoleId(Long roleId) | ||||
|     { | ||||
|         return userRoleMapper.countUserRoleByRoleId(roleId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存角色信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Caching(put = { | ||||
|             @CachePut(value = "role", key = "'selectRoleById' + '_' + #role.roleId", condition = "#result != null"), | ||||
|     }) | ||||
|     @Override | ||||
|     @Transactional(rollbackFor = Exception.class) | ||||
|     public int insertRole(SysRole role) | ||||
|     { | ||||
|         // 新增角色信息 | ||||
|         roleMapper.insertRole(role); | ||||
|         // 绑定部门角色 | ||||
|         List<SysRoleDept> sysRoleDeptList = new ArrayList<>(); | ||||
|         SysRoleDept sysRoleDept = new SysRoleDept(); | ||||
|         sysRoleDept.setDeptId(role.getDeptId()); | ||||
|         sysRoleDept.setRoleId(role.getRoleId()); | ||||
|         sysRoleDeptList.add(sysRoleDept); | ||||
|         if (CollectionUtils.isNotEmpty(sysRoleDeptList)) { | ||||
|             roleDeptMapper.batchRoleDept(sysRoleDeptList); | ||||
|         } | ||||
|         return insertRoleMenu(role); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存角色信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Caching(put = { | ||||
|             @CachePut(value = "role", key = "'selectRoleById' + '_' + #role.roleId", condition = "#result != null"), | ||||
|     }) | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int updateRole(SysRole role) | ||||
|     { | ||||
|         // 修改角色信息 | ||||
|         roleMapper.updateRole(role); | ||||
|         // 删除角色与菜单关联 | ||||
|         roleMenuMapper.deleteRoleMenuByRoleId(role.getRoleId()); | ||||
|         return insertRoleMenu(role); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改角色状态 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Caching(put = { | ||||
|             @CachePut(value = "role", key = "'selectRoleById' + '_' + #role.roleId", condition = "#result != null"), | ||||
|     }) | ||||
|     @Override | ||||
|     public int updateRoleStatus(SysRole role) | ||||
|     { | ||||
|         return roleMapper.updateRole(role); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改数据权限信息 | ||||
|      * | ||||
|      * @param role 角色信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int authDataScope(SysRole role) | ||||
|     { | ||||
|         // 修改角色信息 | ||||
|         roleMapper.updateRole(role); | ||||
|         // 删除角色与部门关联 | ||||
|         roleDeptMapper.deleteRoleDeptByRoleId(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.batchRoleMenu(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.batchRoleDept(list); | ||||
|         } | ||||
|         return rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过角色ID删除角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @CacheEvict(value = "role", allEntries = true) | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int deleteRoleById(Long roleId) | ||||
|     { | ||||
|         // 删除角色与菜单关联 | ||||
|         roleMenuMapper.deleteRoleMenuByRoleId(roleId); | ||||
|         // 删除角色与部门关联 | ||||
|         roleDeptMapper.deleteRoleDeptByRoleId(roleId); | ||||
|         return roleMapper.deleteRoleById(roleId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除角色信息 | ||||
|      * | ||||
|      * @param roleIds 需要删除的角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @CacheEvict(value = "role", allEntries = true) | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int deleteRoleByIds(Long[] roleIds) | ||||
|     { | ||||
|         for (Long roleId : roleIds) | ||||
|         { | ||||
|             checkRoleAllowed(new SysRole(roleId)); | ||||
|             checkRoleDataScope(roleId); | ||||
|             SysRole role = selectRoleById(roleId); | ||||
|             //if (countUserRoleByRoleId(roleId) > 0) | ||||
|             //{ | ||||
|             //    throw new ServiceException(String.format("%1$s已分配,不能删除", role.getRoleName())); | ||||
|             //} | ||||
|         } | ||||
|         // 删除角色与菜单关联 | ||||
|         roleMenuMapper.deleteRoleMenu(roleIds); | ||||
|         // 删除角色与部门关联 | ||||
|         roleDeptMapper.deleteRoleDept(roleIds); | ||||
|         return roleMapper.deleteRoleByIds(roleIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 取消授权用户角色 | ||||
|      * | ||||
|      * @param userRole 用户和角色关联信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @CacheEvict(value = "role", allEntries = true) | ||||
|     @Override | ||||
|     public int deleteAuthUser(SysUserRole userRole) | ||||
|     { | ||||
|         return userRoleMapper.deleteUserRoleInfo(userRole); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量取消授权用户角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @param userIds 需要取消授权的用户数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @CacheEvict(value = "role", allEntries = true) | ||||
|     @Override | ||||
|     public int deleteAuthUsers(Long roleId, Long[] userIds) | ||||
|     { | ||||
|         return userRoleMapper.deleteUserRoleInfos(roleId, userIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量选择授权用户角色 | ||||
|      * | ||||
|      * @param roleId 角色ID | ||||
|      * @param userIds 需要授权的用户数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int insertAuthUsers(Long roleId, Long[] userIds) | ||||
|     { | ||||
|         // 新增用户与角色管理 | ||||
|         List<SysUserRole> list = new ArrayList<SysUserRole>(); | ||||
|         for (Long userId : userIds) | ||||
|         { | ||||
|             SysUserRole ur = new SysUserRole(); | ||||
|             ur.setUserId(userId); | ||||
|             ur.setRoleId(roleId); | ||||
|             list.add(ur); | ||||
|         } | ||||
|         return userRoleMapper.batchUserRole(list); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,95 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import com.fastbee.common.core.domain.entity.SysTranslate; | ||||
| import com.fastbee.common.enums.TranslateType; | ||||
| import com.fastbee.system.mapper.SysTranslateMapper; | ||||
| import com.fastbee.system.service.ISysTranslateService; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import javax.annotation.Resource; | ||||
| import java.util.List; | ||||
|  | ||||
| import static com.fastbee.common.constant.Constants.*; | ||||
|  | ||||
| /** | ||||
|  * 翻译Service业务层处理 | ||||
|  * | ||||
|  * @author kerwincui | ||||
|  * @date 2024-05-29 | ||||
|  */ | ||||
| @Service | ||||
| public class SysTranslateServiceImpl implements ISysTranslateService | ||||
| { | ||||
|     @Resource | ||||
|     private SysTranslateMapper sysTranslateMapper; | ||||
|  | ||||
|     /** | ||||
|      * 导入翻译列表 | ||||
|      * @param list | ||||
|      * @return | ||||
|      */ | ||||
|     public void importSysTranslate(List<SysTranslate> list, String type, Long productId) { | ||||
|         TranslateType translateType = matchTranslateType(type); | ||||
|         if (translateType == null) { | ||||
|             return; | ||||
|         } | ||||
|         for (SysTranslate sysTranslate : list) { | ||||
|             sysTranslate.setTableName(translateType.getTranslateTable()); | ||||
|             sysTranslate.setProductId(productId); | ||||
|             sysTranslateMapper.insertSysTranslate(sysTranslate); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询翻译列表 | ||||
|      * @param sysTranslate 翻译类 | ||||
|      * @return 翻译列表 | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysTranslate> selectSysTranslateList(SysTranslate sysTranslate, String type) | ||||
|     { | ||||
|         TranslateType translateType = matchTranslateType(type); | ||||
|         if (translateType == null) { | ||||
|             return null; | ||||
|         } | ||||
|         sysTranslate.setTableName(translateType.getTranslateTable()); | ||||
|         return sysTranslateMapper.selectSysTranslateList(sysTranslate); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询原表数据列表 | ||||
|      * @param type | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysTranslate> selectSourceList(String type, Long productId) { | ||||
|         TranslateType translateType = matchTranslateType(type); | ||||
|         if (translateType == null) { | ||||
|             return null; | ||||
|         } | ||||
|         return sysTranslateMapper.selectSourceList(translateType.getSourceTable(), translateType.getIdColumn(), translateType.getNameColumn(), productId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据type匹配对应的翻译类型 | ||||
|      * @param type | ||||
|      * @return | ||||
|      */ | ||||
|     public TranslateType matchTranslateType(String type) { | ||||
|         switch (type) { | ||||
|             case MENU: | ||||
|                 return TranslateType.MENU_TYPE; | ||||
|             case DICT_DATA: | ||||
|                 return TranslateType.DICT_DATA_TYPE; | ||||
|             case DICT_TYPE: | ||||
|                 return TranslateType.DICT_TYPE_TYPE; | ||||
|             case THINGS_MODEL: | ||||
|                 return TranslateType.THINGS_MODEL_TYPE; | ||||
|             case THINGS_MODEL_TEMPLATE: | ||||
|                 return TranslateType.THINGS_MODEL_TEMPLATE_TYPE; | ||||
|             default: | ||||
|                 return null; | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,96 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import org.springframework.stereotype.Service; | ||||
| import com.fastbee.common.core.domain.model.LoginUser; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.system.domain.SysUserOnline; | ||||
| import com.fastbee.system.service.ISysUserOnlineService; | ||||
|  | ||||
| /** | ||||
|  * 在线用户 服务层处理 | ||||
|  *  | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysUserOnlineServiceImpl implements ISysUserOnlineService | ||||
| { | ||||
|     /** | ||||
|      * 通过登录地址查询信息 | ||||
|      *  | ||||
|      * @param ipaddr 登录地址 | ||||
|      * @param user 用户信息 | ||||
|      * @return 在线用户信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUserOnline selectOnlineByIpaddr(String ipaddr, LoginUser user) | ||||
|     { | ||||
|         if (StringUtils.equals(ipaddr, user.getIpaddr())) | ||||
|         { | ||||
|             return loginUserToUserOnline(user); | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名称查询信息 | ||||
|      *  | ||||
|      * @param userName 用户名称 | ||||
|      * @param user 用户信息 | ||||
|      * @return 在线用户信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUserOnline selectOnlineByUserName(String userName, LoginUser user) | ||||
|     { | ||||
|         if (StringUtils.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 (StringUtils.equals(ipaddr, user.getIpaddr()) && StringUtils.equals(userName, user.getUsername())) | ||||
|         { | ||||
|             return loginUserToUserOnline(user); | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 设置在线用户信息 | ||||
|      *  | ||||
|      * @param user 用户信息 | ||||
|      * @return 在线用户 | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUserOnline loginUserToUserOnline(LoginUser user) | ||||
|     { | ||||
|         if (StringUtils.isNull(user) || StringUtils.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 (StringUtils.isNotNull(user.getUser().getDept())) | ||||
|         { | ||||
|             sysUserOnline.setDeptName(user.getUser().getDept().getDeptName()); | ||||
|         } | ||||
|         return sysUserOnline; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,644 @@ | ||||
| package com.fastbee.system.service.impl; | ||||
|  | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import com.fastbee.common.annotation.DataScope; | ||||
| import com.fastbee.common.constant.UserConstants; | ||||
| import com.fastbee.common.core.domain.entity.SysDept; | ||||
| import com.fastbee.common.core.domain.entity.SysRole; | ||||
| import com.fastbee.common.core.domain.entity.SysUser; | ||||
| import com.fastbee.common.enums.SocialPlatformType; | ||||
| import com.fastbee.common.exception.ServiceException; | ||||
| import com.fastbee.common.utils.SecurityUtils; | ||||
| import com.fastbee.common.utils.StringUtils; | ||||
| import com.fastbee.common.utils.bean.BeanValidators; | ||||
| import com.fastbee.common.utils.spring.SpringUtils; | ||||
| import com.fastbee.system.domain.SysPost; | ||||
| import com.fastbee.system.domain.SysUserPost; | ||||
| import com.fastbee.system.domain.SysUserRole; | ||||
| import com.fastbee.system.mapper.SysPostMapper; | ||||
| import com.fastbee.system.mapper.SysRoleMapper; | ||||
| import com.fastbee.system.mapper.SysUserMapper; | ||||
| import com.fastbee.system.mapper.SysUserPostMapper; | ||||
| import com.fastbee.system.mapper.SysUserRoleMapper; | ||||
| import com.fastbee.system.service.ISysConfigService; | ||||
| import com.fastbee.system.service.ISysUserService; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.cache.annotation.CacheEvict; | ||||
| import org.springframework.cache.annotation.CachePut; | ||||
| import org.springframework.cache.annotation.Cacheable; | ||||
| import org.springframework.cache.annotation.Caching; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
| import org.springframework.util.CollectionUtils; | ||||
|  | ||||
| import javax.validation.Validator; | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| import static com.fastbee.common.utils.SecurityUtils.getLoginUser; | ||||
| import static com.fastbee.common.utils.SecurityUtils.isAdmin; | ||||
|  | ||||
| /** | ||||
|  * 用户 业务层处理 | ||||
|  * | ||||
|  * @author ruoyi | ||||
|  */ | ||||
| @Service | ||||
| public class SysUserServiceImpl implements ISysUserService | ||||
| { | ||||
|     private static final Logger log = LoggerFactory.getLogger(SysUserServiceImpl.class); | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserMapper userMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysRoleMapper roleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysPostMapper postMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserRoleMapper userRoleMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private SysUserPostMapper userPostMapper; | ||||
|  | ||||
|     @Autowired | ||||
|     private ISysConfigService configService; | ||||
|  | ||||
|     @Autowired | ||||
|     protected Validator validator; | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询用户列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d", userAlias = "u") | ||||
|     public List<SysUser> selectUserList(SysUser user) | ||||
|     { | ||||
|         List<SysUser> sysUserList = userMapper.selectUserList(user); | ||||
|         for (SysUser sysUser : sysUserList) { | ||||
|             SysDept dept = sysUser.getDept(); | ||||
|             sysUser.setManager(sysUser.getUserId().equals(dept.getDeptUserId())); | ||||
|         } | ||||
|         return sysUserList; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询已分配用户角色列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d", userAlias = "u") | ||||
|     public List<SysUser> selectAllocatedList(SysUser user) | ||||
|     { | ||||
|         return userMapper.selectAllocatedList(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据条件分页查询未分配用户角色列表 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 用户信息集合信息 | ||||
|      */ | ||||
|     @Override | ||||
|     @DataScope(deptAlias = "d", userAlias = "u") | ||||
|     public List<SysUser> selectUnallocatedList(SysUser user) | ||||
|     { | ||||
|         user.setDeptId(getLoginUser().getUser().getDeptId()); | ||||
|         return userMapper.selectUnallocatedList(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过用户名查询用户 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     @Cacheable(value = "sysUser", key = "#root.methodName + '_' + #userName", unless = "#result == null") | ||||
|     @Override | ||||
|     public SysUser selectUserByUserName(String userName) | ||||
|     { | ||||
|         return userMapper.selectUserByUserName(userName); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID查询用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     @Cacheable(value = "sysUser", key = "#root.methodName + '_' + #userId", unless = "#result == null") | ||||
|     @Override | ||||
|     public SysUser selectUserById(Long userId) | ||||
|     { | ||||
|         return userMapper.selectUserById(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询用户所属角色组 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Cacheable(value = "sysUser", key = "#root.methodName + '_' + #userName", unless = "#result == null") | ||||
|     @Override | ||||
|     public String selectUserRoleGroup(String userName) | ||||
|     { | ||||
|         List<SysRole> list = roleMapper.selectRolesByUserName(userName); | ||||
|         if (CollectionUtils.isEmpty(list)) | ||||
|         { | ||||
|             return StringUtils.EMPTY; | ||||
|         } | ||||
|         return list.stream().map(SysRole::getRoleName).collect(Collectors.joining(",")); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 查询用户所属岗位组 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Cacheable(value = "sysUser", key = "#root.methodName + '_' + #userName", unless = "#result == null") | ||||
|     @Override | ||||
|     public String selectUserPostGroup(String userName) | ||||
|     { | ||||
|         List<SysPost> list = postMapper.selectPostsByUserName(userName); | ||||
|         if (CollectionUtils.isEmpty(list)) | ||||
|         { | ||||
|             return StringUtils.EMPTY; | ||||
|         } | ||||
|         return list.stream().map(SysPost::getPostName).collect(Collectors.joining(",")); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验用户名称是否唯一 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkUserNameUnique(SysUser user) | ||||
|     { | ||||
|         Long userId = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId(); | ||||
|         SysUser info = userMapper.checkUserNameUnique(user.getUserName()); | ||||
|         if (StringUtils.isNotNull(info) && info.getUserId().longValue() != userId.longValue()) | ||||
|         { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验手机号码是否唯一 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public String checkPhoneUnique(SysUser user) | ||||
|     { | ||||
|         Long userId = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId(); | ||||
|         SysUser info = userMapper.checkPhoneUnique(user.getPhonenumber()); | ||||
|         if (StringUtils.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 = StringUtils.isNull(user.getUserId()) ? -1L : user.getUserId(); | ||||
|         SysUser info = userMapper.checkEmailUnique(user.getEmail()); | ||||
|         if (StringUtils.isNotNull(info) && info.getUserId().longValue() != userId.longValue()) | ||||
|         { | ||||
|             return UserConstants.NOT_UNIQUE; | ||||
|         } | ||||
|         return UserConstants.UNIQUE; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验用户是否允许操作 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      */ | ||||
|     @Override | ||||
|     public void checkUserAllowed(SysUser user) | ||||
|     { | ||||
|         if (StringUtils.isNotNull(user.getUserId()) && user.isAdmin()) | ||||
|         { | ||||
|             throw new ServiceException("不允许操作超级管理员用户"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 校验用户是否有数据权限 | ||||
|      * | ||||
|      * @param userId 用户id | ||||
|      */ | ||||
|     @Override | ||||
|     public void checkUserDataScope(Long userId) | ||||
|     { | ||||
|         if (!SysUser.isAdmin(SecurityUtils.getUserId())) | ||||
|         { | ||||
|             SysUser user = new SysUser(); | ||||
|             user.setUserId(userId); | ||||
|             List<SysUser> users = SpringUtils.getAopProxy(this).selectUserList(user); | ||||
|             if (StringUtils.isEmpty(users)) | ||||
|             { | ||||
|                 throw new ServiceException("没有权限访问用户数据!"); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增保存用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Caching(put = { | ||||
|             @CachePut(value = "sysUser", key = "'selectUserByUserName' + '_' + #user.userName", condition = "#result != null"), | ||||
|             @CachePut(value = "sysUser", key = "'selectUserById' + '_' + #user.userId", condition = "#result != null"), | ||||
|             @CachePut(value = "sysUser", key = "'selectUserByPhoneNumber' + '_' + #user.phonenumber", condition = "#result != null") | ||||
|     }) | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int insertUser(SysUser user) | ||||
|     { | ||||
|         // 新增用户信息 | ||||
|         int rows = userMapper.insertUser(user); | ||||
|         // 新增用户岗位关联 | ||||
|         insertUserPost(user); | ||||
|         // 新增用户与角色管理 | ||||
|         insertUserRole(user); | ||||
|         return rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 注册用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean registerUser(SysUser user) | ||||
|     { | ||||
|         return userMapper.insertUser(user) > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改保存用户信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Caching(put = { | ||||
|             @CachePut(value = "sysUser", key = "'selectUserByUserName' + '_' + #user.userName", condition = "#result != null"), | ||||
|             @CachePut(value = "sysUser", key = "'selectUserById' + '_' + #user.userId", condition = "#result != null"), | ||||
|             @CachePut(value = "sysUser", key = "'selectUserByPhoneNumber' + '_' + #user.phonenumber", condition = "#result != null") | ||||
|     }) | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int updateUser(SysUser user) | ||||
|     { | ||||
|         Long userId = user.getUserId(); | ||||
|         // 删除用户与角色关联 | ||||
|         userRoleMapper.deleteUserRoleByUserId(userId); | ||||
|         // 新增用户与角色管理 | ||||
|         insertUserRole(user); | ||||
|         // 删除用户与岗位关联 | ||||
|         userPostMapper.deleteUserPostByUserId(userId); | ||||
|         // 新增用户与岗位管理 | ||||
|         insertUserPost(user); | ||||
|         return userMapper.updateUser(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 用户授权角色 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @param roleIds 角色组 | ||||
|      */ | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public void insertUserAuth(Long userId, Long[] roleIds) | ||||
|     { | ||||
|         userRoleMapper.deleteUserRoleByUserId(userId); | ||||
|         insertUserRole(userId, roleIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改用户状态 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateUserStatus(SysUser user) | ||||
|     { | ||||
|         return userMapper.updateUser(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改用户基本信息 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int updateUserProfile(SysUser user) | ||||
|     { | ||||
|         return userMapper.updateUser(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 修改用户头像 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @param avatar 头像地址 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public boolean updateUserAvatar(String userName, String avatar) | ||||
|     { | ||||
|         return userMapper.updateUserAvatar(userName, avatar) > 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 重置用户密码 | ||||
|      * | ||||
|      * @param user 用户信息 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int resetPwd(SysUser user) | ||||
|     { | ||||
|         return userMapper.updateUser(user); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 重置用户密码 | ||||
|      * | ||||
|      * @param userName 用户名 | ||||
|      * @param password 密码 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public int resetUserPwd(String userName, String password) | ||||
|     { | ||||
|         return userMapper.resetUserPwd(userName, password); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增用户角色信息 | ||||
|      * | ||||
|      * @param user 用户对象 | ||||
|      */ | ||||
|     public void insertUserRole(SysUser user) | ||||
|     { | ||||
|         this.insertUserRole(user.getUserId(), user.getRoleIds()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增用户岗位信息 | ||||
|      * | ||||
|      * @param user 用户对象 | ||||
|      */ | ||||
|     public void insertUserPost(SysUser user) | ||||
|     { | ||||
|         Long[] posts = user.getPostIds(); | ||||
|         if (StringUtils.isNotEmpty(posts)) | ||||
|         { | ||||
|             // 新增用户与岗位管理 | ||||
|             List<SysUserPost> list = new ArrayList<SysUserPost>(posts.length); | ||||
|             for (Long postId : posts) | ||||
|             { | ||||
|                 SysUserPost up = new SysUserPost(); | ||||
|                 up.setUserId(user.getUserId()); | ||||
|                 up.setPostId(postId); | ||||
|                 list.add(up); | ||||
|             } | ||||
|             userPostMapper.batchUserPost(list); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 新增用户角色信息 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @param roleIds 角色组 | ||||
|      */ | ||||
|     public void insertUserRole(Long userId, Long[] roleIds) | ||||
|     { | ||||
|         if (StringUtils.isNotEmpty(roleIds)) | ||||
|         { | ||||
|             // 新增用户与角色管理 | ||||
|             List<SysUserRole> list = new ArrayList<SysUserRole>(roleIds.length); | ||||
|             for (Long roleId : roleIds) | ||||
|             { | ||||
|                 SysUserRole ur = new SysUserRole(); | ||||
|                 ur.setUserId(userId); | ||||
|                 ur.setRoleId(roleId); | ||||
|                 list.add(ur); | ||||
|             } | ||||
|             userRoleMapper.batchUserRole(list); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过用户ID删除用户 | ||||
|      * | ||||
|      * @param userId 用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @CacheEvict(value = "sysUser", allEntries = true) | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int deleteUserById(Long userId) | ||||
|     { | ||||
|         // 删除用户与角色关联 | ||||
|         userRoleMapper.deleteUserRoleByUserId(userId); | ||||
|         // 删除用户与岗位表 | ||||
|         userPostMapper.deleteUserPostByUserId(userId); | ||||
|         // 删除用户与微信绑定,因为引入iot-service模块会产生循环依赖,所以先写在这个mapper里 | ||||
|         userMapper.deleteBySysUserIdAndSourceClient(userId, SocialPlatformType.listWechatPlatform); | ||||
|         return userMapper.deleteUserById(userId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 批量删除用户信息 | ||||
|      * | ||||
|      * @param userIds 需要删除的用户ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @CacheEvict(value = "sysUser", allEntries = true) | ||||
|     @Override | ||||
|     @Transactional | ||||
|     public int deleteUserByIds(Long[] userIds) | ||||
|     { | ||||
|         for (Long userId : userIds) | ||||
|         { | ||||
|             checkUserAllowed(new SysUser(userId)); | ||||
|             checkUserDataScope(userId); | ||||
|         } | ||||
|         // 删除用户与角色关联 | ||||
|         userRoleMapper.deleteUserRole(userIds); | ||||
|         // 删除用户与岗位关联 | ||||
|         userPostMapper.deleteUserPost(userIds); | ||||
|         // 删除用户与微信关联,因为引入iot-service模块会产生循环依赖,所以先写在这个mapper里 | ||||
|         userMapper.deleteBySysUserIdsAndSourceClient(userIds, SocialPlatformType.listWechatPlatform); | ||||
|         return userMapper.deleteUserByIds(userIds); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 导入用户数据 | ||||
|      * | ||||
|      * @param userList 用户数据列表 | ||||
|      * @param isUpdateSupport 是否更新支持,如果已存在,则进行更新数据 | ||||
|      * @param operName 操作用户 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public String importUser(List<SysUser> userList, Boolean isUpdateSupport, String operName) | ||||
|     { | ||||
|         if (StringUtils.isNull(userList) || userList.size() == 0) | ||||
|         { | ||||
|             throw new ServiceException("导入用户数据不能为空!"); | ||||
|         } | ||||
|         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 = userMapper.selectUserByUserName(user.getUserName()); | ||||
|                 if (StringUtils.isNull(u)) | ||||
|                 { | ||||
|                     BeanValidators.validateWithException(validator, user); | ||||
|                     user.setPassword(SecurityUtils.encryptPassword(password)); | ||||
|                     user.setCreateBy(operName); | ||||
|                     this.insertUser(user); | ||||
|                     successNum++; | ||||
|                     successMsg.append("<br/>" + successNum + "、账号 " + user.getUserName() + " 导入成功"); | ||||
|                 } | ||||
|                 else if (isUpdateSupport) | ||||
|                 { | ||||
|                     BeanValidators.validateWithException(validator, user); | ||||
|                     checkUserAllowed(user); | ||||
|                     checkUserDataScope(user.getUserId()); | ||||
|                     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 ServiceException(failureMsg.toString()); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             successMsg.insert(0, "恭喜您,数据已全部导入成功!共 " + successNum + " 条,数据如下:"); | ||||
|         } | ||||
|         return successMsg.toString(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 通过手机号查询用户 | ||||
|      * | ||||
|      * @param phoneNumber 手机号 | ||||
|      * @return 用户对象信息 | ||||
|      */ | ||||
|     @Cacheable(value = "sysUser", key = "#root.methodName + '_' + #phoneNumber", unless = "#result == null") | ||||
|     @Override | ||||
|     public SysUser selectUserByPhoneNumber(String phoneNumber) { | ||||
|         return userMapper.selectUserByPhoneNumber(phoneNumber); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 验证用户密码 | ||||
|      * @param userPassword 用户原密码 | ||||
|      * @param inputPassword 用户输入密码 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     @Override | ||||
|     public Boolean validatePassword(String userPassword, String inputPassword) { | ||||
|         return SecurityUtils.matchesPassword(inputPassword, userPassword); | ||||
|     } | ||||
|  | ||||
|     @CacheEvict(value = "sysUser", allEntries = true) | ||||
|     @Override | ||||
|     public int deleteUserByDeptID(Long deptId) { | ||||
|         return userMapper.deleteUserByDeptID(deptId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取下级所有子节点用户 | ||||
|      * @param deptId | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysUser> selectAllSubUser(Long deptId){ | ||||
|         return userMapper.selectAllSubUser(deptId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 根据用户id获取当前机构的管理员账号 | ||||
|      * @param userId | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public SysUser getDeptUserByUserId(Long userId){ | ||||
|         return userMapper.getDeptUserByUserId(userId); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public List<SysUser> listTerminal(SysUser user) { | ||||
|         return userMapper.listTerminal(user); | ||||
|     } | ||||
|     /** | ||||
|      * 根据机构id获取当前机构所有非管理用户 | ||||
|      * @return | ||||
|      */ | ||||
|     @Override | ||||
|     public List<SysUser> selectByDeptId(){ | ||||
|         Long deptId = SecurityUtils.getDeptId(); | ||||
|         return userMapper.selectByDeptId(deptId); | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,81 @@ | ||||
| <?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.fastbee.system.mapper.AppLanguageMapper"> | ||||
|  | ||||
|     <resultMap type="com.fastbee.system.domain.AppLanguage" id="AppLanguageResult"> | ||||
|         <result property="id"    column="id"    /> | ||||
|         <result property="language"    column="language"    /> | ||||
|         <result property="country"    column="country"    /> | ||||
|         <result property="timeZone"    column="time_zone"    /> | ||||
|         <result property="createBy"    column="create_by"    /> | ||||
|         <result property="createTime"    column="create_time"    /> | ||||
|         <result property="langName"    column="lang_name"    /> | ||||
|     </resultMap> | ||||
|  | ||||
|     <sql id="selectAppLanguageVo"> | ||||
|         select id, language, country, time_zone, create_by, create_time, lang_name from app_language | ||||
|     </sql> | ||||
|  | ||||
|     <select id="selectAppLanguageList" parameterType="com.fastbee.system.domain.AppLanguage" resultMap="AppLanguageResult"> | ||||
|         <include refid="selectAppLanguageVo"/> | ||||
|         <where> | ||||
|             <if test="language != null  and language != ''"> and language = #{language}</if> | ||||
|             <if test="country != null  and country != ''"> and country = #{country}</if> | ||||
|             <if test="timeZone != null  and timeZone != ''"> and time_zone = #{timeZone}</if> | ||||
|             <if test="langName != null  and langName != ''"> and lang_name like concat('%', #{langName}, '%')</if> | ||||
|         </where> | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectAppLanguageById" parameterType="Long" resultMap="AppLanguageResult"> | ||||
|         <include refid="selectAppLanguageVo"/> | ||||
|         where id = #{id} | ||||
|     </select> | ||||
|  | ||||
|     <insert id="insertAppLanguage" parameterType="com.fastbee.system.domain.AppLanguage"> | ||||
|         insert into app_language | ||||
|         <trim prefix="(" suffix=")" suffixOverrides=","> | ||||
|             <if test="id != null">id,</if> | ||||
|             <if test="language != null">language,</if> | ||||
|             <if test="country != null">country,</if> | ||||
|             <if test="timeZone != null">time_zone,</if> | ||||
|             <if test="createBy != null">create_by,</if> | ||||
|             <if test="createTime != null">create_time,</if> | ||||
|             <if test="langName != null">lang_name,</if> | ||||
|          </trim> | ||||
|         <trim prefix="values (" suffix=")" suffixOverrides=","> | ||||
|             <if test="id != null">#{id},</if> | ||||
|             <if test="language != null">#{language},</if> | ||||
|             <if test="country != null">#{country},</if> | ||||
|             <if test="timeZone != null">#{timeZone},</if> | ||||
|             <if test="createBy != null">#{createBy},</if> | ||||
|             <if test="createTime != null">#{createTime},</if> | ||||
|             <if test="langName != null">#{langName},</if> | ||||
|          </trim> | ||||
|     </insert> | ||||
|  | ||||
|     <update id="updateAppLanguage" parameterType="com.fastbee.system.domain.AppLanguage"> | ||||
|         update app_language | ||||
|         <trim prefix="SET" suffixOverrides=","> | ||||
|             <if test="language != null">language = #{language},</if> | ||||
|             <if test="country != null">country = #{country},</if> | ||||
|             <if test="timeZone != null">time_zone = #{timeZone},</if> | ||||
|             <if test="createBy != null">create_by = #{createBy},</if> | ||||
|             <if test="createTime != null">create_time = #{createTime},</if> | ||||
|             <if test="langName != null">lang_name = #{langName},</if> | ||||
|         </trim> | ||||
|         where id = #{id} | ||||
|     </update> | ||||
|  | ||||
|     <delete id="deleteAppLanguageById" parameterType="Long"> | ||||
|         delete from app_language where id = #{id} | ||||
|     </delete> | ||||
|  | ||||
|     <delete id="deleteAppLanguageByIds" parameterType="String"> | ||||
|         delete from app_language where id in | ||||
|         <foreach item="id" collection="array" open="(" separator="," close=")"> | ||||
|             #{id} | ||||
|         </foreach> | ||||
|     </delete> | ||||
| </mapper> | ||||
| @@ -0,0 +1,93 @@ | ||||
| <?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.fastbee.system.mapper.AppPreferencesMapper"> | ||||
|      | ||||
|     <resultMap type="com.fastbee.system.domain.AppPreferences" id="AppPreferencesResult"> | ||||
|         <result property="id"    column="id"    /> | ||||
|         <result property="userId"    column="user_id"    /> | ||||
|         <result property="language"    column="language"    /> | ||||
|         <result property="timeZone"    column="time_zone"    /> | ||||
|         <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="selectAppPreferencesVo"> | ||||
|         select id, user_id, language, time_zone, create_by, create_time, update_by, update_time, remark from app_preferences | ||||
|     </sql> | ||||
|  | ||||
|     <select id="selectAppPreferencesList" parameterType="com.fastbee.system.domain.AppPreferences" resultMap="AppPreferencesResult"> | ||||
|         <include refid="selectAppPreferencesVo"/> | ||||
|         <where>   | ||||
|             <if test="userId != null "> and user_id = #{userId}</if> | ||||
|             <if test="language != null  and language != ''"> and `language` = #{language}</if> | ||||
|             <if test="timeZone != null  and timeZone != ''"> and time_zone = #{timeZone}</if> | ||||
|         </where> | ||||
|     </select> | ||||
|      | ||||
|     <select id="selectAppPreferencesById" parameterType="Long" resultMap="AppPreferencesResult"> | ||||
|         <include refid="selectAppPreferencesVo"/> | ||||
|         where id = #{id} | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectAppPreferencesByUserId" parameterType="Long" resultMap="AppPreferencesResult"> | ||||
|         <include refid="selectAppPreferencesVo"/> | ||||
|         where user_id = #{userId} | ||||
|     </select> | ||||
|  | ||||
|     <insert id="insertAppPreferences" parameterType="com.fastbee.system.domain.AppPreferences"> | ||||
|         insert into app_preferences | ||||
|         <trim prefix="(" suffix=")" suffixOverrides=","> | ||||
|             <if test="id != null">id,</if> | ||||
|             <if test="userId != null">user_id,</if> | ||||
|             <if test="language != null">`language`,</if> | ||||
|             <if test="timeZone != null">time_zone,</if> | ||||
|             <if test="createBy != null">create_by,</if> | ||||
|             <if test="createTime != null">create_time,</if> | ||||
|             <if test="updateBy != null">update_by,</if> | ||||
|             <if test="updateTime != null">update_time,</if> | ||||
|             <if test="remark != null">remark,</if> | ||||
|          </trim> | ||||
|         <trim prefix="values (" suffix=")" suffixOverrides=","> | ||||
|             <if test="id != null">#{id},</if> | ||||
|             <if test="userId != null">#{userId},</if> | ||||
|             <if test="language != null">#{language},</if> | ||||
|             <if test="timeZone != null">#{timeZone},</if> | ||||
|             <if test="createBy != null">#{createBy},</if> | ||||
|             <if test="createTime != null">#{createTime},</if> | ||||
|             <if test="updateBy != null">#{updateBy},</if> | ||||
|             <if test="updateTime != null">#{updateTime},</if> | ||||
|             <if test="remark != null">#{remark},</if> | ||||
|          </trim> | ||||
|     </insert> | ||||
|  | ||||
|     <update id="updateAppPreferences" parameterType="com.fastbee.system.domain.AppPreferences"> | ||||
|         update app_preferences | ||||
|         <trim prefix="SET" suffixOverrides=","> | ||||
|             <if test="userId != null">user_id = #{userId},</if> | ||||
|             <if test="language != null">`language` = #{language},</if> | ||||
|             <if test="timeZone != null">time_zone = #{timeZone},</if> | ||||
|             <if test="createBy != null">create_by = #{createBy},</if> | ||||
|             <if test="createTime != null">create_time = #{createTime},</if> | ||||
|             <if test="updateBy != null">update_by = #{updateBy},</if> | ||||
|             <if test="updateTime != null">update_time = #{updateTime},</if> | ||||
|             <if test="remark != null">remark = #{remark},</if> | ||||
|         </trim> | ||||
|         where id = #{id} | ||||
|     </update> | ||||
|  | ||||
|     <delete id="deleteAppPreferencesByUserId" parameterType="Long"> | ||||
|         delete from app_preferences where user_id = #{userId} | ||||
|     </delete> | ||||
|  | ||||
|     <delete id="deleteAppPreferencesByUserIds" parameterType="String"> | ||||
|         delete from app_preferences where user_id in | ||||
|         <foreach item="userId" collection="array" open="(" separator="," close=")"> | ||||
|             #{userId} | ||||
|         </foreach> | ||||
|     </delete> | ||||
| </mapper> | ||||
| @@ -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.fastbee.system.mapper.SysClientMapper"> | ||||
|  | ||||
|     <resultMap type="SysClient" id="SysClientResult"> | ||||
|         <result property="id"    column="id"    /> | ||||
|         <result property="clientKey"    column="client_key"    /> | ||||
|         <result property="clientSecret"    column="client_secret"    /> | ||||
|         <result property="token"    column="token"    /> | ||||
|         <result property="grantType"    column="grant_type"    /> | ||||
|         <result property="deviceType"    column="device_type"    /> | ||||
|         <result property="timeout"    column="timeout"    /> | ||||
|         <result property="enable"    column="enable"    /> | ||||
|         <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="selectSysClientVo"> | ||||
|         select id, client_key, client_secret, token, grant_type, device_type, timeout, enable, del_flag, create_by, create_time, update_by, update_time, remark from sys_client | ||||
|     </sql> | ||||
|  | ||||
|     <select id="selectSysClientList" parameterType="SysClient" resultMap="SysClientResult"> | ||||
|         <include refid="selectSysClientVo"/> | ||||
|         <where> | ||||
|             <if test="clientKey != null  and clientKey != ''"> and client_key = #{clientKey}</if> | ||||
|             <if test="clientSecret != null  and clientSecret != ''"> and client_secret = #{clientSecret}</if> | ||||
|             <if test="token != null  and token != ''"> and token = #{token}</if> | ||||
|             <if test="grantType != null  and grantType != ''"> and grant_type = #{grantType}</if> | ||||
|             <if test="deviceType != null  and deviceType != ''"> and device_type = #{deviceType}</if> | ||||
|             <if test="timeout != null "> and timeout = #{timeout}</if> | ||||
|             <if test="enable != null  and enable != ''"> and enable = #{enable}</if> | ||||
|         </where> | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectSysClientById" parameterType="Long" resultMap="SysClientResult"> | ||||
|         <include refid="selectSysClientVo"/> | ||||
|         where id = #{id} | ||||
|     </select> | ||||
|  | ||||
|     <insert id="insertSysClient" parameterType="SysClient" useGeneratedKeys="true" keyProperty="id"> | ||||
|         insert into sys_client | ||||
|         <trim prefix="(" suffix=")" suffixOverrides=","> | ||||
|             <if test="clientKey != null">client_key,</if> | ||||
|             <if test="clientSecret != null">client_secret,</if> | ||||
|             <if test="token != null">token,</if> | ||||
|             <if test="grantType != null">grant_type,</if> | ||||
|             <if test="deviceType != null">device_type,</if> | ||||
|             <if test="timeout != null">timeout,</if> | ||||
|             <if test="enable != null">enable,</if> | ||||
|             <if test="delFlag != null">del_flag,</if> | ||||
|             <if test="createBy != null">create_by,</if> | ||||
|             <if test="createTime != null">create_time,</if> | ||||
|             <if test="updateBy != null">update_by,</if> | ||||
|             <if test="updateTime != null">update_time,</if> | ||||
|             <if test="remark != null">remark,</if> | ||||
|         </trim> | ||||
|         <trim prefix="values (" suffix=")" suffixOverrides=","> | ||||
|             <if test="clientKey != null">#{clientKey},</if> | ||||
|             <if test="clientSecret != null">#{clientSecret},</if> | ||||
|             <if test="token != null">#{token},</if> | ||||
|             <if test="grantType != null">#{grantType},</if> | ||||
|             <if test="deviceType != null">#{deviceType},</if> | ||||
|             <if test="timeout != null">#{timeout},</if> | ||||
|             <if test="enable != null">#{enable},</if> | ||||
|             <if test="delFlag != null">#{delFlag},</if> | ||||
|             <if test="createBy != null">#{createBy},</if> | ||||
|             <if test="createTime != null">#{createTime},</if> | ||||
|             <if test="updateBy != null">#{updateBy},</if> | ||||
|             <if test="updateTime != null">#{updateTime},</if> | ||||
|             <if test="remark != null">#{remark},</if> | ||||
|         </trim> | ||||
|     </insert> | ||||
|  | ||||
|     <update id="updateSysClient" parameterType="SysClient"> | ||||
|         update sys_client | ||||
|         <trim prefix="SET" suffixOverrides=","> | ||||
|             <if test="clientKey != null">client_key = #{clientKey},</if> | ||||
|             <if test="clientSecret != null">client_secret = #{clientSecret},</if> | ||||
|             <if test="token != null">token = #{token},</if> | ||||
|             <if test="grantType != null">grant_type = #{grantType},</if> | ||||
|             <if test="deviceType != null">device_type = #{deviceType},</if> | ||||
|             <if test="timeout != null">timeout = #{timeout},</if> | ||||
|             <if test="enable != null">enable = #{enable},</if> | ||||
|             <if test="delFlag != null">del_flag = #{delFlag},</if> | ||||
|             <if test="createBy != null">create_by = #{createBy},</if> | ||||
|             <if test="createTime != null">create_time = #{createTime},</if> | ||||
|             <if test="updateBy != null">update_by = #{updateBy},</if> | ||||
|             <if test="updateTime != null">update_time = #{updateTime},</if> | ||||
|             <if test="remark != null">remark = #{remark},</if> | ||||
|         </trim> | ||||
|         where id = #{id} | ||||
|     </update> | ||||
|  | ||||
|     <delete id="deleteSysClientById" parameterType="Long"> | ||||
|         delete from sys_client where id = #{id} | ||||
|     </delete> | ||||
|  | ||||
|     <delete id="deleteSysClientByIds" parameterType="String"> | ||||
|         delete from sys_client where id in | ||||
|         <foreach item="id" collection="array" open="(" separator="," close=")"> | ||||
|             #{id} | ||||
|         </foreach> | ||||
|     </delete> | ||||
| </mapper> | ||||
| @@ -0,0 +1,117 @@ | ||||
| <?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.fastbee.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> | ||||
|      | ||||
|     <sql id="selectConfigVo"> | ||||
|         select config_id, config_name, config_key, config_value, config_type, create_by, create_time, update_by, update_time, remark  | ||||
| 		from sys_config | ||||
|     </sql> | ||||
|      | ||||
|     <!-- 查询条件 --> | ||||
| 	<sql id="sqlwhereSearch"> | ||||
| 		<where> | ||||
| 			<if test="configId !=null"> | ||||
| 				and config_id = #{configId} | ||||
| 			</if> | ||||
| 			<if test="configKey !=null and configKey != ''"> | ||||
| 				and config_key = #{configKey} | ||||
| 			</if> | ||||
| 		</where> | ||||
| 	</sql> | ||||
|      | ||||
|     <select id="selectConfig" parameterType="SysConfig" resultMap="SysConfigResult"> | ||||
|         <include refid="selectConfigVo"/> | ||||
|         <include refid="sqlwhereSearch"/> | ||||
|     </select> | ||||
|      | ||||
|     <select id="selectConfigList" parameterType="SysConfig" resultMap="SysConfigResult"> | ||||
|         <include refid="selectConfigVo"/> | ||||
|         <where> | ||||
| 			<if test="configName != null and configName != ''"> | ||||
| 				AND config_name like concat('%', #{configName}, '%') | ||||
| 			</if> | ||||
| 			<if test="configType != null and configType != ''"> | ||||
| 				AND config_type = #{configType} | ||||
| 			</if> | ||||
| 			<if test="configKey != null and configKey != ''"> | ||||
| 				AND config_key like concat('%', #{configKey}, '%') | ||||
| 			</if> | ||||
| 			<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> | ||||
| 				and date_format(create_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d') | ||||
| 			</if> | ||||
| 			<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> | ||||
| 				and date_format(create_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d') | ||||
| 			</if> | ||||
| 		</where> | ||||
|     </select> | ||||
|      | ||||
|     <select id="selectConfigById" parameterType="Long" resultMap="SysConfigResult"> | ||||
|         <include refid="selectConfigVo"/> | ||||
|         where config_id = #{configId} | ||||
|     </select> | ||||
| 	 | ||||
|     <select id="checkConfigKeyUnique" parameterType="String" resultMap="SysConfigResult"> | ||||
|         <include refid="selectConfigVo"/> | ||||
|         where config_key = #{configKey} limit 1 | ||||
|     </select> | ||||
|      | ||||
|     <insert id="insertConfig" parameterType="SysConfig"> | ||||
|         insert into sys_config ( | ||||
| 			<if test="configName != null and configName != '' ">config_name,</if> | ||||
| 			<if test="configKey != null and configKey != '' ">config_key,</if> | ||||
| 			<if test="configValue != null and configValue != '' ">config_value,</if> | ||||
| 			<if test="configType != null and configType != '' ">config_type,</if> | ||||
| 			<if test="createBy != null and createBy != ''">create_by,</if> | ||||
| 			<if test="remark != null and remark != ''">remark,</if> | ||||
|  			create_time | ||||
|         )values( | ||||
| 			<if test="configName != null and configName != ''">#{configName},</if> | ||||
| 			<if test="configKey != null and configKey != ''">#{configKey},</if> | ||||
| 			<if test="configValue != null and configValue != ''">#{configValue},</if> | ||||
| 			<if test="configType != null and configType != ''">#{configType},</if> | ||||
| 			<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
| 			<if test="remark != null and remark != ''">#{remark},</if> | ||||
|  			sysdate() | ||||
| 		) | ||||
|     </insert> | ||||
| 	  | ||||
|     <update id="updateConfig" parameterType="SysConfig"> | ||||
|         update sys_config  | ||||
|         <set> | ||||
|             <if test="configName != null and configName != ''">config_name = #{configName},</if> | ||||
|             <if test="configKey != null and configKey != ''">config_key = #{configKey},</if> | ||||
|             <if test="configValue != null and configValue != ''">config_value = #{configValue},</if> | ||||
|             <if test="configType != null and configType != ''">config_type = #{configType},</if> | ||||
|             <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
|             <if test="remark != null">remark = #{remark},</if> | ||||
|  			update_time = sysdate() | ||||
|         </set> | ||||
|         where config_id = #{configId} | ||||
|     </update> | ||||
| 	 | ||||
|     <delete id="deleteConfigById" parameterType="Long"> | ||||
|         delete from sys_config where config_id = #{configId} | ||||
|     </delete> | ||||
|      | ||||
|     <delete id="deleteConfigByIds" parameterType="Long"> | ||||
|         delete from sys_config where config_id in  | ||||
|         <foreach item="configId" collection="array" open="(" separator="," close=")"> | ||||
|         	#{configId} | ||||
|         </foreach> | ||||
|     </delete> | ||||
|      | ||||
| </mapper> | ||||
| @@ -0,0 +1,221 @@ | ||||
| <?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.fastbee.system.mapper.SysDeptMapper"> | ||||
|  | ||||
| 	<resultMap type="SysDept" id="SysDeptResult"> | ||||
| 		<id     property="deptId"     column="dept_id"     /> | ||||
| 		<result property="deptUserId"   column="dept_user_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" /> | ||||
| 		<result property="deptType" column="dept_type" /> | ||||
| 	</resultMap> | ||||
|  | ||||
| 	<sql id="selectDeptVo"> | ||||
|         select d.dept_id, d.dept_user_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, d.dept_type | ||||
|         from sys_dept d | ||||
|     </sql> | ||||
|  | ||||
| 	<select id="selectDeptList" parameterType="SysDept" resultMap="SysDeptResult"> | ||||
|         <include refid="selectDeptVo"/> | ||||
|         where d.del_flag = '0' | ||||
| 		<if test="deptId != null and deptId != 0"> | ||||
| 			AND dept_id = #{deptId} | ||||
| 		</if> | ||||
|         <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> | ||||
| 		<!-- 数据范围过滤 --> | ||||
| 		${params.dataScope} | ||||
| 		order by d.parent_id, d.order_num | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectDeptListByRoleId" resultType="Long"> | ||||
| 		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> | ||||
|  | ||||
|     <select id="selectDeptById" parameterType="Long" resultMap="SysDeptResult"> | ||||
| 		select d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.phone, d.email, d.status, d.dept_type, d.dept_user_id, | ||||
| 			(select dept_name from sys_dept where dept_id = d.parent_id) parent_name | ||||
| 		from sys_dept d | ||||
| 		where d.dept_id = #{deptId} | ||||
| 	</select> | ||||
|  | ||||
|     <select id="checkDeptExistUser" parameterType="Long" resultType="int"> | ||||
| 		select count(1) from sys_user where dept_id = #{deptId} and del_flag = '0' | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="hasChildByDeptId" parameterType="Long" resultType="int"> | ||||
| 		select count(1) from sys_dept | ||||
| 		where del_flag = '0' and parent_id = #{deptId} limit 1 | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectChildrenDeptById" parameterType="Long" resultMap="SysDeptResult"> | ||||
| 		select * from sys_dept where find_in_set(#{deptId}, ancestors) | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectNormalChildrenDeptById" parameterType="Long" resultType="int"> | ||||
| 		select count(*) from sys_dept where status = 0 and del_flag = '0' and find_in_set(#{deptId}, ancestors) | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="checkDeptNameUnique" resultMap="SysDeptResult"> | ||||
| 	    <include refid="selectDeptVo"/> | ||||
| 		where dept_name=#{deptName} and parent_id = #{parentId} and del_flag = '0' limit 1 | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="listDeptAndChild" parameterType="SysDept" resultMap="SysDeptResult"> | ||||
| 		<include refid="selectDeptVo"/> | ||||
| 		where d.del_flag = '0' | ||||
| 		<if test="deptId != null and deptId != 0 and (showOwner == null or showOwner)"> | ||||
| 			AND (dept_id = #{deptId} OR find_in_set(#{deptId}, ancestors)) | ||||
| 		</if> | ||||
| 		<if test="deptId != null and deptId != 0 and showOwner != null and !showOwner"> | ||||
| 			AND find_in_set(#{deptId}, ancestors) | ||||
| 		</if> | ||||
| 		<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> | ||||
| 		<!-- 数据范围过滤 --> | ||||
| 		${params.dataScope} | ||||
| 		order by d.parent_id, d.order_num | ||||
| 	</select> | ||||
|  | ||||
|     <select id="selectDeptByIds" resultMap="SysDeptResult"> | ||||
| 		<include refid="selectDeptVo"/> | ||||
| 		where d.del_flag = '0' | ||||
| 		and dept_id in | ||||
| 			<foreach collection="deptIdList" item="deptId" open="(" separator="," close=")"> | ||||
| 				#{deptId} | ||||
| 			</foreach> | ||||
| 	</select> | ||||
|  | ||||
|     <insert id="insertDept" parameterType="SysDept" useGeneratedKeys="true" keyProperty="deptId"> | ||||
|  		insert into sys_dept( | ||||
|  			<if test="deptId != null and deptId != 0">dept_id,</if> | ||||
|  			<if test="deptUserId != null and deptUserId != 0">dept_user_id,</if> | ||||
|  			<if test="parentId != null and parentId != 0">parent_id,</if> | ||||
|  			<if test="deptName != null and deptName != ''">dept_name,</if> | ||||
|  			<if test="ancestors != null and ancestors != ''">ancestors,</if> | ||||
|  			<if test="orderNum != null">order_num,</if> | ||||
|  			<if test="leader != null and leader != ''">leader,</if> | ||||
|  			<if test="phone != null and phone != ''">phone,</if> | ||||
|  			<if test="email != null and email != ''">email,</if> | ||||
|  			<if test="status != null">status,</if> | ||||
|  			<if test="createBy != null and createBy != ''">create_by,</if> | ||||
|  			<if test="deptType != null and deptType != ''">dept_type,</if> | ||||
|  			create_time | ||||
|  		)values( | ||||
|  			<if test="deptId != null and deptId != 0">#{deptId},</if> | ||||
| 			<if test="deptUserId != null and deptUserId != 0">#{deptUserId},</if> | ||||
|  			<if test="parentId != null and parentId != 0">#{parentId},</if> | ||||
|  			<if test="deptName != null and deptName != ''">#{deptName},</if> | ||||
|  			<if test="ancestors != null and ancestors != ''">#{ancestors},</if> | ||||
|  			<if test="orderNum != null">#{orderNum},</if> | ||||
|  			<if test="leader != null and leader != ''">#{leader},</if> | ||||
|  			<if test="phone != null and phone != ''">#{phone},</if> | ||||
|  			<if test="email != null and email != ''">#{email},</if> | ||||
|  			<if test="status != null">#{status},</if> | ||||
|  			<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
|  			<if test="deptType != null and deptType != ''">#{deptType},</if> | ||||
|  			sysdate() | ||||
|  		) | ||||
| 	</insert> | ||||
|  | ||||
| 	<update id="updateDept" parameterType="SysDept"> | ||||
|  		update sys_dept | ||||
|  		<set> | ||||
|  			<if test="parentId != null and parentId != 0">parent_id = #{parentId},</if> | ||||
| 			<if test="deptUserId != null and deptUserId != 0">dept_user_id = #{deptUserId},</if> | ||||
|  			<if test="deptName != null and deptName != ''">dept_name = #{deptName},</if> | ||||
|  			<if test="ancestors != null and ancestors != ''">ancestors = #{ancestors},</if> | ||||
|  			<if test="orderNum != null">order_num = #{orderNum},</if> | ||||
|  			<if test="leader != null">leader = #{leader},</if> | ||||
|  			<if test="phone != null">phone = #{phone},</if> | ||||
|  			<if test="email != null">email = #{email},</if> | ||||
|  			<if test="status != null and status != ''">status = #{status},</if> | ||||
|  			<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
|  			update_time = sysdate() | ||||
|  		</set> | ||||
|  		where dept_id = #{deptId} | ||||
| 	</update> | ||||
|  | ||||
| 	<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> | ||||
|  | ||||
| 	<update id="updateDeptStatusNormal" parameterType="Long"> | ||||
|  	    update sys_dept set status = '0' where dept_id in | ||||
|  	    <foreach collection="array" item="deptId" open="(" separator="," close=")"> | ||||
|         	#{deptId} | ||||
|         </foreach> | ||||
| 	</update> | ||||
|  | ||||
|     <update id="updateDeptUserId"> | ||||
| 		update sys_dept | ||||
| 		set dept_user_id = #{deptUserId} | ||||
| 		where dept_id = #{deptId} | ||||
| 	</update> | ||||
|  | ||||
|     <delete id="deleteDeptById" parameterType="Long"> | ||||
| 		update sys_dept set del_flag = '2' where dept_id = #{deptId} | ||||
| 	</delete> | ||||
|  | ||||
| 	<select id="selectSeniorDeptUser" resultType="java.lang.Long"> | ||||
| 		SELECT de.dept_user_id | ||||
| 		FROM sys_dept de | ||||
| 		WHERE FIND_IN_SET( de.dept_id,( | ||||
| 			SELECT d.ancestors | ||||
| 			FROM sys_dept d | ||||
| 			WHERE d.dept_id = #{deptId} ) | ||||
| 		) | ||||
| 	</select> | ||||
|  | ||||
|     <select id="selectRoleIdByDeptId" resultType="java.lang.Long"> | ||||
| 		select rd.role_id | ||||
| 		from sys_dept d inner join sys_role_dept rd on d.dept_id = rd.dept_id | ||||
| 						inner join sys_role r on rd.role_id = r.role_id | ||||
| 		where d.dept_id = #{deptId} | ||||
| 		  and r.role_key = 'general' | ||||
| 	</select> | ||||
| </mapper> | ||||
| @@ -0,0 +1,211 @@ | ||||
| <?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.fastbee.system.mapper.SysDictDataMapper"> | ||||
|  | ||||
| 	<resultMap type="com.fastbee.common.core.domain.entity.SysDictData" id="SysDictDataResult"> | ||||
| 		<id     property="dictCode"   column="dict_code"   /> | ||||
| 		<result property="dictSort"   column="dict_sort"   /> | ||||
| 		<result property="dictLabel"  column="dict_label"  /> | ||||
| 		<result property="dictLabel_zh_CN"  column="dict_label_zh_cn"  /> | ||||
| 		<result property="dictLabel_en_US"  column="dict_label_en_us"  /> | ||||
| 		<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> | ||||
|  | ||||
| 	<sql id="selectDictDataVo"> | ||||
| 		select dict_code, dict_sort, dict_label, dict_value, dict_type, css_class, list_class, is_default, status, create_by, create_time, remark | ||||
| 		from sys_dict_data | ||||
| 	</sql> | ||||
|  | ||||
| 	<select id="selectDictDataList" parameterType="com.fastbee.common.core.domain.entity.SysDictData" resultMap="SysDictDataResult"> | ||||
| 		select d.dict_code, d.dict_sort, | ||||
| 		case | ||||
| 		when #{language} = 'zh-CN' then d.dict_label | ||||
| 		when #{language} = 'en-US' then t.en_us | ||||
| 		else d.dict_label | ||||
| 		end as dict_label, | ||||
| 		d.dict_value, d.dict_type, d.css_class, d.list_class, d.is_default, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_data d | ||||
| 		left join sys_dict_data_translate t on d.dict_code = t.id | ||||
| 		<where> | ||||
| 			<if test="dictType != null and dictType != ''"> | ||||
| 				AND d.dict_type = #{dictType} | ||||
| 			</if> | ||||
| 			<if test="dictLabel != null and dictLabel != ''"> | ||||
| 				AND d.dict_label like concat('%', #{dictLabel}, '%') | ||||
| 			</if> | ||||
| 			<if test="status != null and status != ''"> | ||||
| 				AND d.status = #{status} | ||||
| 			</if> | ||||
| 		</where> | ||||
| 		order by d.dict_sort asc | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectDictDataListAll" parameterType="com.fastbee.common.core.domain.entity.SysDictData" resultMap="SysDictDataResult"> | ||||
| 		select d.dict_code, d.dict_sort, d.dict_label, t.zh_cn as dict_label_zh_cn, t.en_us as dict_label_en_us, | ||||
| 		d.dict_value, d.dict_type, d.css_class, d.list_class, d.is_default, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_data d | ||||
| 		left join sys_dict_data_translate t on d.dict_code = t.id | ||||
| 		<where> | ||||
| 			<if test="dictType != null and dictType != ''"> | ||||
| 				AND d.dict_type = #{dictType} | ||||
| 			</if> | ||||
| 			<if test="dictLabel != null and dictLabel != ''"> | ||||
| 				AND d.dict_label like concat('%', #{dictLabel}, '%') | ||||
| 			</if> | ||||
| 			<if test="status != null and status != ''"> | ||||
| 				AND d.status = #{status} | ||||
| 			</if> | ||||
| 		</where> | ||||
| 		order by d.dict_sort asc | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectDictDataByType" parameterType="com.fastbee.common.core.domain.entity.SysDictData" resultMap="SysDictDataResult"> | ||||
| 		select d.dict_code, d.dict_sort, d.dict_label, t.zh_cn as dict_label_zh_cn, t.en_us as dict_label_en_us, | ||||
| 			   d.dict_value, d.dict_type, d.css_class, d.list_class, d.is_default, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_data d | ||||
| 				 left join sys_dict_data_translate t on d.dict_code = t.id | ||||
| 		where d.status = '0' and d.dict_type = #{dictType} order by d.dict_sort asc | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectDictLabel" resultType="java.lang.String"> | ||||
| 		select dict_label from sys_dict_data | ||||
| 		where dict_type = #{dictType} and dict_value = #{dictValue} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectDictDataById" resultMap="SysDictDataResult"> | ||||
| 		select d.dict_code, d.dict_sort, | ||||
| 			   case | ||||
| 				   when #{language} = 'zh-CN' then d.dict_label | ||||
| 				   when #{language} = 'en-US' then t.en_us | ||||
| 				   else d.dict_label | ||||
| 				   end as dict_label, | ||||
| 			   d.dict_value, d.dict_type, d.css_class, d.list_class, d.is_default, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_data d | ||||
| 				 left join sys_dict_data_translate t on d.dict_code = t.id | ||||
| 		where d.dict_code = #{dictCode} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="countDictDataByType" resultType="Integer"> | ||||
| 		select count(1) from sys_dict_data where dict_type=#{dictType} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectDictDataListByDictTypes" resultType="com.fastbee.common.core.domain.entity.SysDictData"> | ||||
| 		select d.dict_code, d.dict_sort, | ||||
| 		case | ||||
| 		when #{language} = 'zh-CN' then d.dict_label | ||||
| 		when #{language} = 'en-US' then t.en_us | ||||
| 		else d.dict_label | ||||
| 		end as dict_label, | ||||
| 		d.dict_value, d.dict_type, d.css_class, d.list_class, d.is_default, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_data d | ||||
| 		left join sys_dict_data_translate t on d.dict_code = t.id | ||||
| 		where d.dict_type in | ||||
| 		<foreach collection="dictTypeList" item="dictType" open="(" separator="," close=")"> | ||||
| 			#{dictType} | ||||
| 		</foreach> | ||||
| 		and d.status = 0 | ||||
| 	</select> | ||||
|  | ||||
| 	<delete id="deleteDictDataById" parameterType="Long"> | ||||
| 		delete from sys_dict_data where dict_code = #{dictCode} | ||||
| 	</delete> | ||||
|  | ||||
| 	<delete id="deleteDictDataByIds" parameterType="Long"> | ||||
| 		delete from sys_dict_data where dict_code in | ||||
| 		<foreach collection="array" item="dictCode" open="(" separator="," close=")"> | ||||
| 			#{dictCode} | ||||
| 		</foreach> | ||||
| 	</delete> | ||||
|  | ||||
| 	<update id="updateDictData" parameterType="com.fastbee.common.core.domain.entity.SysDictData"> | ||||
| 		update sys_dict_data | ||||
| 		<set> | ||||
| 			<if test="dictSort != null">dict_sort = #{dictSort},</if> | ||||
| 			<if test="dictLabel != null and dictLabel != ''">dict_label = #{dictLabel},</if> | ||||
| 			<if test="dictValue != null and dictValue != ''">dict_value = #{dictValue},</if> | ||||
| 			<if test="dictType != null and dictType != ''">dict_type = #{dictType},</if> | ||||
| 			<if test="cssClass != null">css_class = #{cssClass},</if> | ||||
| 			<if test="listClass != null">list_class = #{listClass},</if> | ||||
| 			<if test="isDefault != null and isDefault != ''">is_default = #{isDefault},</if> | ||||
| 			<if test="status != null">status = #{status},</if> | ||||
| 			<if test="remark != null">remark = #{remark},</if> | ||||
| 			<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
| 			update_time = sysdate() | ||||
| 		</set> | ||||
| 		where dict_code = #{dictCode} | ||||
| 	</update> | ||||
|  | ||||
| 	<update id="updateDictDataType" parameterType="String"> | ||||
| 		update sys_dict_data set dict_type = #{newDictType} where dict_type = #{oldDictType} | ||||
| 	</update> | ||||
|  | ||||
| 	<insert id="insertDictData" parameterType="com.fastbee.common.core.domain.entity.SysDictData"> | ||||
| 		insert into sys_dict_data( | ||||
| 		<if test="dictSort != null">dict_sort,</if> | ||||
| 		<if test="dictLabel != null and dictLabel != ''">dict_label,</if> | ||||
| 		<if test="dictValue != null and dictValue != ''">dict_value,</if> | ||||
| 		<if test="dictType != null and dictType != ''">dict_type,</if> | ||||
| 		<if test="cssClass != null and cssClass != ''">css_class,</if> | ||||
| 		<if test="listClass != null and listClass != ''">list_class,</if> | ||||
| 		<if test="isDefault != null and isDefault != ''">is_default,</if> | ||||
| 		<if test="status != null">status,</if> | ||||
| 		<if test="remark != null and remark != ''">remark,</if> | ||||
| 		<if test="createBy != null and createBy != ''">create_by,</if> | ||||
| 		create_time | ||||
| 		)values( | ||||
| 		<if test="dictSort != null">#{dictSort},</if> | ||||
| 		<if test="dictLabel != null and dictLabel != ''">#{dictLabel},</if> | ||||
| 		<if test="dictValue != null and dictValue != ''">#{dictValue},</if> | ||||
| 		<if test="dictType != null and dictType != ''">#{dictType},</if> | ||||
| 		<if test="cssClass != null and cssClass != ''">#{cssClass},</if> | ||||
| 		<if test="listClass != null and listClass != ''">#{listClass},</if> | ||||
| 		<if test="isDefault != null and isDefault != ''">#{isDefault},</if> | ||||
| 		<if test="status != null">#{status},</if> | ||||
| 		<if test="remark != null and remark != ''">#{remark},</if> | ||||
| 		<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
| 		sysdate() | ||||
| 		) | ||||
| 	</insert> | ||||
|  | ||||
| 	<select id="selectByDictTypeAndDictValue" resultType="com.fastbee.common.core.domain.entity.SysDictData"> | ||||
| 		select d.dict_code, d.dict_sort, | ||||
| 			   case | ||||
| 				   when #{language} = 'zh-CN' then d.dict_label | ||||
| 				   when #{language} = 'en-US' then t.en_us | ||||
| 				   else d.dict_label | ||||
| 				   end as dict_label, | ||||
| 			   d.dict_value, d.dict_type, d.css_class, d.list_class, d.is_default, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_data d | ||||
| 				 left join sys_dict_data_translate t on d.dict_code = t.id | ||||
| 		where d.dict_type = #{dictType} and d.dict_value = #{dictValue} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="listByDictTypeAndDictValue" resultType="com.fastbee.common.core.domain.entity.SysDictData"> | ||||
| 		select d.dict_code, d.dict_sort, | ||||
| 		case | ||||
| 		when #{language} = 'zh-CN' then d.dict_label | ||||
| 		when #{language} = 'en-US' then t.en_us | ||||
| 		else d.dict_label | ||||
| 		end as dict_label, | ||||
| 		d.dict_value, d.dict_type, d.css_class, d.list_class, d.is_default, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_data d | ||||
| 		left join sys_dict_data_translate t on d.dict_code = t.id | ||||
| 		where d.dict_type = #{dictType} | ||||
| 		and d.dict_value in | ||||
| 		<foreach collection="dictValueList" item="dictValue" open="(" separator="," close=")"> | ||||
| 			#{dictValue} | ||||
| 		</foreach> | ||||
| 	</select> | ||||
|  | ||||
| </mapper> | ||||
| @@ -0,0 +1,145 @@ | ||||
| <?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.fastbee.system.mapper.SysDictTypeMapper"> | ||||
|  | ||||
| 	<resultMap type="com.fastbee.common.core.domain.entity.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> | ||||
|  | ||||
| 	<sql id="selectDictTypeVo"> | ||||
| 		select dict_id, dict_name, dict_type, status, create_by, create_time, remark | ||||
| 		from sys_dict_type | ||||
| 	</sql> | ||||
|  | ||||
| 	<select id="selectDictTypeList" parameterType="com.fastbee.common.core.domain.entity.SysDictType" resultMap="SysDictTypeResult"> | ||||
| 		select d.dict_id, | ||||
| 		case | ||||
| 		when #{language} = 'zh-CN' then d.dict_name | ||||
| 		when #{language} = 'en-US' then t.en_us | ||||
| 		else d.dict_name | ||||
| 		end as dict_name, | ||||
| 		d.dict_type, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_type d | ||||
| 		left join sys_dict_type_translate t on d.dict_id = t.id | ||||
| 		<where> | ||||
| 			<if test="dictName != null and dictName != ''"> | ||||
| 				AND d.dict_name like concat('%', #{dictName}, '%') | ||||
| 			</if> | ||||
| 			<if test="status != null and status != ''"> | ||||
| 				AND d.status = #{status} | ||||
| 			</if> | ||||
| 			<if test="dictType != null and dictType != ''"> | ||||
| 				AND d.dict_type like concat('%', #{dictType}, '%') | ||||
| 			</if> | ||||
| 			<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> | ||||
| 				and date_format(create_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d') | ||||
| 			</if> | ||||
| 			<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> | ||||
| 				and date_format(create_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d') | ||||
| 			</if> | ||||
| 		</where> | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectDictTypeAll" resultMap="SysDictTypeResult"> | ||||
| 		select d.dict_id, | ||||
| 			   case | ||||
| 				   when #{language} = 'zh-CN' then d.dict_name | ||||
| 				   when #{language} = 'en-US' then t.en_us | ||||
| 				   else d.dict_name | ||||
| 				   end as dict_name, | ||||
| 			   d.dict_type, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_type d | ||||
| 				 left join sys_dict_type_translate t on d.dict_id = t.id | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectDictTypeById" resultMap="SysDictTypeResult"> | ||||
| 		select d.dict_id, | ||||
| 			   case | ||||
| 				   when #{language} = 'zh-CN' then d.dict_name | ||||
| 				   when #{language} = 'en-US' then t.en_us | ||||
| 				   else d.dict_name | ||||
| 				   end as dict_name, | ||||
| 			   d.dict_type, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_type d | ||||
| 				 left join sys_dict_type_translate t on d.dict_id = t.id | ||||
| 		where d.dict_id = #{dictId} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectDictTypeByType" parameterType="String" resultMap="SysDictTypeResult"> | ||||
| 		select d.dict_id, | ||||
| 			   case | ||||
| 				   when #{language} = 'zh-CN' then d.dict_name | ||||
| 				   when #{language} = 'en-US' then t.en_us | ||||
| 				   else d.dict_name | ||||
| 				   end as dict_name, | ||||
| 			   d.dict_type, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_type d | ||||
| 				 left join sys_dict_type_translate t on d.dict_id = t.id | ||||
| 		where d.dict_type = #{dictType} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="checkDictTypeUnique" parameterType="String" resultMap="SysDictTypeResult"> | ||||
| 		select d.dict_id, | ||||
| 			   case | ||||
| 				   when #{language} = 'zh-CN' then d.dict_name | ||||
| 				   when #{language} = 'en-US' then t.en_us | ||||
| 				   else d.dict_name | ||||
| 				   end as dict_name, | ||||
| 			   d.dict_type, d.status, d.create_by, d.create_time, d.remark | ||||
| 		from sys_dict_type d | ||||
| 				 left join sys_dict_type_translate t on d.dict_id = t.id | ||||
| 		where d.dict_type = #{dictType} limit 1 | ||||
| 	</select> | ||||
|  | ||||
| 	<delete id="deleteDictTypeById" parameterType="Long"> | ||||
| 		delete from sys_dict_type where dict_id = #{dictId} | ||||
| 	</delete> | ||||
|  | ||||
| 	<delete id="deleteDictTypeByIds" parameterType="Long"> | ||||
| 		delete from sys_dict_type where dict_id in | ||||
| 		<foreach collection="array" item="dictId" open="(" separator="," close=")"> | ||||
| 			#{dictId} | ||||
| 		</foreach> | ||||
| 	</delete> | ||||
|  | ||||
| 	<update id="updateDictType" parameterType="com.fastbee.common.core.domain.entity.SysDictType"> | ||||
| 		update sys_dict_type | ||||
| 		<set> | ||||
| 			<if test="dictName != null and dictName != ''">dict_name = #{dictName},</if> | ||||
| 			<if test="dictType != null and dictType != ''">dict_type = #{dictType},</if> | ||||
| 			<if test="status != null">status = #{status},</if> | ||||
| 			<if test="remark != null">remark = #{remark},</if> | ||||
| 			<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
| 			update_time = sysdate() | ||||
| 		</set> | ||||
| 		where dict_id = #{dictId} | ||||
| 	</update> | ||||
|  | ||||
| 	<insert id="insertDictType" parameterType="com.fastbee.common.core.domain.entity.SysDictType"> | ||||
| 		insert into sys_dict_type( | ||||
| 		<if test="dictName != null and dictName != ''">dict_name,</if> | ||||
| 		<if test="dictType != null and dictType != ''">dict_type,</if> | ||||
| 		<if test="status != null">status,</if> | ||||
| 		<if test="remark != null and remark != ''">remark,</if> | ||||
| 		<if test="createBy != null and createBy != ''">create_by,</if> | ||||
| 		create_time | ||||
| 		)values( | ||||
| 		<if test="dictName != null and dictName != ''">#{dictName},</if> | ||||
| 		<if test="dictType != null and dictType != ''">#{dictType},</if> | ||||
| 		<if test="status != null">#{status},</if> | ||||
| 		<if test="remark != null and remark != ''">#{remark},</if> | ||||
| 		<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
| 		sysdate() | ||||
| 		) | ||||
| 	</insert> | ||||
|  | ||||
| </mapper> | ||||
| @@ -0,0 +1,57 @@ | ||||
| <?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.fastbee.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> | ||||
|  | ||||
| 	<insert id="insertLogininfor" parameterType="SysLogininfor"> | ||||
| 		insert into sys_logininfor (user_name, status, ipaddr, login_location, browser, os, msg, login_time) | ||||
| 		values (#{userName}, #{status}, #{ipaddr}, #{loginLocation}, #{browser}, #{os}, #{msg}, sysdate()) | ||||
| 	</insert> | ||||
| 	 | ||||
| 	<select id="selectLogininforList" parameterType="SysLogininfor" resultMap="SysLogininforResult"> | ||||
| 		select info_id, user_name, ipaddr, login_location, browser, os, status, msg, login_time from sys_logininfor | ||||
| 		<where> | ||||
| 			<if test="ipaddr != null and ipaddr != ''"> | ||||
| 				AND ipaddr like concat('%', #{ipaddr}, '%') | ||||
| 			</if> | ||||
| 			<if test="status != null and status != ''"> | ||||
| 				AND status = #{status} | ||||
| 			</if> | ||||
| 			<if test="userName != null and userName != ''"> | ||||
| 				AND user_name like concat('%', #{userName}, '%') | ||||
| 			</if> | ||||
| 			<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> | ||||
| 				and date_format(login_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d') | ||||
| 			</if> | ||||
| 			<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> | ||||
| 				and date_format(login_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d') | ||||
| 			</if> | ||||
| 		</where> | ||||
| 		order by info_id desc | ||||
| 	</select> | ||||
| 	 | ||||
| 	<delete id="deleteLogininforByIds" parameterType="Long"> | ||||
|  		delete from sys_logininfor where info_id in | ||||
|  		<foreach collection="array" item="infoId" open="(" separator="," close=")"> | ||||
|  			#{infoId} | ||||
|         </foreach>  | ||||
|  	</delete> | ||||
|      | ||||
|     <update id="cleanLogininfor"> | ||||
|         truncate table sys_logininfor | ||||
|     </update> | ||||
|      | ||||
| </mapper>  | ||||
| @@ -0,0 +1,241 @@ | ||||
| <?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.fastbee.system.mapper.SysMenuMapper"> | ||||
|  | ||||
| 	<resultMap type="com.fastbee.common.core.domain.entity.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="query"          column="query"          /> | ||||
| 		<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, `query`, is_frame, is_cache, menu_type, visible, status, ifnull(perms,'') as perms, icon, create_time | ||||
| 		from sys_menu | ||||
| 	</sql> | ||||
|  | ||||
| 	<select id="selectMenuList" parameterType="com.fastbee.common.core.domain.entity.SysMenu" resultMap="SysMenuResult"> | ||||
| 		select distinct m.menu_id, | ||||
| 		case | ||||
| 		when #{language} = 'zh-CN' then m.menu_name | ||||
| 		when #{language} = 'en-US' then t.en_us | ||||
| 		else m.menu_name | ||||
| 		end as menu_name, | ||||
| 		m.parent_id, m.order_num, m.path, m.component, m.query, m.is_frame, m.is_cache, m.menu_type, m.visible, m.status, ifnull(m.perms,'') as perms, m.icon, m.create_time | ||||
| 		from sys_menu m | ||||
| 		left join sys_menu_translate t on m.menu_id = t.id | ||||
| 		<where> | ||||
| 			<if test="menuName != null and menuName != ''"> | ||||
| 				AND m.menu_name like concat('%', #{menuName}, '%') | ||||
| 			</if> | ||||
| 			<if test="visible != null and visible != ''"> | ||||
| 				AND m.visible = #{visible} | ||||
| 			</if> | ||||
| 			<if test="status != null and status != ''"> | ||||
| 				AND m.status = #{status} | ||||
| 			</if> | ||||
| 		</where> | ||||
| 		order by m.parent_id, m.order_num | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectMenuTreeAll" resultMap="SysMenuResult"> | ||||
| 		select distinct m.menu_id, m.parent_id, | ||||
| 						case | ||||
| 							when #{language} = 'zh-CN' then m.menu_name | ||||
| 							when #{language} = 'en-US' then t.en_us | ||||
| 							else m.menu_name | ||||
| 							end as menu_name, | ||||
| 						m.path, m.component, m.`query`, 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_menu_translate t on m.menu_id = t.id | ||||
| 		where m.menu_type in ('M', 'C') and m.status = 0 | ||||
| 		order by m.parent_id, m.order_num | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectMenuListByUserId" parameterType="com.fastbee.common.core.domain.entity.SysMenu" resultMap="SysMenuResult"> | ||||
| 		select distinct m.menu_id, m.parent_id, | ||||
| 		case | ||||
| 		when #{language} = 'zh-CN' then m.menu_name | ||||
| 		when #{language} = 'en-US' then t.en_us | ||||
| 		else m.menu_name | ||||
| 		end as menu_name, | ||||
| 		m.path, m.component, m.`query`, 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_menu_translate t on m.menu_id = t.id | ||||
| 		where ur.user_id = #{params.userId} | ||||
| 		<if test="menuName != null and menuName != ''"> | ||||
| 			AND m.menu_name like concat('%', #{menuName}, '%') | ||||
| 		</if> | ||||
| 		<if test="visible != null and visible != ''"> | ||||
| 			AND m.visible = #{visible} | ||||
| 		</if> | ||||
| 		<if test="status != null and status != ''"> | ||||
| 			AND m.status = #{status} | ||||
| 		</if> | ||||
| 		order by m.parent_id, m.order_num | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectMenuTreeByUserId"  resultMap="SysMenuResult"> | ||||
| 		select distinct m.menu_id, m.parent_id, | ||||
| 						case | ||||
| 							when #{language} = 'zh-CN' then m.menu_name | ||||
| 							when #{language} = 'en-US' then t.en_us | ||||
| 							else m.menu_name | ||||
| 							end as menu_name, | ||||
| 						m.path, m.component, m.`query`, 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 | ||||
| 				 left join sys_menu_translate t on m.menu_id = t.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="Long"> | ||||
| 		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> | ||||
|  | ||||
| 	<select id="selectMenuPermsByRoleId" 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 | ||||
| 		where m.status = '0' and rm.role_id = #{roleId} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectMenuById"  resultMap="SysMenuResult"> | ||||
| 		select distinct m.menu_id, | ||||
| 						case | ||||
| 							when #{language} = 'zh-CN' then m.menu_name | ||||
| 							when #{language} = 'en-US' then t.en_us | ||||
| 							else m.menu_name | ||||
| 							end as menu_name, | ||||
| 						m.parent_id, m.order_num, m.path, m.component, m.query, m.is_frame, m.is_cache, m.menu_type, m.visible, m.status, ifnull(m.perms,'') as perms, m.icon, m.create_time | ||||
| 		from sys_menu m | ||||
| 				 left join sys_menu_translate t on m.menu_id = t.id | ||||
| 		where m.menu_id = #{menuId} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="hasChildByMenuId" resultType="Integer"> | ||||
| 		select count(1) from sys_menu where parent_id = #{menuId} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="checkMenuNameUnique" parameterType="com.fastbee.common.core.domain.entity.SysMenu" resultMap="SysMenuResult"> | ||||
| 		select distinct menu_id, menu_name, parent_id, order_num, path, component, query, is_frame, is_cache, menu_type, visible, status, ifnull(perms,'') as perms, icon, create_time | ||||
| 		from sys_menu | ||||
| 		where menu_name=#{menuName} and parent_id = #{parentId} limit 1 | ||||
| 	</select> | ||||
|  | ||||
| 	<update id="updateMenu" parameterType="com.fastbee.common.core.domain.entity.SysMenu"> | ||||
| 		update sys_menu | ||||
| 		<set> | ||||
| 			<if test="menuName != null and menuName != ''">menu_name = #{menuName},</if> | ||||
| 			<if test="parentId != null">parent_id = #{parentId},</if> | ||||
| 			<if test="orderNum != null">order_num = #{orderNum},</if> | ||||
| 			<if test="path != null and path != ''">path = #{path},</if> | ||||
| 			<if test="component != null">component = #{component},</if> | ||||
| 			<if test="query != null">`query` = #{query},</if> | ||||
| 			<if test="isFrame != null and isFrame != ''">is_frame = #{isFrame},</if> | ||||
| 			<if test="isCache != null and isCache != ''">is_cache = #{isCache},</if> | ||||
| 			<if test="menuType != null and menuType != ''">menu_type = #{menuType},</if> | ||||
| 			<if test="visible != null">visible = #{visible},</if> | ||||
| 			<if test="status != null">status = #{status},</if> | ||||
| 			<if test="perms !=null">perms = #{perms},</if> | ||||
| 			<if test="icon !=null and icon != ''">icon = #{icon},</if> | ||||
| 			<if test="remark != null and remark != ''">remark = #{remark},</if> | ||||
| 			<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
| 			update_time = sysdate() | ||||
| 		</set> | ||||
| 		where menu_id = #{menuId} | ||||
| 	</update> | ||||
|  | ||||
| 	<insert id="insertMenu" parameterType="com.fastbee.common.core.domain.entity.SysMenu"> | ||||
| 		insert into sys_menu( | ||||
| 		<if test="menuId != null and menuId != 0">menu_id,</if> | ||||
| 		<if test="parentId != null and parentId != 0">parent_id,</if> | ||||
| 		<if test="menuName != null and menuName != ''">menu_name,</if> | ||||
| 		<if test="orderNum != null">order_num,</if> | ||||
| 		<if test="path != null and path != ''">path,</if> | ||||
| 		<if test="component != null and component != ''">component,</if> | ||||
| 		<if test="query != null and query != ''">`query`,</if> | ||||
| 		<if test="isFrame != null and isFrame != ''">is_frame,</if> | ||||
| 		<if test="isCache != null and isCache != ''">is_cache,</if> | ||||
| 		<if test="menuType != null and menuType != ''">menu_type,</if> | ||||
| 		<if test="visible != null">visible,</if> | ||||
| 		<if test="status != null">status,</if> | ||||
| 		<if test="perms !=null and perms != ''">perms,</if> | ||||
| 		<if test="icon != null and icon != ''">icon,</if> | ||||
| 		<if test="remark != null and remark != ''">remark,</if> | ||||
| 		<if test="createBy != null and createBy != ''">create_by,</if> | ||||
| 		create_time | ||||
| 		)values( | ||||
| 		<if test="menuId != null and menuId != 0">#{menuId},</if> | ||||
| 		<if test="parentId != null and parentId != 0">#{parentId},</if> | ||||
| 		<if test="menuName != null and menuName != ''">#{menuName},</if> | ||||
| 		<if test="orderNum != null">#{orderNum},</if> | ||||
| 		<if test="path != null and path != ''">#{path},</if> | ||||
| 		<if test="component != null and component != ''">#{component},</if> | ||||
| 		<if test="query != null and query != ''">#{query},</if> | ||||
| 		<if test="isFrame != null and isFrame != ''">#{isFrame},</if> | ||||
| 		<if test="isCache != null and isCache != ''">#{isCache},</if> | ||||
| 		<if test="menuType != null and menuType != ''">#{menuType},</if> | ||||
| 		<if test="visible != null">#{visible},</if> | ||||
| 		<if test="status != null">#{status},</if> | ||||
| 		<if test="perms !=null and perms != ''">#{perms},</if> | ||||
| 		<if test="icon != null and icon != ''">#{icon},</if> | ||||
| 		<if test="remark != null and remark != ''">#{remark},</if> | ||||
| 		<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
| 		sysdate() | ||||
| 		) | ||||
| 	</insert> | ||||
|  | ||||
| 	<delete id="deleteMenuById" parameterType="Long"> | ||||
| 		delete from sys_menu where menu_id = #{menuId} | ||||
| 	</delete> | ||||
|  | ||||
| </mapper> | ||||
| @@ -0,0 +1,89 @@ | ||||
| <?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.fastbee.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> | ||||
|      | ||||
|     <sql id="selectNoticeVo"> | ||||
|         select notice_id, notice_title, notice_type, cast(notice_content as char) as notice_content, status, create_by, create_time, update_by, update_time, remark  | ||||
| 		from sys_notice | ||||
|     </sql> | ||||
|      | ||||
|     <select id="selectNoticeById" parameterType="Long" resultMap="SysNoticeResult"> | ||||
|         <include refid="selectNoticeVo"/> | ||||
|         where notice_id = #{noticeId} | ||||
|     </select> | ||||
|      | ||||
|     <select id="selectNoticeList" parameterType="SysNotice" resultMap="SysNoticeResult"> | ||||
|         <include refid="selectNoticeVo"/> | ||||
|         <where> | ||||
| 			<if test="noticeTitle != null and noticeTitle != ''"> | ||||
| 				AND notice_title like concat('%', #{noticeTitle}, '%') | ||||
| 			</if> | ||||
| 			<if test="noticeType != null and noticeType != ''"> | ||||
| 				AND notice_type = #{noticeType} | ||||
| 			</if> | ||||
| 			<if test="createBy != null and createBy != ''"> | ||||
| 				AND create_by like concat('%', #{createBy}, '%') | ||||
| 			</if> | ||||
| 		</where> | ||||
|     </select> | ||||
|      | ||||
|     <insert id="insertNotice" parameterType="SysNotice"> | ||||
|         insert into sys_notice ( | ||||
| 			<if test="noticeTitle != null and noticeTitle != '' ">notice_title, </if> | ||||
| 			<if test="noticeType != null and noticeType != '' ">notice_type, </if> | ||||
| 			<if test="noticeContent != null and noticeContent != '' ">notice_content, </if> | ||||
| 			<if test="status != null and status != '' ">status, </if> | ||||
| 			<if test="remark != null and remark != ''">remark,</if> | ||||
|  			<if test="createBy != null and createBy != ''">create_by,</if> | ||||
|  			create_time | ||||
|  		)values( | ||||
| 			<if test="noticeTitle != null and noticeTitle != ''">#{noticeTitle}, </if> | ||||
| 			<if test="noticeType != null and noticeType != ''">#{noticeType}, </if> | ||||
| 			<if test="noticeContent != null and noticeContent != ''">#{noticeContent}, </if> | ||||
| 			<if test="status != null and status != ''">#{status}, </if> | ||||
| 			<if test="remark != null and remark != ''">#{remark},</if> | ||||
|  			<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
|  			sysdate() | ||||
| 		) | ||||
|     </insert> | ||||
| 	  | ||||
|     <update id="updateNotice" parameterType="SysNotice"> | ||||
|         update sys_notice  | ||||
|         <set> | ||||
|             <if test="noticeTitle != null and noticeTitle != ''">notice_title = #{noticeTitle}, </if> | ||||
|             <if test="noticeType != null and noticeType != ''">notice_type = #{noticeType}, </if> | ||||
|             <if test="noticeContent != null">notice_content = #{noticeContent}, </if> | ||||
|             <if test="status != null and status != ''">status = #{status}, </if> | ||||
|             <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
|  			update_time = sysdate() | ||||
|         </set> | ||||
|         where notice_id = #{noticeId} | ||||
|     </update> | ||||
| 	 | ||||
|     <delete id="deleteNoticeById" parameterType="Long"> | ||||
|         delete from sys_notice where notice_id = #{noticeId} | ||||
|     </delete> | ||||
|      | ||||
|     <delete id="deleteNoticeByIds" parameterType="Long"> | ||||
|         delete from sys_notice where notice_id in  | ||||
|         <foreach item="noticeId" collection="array" open="(" separator="," close=")"> | ||||
|             #{noticeId} | ||||
|         </foreach> | ||||
|     </delete> | ||||
|      | ||||
| </mapper> | ||||
| @@ -0,0 +1,83 @@ | ||||
| <?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.fastbee.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> | ||||
|  | ||||
| 	<sql id="selectOperLogVo"> | ||||
|         select oper_id, title, business_type, method, request_method, operator_type, oper_name, dept_name, oper_url, oper_ip, oper_location, oper_param, json_result, status, error_msg, oper_time | ||||
|         from sys_oper_log | ||||
|     </sql> | ||||
|      | ||||
| 	<insert id="insertOperlog" parameterType="SysOperLog"> | ||||
| 		insert into sys_oper_log(title, business_type, method, request_method, operator_type, oper_name, dept_name, oper_url, oper_ip, oper_location, oper_param, json_result, status, error_msg, oper_time) | ||||
|         values (#{title}, #{businessType}, #{method}, #{requestMethod}, #{operatorType}, #{operName}, #{deptName}, #{operUrl}, #{operIp}, #{operLocation}, #{operParam}, #{jsonResult}, #{status}, #{errorMsg}, sysdate()) | ||||
| 	</insert> | ||||
| 	 | ||||
| 	<select id="selectOperLogList" parameterType="SysOperLog" resultMap="SysOperLogResult"> | ||||
| 		<include refid="selectOperLogVo"/> | ||||
| 		<where> | ||||
| 			<if test="title != null and title != ''"> | ||||
| 				AND title like concat('%', #{title}, '%') | ||||
| 			</if> | ||||
| 			<if test="businessType != null"> | ||||
| 				AND business_type = #{businessType} | ||||
| 			</if> | ||||
| 			<if test="businessTypes != null and businessTypes.length > 0"> | ||||
| 			    AND business_type in | ||||
| 			    <foreach collection="businessTypes" item="businessType" open="(" separator="," close=")"> | ||||
| 		 			#{businessType} | ||||
| 		        </foreach>  | ||||
| 			</if> | ||||
| 			<if test="status != null"> | ||||
| 				AND status = #{status} | ||||
| 			</if> | ||||
| 			<if test="operName != null and operName != ''"> | ||||
| 				AND oper_name like concat('%', #{operName}, '%') | ||||
| 			</if> | ||||
| 			<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 --> | ||||
| 				and date_format(oper_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d') | ||||
| 			</if> | ||||
| 			<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 --> | ||||
| 				and date_format(oper_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d') | ||||
| 			</if> | ||||
| 		</where> | ||||
| 		order by oper_id desc | ||||
| 	</select> | ||||
| 	 | ||||
| 	<delete id="deleteOperLogByIds" parameterType="Long"> | ||||
|  		delete from sys_oper_log where oper_id in | ||||
|  		<foreach collection="array" item="operId" open="(" separator="," close=")"> | ||||
|  			#{operId} | ||||
|         </foreach>  | ||||
|  	</delete> | ||||
|  	 | ||||
|  	<select id="selectOperLogById" parameterType="Long" resultMap="SysOperLogResult"> | ||||
| 		<include refid="selectOperLogVo"/> | ||||
| 		where oper_id = #{operId} | ||||
| 	</select> | ||||
| 	 | ||||
| 	<update id="cleanOperLog"> | ||||
|         truncate table sys_oper_log | ||||
|     </update> | ||||
|  | ||||
| </mapper>  | ||||
| @@ -0,0 +1,122 @@ | ||||
| <?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.fastbee.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="selectPostList" parameterType="SysPost" resultMap="SysPostResult"> | ||||
| 	    <include refid="selectPostVo"/> | ||||
| 		<where> | ||||
| 			<if test="postCode != null and postCode != ''"> | ||||
| 				AND post_code like concat('%', #{postCode}, '%') | ||||
| 			</if> | ||||
| 			<if test="status != null and status != ''"> | ||||
| 				AND status = #{status} | ||||
| 			</if> | ||||
| 			<if test="postName != null and postName != ''"> | ||||
| 				AND post_name like concat('%', #{postName}, '%') | ||||
| 			</if> | ||||
| 		</where> | ||||
| 	</select> | ||||
| 	 | ||||
| 	<select id="selectPostAll" resultMap="SysPostResult"> | ||||
| 		<include refid="selectPostVo"/> | ||||
| 	</select> | ||||
| 	 | ||||
| 	<select id="selectPostById" parameterType="Long" resultMap="SysPostResult"> | ||||
| 		<include refid="selectPostVo"/> | ||||
| 		where post_id = #{postId} | ||||
| 	</select> | ||||
| 	 | ||||
| 	<select id="selectPostListByUserId" parameterType="Long" resultType="Long"> | ||||
| 		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> | ||||
| 	 | ||||
| 	<select id="checkPostNameUnique" parameterType="String" resultMap="SysPostResult"> | ||||
| 		<include refid="selectPostVo"/> | ||||
| 		 where post_name=#{postName} limit 1 | ||||
| 	</select> | ||||
| 	 | ||||
| 	<select id="checkPostCodeUnique" parameterType="String" resultMap="SysPostResult"> | ||||
| 		<include refid="selectPostVo"/> | ||||
| 		 where post_code=#{postCode} limit 1 | ||||
| 	</select> | ||||
| 	 | ||||
| 	<update id="updatePost" parameterType="SysPost"> | ||||
|  		update sys_post | ||||
|  		<set> | ||||
|  			<if test="postCode != null and postCode != ''">post_code = #{postCode},</if> | ||||
|  			<if test="postName != null and postName != ''">post_name = #{postName},</if> | ||||
|  			<if test="postSort != null">post_sort = #{postSort},</if> | ||||
|  			<if test="status != null and status != ''">status = #{status},</if> | ||||
|  			<if test="remark != null">remark = #{remark},</if> | ||||
|  			<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
|  			update_time = sysdate() | ||||
|  		</set> | ||||
|  		where post_id = #{postId} | ||||
| 	</update> | ||||
|  	 | ||||
|  	<insert id="insertPost" parameterType="SysPost" useGeneratedKeys="true" keyProperty="postId"> | ||||
|  		insert into sys_post( | ||||
|  			<if test="postId != null and postId != 0">post_id,</if> | ||||
|  			<if test="postCode != null and postCode != ''">post_code,</if> | ||||
|  			<if test="postName != null and postName != ''">post_name,</if> | ||||
|  			<if test="postSort != null">post_sort,</if> | ||||
|  			<if test="status != null and status != ''">status,</if> | ||||
|  			<if test="remark != null and remark != ''">remark,</if> | ||||
|  			<if test="createBy != null and createBy != ''">create_by,</if> | ||||
|  			create_time | ||||
|  		)values( | ||||
|  			<if test="postId != null and postId != 0">#{postId},</if> | ||||
|  			<if test="postCode != null and postCode != ''">#{postCode},</if> | ||||
|  			<if test="postName != null and postName != ''">#{postName},</if> | ||||
|  			<if test="postSort != null">#{postSort},</if> | ||||
|  			<if test="status != null and status != ''">#{status},</if> | ||||
|  			<if test="remark != null and remark != ''">#{remark},</if> | ||||
|  			<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
|  			sysdate() | ||||
|  		) | ||||
| 	</insert> | ||||
| 	 | ||||
| 	<delete id="deletePostById" parameterType="Long"> | ||||
| 		delete from sys_post where post_id = #{postId} | ||||
| 	</delete> | ||||
| 	 | ||||
| 	<delete id="deletePostByIds" parameterType="Long"> | ||||
|  		delete from sys_post where post_id in | ||||
|  		<foreach collection="array" item="postId" open="(" separator="," close=")"> | ||||
|  			#{postId} | ||||
|         </foreach>  | ||||
|  	</delete> | ||||
|  | ||||
| </mapper>  | ||||
| @@ -0,0 +1,54 @@ | ||||
| <?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.fastbee.system.mapper.SysRoleDeptMapper"> | ||||
|  | ||||
| 	<resultMap type="SysRoleDept" id="SysRoleDeptResult"> | ||||
| 		<result property="roleId"     column="role_id"      /> | ||||
| 		<result property="deptId"     column="dept_id"      /> | ||||
| 	</resultMap> | ||||
|  | ||||
| 	<delete id="deleteRoleDeptByRoleId" parameterType="Long"> | ||||
| 		delete from sys_role_dept where role_id=#{roleId} | ||||
| 	</delete> | ||||
|  | ||||
| 	<select id="selectCountRoleDeptByDeptId" resultType="Integer"> | ||||
| 	    select count(1) from sys_role_dept where dept_id=#{deptId} | ||||
| 	</select> | ||||
|  | ||||
|     <select id="selectRoleDeptByDeptIds" resultType="com.fastbee.system.domain.SysRoleDept"> | ||||
| 		select dept_id, role_id | ||||
| 		from sys_role_dept | ||||
| 		where dept_id in | ||||
| 			<foreach collection="deptIdList" item="deptId" open="(" separator="," close=")"> | ||||
| 				#{deptId} | ||||
| 			</foreach> | ||||
| 	</select> | ||||
|  | ||||
|     <select id="selectByRoleId" resultType="com.fastbee.system.domain.SysRoleDept"> | ||||
| 		select dept_id, role_id | ||||
| 		from sys_role_dept | ||||
| 		where role_id = #{roleId} | ||||
| 	</select> | ||||
|     <select id="selectByDeptId" resultType="java.lang.Long"> | ||||
| 		select role_id | ||||
| 		from sys_role_dept | ||||
| 		where dept_id = #{deptId} | ||||
| 	</select> | ||||
|  | ||||
|     <delete id="deleteRoleDept" parameterType="Long"> | ||||
|  		delete from sys_role_dept where role_id in | ||||
|  		<foreach collection="array" item="roleId" open="(" separator="," close=")"> | ||||
|  			#{roleId} | ||||
|         </foreach> | ||||
|  	</delete> | ||||
|  | ||||
| 	<insert id="batchRoleDept"> | ||||
| 		insert into sys_role_dept(role_id, dept_id) values | ||||
| 		<foreach item="item" index="index" collection="list" separator=","> | ||||
| 			(#{item.roleId},#{item.deptId}) | ||||
| 		</foreach> | ||||
| 	</insert> | ||||
|  | ||||
| </mapper> | ||||
| @@ -0,0 +1,166 @@ | ||||
| <?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.fastbee.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="selectRoleList" parameterType="SysRole" resultMap="SysRoleResult"> | ||||
| 		<include refid="selectRoleVo"/> | ||||
| 		where r.del_flag = '0' | ||||
| 		<if test="roleId != null and roleId != 0"> | ||||
| 			AND r.role_id = #{roleId} | ||||
| 		</if> | ||||
| 		<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> | ||||
| 		<!-- 数据范围过滤 --> | ||||
| 		${params.dataScope} | ||||
| 		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="selectRoleAll" resultMap="SysRoleResult"> | ||||
| 		<include refid="selectRoleVo"/> | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectRoleListByUserId" parameterType="Long" resultType="Long"> | ||||
| 		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="selectRoleById" parameterType="Long" resultMap="SysRoleResult"> | ||||
| 		<include refid="selectRoleVo"/> | ||||
| 		where r.role_id = #{roleId} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectRolesByUserName" parameterType="String" resultMap="SysRoleResult"> | ||||
| 		<include refid="selectRoleVo"/> | ||||
| 		WHERE r.del_flag = '0' and u.user_name = #{userName} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="checkRoleNameUnique" parameterType="String" resultMap="SysRoleResult"> | ||||
| 		<include refid="selectRoleVo"/> | ||||
| 		 where r.role_name=#{roleName} and r.del_flag = '0' limit 1 | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="checkRoleKeyUnique" parameterType="String" resultMap="SysRoleResult"> | ||||
| 		<include refid="selectRoleVo"/> | ||||
| 		 where r.role_key=#{roleKey} and r.del_flag = '0' limit 1 | ||||
| 	</select> | ||||
|  | ||||
|     <select id="selectRoleByIds" resultMap="SysRoleResult"> | ||||
| 		<include refid="selectRoleVo"/> | ||||
| 		where r.role_id in | ||||
| 		 	<foreach collection="roleIdList" item="roleId" open="(" separator="," close=")"> | ||||
| 				#{roleId} | ||||
| 			</foreach> | ||||
| 			<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> | ||||
| 	</select> | ||||
|  | ||||
|     <insert id="insertRole" parameterType="SysRole" useGeneratedKeys="true" keyProperty="roleId"> | ||||
|  		insert into sys_role( | ||||
|  			<if test="roleId != null and roleId != 0">role_id,</if> | ||||
|  			<if test="roleName != null and roleName != ''">role_name,</if> | ||||
|  			<if test="roleKey != null and roleKey != ''">role_key,</if> | ||||
|  			<if test="roleSort != null">role_sort,</if> | ||||
|  			<if test="dataScope != null and dataScope != ''">data_scope,</if> | ||||
|  			<if test="menuCheckStrictly != null">menu_check_strictly,</if> | ||||
|  			<if test="deptCheckStrictly != null">dept_check_strictly,</if> | ||||
|  			<if test="status != null and status != ''">status,</if> | ||||
|  			<if test="remark != null and remark != ''">remark,</if> | ||||
|  			<if test="createBy != null and createBy != ''">create_by,</if> | ||||
|  			create_time | ||||
|  		)values( | ||||
|  			<if test="roleId != null and roleId != 0">#{roleId},</if> | ||||
|  			<if test="roleName != null and roleName != ''">#{roleName},</if> | ||||
|  			<if test="roleKey != null and roleKey != ''">#{roleKey},</if> | ||||
|  			<if test="roleSort != null">#{roleSort},</if> | ||||
|  			<if test="dataScope != null and dataScope != ''">#{dataScope},</if> | ||||
|  			<if test="menuCheckStrictly != null">#{menuCheckStrictly},</if> | ||||
|  			<if test="deptCheckStrictly != null">#{deptCheckStrictly},</if> | ||||
|  			<if test="status != null and status != ''">#{status},</if> | ||||
|  			<if test="remark != null and remark != ''">#{remark},</if> | ||||
|  			<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
|  			sysdate() | ||||
|  		) | ||||
| 	</insert> | ||||
|  | ||||
| 	<update id="updateRole" parameterType="SysRole"> | ||||
|  		update sys_role | ||||
|  		<set> | ||||
|  			<if test="roleName != null and roleName != ''">role_name = #{roleName},</if> | ||||
|  			<if test="roleKey != null and roleKey != ''">role_key = #{roleKey},</if> | ||||
|  			<if test="roleSort != null">role_sort = #{roleSort},</if> | ||||
|  			<if test="dataScope != null and dataScope != ''">data_scope = #{dataScope},</if> | ||||
|  			<if test="menuCheckStrictly != null">menu_check_strictly = #{menuCheckStrictly},</if> | ||||
|  			<if test="deptCheckStrictly != null">dept_check_strictly = #{deptCheckStrictly},</if> | ||||
|  			<if test="status != null and status != ''">status = #{status},</if> | ||||
|  			<if test="remark != null">remark = #{remark},</if> | ||||
|  			<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
|  			update_time = sysdate() | ||||
|  		</set> | ||||
|  		where role_id = #{roleId} | ||||
| 	</update> | ||||
|  | ||||
| 	<delete id="deleteRoleById" parameterType="Long"> | ||||
|  		update sys_role set del_flag = '2' where role_id = #{roleId} | ||||
|  	</delete> | ||||
|  | ||||
|  	<delete id="deleteRoleByIds" parameterType="Long"> | ||||
|  	    update sys_role set del_flag = '2' where role_id in | ||||
|  		<foreach collection="array" item="roleId" open="(" separator="," close=")"> | ||||
|  			#{roleId} | ||||
|         </foreach> | ||||
|  	</delete> | ||||
|  | ||||
| </mapper> | ||||
| @@ -0,0 +1,40 @@ | ||||
| <?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.fastbee.system.mapper.SysRoleMenuMapper"> | ||||
|  | ||||
| 	<resultMap type="SysRoleMenu" id="SysRoleMenuResult"> | ||||
| 		<result property="roleId"     column="role_id"      /> | ||||
| 		<result property="menuId"     column="menu_id"      /> | ||||
| 	</resultMap> | ||||
| 	 | ||||
| 	<select id="checkMenuExistRole" resultType="Integer"> | ||||
| 	    select count(1) from sys_role_menu where menu_id = #{menuId} | ||||
| 	</select> | ||||
|  | ||||
|     <select id="selectRoleMenuList" resultType="com.fastbee.system.domain.SysRoleMenu"> | ||||
| 		select * | ||||
| 		from sys_role_menu | ||||
| 		where role_id = #{roleId} | ||||
| 	</select> | ||||
|  | ||||
|     <delete id="deleteRoleMenuByRoleId" parameterType="Long"> | ||||
| 		delete from sys_role_menu where role_id=#{roleId} | ||||
| 	</delete> | ||||
| 	 | ||||
| 	<delete id="deleteRoleMenu" parameterType="Long"> | ||||
|  		delete from sys_role_menu where role_id in | ||||
|  		<foreach collection="array" item="ids" index="roleId" open="(" separator="," close=")"> | ||||
|  			#{roleId} | ||||
|         </foreach>  | ||||
|  	</delete> | ||||
| 	 | ||||
| 	<insert id="batchRoleMenu"> | ||||
| 		insert into sys_role_menu(role_id, menu_id) values | ||||
| 		<foreach item="item" index="index" collection="list" separator=","> | ||||
| 			(#{item.roleId},#{item.menuId}) | ||||
| 		</foreach> | ||||
| 	</insert> | ||||
| 	 | ||||
| </mapper>  | ||||
| @@ -0,0 +1,49 @@ | ||||
| <?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.fastbee.system.mapper.SysTranslateMapper"> | ||||
|  | ||||
|     <resultMap type="com.fastbee.common.core.domain.entity.SysTranslate" id="SysTranslateResult"> | ||||
|         <result property="id"    column="id"    /> | ||||
|         <result property="zh_CN"    column="zh_cn"    /> | ||||
|         <result property="en_US"    column="en_us"    /> | ||||
|     </resultMap> | ||||
|  | ||||
|     <insert id="insertSysTranslate" parameterType="com.fastbee.common.core.domain.entity.SysTranslate"> | ||||
|         insert into ${tableName} | ||||
|         <trim prefix="(" suffix=")" suffixOverrides=","> | ||||
|             <if test="id != null">id,</if> | ||||
|             <if test="productId != null">product_id,</if> | ||||
|             <if test="zh_CN != null">zh_cn,</if> | ||||
|             <if test="en_US != null">en_us</if> | ||||
|         </trim> | ||||
|         <trim prefix="values (" suffix=")" suffixOverrides=","> | ||||
|             <if test="id != null">#{id},</if> | ||||
|             <if test="productId != null">#{productId},</if> | ||||
|             <if test="zh_CN != null">#{zh_CN},</if> | ||||
|             <if test="en_US != null">#{en_US}</if> | ||||
|         </trim> | ||||
|         on duplicate key update | ||||
|         <if test="productId != null">product_id = #{productId},</if> | ||||
|         <if test="zh_CN != null">zh_cn = #{zh_CN},</if> | ||||
|         <if test="en_US != null">en_us = #{en_US}</if> | ||||
|     </insert> | ||||
|  | ||||
|     <select id="selectSysTranslateList" parameterType="com.fastbee.common.core.domain.entity.SysTranslate" resultMap="SysTranslateResult"> | ||||
|         select id, zh_cn, en_us from ${tableName} | ||||
|         <where> | ||||
|             <if test="zh_CN != null  and zh_CN != ''"> and zh_cn = #{zh_CN}</if> | ||||
|             <if test="en_US != null  and en_US != ''"> and en_us = #{en_US}</if> | ||||
|             <if test="productId != null and productId != ''"> and product_id = #{productId}</if> | ||||
|         </where> | ||||
|     </select> | ||||
|  | ||||
|     <select id="selectSourceList" resultType="com.fastbee.common.core.domain.entity.SysTranslate"  resultMap="SysTranslateResult"> | ||||
|         select ${idColumn} as id, ${nameColumn} as zh_cn from ${tableName} | ||||
|         <where> | ||||
|             <if test="productId != null">product_id = #{productId}</if> | ||||
|         </where> | ||||
|     </select> | ||||
|  | ||||
| </mapper> | ||||
| @@ -0,0 +1,355 @@ | ||||
| <?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.fastbee.system.mapper.SysUserMapper"> | ||||
|  | ||||
| 	<resultMap type="com.fastbee.common.core.domain.entity.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"       /> | ||||
| 		<result property="language"     column="language"/> | ||||
| 		<result property="timeZone"     column="time_zone"/> | ||||
| 		<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="ancestors" column="ancestors"   /> | ||||
| 		<result property="orderNum"  column="order_num"   /> | ||||
| 		<result property="leader"    column="leader"      /> | ||||
| 		<result property="status"    column="dept_status" /> | ||||
| 		<result property="deptUserId" column="dept_user_id"/> | ||||
| 		<result property="deptUserName" column="dept_user_name"/> | ||||
| 	</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.ancestors, d.dept_name, d.order_num, d.leader, d.status as dept_status, d.dept_user_id, | ||||
| 			   r.role_id, r.role_name, r.role_key, r.role_sort, r.data_scope, r.status as role_status, | ||||
| 			   (select su.user_name from sys_user su where su.user_id = d.dept_user_id) as dept_user_name, | ||||
| 			   ap.language,ap.time_zone | ||||
| 		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 | ||||
| 				 left join app_preferences ap on u.user_id = ap.user_id | ||||
| 	</sql> | ||||
|  | ||||
| 	<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.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, d.dept_user_id, r.role_id, r.role_key | ||||
| 		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 | ||||
| 		where u.del_flag = '0' | ||||
| 		<if test="userId != null and userId != 0"> | ||||
| 			AND u.user_id = #{userId} | ||||
| 		</if> | ||||
| 		<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 showChild != null and showChild"> | ||||
| 			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="deptId != null and deptId != 0 and showChild != null and !showChild"> | ||||
| 			AND u.dept_id = #{deptId} | ||||
| 		</if> | ||||
| 		<!-- 数据范围过滤 --> | ||||
| 		${params.dataScope} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectAllocatedList" parameterType="SysUser" resultMap="SysUserResult"> | ||||
| 		select distinct u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.phonenumber, u.status, u.create_time | ||||
| 		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 | ||||
| 		where u.del_flag = '0' and r.role_id = #{roleId} | ||||
| 		<if test="userName != null and userName != ''"> | ||||
| 			AND u.user_name like concat('%', #{userName}, '%') | ||||
| 		</if> | ||||
| 		<if test="phonenumber != null and phonenumber != ''"> | ||||
| 			AND u.phonenumber like concat('%', #{phonenumber}, '%') | ||||
| 		</if> | ||||
| 		<!-- 数据范围过滤 --> | ||||
| 		${params.dataScope} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectUnallocatedList" parameterType="SysUser" resultMap="SysUserResult"> | ||||
| 		select distinct u.user_id, u.dept_id, u.user_name, u.nick_name, u.email, u.phonenumber, u.status, u.create_time | ||||
| 		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 | ||||
| 		where u.del_flag = '0' and (r.role_id != #{roleId} or r.role_id IS NULL) | ||||
| 		and u.dept_id = #{deptId} | ||||
| 		and u.user_id not in (select u.user_id from sys_user u inner join sys_user_role ur on u.user_id = ur.user_id and ur.role_id = #{roleId}) | ||||
| 		<if test="userName != null and userName != ''"> | ||||
| 			AND u.user_name like concat('%', #{userName}, '%') | ||||
| 		</if> | ||||
| 		<if test="phonenumber != null and phonenumber != ''"> | ||||
| 			AND u.phonenumber like concat('%', #{phonenumber}, '%') | ||||
| 		</if> | ||||
| 		<!-- 数据范围过滤 --> | ||||
| 		${params.dataScope} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectUserByUserName" parameterType="String" resultMap="SysUserResult"> | ||||
| 		<include refid="selectUserVo"/> | ||||
| 		where u.user_name = #{userName} and u.del_flag = '0' | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectUserById" parameterType="Long" resultMap="SysUserResult"> | ||||
| 		<include refid="selectUserVo"/> | ||||
| 		where u.user_id = #{userId} | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="checkUserNameUnique" parameterType="String" resultMap="SysUserResult"> | ||||
| 		select user_id, user_name from sys_user where user_name = #{userName} and del_flag = '0' limit 1 | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="checkPhoneUnique" parameterType="String" resultMap="SysUserResult"> | ||||
| 		select user_id, phonenumber from sys_user where phonenumber = #{phonenumber} and del_flag = '0' limit 1 | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="checkEmailUnique" parameterType="String" resultMap="SysUserResult"> | ||||
| 		select user_id, email from sys_user where email = #{email} and del_flag = '0' limit 1 | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectUserByPhoneNumber" parameterType="String" resultMap="SysUserResult"> | ||||
| 		<include refid="selectUserVo"/> | ||||
| 		where u.phonenumber = #{phoneNumber} and u.del_flag = '0' | ||||
| 	</select> | ||||
|  | ||||
|     <insert id="insertUser" parameterType="SysUser" useGeneratedKeys="true" keyProperty="userId"> | ||||
|  		insert into sys_user( | ||||
|  			<if test="userId != null and userId != 0">user_id,</if> | ||||
|  			<if test="deptId != null and deptId != 0">dept_id,</if> | ||||
|  			<if test="userName != null and userName != ''">user_name,</if> | ||||
|  			<if test="nickName != null and nickName != ''">nick_name,</if> | ||||
|  			<if test="email != null and email != ''">email,</if> | ||||
|  			<if test="avatar != null and avatar != ''">avatar,</if> | ||||
|  			<if test="phonenumber != null and phonenumber != ''">phonenumber,</if> | ||||
|  			<if test="sex != null and sex != ''">sex,</if> | ||||
|  			<if test="password != null and password != ''">password,</if> | ||||
|  			<if test="status != null and status != ''">status,</if> | ||||
|  			<if test="createBy != null and createBy != ''">create_by,</if> | ||||
|  			<if test="remark != null and remark != ''">remark,</if> | ||||
|  			create_time | ||||
|  		)values( | ||||
|  			<if test="userId != null and userId != ''">#{userId},</if> | ||||
|  			<if test="deptId != null and deptId != ''">#{deptId},</if> | ||||
|  			<if test="userName != null and userName != ''">#{userName},</if> | ||||
|  			<if test="nickName != null and nickName != ''">#{nickName},</if> | ||||
|  			<if test="email != null and email != ''">#{email},</if> | ||||
|  			<if test="avatar != null and avatar != ''">#{avatar},</if> | ||||
|  			<if test="phonenumber != null and phonenumber != ''">#{phonenumber},</if> | ||||
|  			<if test="sex != null and sex != ''">#{sex},</if> | ||||
|  			<if test="password != null and password != ''">#{password},</if> | ||||
|  			<if test="status != null and status != ''">#{status},</if> | ||||
|  			<if test="createBy != null and createBy != ''">#{createBy},</if> | ||||
|  			<if test="remark != null and remark != ''">#{remark},</if> | ||||
|  			sysdate() | ||||
|  		) | ||||
| 	</insert> | ||||
|  | ||||
| 	<update id="updateUser" parameterType="SysUser"> | ||||
|  		update sys_user | ||||
|  		<set> | ||||
|  			<if test="deptId != null and deptId != 0">dept_id = #{deptId},</if> | ||||
|  			<if test="userName != null and userName != ''">user_name = #{userName},</if> | ||||
|  			<if test="nickName != null and nickName != ''">nick_name = #{nickName},</if> | ||||
|  			<if test="email != null ">email = #{email},</if> | ||||
|  			<if test="phonenumber != null ">phonenumber = #{phonenumber},</if> | ||||
|  			<if test="sex != null and sex != ''">sex = #{sex},</if> | ||||
|  			<if test="avatar != null and avatar != ''">avatar = #{avatar},</if> | ||||
|  			<if test="password != null and password != ''">password = #{password},</if> | ||||
|  			<if test="status != null and status != ''">status = #{status},</if> | ||||
|  			<if test="loginIp != null and loginIp != ''">login_ip = #{loginIp},</if> | ||||
|  			<if test="loginDate != null">login_date = #{loginDate},</if> | ||||
|  			<if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
|  			<if test="remark != null">remark = #{remark},</if> | ||||
|  			update_time = sysdate() | ||||
|  		</set> | ||||
|  		where user_id = #{userId} | ||||
| 	</update> | ||||
|  | ||||
| 	<update id="updateUserStatus" parameterType="SysUser"> | ||||
| 		update sys_user set status = #{status} where user_id = #{userId} | ||||
| 	</update> | ||||
|  | ||||
| 	<update id="updateUserAvatar" parameterType="SysUser"> | ||||
| 		update sys_user set avatar = #{avatar} where user_name = #{userName} | ||||
| 	</update> | ||||
|  | ||||
| 	<update id="resetUserPwd" parameterType="SysUser"> | ||||
| 		update sys_user set password = #{password} where user_name = #{userName} | ||||
| 	</update> | ||||
|  | ||||
| 	<delete id="deleteUserById" parameterType="Long"> | ||||
|  		update sys_user set del_flag = '2' where user_id = #{userId} | ||||
|  	</delete> | ||||
|  | ||||
|  	<delete id="deleteUserByIds" parameterType="Long"> | ||||
|  		update sys_user set del_flag = '2' where user_id in | ||||
|  		<foreach collection="array" item="userId" open="(" separator="," close=")"> | ||||
|  			#{userId} | ||||
|         </foreach> | ||||
|  	</delete> | ||||
|  | ||||
| 	<delete id="deleteBySysUserIdAndSourceClient"> | ||||
| 		update iot_social_user | ||||
| 		set del_flag = 1, | ||||
| 		update_time = now() | ||||
| 		where sys_user_id = #{sysUserId} | ||||
| 		and source_client in | ||||
| 		<foreach item="sourceClient" collection="sourceClientList" open="(" separator="," close=")"> | ||||
| 			#{sourceClient} | ||||
| 		</foreach> | ||||
| 	</delete> | ||||
|  | ||||
| 	<delete id="deleteBySysUserIdsAndSourceClient"> | ||||
| 		update iot_social_user | ||||
| 		set del_flag = 1, | ||||
| 		update_time = now() | ||||
| 		where sys_user_id in | ||||
| 		<foreach item="sysUserId" collection="sysUserIds" open="(" separator="," close=")"> | ||||
| 			#{sysUserId} | ||||
| 		</foreach> | ||||
| 		and source_client in | ||||
| 		<foreach item="sourceClient" collection="sourceClientList" open="(" separator="," close=")"> | ||||
| 			#{sourceClient} | ||||
| 		</foreach> | ||||
| 	</delete> | ||||
|  | ||||
| 	<delete id="deleteUserByDeptID"> | ||||
| 		update sys_user set del_flag = '2' | ||||
| 		where dept_id = #{deptId} | ||||
| 	</delete> | ||||
|  | ||||
| 	<select id="selectAllSubUser" parameterType="Long" resultMap="SysUserResult"> | ||||
| 		SELECT | ||||
| 			u.user_id, | ||||
| 			u.dept_id, | ||||
| 			u.nick_name, | ||||
| 			u.user_name, | ||||
| 			u.email, | ||||
| 			u.avatar, | ||||
| 			u.phonenumber, | ||||
| 			u.sex, | ||||
| 			u.STATUS, | ||||
| 			u.del_flag, | ||||
| 			u.login_ip, | ||||
| 			u.login_date, | ||||
| 			u.create_by, | ||||
| 			u.create_time, | ||||
| 			u.remark | ||||
| 		FROM | ||||
| 			sys_user u | ||||
| 		WHERE | ||||
| 				u.dept_id IN ( | ||||
| 				SELECT | ||||
| 					dept_id | ||||
| 				FROM | ||||
| 					sys_dept | ||||
| 				WHERE | ||||
| 					find_in_set(#{deptId}, ancestors)) | ||||
|     </select> | ||||
|  | ||||
|     <select id="getDeptUserByUserId" parameterType="Long" resultMap="SysUserResult"> | ||||
| 		SELECT | ||||
| 			u.user_id, | ||||
| 			u.dept_id, | ||||
| 			u.nick_name, | ||||
| 			u.user_name | ||||
| 		FROM | ||||
| 			sys_user u | ||||
| 		WHERE | ||||
| 				u.user_id = ( | ||||
| 				SELECT | ||||
| 					d.dept_user_id | ||||
| 				FROM | ||||
| 					sys_dept d | ||||
| 						INNER JOIN sys_user su ON d.dept_id = su.dept_id | ||||
| 				WHERE | ||||
| 					su.user_id = #{userId,jdbcType=BIGINT}) | ||||
|     </select> | ||||
|  | ||||
|     <select id="listTerminal" resultType="com.fastbee.common.core.domain.entity.SysUser"> | ||||
| 		select u.user_id, u.dept_id, u.nick_name, u.user_name, u.email, u.avatar, u.phonenumber, 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, d.dept_user_id, r.role_id, r.role_key | ||||
| 		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 | ||||
| 		where u.del_flag = '0' | ||||
| 		    and isnull(u.dept_id) | ||||
| 		<if test="userId != null and userId != 0"> | ||||
| 			AND u.user_id = #{userId} | ||||
| 		</if> | ||||
| 		<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> | ||||
| 		order by u.user_id desc | ||||
| 	</select> | ||||
|  | ||||
| 	<select id="selectByDeptId" parameterType="Long" resultMap="SysUserResult"> | ||||
| 		select u.user_id,u.user_name,u.nick_name from | ||||
| 			sys_user u inner join sys_dept d on u.dept_id = d.dept_id | ||||
| 		where u.dept_id = #{deptId} | ||||
| 		and u.user_id != d.dept_user_id | ||||
|     </select> | ||||
| </mapper> | ||||
| @@ -0,0 +1,34 @@ | ||||
| <?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.fastbee.system.mapper.SysUserPostMapper"> | ||||
|  | ||||
| 	<resultMap type="SysUserPost" id="SysUserPostResult"> | ||||
| 		<result property="userId"     column="user_id"      /> | ||||
| 		<result property="postId"     column="post_id"      /> | ||||
| 	</resultMap> | ||||
|  | ||||
| 	<delete id="deleteUserPostByUserId" parameterType="Long"> | ||||
| 		delete from sys_user_post where user_id=#{userId} | ||||
| 	</delete> | ||||
| 	 | ||||
| 	<select id="countUserPostById" resultType="Integer"> | ||||
| 	    select count(1) from sys_user_post where post_id=#{postId}   | ||||
| 	</select> | ||||
| 	 | ||||
| 	<delete id="deleteUserPost" parameterType="Long"> | ||||
|  		delete from sys_user_post where user_id in | ||||
|  		<foreach collection="array" item="userId" open="(" separator="," close=")"> | ||||
|  			#{userId} | ||||
|         </foreach>  | ||||
|  	</delete> | ||||
| 	 | ||||
| 	<insert id="batchUserPost"> | ||||
| 		insert into sys_user_post(user_id, post_id) values | ||||
| 		<foreach item="item" index="index" collection="list" separator=","> | ||||
| 			(#{item.userId},#{item.postId}) | ||||
| 		</foreach> | ||||
| 	</insert> | ||||
| 	 | ||||
| </mapper>  | ||||
| @@ -0,0 +1,50 @@ | ||||
| <?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.fastbee.system.mapper.SysUserRoleMapper"> | ||||
|  | ||||
| 	<resultMap type="SysUserRole" id="SysUserRoleResult"> | ||||
| 		<result property="userId"     column="user_id"      /> | ||||
| 		<result property="roleId"     column="role_id"      /> | ||||
| 	</resultMap> | ||||
|  | ||||
| 	<delete id="deleteUserRoleByUserId" parameterType="Long"> | ||||
| 		delete from sys_user_role where user_id=#{userId} | ||||
| 	</delete> | ||||
| 	 | ||||
| 	<select id="countUserRoleByRoleId" resultType="Integer"> | ||||
| 	    select count(1) from sys_user_role where role_id=#{roleId}   | ||||
| 	</select> | ||||
|  | ||||
|     <select id="selectRoleByUserId" resultType="com.fastbee.system.domain.SysUserRole"> | ||||
| 		select user_id, role_id | ||||
| 		from sys_user_role | ||||
| 		where user_id = #{userId} | ||||
| 	</select> | ||||
|  | ||||
|     <delete id="deleteUserRole" parameterType="Long"> | ||||
|  		delete from sys_user_role where user_id in | ||||
|  		<foreach collection="array" item="userId" open="(" separator="," close=")"> | ||||
|  			#{userId} | ||||
|         </foreach>  | ||||
|  	</delete> | ||||
| 	 | ||||
| 	<insert id="batchUserRole"> | ||||
| 		insert into sys_user_role(user_id, role_id) values | ||||
| 		<foreach item="item" index="index" collection="list" separator=","> | ||||
| 			(#{item.userId},#{item.roleId}) | ||||
| 		</foreach> | ||||
| 	</insert> | ||||
| 	 | ||||
| 	<delete id="deleteUserRoleInfo" parameterType="SysUserRole"> | ||||
| 		delete from sys_user_role where user_id=#{userId} and role_id=#{roleId} | ||||
| 	</delete> | ||||
| 	 | ||||
| 	<delete id="deleteUserRoleInfos"> | ||||
| 	    delete from sys_user_role where role_id=#{roleId} and user_id in | ||||
|  	    <foreach collection="userIds" item="userId" open="(" separator="," close=")"> | ||||
|  	        #{userId} | ||||
|             </foreach>  | ||||
| 	</delete> | ||||
| </mapper>  | ||||
		Reference in New Issue
	
	Block a user
	 wyw
					wyw