From 3aea3a7c882fece5d04ae16de11d040f2193541f Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?=E5=B0=91=E5=B9=B4=E6=A2=A6=E4=B8=8E=E7=A0=96?=
<2847127106@qq.com>
Date: Mon, 19 Aug 2024 18:34:27 +0800
Subject: [PATCH] =?UTF-8?q?=E5=88=9D=E5=A7=8B=E5=8C=96?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.gitignore | 46 ++
Dockerfile | 12 +
pom.xml | 106 ++++
.../muyu/system/CloudSystemApplication.java | 23 +
.../controller/SysConfigController.java | 122 +++++
.../system/controller/SysDeptController.java | 115 ++++
.../controller/SysDictDataController.java | 107 ++++
.../controller/SysDictTypeController.java | 115 ++++
.../controller/SysLogininforController.java | 80 +++
.../system/controller/SysMenuController.java | 137 +++++
.../controller/SysNoticeController.java | 125 +++++
.../controller/SysOperlogController.java | 67 +++
.../system/controller/SysPostController.java | 110 ++++
.../controller/SysProfileController.java | 134 +++++
.../system/controller/SysRoleController.java | 215 ++++++++
.../system/controller/SysUserController.java | 317 +++++++++++
.../controller/SysUserOnlineController.java | 69 +++
.../com/muyu/system/domain/SysConfig.java | 81 +++
.../java/com/muyu/system/domain/SysMenu.java | 138 +++++
.../com/muyu/system/domain/SysNotice.java | 72 +++
.../com/muyu/system/domain/SysNoticeUser.java | 29 +
.../java/com/muyu/system/domain/SysPost.java | 78 +++
.../com/muyu/system/domain/SysRoleDept.java | 27 +
.../com/muyu/system/domain/SysRoleMenu.java | 28 +
.../com/muyu/system/domain/SysUserOnline.java | 52 ++
.../com/muyu/system/domain/SysUserPost.java | 28 +
.../com/muyu/system/domain/SysUserRole.java | 27 +
.../muyu/system/domain/resp/AuthRoleResp.java | 33 ++
.../muyu/system/domain/resp/DeptTreeResp.java | 32 ++
.../system/domain/resp/DeptUserTreeResp.java | 28 +
.../muyu/system/domain/resp/NoticeResp.java | 70 +++
.../system/domain/resp/NoticeUserResp.java | 64 +++
.../muyu/system/domain/resp/ProfileResp.java | 34 ++
.../system/domain/resp/RoleMenuTreeResp.java | 31 ++
.../domain/resp/UserDetailInfoResp.java | 47 ++
.../muyu/system/domain/resp/UserInfoResp.java | 36 ++
.../com/muyu/system/domain/vo/MetaVo.java | 54 ++
.../com/muyu/system/domain/vo/RouterVo.java | 62 +++
.../com/muyu/system/domain/vo/TreeSelect.java | 56 ++
.../muyu/system/mapper/SysConfigMapper.java | 12 +
.../com/muyu/system/mapper/SysDeptMapper.java | 131 +++++
.../muyu/system/mapper/SysDictDataMapper.java | 106 ++++
.../muyu/system/mapper/SysDictTypeMapper.java | 92 ++++
.../system/mapper/SysLogininforMapper.java | 45 ++
.../com/muyu/system/mapper/SysMenuMapper.java | 140 +++++
.../muyu/system/mapper/SysNoticeMapper.java | 91 ++++
.../muyu/system/mapper/SysOperLogMapper.java | 52 ++
.../com/muyu/system/mapper/SysPostMapper.java | 110 ++++
.../muyu/system/mapper/SysRoleDeptMapper.java | 50 ++
.../com/muyu/system/mapper/SysRoleMapper.java | 119 ++++
.../muyu/system/mapper/SysRoleMenuMapper.java | 50 ++
.../com/muyu/system/mapper/SysUserMapper.java | 148 +++++
.../muyu/system/mapper/SysUserPostMapper.java | 49 ++
.../muyu/system/mapper/SysUserRoleMapper.java | 69 +++
.../muyu/system/service/SysConfigService.java | 44 ++
.../muyu/system/service/SysDeptService.java | 140 +++++
.../system/service/SysDictDataService.java | 66 +++
.../system/service/SysDictTypeService.java | 106 ++++
.../system/service/SysLogininforService.java | 43 ++
.../muyu/system/service/SysMenuService.java | 161 ++++++
.../muyu/system/service/SysNoticeService.java | 81 +++
.../system/service/SysOperLogService.java | 54 ++
.../system/service/SysPermissionService.java | 30 +
.../muyu/system/service/SysPostService.java | 110 ++++
.../muyu/system/service/SysRoleService.java | 191 +++++++
.../system/service/SysUserOnlineService.java | 52 ++
.../muyu/system/service/SysUserService.java | 232 ++++++++
.../service/impl/SysConfigServiceImpl.java | 114 ++++
.../service/impl/SysDeptServiceImpl.java | 321 +++++++++++
.../service/impl/SysDictDataServiceImpl.java | 108 ++++
.../service/impl/SysDictTypeServiceImpl.java | 210 +++++++
.../impl/SysLogininforServiceImpl.java | 64 +++
.../service/impl/SysMenuServiceImpl.java | 502 +++++++++++++++++
.../service/impl/SysNoticeServiceImpl.java | 140 +++++
.../service/impl/SysOperLogServiceImpl.java | 77 +++
.../impl/SysPermissionServiceImpl.java | 77 +++
.../service/impl/SysPostServiceImpl.java | 174 ++++++
.../service/impl/SysRoleServiceImpl.java | 399 ++++++++++++++
.../impl/SysUserOnlineServiceImpl.java | 85 +++
.../service/impl/SysUserServiceImpl.java | 515 ++++++++++++++++++
src/main/resources/banner.txt | 2 +
src/main/resources/bootstrap.yml | 55 ++
src/main/resources/deploy.sh | 54 ++
src/main/resources/logback/dev.xml | 74 +++
src/main/resources/logback/prod.xml | 81 +++
src/main/resources/logback/test.xml | 81 +++
.../mapper/system/SysConfigMapper.xml | 128 +++++
.../resources/mapper/system/SysDeptMapper.xml | 183 +++++++
.../mapper/system/SysDictDataMapper.xml | 143 +++++
.../mapper/system/SysDictTypeMapper.xml | 107 ++++
.../mapper/system/SysLogininforMapper.xml | 54 ++
.../resources/mapper/system/SysMenuMapper.xml | 288 ++++++++++
.../mapper/system/SysNoticeMapper.xml | 198 +++++++
.../mapper/system/SysOperLogMapper.xml | 103 ++++
.../resources/mapper/system/SysPostMapper.xml | 131 +++++
.../mapper/system/SysRoleDeptMapper.xml | 38 ++
.../resources/mapper/system/SysRoleMapper.xml | 163 ++++++
.../mapper/system/SysRoleMenuMapper.xml | 38 ++
.../resources/mapper/system/SysUserMapper.xml | 289 ++++++++++
.../mapper/system/SysUserPostMapper.xml | 38 ++
.../mapper/system/SysUserRoleMapper.xml | 51 ++
src/main/resources/restartDocker.sh | 23 +
src/main/resources/startCloud.sh | 11 +
103 files changed, 10700 insertions(+)
create mode 100644 .gitignore
create mode 100644 Dockerfile
create mode 100644 pom.xml
create mode 100644 src/main/java/com/muyu/system/CloudSystemApplication.java
create mode 100644 src/main/java/com/muyu/system/controller/SysConfigController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysDeptController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysDictDataController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysDictTypeController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysLogininforController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysMenuController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysNoticeController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysOperlogController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysPostController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysProfileController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysRoleController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysUserController.java
create mode 100644 src/main/java/com/muyu/system/controller/SysUserOnlineController.java
create mode 100644 src/main/java/com/muyu/system/domain/SysConfig.java
create mode 100644 src/main/java/com/muyu/system/domain/SysMenu.java
create mode 100644 src/main/java/com/muyu/system/domain/SysNotice.java
create mode 100644 src/main/java/com/muyu/system/domain/SysNoticeUser.java
create mode 100644 src/main/java/com/muyu/system/domain/SysPost.java
create mode 100644 src/main/java/com/muyu/system/domain/SysRoleDept.java
create mode 100644 src/main/java/com/muyu/system/domain/SysRoleMenu.java
create mode 100644 src/main/java/com/muyu/system/domain/SysUserOnline.java
create mode 100644 src/main/java/com/muyu/system/domain/SysUserPost.java
create mode 100644 src/main/java/com/muyu/system/domain/SysUserRole.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/AuthRoleResp.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/DeptTreeResp.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/DeptUserTreeResp.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/NoticeResp.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/NoticeUserResp.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/ProfileResp.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/RoleMenuTreeResp.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/UserDetailInfoResp.java
create mode 100644 src/main/java/com/muyu/system/domain/resp/UserInfoResp.java
create mode 100644 src/main/java/com/muyu/system/domain/vo/MetaVo.java
create mode 100644 src/main/java/com/muyu/system/domain/vo/RouterVo.java
create mode 100644 src/main/java/com/muyu/system/domain/vo/TreeSelect.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysConfigMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysDeptMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysDictDataMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysDictTypeMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysLogininforMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysMenuMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysNoticeMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysOperLogMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysPostMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysRoleDeptMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysRoleMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysRoleMenuMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysUserMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysUserPostMapper.java
create mode 100644 src/main/java/com/muyu/system/mapper/SysUserRoleMapper.java
create mode 100644 src/main/java/com/muyu/system/service/SysConfigService.java
create mode 100644 src/main/java/com/muyu/system/service/SysDeptService.java
create mode 100644 src/main/java/com/muyu/system/service/SysDictDataService.java
create mode 100644 src/main/java/com/muyu/system/service/SysDictTypeService.java
create mode 100644 src/main/java/com/muyu/system/service/SysLogininforService.java
create mode 100644 src/main/java/com/muyu/system/service/SysMenuService.java
create mode 100644 src/main/java/com/muyu/system/service/SysNoticeService.java
create mode 100644 src/main/java/com/muyu/system/service/SysOperLogService.java
create mode 100644 src/main/java/com/muyu/system/service/SysPermissionService.java
create mode 100644 src/main/java/com/muyu/system/service/SysPostService.java
create mode 100644 src/main/java/com/muyu/system/service/SysRoleService.java
create mode 100644 src/main/java/com/muyu/system/service/SysUserOnlineService.java
create mode 100644 src/main/java/com/muyu/system/service/SysUserService.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysConfigServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysDeptServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysDictDataServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysDictTypeServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysLogininforServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysMenuServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysNoticeServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysOperLogServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysPermissionServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysPostServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysRoleServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysUserOnlineServiceImpl.java
create mode 100644 src/main/java/com/muyu/system/service/impl/SysUserServiceImpl.java
create mode 100644 src/main/resources/banner.txt
create mode 100644 src/main/resources/bootstrap.yml
create mode 100644 src/main/resources/deploy.sh
create mode 100644 src/main/resources/logback/dev.xml
create mode 100644 src/main/resources/logback/prod.xml
create mode 100644 src/main/resources/logback/test.xml
create mode 100644 src/main/resources/mapper/system/SysConfigMapper.xml
create mode 100644 src/main/resources/mapper/system/SysDeptMapper.xml
create mode 100644 src/main/resources/mapper/system/SysDictDataMapper.xml
create mode 100644 src/main/resources/mapper/system/SysDictTypeMapper.xml
create mode 100644 src/main/resources/mapper/system/SysLogininforMapper.xml
create mode 100644 src/main/resources/mapper/system/SysMenuMapper.xml
create mode 100644 src/main/resources/mapper/system/SysNoticeMapper.xml
create mode 100644 src/main/resources/mapper/system/SysOperLogMapper.xml
create mode 100644 src/main/resources/mapper/system/SysPostMapper.xml
create mode 100644 src/main/resources/mapper/system/SysRoleDeptMapper.xml
create mode 100644 src/main/resources/mapper/system/SysRoleMapper.xml
create mode 100644 src/main/resources/mapper/system/SysRoleMenuMapper.xml
create mode 100644 src/main/resources/mapper/system/SysUserMapper.xml
create mode 100644 src/main/resources/mapper/system/SysUserPostMapper.xml
create mode 100644 src/main/resources/mapper/system/SysUserRoleMapper.xml
create mode 100644 src/main/resources/restartDocker.sh
create mode 100644 src/main/resources/startCloud.sh
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..09bdfea
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,46 @@
+######################################################################
+# Build Tools
+
+.gradle
+/build/
+!gradle/wrapper/gradle-wrapper.jar
+
+target/
+!.mvn/wrapper/maven-wrapper.jar
+
+######################################################################
+# IDE
+
+### STS ###
+.apt_generated
+.classpath
+.factorypath
+.project
+.settings
+.springBeans
+
+### IntelliJ IDEA ###
+.idea
+*.iws
+*.iml
+*.ipr
+
+### JRebel ###
+rebel.xml
+### NetBeans ###
+nbproject/private/
+build/*
+nbbuild/
+dist/
+nbdist/
+.nb-gradle/
+
+######################################################################
+# Others
+*.log
+*.xml.versionsBackup
+*.swp
+
+!*/build/*.java
+!*/build/*.html
+!*/build/*.xml
\ No newline at end of file
diff --git a/Dockerfile b/Dockerfile
new file mode 100644
index 0000000..e0d835d
--- /dev/null
+++ b/Dockerfile
@@ -0,0 +1,12 @@
+# |- home
+# |- app.jar
+# |- logs
+FROM openjdk:17-jdk
+
+WORKDIR /home
+
+VOLUME ["/home/logs/cloud-system"]
+
+COPY ./target/cloud-system.jar /home/app.jar
+
+ENTRYPOINT ["java","-jar","/home/app.jar"]
diff --git a/pom.xml b/pom.xml
new file mode 100644
index 0000000..de8737f
--- /dev/null
+++ b/pom.xml
@@ -0,0 +1,106 @@
+
+
+
+ com.muyu
+ cloud-modules
+ 3.6.5
+
+ 4.0.0
+
+ cloud-system
+
+ 3.6.5
+
+
+ cloud-system系统模块
+
+
+
+
+
+
+ com.alibaba.cloud
+ spring-cloud-starter-alibaba-nacos-discovery
+
+
+
+
+ com.alibaba.cloud
+ spring-cloud-starter-alibaba-nacos-config
+
+
+
+
+ com.alibaba.cloud
+ spring-cloud-starter-alibaba-sentinel
+
+
+
+
+ org.springframework.boot
+ spring-boot-starter-actuator
+
+
+
+
+ com.mysql
+ mysql-connector-j
+
+
+
+
+ com.muyu
+ cloud-common-datasource
+
+
+
+
+ com.muyu
+ cloud-common-datascope
+
+
+
+
+ com.muyu
+ cloud-common-log
+
+
+
+
+ com.muyu
+ cloud-common-api-doc
+
+
+
+
+ com.muyu
+ cloud-common-xxl
+
+
+
+
+ ${project.artifactId}
+
+
+ org.springframework.boot
+ spring-boot-maven-plugin
+
+
+
+ repackage
+
+
+
+
+
+
+
+
+ yun-releases
+ yun-releases
+ http://47.116.173.119:8081/repository/maven-releases/
+
+
+
diff --git a/src/main/java/com/muyu/system/CloudSystemApplication.java b/src/main/java/com/muyu/system/CloudSystemApplication.java
new file mode 100644
index 0000000..5fcbaf5
--- /dev/null
+++ b/src/main/java/com/muyu/system/CloudSystemApplication.java
@@ -0,0 +1,23 @@
+package com.muyu.system;
+
+import com.muyu.common.security.annotation.EnableCustomConfig;
+import com.muyu.common.security.annotation.EnableMyFeignClients;
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+
+/**
+ * 系统模块
+ *
+ * @author muyu
+ */
+@EnableCustomConfig
+//@EnableCustomSwagger2
+@EnableMyFeignClients
+@SpringBootApplication
+public class CloudSystemApplication {
+
+ public static void main (String[] args) {
+ SpringApplication.run(CloudSystemApplication.class, args);
+ System.out.println("CloudSystem 模块启动成功!");
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysConfigController.java b/src/main/java/com/muyu/system/controller/SysConfigController.java
new file mode 100644
index 0000000..3bced52
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysConfigController.java
@@ -0,0 +1,122 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.utils.poi.ExcelUtil;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.system.domain.SysConfig;
+import com.muyu.system.service.SysConfigService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import jakarta.servlet.http.HttpServletResponse;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.Arrays;
+import java.util.List;
+
+/**
+ * 参数配置 信息操作处理
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/config")
+@Tag(name = "SysConfigController", description = "系统参数配置")
+public class SysConfigController extends BaseController {
+
+ @Autowired
+ private SysConfigService configService;
+
+ /**
+ * 获取参数配置列表
+ */
+ @RequiresPermissions("system:config:list")
+ @GetMapping("/list")
+ @Operation(summary = "查询集合", description = "更新水果信息")
+ public Result> list (SysConfig config) {
+ startPage();
+ List list = configService.pageQuery(config);
+ return getDataTable(list);
+ }
+
+ @Log(title = "参数管理", businessType = BusinessType.EXPORT)
+ @RequiresPermissions("system:config:export")
+ @PostMapping("/export")
+ public void export (HttpServletResponse response, SysConfig config) {
+ List list = configService.pageQuery(config);
+ ExcelUtil util = new ExcelUtil(SysConfig.class);
+ util.exportExcel(response, list, "参数数据");
+ }
+
+ /**
+ * 根据参数编号获取详细信息
+ */
+ @GetMapping(value = "/{configId}")
+ public Result getInfo (@PathVariable("configId") Long configId) {
+ return success(configService.getById(configId));
+ }
+
+ /**
+ * 根据参数键名查询参数值
+ */
+ @GetMapping(value = "/configKey/{configKey}")
+ public Result getConfigKey (@PathVariable("configKey") String configKey) {
+ return success(configService.selectConfigByKey(configKey));
+ }
+
+ /**
+ * 新增参数配置
+ */
+ @RequiresPermissions("system:config:add")
+ @Log(title = "参数管理", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysConfig config) {
+ if (!configService.checkConfigKeyUnique(config)) {
+ return error("新增参数'" + config.getConfigName() + "'失败,参数键名已存在");
+ }
+ config.setCreateBy(SecurityUtils.getUsername());
+ return toAjax(configService.save(config));
+ }
+
+ /**
+ * 修改参数配置
+ */
+ @RequiresPermissions("system:config:edit")
+ @Log(title = "参数管理", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysConfig config) {
+ if (!configService.checkConfigKeyUnique(config)) {
+ return error("修改参数'" + config.getConfigName() + "'失败,参数键名已存在");
+ }
+ config.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(configService.updateById(config));
+ }
+
+ /**
+ * 删除参数配置
+ */
+ @RequiresPermissions("system:config:remove")
+ @Log(title = "参数管理", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{configIds}")
+ public Result remove (@PathVariable("configIds") Long[] configIds) {
+ configService.removeBatchByIds(Arrays.asList(configIds));
+ return success();
+ }
+
+ /**
+ * 刷新参数缓存
+ */
+ @RequiresPermissions("system:config:remove")
+ @Log(title = "参数管理", businessType = BusinessType.CLEAN)
+ @DeleteMapping("/refreshCache")
+ public Result refreshCache () {
+ configService.resetConfigCache();
+ return success();
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysDeptController.java b/src/main/java/com/muyu/system/controller/SysDeptController.java
new file mode 100644
index 0000000..4f552ca
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysDeptController.java
@@ -0,0 +1,115 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.constant.UserConstants;
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.common.system.domain.SysDept;
+import com.muyu.system.service.SysDeptService;
+import org.apache.commons.lang3.ArrayUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+
+/**
+ * 部门信息
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/dept")
+public class SysDeptController extends BaseController {
+
+ @Autowired
+ private SysDeptService deptService;
+
+ /**
+ * 获取部门列表
+ */
+ @RequiresPermissions("system:dept:list")
+ @GetMapping("/list")
+ public Result list (SysDept dept) {
+ List depts = deptService.selectDeptList(dept);
+ return success(depts);
+ }
+
+ /**
+ * 查询部门列表(排除节点)
+ */
+ @RequiresPermissions("system:dept:list")
+ @GetMapping("/list/exclude/{deptId}")
+ public Result excludeChild (@PathVariable(value = "deptId", required = false) Long deptId) {
+ List depts = deptService.selectDeptList(new SysDept());
+ depts.removeIf(d -> d.getDeptId().intValue() == deptId || ArrayUtils.contains(StringUtils.split(d.getAncestors(), ","), deptId + ""));
+ return success(depts);
+ }
+
+ /**
+ * 根据部门编号获取详细信息
+ */
+ @RequiresPermissions("system:dept:query")
+ @GetMapping(value = "/{deptId}")
+ public Result getInfo (@PathVariable("deptId") Long deptId) {
+ deptService.checkDeptDataScope(deptId);
+ return success(deptService.selectDeptById(deptId));
+ }
+
+ /**
+ * 新增部门
+ */
+ @RequiresPermissions("system:dept:add")
+ @Log(title = "部门管理", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysDept dept) {
+ if (!deptService.checkDeptNameUnique(dept)) {
+ return error("新增部门'" + dept.getDeptName() + "'失败,部门名称已存在");
+ }
+ dept.setCreateBy(SecurityUtils.getUsername());
+ return toAjax(deptService.insertDept(dept));
+ }
+
+ /**
+ * 修改部门
+ */
+ @RequiresPermissions("system:dept:edit")
+ @Log(title = "部门管理", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysDept dept) {
+ Long deptId = dept.getDeptId();
+ deptService.checkDeptDataScope(deptId);
+ if (!deptService.checkDeptNameUnique(dept)) {
+ return error("修改部门'" + dept.getDeptName() + "'失败,部门名称已存在");
+ } else if (dept.getParentId().equals(deptId)) {
+ return error("修改部门'" + dept.getDeptName() + "'失败,上级部门不能是自己");
+ } else if (StringUtils.equals(UserConstants.DEPT_DISABLE, dept.getStatus()) && deptService.selectNormalChildrenDeptById(deptId) > 0) {
+ return error("该部门包含未停用的子部门!");
+ }
+ dept.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(deptService.updateDept(dept));
+ }
+
+ /**
+ * 删除部门
+ */
+ @RequiresPermissions("system:dept:remove")
+ @Log(title = "部门管理", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{deptId}")
+ public Result remove (@PathVariable("deptId") Long deptId) {
+ if (deptService.hasChildByDeptId(deptId)) {
+ return warn("存在下级部门,不允许删除");
+ }
+ if (deptService.checkDeptExistUser(deptId)) {
+ return warn("部门存在用户,不允许删除");
+ }
+ deptService.checkDeptDataScope(deptId);
+ return toAjax(deptService.deleteDeptById(deptId));
+ }
+
+
+}
diff --git a/src/main/java/com/muyu/system/controller/SysDictDataController.java b/src/main/java/com/muyu/system/controller/SysDictDataController.java
new file mode 100644
index 0000000..f9862d9
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysDictDataController.java
@@ -0,0 +1,107 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.core.utils.poi.ExcelUtil;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.common.system.domain.SysDictData;
+import com.muyu.system.service.SysDictDataService;
+import com.muyu.system.service.SysDictTypeService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import jakarta.servlet.http.HttpServletResponse;
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * 数据字典信息
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/dict/data")
+public class SysDictDataController extends BaseController {
+ @Autowired
+ private SysDictDataService dictDataService;
+
+ @Autowired
+ private SysDictTypeService dictTypeService;
+
+ @RequiresPermissions("system:dict:list")
+ @GetMapping("/list")
+ public Result> list (SysDictData dictData) {
+ startPage();
+ List list = dictDataService.selectDictDataList(dictData);
+ return getDataTable(list);
+ }
+
+ @Log(title = "字典数据", businessType = BusinessType.EXPORT)
+ @RequiresPermissions("system:dict:export")
+ @PostMapping("/export")
+ public void export (HttpServletResponse response, SysDictData dictData) {
+ List list = dictDataService.selectDictDataList(dictData);
+ ExcelUtil util = new ExcelUtil(SysDictData.class);
+ util.exportExcel(response, list, "字典数据");
+ }
+
+ /**
+ * 查询字典数据详细
+ */
+ @RequiresPermissions("system:dict:query")
+ @GetMapping(value = "/{dictCode}")
+ public Result getInfo (@PathVariable("dictCode") Long dictCode) {
+ return success(dictDataService.selectDictDataById(dictCode));
+ }
+
+ /**
+ * 根据字典类型查询字典数据信息
+ */
+ @GetMapping(value = "/type/{dictType}")
+ public Result dictType (@PathVariable("dictType") String dictType) {
+ List data = dictTypeService.selectDictDataByType(dictType);
+ if (StringUtils.isNull(data)) {
+ data = new ArrayList();
+ }
+ return success(data);
+ }
+
+ /**
+ * 新增字典类型
+ */
+ @RequiresPermissions("system:dict:add")
+ @Log(title = "字典数据", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysDictData dict) {
+ dict.setCreateBy(SecurityUtils.getUsername());
+ return toAjax(dictDataService.insertDictData(dict));
+ }
+
+ /**
+ * 修改保存字典类型
+ */
+ @RequiresPermissions("system:dict:edit")
+ @Log(title = "字典数据", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysDictData dict) {
+ dict.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(dictDataService.updateDictData(dict));
+ }
+
+ /**
+ * 删除字典类型
+ */
+ @RequiresPermissions("system:dict:remove")
+ @Log(title = "字典类型", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{dictCodes}")
+ public Result remove (@PathVariable("dictCode") Long[] dictCodes) {
+ dictDataService.deleteDictDataByIds(dictCodes);
+ return success();
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysDictTypeController.java b/src/main/java/com/muyu/system/controller/SysDictTypeController.java
new file mode 100644
index 0000000..c4a7b9f
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysDictTypeController.java
@@ -0,0 +1,115 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.utils.poi.ExcelUtil;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.common.system.domain.SysDictType;
+import com.muyu.system.service.SysDictTypeService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import jakarta.servlet.http.HttpServletResponse;
+import java.util.List;
+
+/**
+ * 数据字典信息
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/dict/type")
+public class SysDictTypeController extends BaseController {
+ @Autowired
+ private SysDictTypeService dictTypeService;
+
+ @RequiresPermissions("system:dict:list")
+ @GetMapping("/list")
+ public Result> list (SysDictType dictType) {
+ startPage();
+ List list = dictTypeService.selectDictTypeList(dictType);
+ return getDataTable(list);
+ }
+
+ @Log(title = "字典类型", businessType = BusinessType.EXPORT)
+ @RequiresPermissions("system:dict:export")
+ @PostMapping("/export")
+ public void export (HttpServletResponse response, SysDictType dictType) {
+ List list = dictTypeService.selectDictTypeList(dictType);
+ ExcelUtil util = new ExcelUtil(SysDictType.class);
+ util.exportExcel(response, list, "字典类型");
+ }
+
+ /**
+ * 查询字典类型详细
+ */
+ @RequiresPermissions("system:dict:query")
+ @GetMapping(value = "/{dictId}")
+ public Result getInfo (@PathVariable("dictId") Long dictId) {
+ return success(dictTypeService.selectDictTypeById(dictId));
+ }
+
+ /**
+ * 新增字典类型
+ */
+ @RequiresPermissions("system:dict:add")
+ @Log(title = "字典类型", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysDictType dict) {
+ if (!dictTypeService.checkDictTypeUnique(dict)) {
+ return error("新增字典'" + dict.getDictName() + "'失败,字典类型已存在");
+ }
+ dict.setCreateBy(SecurityUtils.getUsername());
+ return toAjax(dictTypeService.insertDictType(dict));
+ }
+
+ /**
+ * 修改字典类型
+ */
+ @RequiresPermissions("system:dict:edit")
+ @Log(title = "字典类型", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysDictType dict) {
+ if (!dictTypeService.checkDictTypeUnique(dict)) {
+ return error("修改字典'" + dict.getDictName() + "'失败,字典类型已存在");
+ }
+ dict.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(dictTypeService.updateDictType(dict));
+ }
+
+ /**
+ * 删除字典类型
+ */
+ @RequiresPermissions("system:dict:remove")
+ @Log(title = "字典类型", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{dictIds}")
+ public Result remove (@PathVariable("dictIds") Long[] dictIds) {
+ dictTypeService.deleteDictTypeByIds(dictIds);
+ return success();
+ }
+
+ /**
+ * 刷新字典缓存
+ */
+ @RequiresPermissions("system:dict:remove")
+ @Log(title = "字典类型", businessType = BusinessType.CLEAN)
+ @DeleteMapping("/refreshCache")
+ public Result refreshCache () {
+ dictTypeService.resetDictCache();
+ return success();
+ }
+
+ /**
+ * 获取字典选择框列表
+ */
+ @GetMapping("/optionselect")
+ public Result optionselect () {
+ List dictTypes = dictTypeService.selectDictTypeAll();
+ return success(dictTypes);
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysLogininforController.java b/src/main/java/com/muyu/system/controller/SysLogininforController.java
new file mode 100644
index 0000000..c1e92b7
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysLogininforController.java
@@ -0,0 +1,80 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.constant.CacheConstants;
+import com.muyu.common.core.utils.poi.ExcelUtil;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.redis.service.RedisService;
+import com.muyu.common.security.annotation.InnerAuth;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.system.domain.SysLogininfor;
+import com.muyu.system.service.SysLogininforService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import jakarta.servlet.http.HttpServletResponse;
+import java.util.List;
+
+/**
+ * 系统访问记录
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/logininfor")
+public class SysLogininforController extends BaseController {
+ @Autowired
+ private SysLogininforService logininforService;
+
+ @Autowired
+ private RedisService redisService;
+
+ @RequiresPermissions("system:logininfor:list")
+ @GetMapping("/list")
+ public Result> list (SysLogininfor logininfor) {
+ startPage();
+ List list = logininforService.selectLogininforList(logininfor);
+ return getDataTable(list);
+ }
+
+ @Log(title = "登录日志", businessType = BusinessType.EXPORT)
+ @RequiresPermissions("system:logininfor:export")
+ @PostMapping("/export")
+ public void export (HttpServletResponse response, SysLogininfor logininfor) {
+ List list = logininforService.selectLogininforList(logininfor);
+ ExcelUtil util = new ExcelUtil(SysLogininfor.class);
+ util.exportExcel(response, list, "登录日志");
+ }
+
+ @RequiresPermissions("system:logininfor:remove")
+ @Log(title = "登录日志", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{infoIds}")
+ public Result remove (@PathVariable("infoIds") Long[] infoIds) {
+ return toAjax(logininforService.deleteLogininforByIds(infoIds));
+ }
+
+ @RequiresPermissions("system:logininfor:remove")
+ @Log(title = "登录日志", businessType = BusinessType.DELETE)
+ @DeleteMapping("/clean")
+ public Result clean () {
+ logininforService.cleanLogininfor();
+ return success();
+ }
+
+ @RequiresPermissions("system:logininfor:unlock")
+ @Log(title = "账户解锁", businessType = BusinessType.OTHER)
+ @GetMapping("/unlock/{userName}")
+ public Result unlock (@PathVariable("userName") String userName) {
+ redisService.deleteObject(CacheConstants.PWD_ERR_CNT_KEY + userName);
+ return success();
+ }
+
+ @InnerAuth
+ @PostMapping
+ public Result add (@RequestBody SysLogininfor logininfor) {
+ return toAjax(logininforService.insertLogininfor(logininfor));
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysMenuController.java b/src/main/java/com/muyu/system/controller/SysMenuController.java
new file mode 100644
index 0000000..e5ae348
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysMenuController.java
@@ -0,0 +1,137 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.constant.UserConstants;
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.system.domain.SysMenu;
+import com.muyu.system.domain.resp.RoleMenuTreeResp;
+import com.muyu.system.service.SysMenuService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+
+/**
+ * 菜单信息
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/menu")
+public class SysMenuController extends BaseController {
+ @Autowired
+ private SysMenuService menuService;
+
+ /**
+ * 获取菜单列表
+ */
+ @RequiresPermissions("system:menu:list")
+ @GetMapping("/list")
+ public Result list (SysMenu menu) {
+ Long userId = SecurityUtils.getUserId();
+ List menus = menuService.selectMenuList(menu, userId);
+ return success(menus);
+ }
+
+ /**
+ * 根据菜单编号获取详细信息
+ */
+ @RequiresPermissions("system:menu:query")
+ @GetMapping(value = "/{menuId}")
+ public Result getInfo (@PathVariable("menuId") Long menuId) {
+ return success(menuService.selectMenuById(menuId));
+ }
+
+ /**
+ * 获取菜单下拉树列表
+ */
+ @GetMapping("/treeselect")
+ public Result treeselect (SysMenu menu) {
+ Long userId = SecurityUtils.getUserId();
+ List menus = menuService.selectMenuList(menu, userId);
+ return success(menuService.buildMenuTreeSelect(menus));
+ }
+
+ /**
+ * 加载对应角色菜单列表树
+ */
+ @GetMapping(value = "/roleMenuTreeselect/{roleId}")
+ public Result roleMenuTreeselect (@PathVariable("roleId") Long roleId) {
+ Long userId = SecurityUtils.getUserId();
+ List menus = menuService.selectMenuList(userId);
+ return Result.success(
+ RoleMenuTreeResp.builder()
+ .menus(menuService.buildMenuTreeSelect(menus))
+ .checkedKeys(menuService.selectMenuListByRoleId(roleId))
+ .build()
+ );
+ }
+
+ /**
+ * 新增菜单
+ */
+ @RequiresPermissions("system:menu:add")
+ @Log(title = "菜单管理", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysMenu menu) {
+ if (!menuService.checkMenuNameUnique(menu)) {
+ return error("新增菜单'" + menu.getMenuName() + "'失败,菜单名称已存在");
+ } else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) {
+ return error("新增菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头");
+ }
+ menu.setCreateBy(SecurityUtils.getUsername());
+ return toAjax(menuService.insertMenu(menu));
+ }
+
+ /**
+ * 修改菜单
+ */
+ @RequiresPermissions("system:menu:edit")
+ @Log(title = "菜单管理", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysMenu menu) {
+ if (!menuService.checkMenuNameUnique(menu)) {
+ return error("修改菜单'" + menu.getMenuName() + "'失败,菜单名称已存在");
+ } else if (UserConstants.YES_FRAME.equals(menu.getIsFrame()) && !StringUtils.ishttp(menu.getPath())) {
+ return error("修改菜单'" + menu.getMenuName() + "'失败,地址必须以http(s)://开头");
+ } else if (menu.getMenuId().equals(menu.getParentId())) {
+ return error("修改菜单'" + menu.getMenuName() + "'失败,上级菜单不能选择自己");
+ }
+ menu.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(menuService.updateMenu(menu));
+ }
+
+ /**
+ * 删除菜单
+ */
+ @RequiresPermissions("system:menu:remove")
+ @Log(title = "菜单管理", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{menuId}")
+ public Result remove (@PathVariable("menuId") Long menuId) {
+ if (menuService.hasChildByMenuId(menuId)) {
+ return warn("存在子菜单,不允许删除");
+ }
+ if (menuService.checkMenuExistRole(menuId)) {
+ return warn("菜单已分配,不允许删除");
+ }
+ return toAjax(menuService.deleteMenuById(menuId));
+ }
+
+ /**
+ * 获取路由信息
+ *
+ * @return 路由信息
+ */
+ @GetMapping("getRouters")
+ public Result getRouters () {
+ Long userId = SecurityUtils.getUserId();
+ List menus = menuService.selectMenuTreeByUserId(userId);
+ return success(menuService.buildMenus(menus));
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysNoticeController.java b/src/main/java/com/muyu/system/controller/SysNoticeController.java
new file mode 100644
index 0000000..f570f65
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysNoticeController.java
@@ -0,0 +1,125 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.system.domain.SysNotice;
+import com.muyu.system.service.SysNoticeService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.List;
+
+/**
+ * 公告 信息操作处理
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/notice")
+public class SysNoticeController extends BaseController {
+ @Autowired
+ private SysNoticeService noticeService;
+
+ /**
+ * 获取通知公告列表
+ */
+ @RequiresPermissions("system:notice:list")
+ @GetMapping("/list")
+ public Result> list (SysNotice notice) {
+ startPage();
+ List list = noticeService.selectNoticeList(notice);
+ return getDataTable(list);
+ }
+
+ /**
+ * 根据通知公告编号获取详细信息
+ */
+ @RequiresPermissions("system:notice:query")
+ @GetMapping(value = "/{noticeId}")
+ public Result getInfo (@PathVariable("noticeId") Long noticeId) {
+ return success(noticeService.selectNoticeById(noticeId));
+ }
+
+ /**
+ * 新增通知公告
+ */
+ @RequiresPermissions("system:notice:add")
+ @Log(title = "通知公告", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysNotice notice) {
+ notice.setCreateBy(SecurityUtils.getUsername());
+ HashSet userIdSet = new HashSet<>();
+ if ("1".equals(notice.getNoticeType())){
+ // 如果通知类型为1(通知),则将整合发送的用户
+ userIdSet = new HashSet<>(notice.getUserIds());
+ if (notice.getDeptIds()!=null && !notice.getDeptIds().isEmpty()){
+ // 获取发送部门的用户ID
+ List> deptIdsList = notice.getDeptIds();
+ ArrayList deptIds = new ArrayList<>();
+ for (List integers : deptIdsList) {
+ deptIds.add(integers.get(2));
+ }
+ userIdSet.addAll(noticeService.selUserByDeptIds(deptIds));
+ }
+ }else{
+ // 否则为公告,查询所有用户ID
+ userIdSet.addAll(noticeService.findUserIdsAll());
+ }
+ return toAjax(noticeService.insertNotice(notice, userIdSet));
+ }
+
+ /**
+ * 修改通知公告
+ */
+ @RequiresPermissions("system:notice:edit")
+ @Log(title = "通知公告", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysNotice notice) {
+ notice.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(noticeService.updateNotice(notice));
+ }
+
+ /**
+ * 删除通知公告
+ */
+ @RequiresPermissions("system:notice:remove")
+ @Log(title = "通知公告", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{noticeIds}")
+ public Result remove (@PathVariable("noticeIds") Long[] noticeIds) {
+ return toAjax(noticeService.deleteNoticeByIds(noticeIds));
+ }
+
+ /**
+ * 查询用户通知公告阅读列表
+ */
+ @GetMapping("/selNoticeByUserId")
+ public Result selNoticeByUserId () {
+ Long userId = SecurityUtils.getUserId();
+ return success(noticeService.selNoticeByUserId(userId));
+ }
+
+ /**
+ * 用户阅读通知公告
+ */
+ @GetMapping("/findNoticeByNoticeIdAndUserId")
+ public Result findNoticeByNoticeIdAndUserId (@RequestParam("noticeId") Long noticeId,@RequestParam("sta") int sta) {
+ Long userId = SecurityUtils.getUserId();
+ return success(noticeService.findNoticeByNoticeIdAndUserId(noticeId,sta,userId));
+ }
+
+ /**
+ * 查询详细公告信息与其阅读状态统计
+ */
+ @GetMapping("/findNoticeByNoticeId/{noticeId}")
+ public Result findNoticeByNoticeId (@PathVariable("noticeId") Long noticeId) {
+ return success(noticeService.findNoticeByNoticeId(noticeId));
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysOperlogController.java b/src/main/java/com/muyu/system/controller/SysOperlogController.java
new file mode 100644
index 0000000..bb00d1d
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysOperlogController.java
@@ -0,0 +1,67 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.utils.poi.ExcelUtil;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.InnerAuth;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.system.domain.SysOperLog;
+import com.muyu.system.service.SysOperLogService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import jakarta.servlet.http.HttpServletResponse;
+import java.util.List;
+
+/**
+ * 操作日志记录
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/operlog")
+public class SysOperlogController extends BaseController {
+ @Autowired
+ private SysOperLogService operLogService;
+
+ @RequiresPermissions("system:operlog:list")
+ @GetMapping("/list")
+ public Result> list (SysOperLog operLog) {
+ startPage();
+ List list = operLogService.selectOperLogList(operLog);
+ return getDataTable(list);
+ }
+
+ @Log(title = "操作日志", businessType = BusinessType.EXPORT)
+ @RequiresPermissions("system:operlog:export")
+ @PostMapping("/export")
+ public void export (HttpServletResponse response, SysOperLog operLog) {
+ List list = operLogService.selectOperLogList(operLog);
+ ExcelUtil util = new ExcelUtil(SysOperLog.class);
+ util.exportExcel(response, list, "操作日志");
+ }
+
+ @Log(title = "操作日志", businessType = BusinessType.DELETE)
+ @RequiresPermissions("system:operlog:remove")
+ @DeleteMapping("/{operIds}")
+ public Result remove (@PathVariable("operIds") Long[] operIds) {
+ return toAjax(operLogService.deleteOperLogByIds(operIds));
+ }
+
+ @RequiresPermissions("system:operlog:remove")
+ @Log(title = "操作日志", businessType = BusinessType.CLEAN)
+ @DeleteMapping("/clean")
+ public Result clean () {
+ operLogService.cleanOperLog();
+ return success();
+ }
+
+ @InnerAuth
+ @PostMapping
+ public Result add (@RequestBody SysOperLog operLog) {
+ return toAjax(operLogService.insertOperlog(operLog));
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysPostController.java b/src/main/java/com/muyu/system/controller/SysPostController.java
new file mode 100644
index 0000000..79f3f47
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysPostController.java
@@ -0,0 +1,110 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.utils.poi.ExcelUtil;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.system.domain.SysPost;
+import com.muyu.system.service.SysPostService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import jakarta.servlet.http.HttpServletResponse;
+import java.util.List;
+
+/**
+ * 岗位信息操作处理
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/post")
+public class SysPostController extends BaseController {
+ @Autowired
+ private SysPostService postService;
+
+ /**
+ * 获取岗位列表
+ */
+ @RequiresPermissions("system:post:list")
+ @GetMapping("/list")
+ public Result> list (SysPost post) {
+ startPage();
+ List list = postService.selectPostList(post);
+ return getDataTable(list);
+ }
+
+ @Log(title = "岗位管理", businessType = BusinessType.EXPORT)
+ @RequiresPermissions("system:post:export")
+ @PostMapping("/export")
+ public void export (HttpServletResponse response, SysPost post) {
+ List list = postService.selectPostList(post);
+ ExcelUtil util = new ExcelUtil(SysPost.class);
+ util.exportExcel(response, list, "岗位数据");
+ }
+
+ /**
+ * 根据岗位编号获取详细信息
+ */
+ @RequiresPermissions("system:post:query")
+ @GetMapping(value = "/{postId}")
+ public Result getInfo (@PathVariable("postId") Long postId) {
+ return success(postService.selectPostById(postId));
+ }
+
+ /**
+ * 新增岗位
+ */
+ @RequiresPermissions("system:post:add")
+ @Log(title = "岗位管理", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysPost post) {
+ if (!postService.checkPostNameUnique(post)) {
+ return error("新增岗位'" + post.getPostName() + "'失败,岗位名称已存在");
+ } else if (!postService.checkPostCodeUnique(post)) {
+ return error("新增岗位'" + post.getPostName() + "'失败,岗位编码已存在");
+ }
+ post.setCreateBy(SecurityUtils.getUsername());
+ return toAjax(postService.insertPost(post));
+ }
+
+ /**
+ * 修改岗位
+ */
+ @RequiresPermissions("system:post:edit")
+ @Log(title = "岗位管理", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysPost post) {
+ if (!postService.checkPostNameUnique(post)) {
+ return error("修改岗位'" + post.getPostName() + "'失败,岗位名称已存在");
+ } else if (!postService.checkPostCodeUnique(post)) {
+ return error("修改岗位'" + post.getPostName() + "'失败,岗位编码已存在");
+ }
+ post.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(postService.updatePost(post));
+ }
+
+ /**
+ * 删除岗位
+ */
+ @RequiresPermissions("system:post:remove")
+ @Log(title = "岗位管理", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{postIds}")
+ public Result remove (@PathVariable("postIds") Long[] postIds) {
+ return toAjax(postService.deletePostByIds(postIds));
+ }
+
+ /**
+ * 获取岗位选择框列表
+ */
+ @GetMapping("/optionselect")
+ public Result optionselect () {
+ List posts = postService.selectPostAll();
+ return success(posts);
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysProfileController.java b/src/main/java/com/muyu/system/controller/SysProfileController.java
new file mode 100644
index 0000000..ae49255
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysProfileController.java
@@ -0,0 +1,134 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.core.utils.file.FileTypeUtils;
+import com.muyu.common.core.utils.file.MimeTypeUtils;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.service.TokenService;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.common.system.remote.RemoteFileService;
+import com.muyu.common.system.domain.SysFile;
+import com.muyu.common.system.domain.SysUser;
+import com.muyu.common.system.domain.LoginUser;
+import com.muyu.system.domain.resp.ProfileResp;
+import com.muyu.system.service.SysUserService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
+
+import java.util.Arrays;
+
+/**
+ * 个人信息 业务处理
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/user/profile")
+public class SysProfileController extends BaseController {
+ @Autowired
+ private SysUserService userService;
+
+ @Autowired
+ private TokenService tokenService;
+
+ @Autowired
+ private RemoteFileService remoteFileService;
+
+ /**
+ * 个人信息
+ */
+ @GetMapping
+ public Result profile () {
+ String username = SecurityUtils.getUsername();
+ SysUser user = userService.selectUserByUserName(username);
+ return Result.success(
+ ProfileResp.builder()
+ .roleGroup( userService.selectUserRoleGroup(username) )
+ .postGroup( userService.selectUserPostGroup(username) )
+ .sysUser(user)
+ .build()
+ );
+ }
+
+ /**
+ * 修改用户
+ */
+ @Log(title = "个人信息", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result updateProfile (@RequestBody SysUser user) {
+ LoginUser loginUser = SecurityUtils.getLoginUser();
+ SysUser currentUser = loginUser.getSysUser();
+ currentUser.setNickName(user.getNickName());
+ currentUser.setEmail(user.getEmail());
+ currentUser.setPhonenumber(user.getPhonenumber());
+ currentUser.setSex(user.getSex());
+ if (StringUtils.isNotEmpty(user.getPhonenumber()) && !userService.checkPhoneUnique(currentUser)) {
+ return error("修改用户'" + user.getUserName() + "'失败,手机号码已存在");
+ }
+ if (StringUtils.isNotEmpty(user.getEmail()) && !userService.checkEmailUnique(currentUser)) {
+ return error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在");
+ }
+ if (userService.updateUserProfile(currentUser) > 0) {
+ // 更新缓存用户信息
+ tokenService.setLoginUser(loginUser);
+ return success();
+ }
+ return error("修改个人信息异常,请联系管理员");
+ }
+
+ /**
+ * 重置密码
+ */
+ @Log(title = "个人信息", businessType = BusinessType.UPDATE)
+ @PutMapping("/updatePwd")
+ public Result updatePwd (String oldPassword, String newPassword) {
+ String username = SecurityUtils.getUsername();
+ SysUser user = userService.selectUserByUserName(username);
+ String password = user.getPassword();
+ if (!SecurityUtils.matchesPassword(oldPassword, password)) {
+ return error("修改密码失败,旧密码错误");
+ }
+ if (SecurityUtils.matchesPassword(newPassword, password)) {
+ return error("新密码不能与旧密码相同");
+ }
+ if (userService.resetUserPwd(username, SecurityUtils.encryptPassword(newPassword)) > 0) {
+ // 更新缓存用户密码
+ LoginUser loginUser = SecurityUtils.getLoginUser();
+ loginUser.getSysUser().setPassword(SecurityUtils.encryptPassword(newPassword));
+ tokenService.setLoginUser(loginUser);
+ return success();
+ }
+ return error("修改密码异常,请联系管理员");
+ }
+
+ /**
+ * 头像上传
+ */
+ @Log(title = "用户头像", businessType = BusinessType.UPDATE)
+ @PostMapping("/avatar")
+ public Result avatar (@RequestParam("avatarfile") MultipartFile file) {
+ if (!file.isEmpty()) {
+ LoginUser loginUser = SecurityUtils.getLoginUser();
+ String extension = FileTypeUtils.getExtension(file);
+ if (!StringUtils.equalsAnyIgnoreCase(extension, MimeTypeUtils.IMAGE_EXTENSION)) {
+ return error("文件格式不正确,请上传" + Arrays.toString(MimeTypeUtils.IMAGE_EXTENSION) + "格式");
+ }
+ Result fileResult = remoteFileService.upload(file);
+ if (StringUtils.isNull(fileResult) || StringUtils.isNull(fileResult.getData())) {
+ return error("文件服务异常,请联系管理员");
+ }
+ String url = fileResult.getData().getUrl();
+ if (userService.updateUserAvatar(loginUser.getUsername(), url)) {
+ // 更新缓存用户头像
+ loginUser.getSysUser().setAvatar(url);
+ tokenService.setLoginUser(loginUser);
+ return Result.success(url);
+ }
+ }
+ return error("上传图片异常,请联系管理员");
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysRoleController.java b/src/main/java/com/muyu/system/controller/SysRoleController.java
new file mode 100644
index 0000000..f8b05ad
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysRoleController.java
@@ -0,0 +1,215 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.utils.poi.ExcelUtil;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.common.system.domain.SysDept;
+import com.muyu.common.system.domain.SysRole;
+import com.muyu.common.system.domain.SysUser;
+import com.muyu.system.domain.SysUserRole;
+import com.muyu.system.domain.resp.DeptTreeResp;
+import com.muyu.system.service.SysDeptService;
+import com.muyu.system.service.SysRoleService;
+import com.muyu.system.service.SysUserService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import jakarta.servlet.http.HttpServletResponse;
+import java.util.List;
+
+/**
+ * 角色信息
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/role")
+public class SysRoleController extends BaseController {
+ @Autowired
+ private SysRoleService roleService;
+
+ @Autowired
+ private SysUserService userService;
+
+ @Autowired
+ private SysDeptService deptService;
+
+ @RequiresPermissions("system:role:list")
+ @GetMapping("/list")
+ public Result> list (SysRole role) {
+ startPage();
+ List list = roleService.selectRoleList(role);
+ return getDataTable(list);
+ }
+
+ @Log(title = "角色管理", businessType = BusinessType.EXPORT)
+ @RequiresPermissions("system:role:export")
+ @PostMapping("/export")
+ public void export (HttpServletResponse response, SysRole role) {
+ List list = roleService.selectRoleList(role);
+ ExcelUtil util = new ExcelUtil(SysRole.class);
+ util.exportExcel(response, list, "角色数据");
+ }
+
+ /**
+ * 根据角色编号获取详细信息
+ */
+ @RequiresPermissions("system:role:query")
+ @GetMapping(value = "/{roleId}")
+ public Result getInfo (@PathVariable("roleId") Long roleId) {
+ roleService.checkRoleDataScope(roleId);
+ return success(roleService.selectRoleById(roleId));
+ }
+
+ /**
+ * 新增角色
+ */
+ @RequiresPermissions("system:role:add")
+ @Log(title = "角色管理", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysRole role) {
+ if (!roleService.checkRoleNameUnique(role)) {
+ return error("新增角色'" + role.getRoleName() + "'失败,角色名称已存在");
+ } else if (!roleService.checkRoleKeyUnique(role)) {
+ return error("新增角色'" + role.getRoleName() + "'失败,角色权限已存在");
+ }
+ role.setCreateBy(SecurityUtils.getUsername());
+ return toAjax(roleService.insertRole(role));
+
+ }
+
+ /**
+ * 修改保存角色
+ */
+ @RequiresPermissions("system:role:edit")
+ @Log(title = "角色管理", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysRole role) {
+ roleService.checkRoleAllowed(role);
+ roleService.checkRoleDataScope(role.getRoleId());
+ if (!roleService.checkRoleNameUnique(role)) {
+ return error("修改角色'" + role.getRoleName() + "'失败,角色名称已存在");
+ } else if (!roleService.checkRoleKeyUnique(role)) {
+ return error("修改角色'" + role.getRoleName() + "'失败,角色权限已存在");
+ }
+ role.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(roleService.updateRole(role));
+ }
+
+ /**
+ * 修改保存数据权限
+ */
+ @RequiresPermissions("system:role:edit")
+ @Log(title = "角色管理", businessType = BusinessType.UPDATE)
+ @PutMapping("/dataScope")
+ public Result dataScope (@RequestBody SysRole role) {
+ roleService.checkRoleAllowed(role);
+ roleService.checkRoleDataScope(role.getRoleId());
+ return toAjax(roleService.authDataScope(role));
+ }
+
+ /**
+ * 状态修改
+ */
+ @RequiresPermissions("system:role:edit")
+ @Log(title = "角色管理", businessType = BusinessType.UPDATE)
+ @PutMapping("/changeStatus")
+ public Result changeStatus (@RequestBody SysRole role) {
+ roleService.checkRoleAllowed(role);
+ roleService.checkRoleDataScope(role.getRoleId());
+ role.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(roleService.updateRoleStatus(role));
+ }
+
+ /**
+ * 删除角色
+ */
+ @RequiresPermissions("system:role:remove")
+ @Log(title = "角色管理", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{roleIds}")
+ public Result remove (@PathVariable("roleIds") Long[] roleIds) {
+ return toAjax(roleService.deleteRoleByIds(roleIds));
+ }
+
+ /**
+ * 获取角色选择框列表
+ */
+ @RequiresPermissions("system:role:query")
+ @GetMapping("/optionselect")
+ public Result optionselect () {
+ return success(roleService.selectRoleAll());
+ }
+
+ /**
+ * 查询已分配用户角色列表
+ */
+ @RequiresPermissions("system:role:list")
+ @GetMapping("/authUser/allocatedList")
+ public Result> allocatedList (SysUser user) {
+ startPage();
+ List list = userService.selectAllocatedList(user);
+ return getDataTable(list);
+ }
+
+ /**
+ * 查询未分配用户角色列表
+ */
+ @RequiresPermissions("system:role:list")
+ @GetMapping("/authUser/unallocatedList")
+ public Result> unallocatedList (SysUser user) {
+ startPage();
+ List list = userService.selectUnallocatedList(user);
+ return getDataTable(list);
+ }
+
+ /**
+ * 取消授权用户
+ */
+ @RequiresPermissions("system:role:edit")
+ @Log(title = "角色管理", businessType = BusinessType.GRANT)
+ @PutMapping("/authUser/cancel")
+ public Result cancelAuthUser (@RequestBody SysUserRole userRole) {
+ return toAjax(roleService.deleteAuthUser(userRole));
+ }
+
+ /**
+ * 批量取消授权用户
+ */
+ @RequiresPermissions("system:role:edit")
+ @Log(title = "角色管理", businessType = BusinessType.GRANT)
+ @PutMapping("/authUser/cancelAll")
+ public Result cancelAuthUserAll (Long roleId, Long[] userIds) {
+ return toAjax(roleService.deleteAuthUsers(roleId, userIds));
+ }
+
+ /**
+ * 批量选择用户授权
+ */
+ @RequiresPermissions("system:role:edit")
+ @Log(title = "角色管理", businessType = BusinessType.GRANT)
+ @PutMapping("/authUser/selectAll")
+ public Result selectAuthUserAll (Long roleId, Long[] userIds) {
+ roleService.checkRoleDataScope(roleId);
+ return toAjax(roleService.insertAuthUsers(roleId, userIds));
+ }
+
+ /**
+ * 获取对应角色部门树列表
+ */
+ @RequiresPermissions("system:role:query")
+ @GetMapping(value = "/deptTree/{roleId}")
+ public Result deptTree (@PathVariable("roleId") Long roleId) {
+ return Result.success(
+ DeptTreeResp.builder()
+ .depts(deptService.selectDeptTreeList(new SysDept()))
+ .checkedKeys(deptService.selectDeptListByRoleId(roleId))
+ .build()
+ );
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysUserController.java b/src/main/java/com/muyu/system/controller/SysUserController.java
new file mode 100644
index 0000000..b17d8f0
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysUserController.java
@@ -0,0 +1,317 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.constant.CacheConstants;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.core.utils.poi.ExcelUtil;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.redis.service.RedisService;
+import com.muyu.common.security.annotation.InnerAuth;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.common.system.domain.SysDept;
+import com.muyu.common.system.domain.SysRole;
+import com.muyu.common.system.domain.SysUser;
+import com.muyu.common.system.domain.LoginUser;
+import com.muyu.system.domain.resp.AuthRoleResp;
+import com.muyu.system.domain.resp.UserDetailInfoResp;
+import com.muyu.system.domain.resp.UserInfoResp;
+import com.muyu.system.service.*;
+import org.apache.commons.lang3.ArrayUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
+
+import jakarta.servlet.http.HttpServletResponse;
+import java.io.IOException;
+import java.util.List;
+import java.util.Set;
+import java.util.stream.Collectors;
+
+/**
+ * 用户信息
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/user")
+public class SysUserController extends BaseController {
+ @Autowired
+ private SysUserService userService;
+
+ @Autowired
+ private SysRoleService roleService;
+
+ @Autowired
+ private SysDeptService deptService;
+
+ @Autowired
+ private SysPostService postService;
+
+ @Autowired
+ private SysPermissionService permissionService;
+
+ @Autowired
+ private SysConfigService configService;
+
+ @Autowired
+ private RedisService redisService;
+
+ /**
+ * 获取用户列表
+ */
+ @RequiresPermissions("system:user:list")
+ @GetMapping("/list")
+ public Result> list (SysUser user) {
+ startPage();
+ List list = userService.selectUserList(user);
+ return getDataTable(list);
+ }
+
+ @Log(title = "用户管理", businessType = BusinessType.EXPORT)
+ @RequiresPermissions("system:user:export")
+ @PostMapping("/export")
+ public void export (HttpServletResponse response, SysUser user) {
+ List list = userService.selectUserList(user);
+ ExcelUtil util = new ExcelUtil(SysUser.class);
+ util.exportExcel(response, list, "用户数据");
+ }
+
+ @Log(title = "用户管理", businessType = BusinessType.IMPORT)
+ @RequiresPermissions("system:user:import")
+ @PostMapping("/importData")
+ public Result importData (MultipartFile file, boolean updateSupport) throws Exception {
+ ExcelUtil util = new ExcelUtil(SysUser.class);
+ List userList = util.importExcel(file.getInputStream());
+ String operName = SecurityUtils.getUsername();
+ String message = userService.importUser(userList, updateSupport, operName);
+ return success(message);
+ }
+
+ @PostMapping("/importTemplate")
+ public void importTemplate (HttpServletResponse response) throws IOException {
+ ExcelUtil util = new ExcelUtil(SysUser.class);
+ util.importTemplateExcel(response, "用户数据");
+ }
+
+ /**
+ * 获取当前用户信息
+ */
+ @InnerAuth
+ @GetMapping("/info/{username}")
+ public Result info (@PathVariable("username") String username) {
+ SysUser sysUser = userService.selectUserByUserName(username);
+ if (StringUtils.isNull(sysUser)) {
+ return Result.error("用户名或密码错误");
+ }
+ // 角色集合
+ Set roles = permissionService.getRolePermission(sysUser);
+ // 权限集合
+ Set permissions = permissionService.getMenuPermission(sysUser);
+ LoginUser sysUserVo = new LoginUser();
+ sysUserVo.setSysUser(sysUser);
+ sysUserVo.setRoles(roles);
+ sysUserVo.setPermissions(permissions);
+ return Result.success(sysUserVo);
+ }
+
+ /**
+ * 注册用户信息
+ */
+ @InnerAuth
+ @PostMapping("/register")
+ public Result register (@RequestBody SysUser sysUser) {
+ String username = sysUser.getUserName();
+ if (!("true".equals(configService.selectConfigByKey("sys.account.registerUser")))) {
+ return Result.error("当前系统没有开启注册功能!");
+ }
+ if (!userService.checkUserNameUnique(sysUser)) {
+ return Result.error("保存用户'" + username + "'失败,注册账号已存在");
+ }
+ return Result.success(userService.registerUser(sysUser));
+ }
+
+ /**
+ * 获取用户信息
+ *
+ * @return 用户信息
+ */
+ @GetMapping("getInfo")
+ public Result getInfo () {
+ SysUser user = userService.selectUserById(SecurityUtils.getUserId());
+ // 角色集合
+ Set roles = permissionService.getRolePermission(user);
+ // 权限集合
+ Set permissions = permissionService.getMenuPermission(user);
+
+ return Result.success(
+ UserInfoResp.builder()
+ .user(user)
+ .roles(roles)
+ .permissions(permissions)
+ .build()
+ );
+ }
+
+ /**
+ * 根据用户编号获取详细信息
+ */
+ @RequiresPermissions("system:user:query")
+ @GetMapping(value = {"/", "/{userId}"})
+ public Result getInfo (@PathVariable(value = "userId", required = false) Long userId) {
+ userService.checkUserDataScope(userId);
+ UserDetailInfoResp.UserDetailInfoRespBuilder, ?> builder = UserDetailInfoResp.builder();
+ List roles = roleService.selectRoleAll();
+ builder.roles(
+ SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList())
+ )
+ .posts( postService.selectPostAll() );
+ if (StringUtils.isNotNull(userId)) {
+ SysUser sysUser = userService.selectUserById(userId);
+ builder.sysUser(sysUser)
+ .postIds(postService.selectPostListByUserId(userId))
+ .roleIds(sysUser.getRoles().stream().map(SysRole::getRoleId).collect(Collectors.toList()))
+ .build();
+ }
+ return Result.success(builder.build());
+ }
+
+ /**
+ * 新增用户
+ */
+ @RequiresPermissions("system:user:add")
+ @Log(title = "用户管理", businessType = BusinessType.INSERT)
+ @PostMapping
+ public Result add (@Validated @RequestBody SysUser user) {
+ if (!userService.checkUserNameUnique(user)) {
+ return error("新增用户'" + user.getUserName() + "'失败,登录账号已存在");
+ } else if (StringUtils.isNotEmpty(user.getPhonenumber()) && !userService.checkPhoneUnique(user)) {
+ return error("新增用户'" + user.getUserName() + "'失败,手机号码已存在");
+ } else if (StringUtils.isNotEmpty(user.getEmail()) && !userService.checkEmailUnique(user)) {
+ return error("新增用户'" + user.getUserName() + "'失败,邮箱账号已存在");
+ }
+ user.setCreateBy(SecurityUtils.getUsername());
+ user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
+ // 查询有效的公告ID
+ List noticeIds = userService.selNoticeIds();
+ return toAjax(userService.insertUser(user,noticeIds));
+ }
+
+ /**
+ * 修改用户
+ */
+ @RequiresPermissions("system:user:edit")
+ @Log(title = "用户管理", businessType = BusinessType.UPDATE)
+ @PutMapping
+ public Result edit (@Validated @RequestBody SysUser user) {
+ userService.checkUserAllowed(user);
+ userService.checkUserDataScope(user.getUserId());
+ if (!userService.checkUserNameUnique(user)) {
+ return error("修改用户'" + user.getUserName() + "'失败,登录账号已存在");
+ } else if (StringUtils.isNotEmpty(user.getPhonenumber()) && !userService.checkPhoneUnique(user)) {
+ return error("修改用户'" + user.getUserName() + "'失败,手机号码已存在");
+ } else if (StringUtils.isNotEmpty(user.getEmail()) && !userService.checkEmailUnique(user)) {
+ return error("修改用户'" + user.getUserName() + "'失败,邮箱账号已存在");
+ }
+ user.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(userService.updateUser(user));
+ }
+
+ /**
+ * 删除用户
+ */
+ @RequiresPermissions("system:user:remove")
+ @Log(title = "用户管理", businessType = BusinessType.DELETE)
+ @DeleteMapping("/{userIds}")
+ public Result remove (@PathVariable("userIds") Long[] userIds) {
+ if (ArrayUtils.contains(userIds, SecurityUtils.getUserId())) {
+ return error("当前用户不能删除");
+ }
+ return toAjax(userService.deleteUserByIds(userIds));
+ }
+
+ /**
+ * 重置密码
+ */
+ @RequiresPermissions("system:user:edit")
+ @Log(title = "用户管理", businessType = BusinessType.UPDATE)
+ @PutMapping("/resetPwd")
+ public Result resetPwd (@RequestBody SysUser user) {
+ userService.checkUserAllowed(user);
+ userService.checkUserDataScope(user.getUserId());
+ user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
+ user.setUpdateBy(SecurityUtils.getUsername());
+ // 查询所有登录记录key
+ for (String key : redisService.keys(CacheConstants.LOGIN_TOKEN_KEY + "*")) {
+ // 获取所有登录信息
+ LoginUser cacheObject = redisService.getCacheObject(key);
+ // 删除所有修改密码用户登录信息
+ if (user.getUserId().equals(cacheObject.getUserid())){
+ redisService.deleteObject(key);
+ }
+ }
+ return toAjax(userService.resetPwd(user));
+ }
+
+ /**
+ * 状态修改
+ */
+ @RequiresPermissions("system:user:edit")
+ @Log(title = "用户管理", businessType = BusinessType.UPDATE)
+ @PutMapping("/changeStatus")
+ public Result changeStatus (@RequestBody SysUser user) {
+ userService.checkUserAllowed(user);
+ userService.checkUserDataScope(user.getUserId());
+ user.setUpdateBy(SecurityUtils.getUsername());
+ return toAjax(userService.updateUserStatus(user));
+ }
+
+ /**
+ * 根据用户编号获取授权角色
+ */
+ @RequiresPermissions("system:user:query")
+ @GetMapping("/authRole/{userId}")
+ public Result authRole (@PathVariable("userId") Long userId) {
+ SysUser user = userService.selectUserById(userId);
+ List roles = roleService.selectRolesByUserId(userId);
+ return Result.success(
+ AuthRoleResp.builder()
+ .roles(SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()))
+ .user(user)
+ .build()
+ );
+ }
+
+ /**
+ * 用户授权角色
+ */
+ @RequiresPermissions("system:user:edit")
+ @Log(title = "用户管理", businessType = BusinessType.GRANT)
+ @PutMapping("/authRole")
+ public Result insertAuthRole (Long userId, Long[] roleIds) {
+ userService.checkUserDataScope(userId);
+ userService.insertUserAuth(userId, roleIds);
+ return success();
+ }
+
+ /**
+ * 获取部门树列表
+ */
+ @RequiresPermissions("system:user:list")
+ @GetMapping("/deptTree")
+ public Result deptTree (SysDept dept) {
+ return success(deptService.selectDeptTreeList(dept));
+ }
+
+ /**
+ * 获取用户列表
+ */
+ @GetMapping("/selUserAll")
+ public Result selUserAll(){
+ return success(userService.selectUserAll());
+ }
+}
diff --git a/src/main/java/com/muyu/system/controller/SysUserOnlineController.java b/src/main/java/com/muyu/system/controller/SysUserOnlineController.java
new file mode 100644
index 0000000..5b78721
--- /dev/null
+++ b/src/main/java/com/muyu/system/controller/SysUserOnlineController.java
@@ -0,0 +1,69 @@
+package com.muyu.system.controller;
+
+import com.muyu.common.core.constant.CacheConstants;
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.core.web.controller.BaseController;
+import com.muyu.common.core.domain.Result;
+import com.muyu.common.core.web.page.TableDataInfo;
+import com.muyu.common.log.annotation.Log;
+import com.muyu.common.log.enums.BusinessType;
+import com.muyu.common.redis.service.RedisService;
+import com.muyu.common.security.annotation.RequiresPermissions;
+import com.muyu.common.system.domain.LoginUser;
+import com.muyu.system.domain.SysUserOnline;
+import com.muyu.system.service.SysUserOnlineService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.List;
+
+/**
+ * 在线用户监控
+ *
+ * @author muyu
+ */
+@RestController
+@RequestMapping("/online")
+public class SysUserOnlineController extends BaseController {
+ @Autowired
+ private SysUserOnlineService userOnlineService;
+
+ @Autowired
+ private RedisService redisService;
+
+ @RequiresPermissions("monitor:online:list")
+ @GetMapping("/list")
+ public Result> list (String ipaddr, String userName) {
+ Collection keys = redisService.keys(CacheConstants.LOGIN_TOKEN_KEY + "*");
+ List userOnlineList = new ArrayList();
+ for (String key : keys) {
+ LoginUser user = redisService.getCacheObject(key);
+ if (StringUtils.isNotEmpty(ipaddr) && StringUtils.isNotEmpty(userName)) {
+ userOnlineList.add(userOnlineService.selectOnlineByInfo(ipaddr, userName, user));
+ } else if (StringUtils.isNotEmpty(ipaddr)) {
+ userOnlineList.add(userOnlineService.selectOnlineByIpaddr(ipaddr, user));
+ } else if (StringUtils.isNotEmpty(userName)) {
+ userOnlineList.add(userOnlineService.selectOnlineByUserName(userName, user));
+ } else {
+ userOnlineList.add(userOnlineService.loginUserToUserOnline(user));
+ }
+ }
+ Collections.reverse(userOnlineList);
+ userOnlineList.removeAll(Collections.singleton(null));
+ return getDataTable(userOnlineList);
+ }
+
+ /**
+ * 强退用户
+ */
+ @RequiresPermissions("monitor:online:forceLogout")
+ @Log(title = "在线用户", businessType = BusinessType.FORCE)
+ @DeleteMapping("/{tokenId}")
+ public Result forceLogout (@PathVariable("tokenId") String tokenId) {
+ redisService.deleteObject(CacheConstants.LOGIN_TOKEN_KEY + tokenId);
+ return success();
+ }
+}
diff --git a/src/main/java/com/muyu/system/domain/SysConfig.java b/src/main/java/com/muyu/system/domain/SysConfig.java
new file mode 100644
index 0000000..6f7e8bf
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysConfig.java
@@ -0,0 +1,81 @@
+package com.muyu.system.domain;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.muyu.common.core.annotation.Excel;
+import com.muyu.common.core.annotation.Excel.ColumnType;
+import com.muyu.common.core.web.domain.BaseEntity;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.Size;
+
+/**
+ * 参数配置表 sys_config
+ *
+ * @author muyu
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+@EqualsAndHashCode(callSuper = true)
+@TableName("sys_config")
+public class SysConfig extends BaseEntity {
+ private static final long serialVersionUID = 1L;
+
+ /**
+ * 参数主键
+ */
+ @Excel(name = "参数主键", cellType = ColumnType.NUMERIC)
+ @TableId( type = IdType.AUTO)
+ private Long configId;
+
+ /**
+ * 参数名称
+ */
+ @Excel(name = "参数名称")
+ private String configName;
+
+ /**
+ * 参数键名
+ */
+ @Excel(name = "参数键名")
+ private String configKey;
+
+ /**
+ * 参数键值
+ */
+ @Excel(name = "参数键值")
+ private String configValue;
+
+ /**
+ * 系统内置(Y是 N否)
+ */
+ @Excel(name = "系统内置", readConverterExp = "Y=是,N=否")
+ private String configType;
+
+ @NotBlank(message = "参数名称不能为空")
+ @Size(min = 0, max = 100, message = "参数名称不能超过100个字符")
+ public String getConfigName () {
+ return configName;
+ }
+
+ @NotBlank(message = "参数键名长度不能为空")
+ @Size(min = 0, max = 100, message = "参数键名长度不能超过100个字符")
+ public String getConfigKey () {
+ return configKey;
+ }
+
+ @NotBlank(message = "参数键值不能为空")
+ @Size(min = 0, max = 500, message = "参数键值长度不能超过500个字符")
+ public String getConfigValue () {
+ return configValue;
+ }
+
+}
diff --git a/src/main/java/com/muyu/system/domain/SysMenu.java b/src/main/java/com/muyu/system/domain/SysMenu.java
new file mode 100644
index 0000000..e4ad4e4
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysMenu.java
@@ -0,0 +1,138 @@
+package com.muyu.system.domain;
+
+import com.muyu.common.core.web.domain.BaseEntity;
+import lombok.*;
+import lombok.experimental.SuperBuilder;
+
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.NotNull;
+import jakarta.validation.constraints.Size;
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * 菜单权限表 sys_menu
+ *
+ * @author muyu
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+@EqualsAndHashCode(callSuper = true)
+public class SysMenu extends BaseEntity {
+ private static final long serialVersionUID = 1L;
+
+ /**
+ * 菜单ID
+ */
+ private Long menuId;
+
+ /**
+ * 菜单名称
+ */
+ private String menuName;
+
+ /**
+ * 父菜单名称
+ */
+ private String parentName;
+
+ /**
+ * 父菜单ID
+ */
+ private Long parentId;
+
+ /**
+ * 显示顺序
+ */
+ private Integer orderNum;
+
+ /**
+ * 路由地址
+ */
+ private String path;
+
+ /**
+ * 组件路径
+ */
+ private String component;
+
+ /**
+ * 路由参数
+ */
+ private String query;
+
+ /**
+ * 是否为外链(0是 1否)
+ */
+ private String isFrame;
+
+ /**
+ * 是否缓存(0缓存 1不缓存)
+ */
+ private String isCache;
+
+ /**
+ * 类型(M目录 C菜单 F按钮)
+ */
+ private String menuType;
+
+ /**
+ * 显示状态(0显示 1隐藏)
+ */
+ private String visible;
+
+ /**
+ * 菜单状态(0正常 1停用)
+ */
+ private String status;
+
+ /**
+ * 权限字符串
+ */
+ private String perms;
+
+ /**
+ * 菜单图标
+ */
+ private String icon;
+
+ /**
+ * 子菜单
+ */
+ @Builder.Default
+ private List children = new ArrayList();
+
+ @NotBlank(message = "菜单名称不能为空")
+ @Size(min = 0, max = 50, message = "菜单名称长度不能超过50个字符")
+ public String getMenuName () {
+ return menuName;
+ }
+
+ @NotNull(message = "显示顺序不能为空")
+ public Integer getOrderNum () {
+ return orderNum;
+ }
+
+ @Size(min = 0, max = 200, message = "路由地址不能超过200个字符")
+ public String getPath () {
+ return path;
+ }
+
+ @Size(min = 0, max = 200, message = "组件路径不能超过255个字符")
+ public String getComponent () {
+ return component;
+ }
+
+ @NotBlank(message = "菜单类型不能为空")
+ public String getMenuType () {
+ return menuType;
+ }
+
+ @Size(min = 0, max = 100, message = "权限标识长度不能超过100个字符")
+ public String getPerms () {
+ return perms;
+ }
+
+}
diff --git a/src/main/java/com/muyu/system/domain/SysNotice.java b/src/main/java/com/muyu/system/domain/SysNotice.java
new file mode 100644
index 0000000..1658e40
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysNotice.java
@@ -0,0 +1,72 @@
+package com.muyu.system.domain;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.muyu.common.core.web.domain.BaseEntity;
+import com.muyu.common.core.xss.Xss;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.Size;
+
+import java.util.Date;
+import java.util.List;
+
+/**
+ * 通知公告表 sys_notice
+ *
+ * @author muyu
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+@EqualsAndHashCode(callSuper = true)
+public class SysNotice extends BaseEntity {
+ private static final long serialVersionUID = 1L;
+
+ /**
+ * 公告ID
+ */
+ private Long noticeId;
+
+ /**
+ * 公告标题
+ */
+ private String noticeTitle;
+
+ /**
+ * 公告类型(1通知 2公告)
+ */
+ private Integer noticeType;
+
+ /**
+ * 公告内容
+ */
+ private String noticeContent;
+
+ /**
+ * 公告状态(0正常 1关闭)
+ */
+ private String status;
+
+ @Xss(message = "公告标题不能包含脚本字符")
+ @NotBlank(message = "公告标题不能为空")
+ @Size(min = 0, max = 50, message = "公告标题不能超过50个字符")
+ public String getNoticeTitle () {
+ return noticeTitle;
+ }
+
+ private List> deptIds;
+
+ private List userIds;
+
+ @JsonFormat(pattern = "yyyy/MM/dd")
+ private Date startData;
+
+ @JsonFormat(pattern = "yyyy/MM/dd")
+ private Date endData;
+ }
diff --git a/src/main/java/com/muyu/system/domain/SysNoticeUser.java b/src/main/java/com/muyu/system/domain/SysNoticeUser.java
new file mode 100644
index 0000000..7b70853
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysNoticeUser.java
@@ -0,0 +1,29 @@
+package com.muyu.system.domain;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.ToString;
+
+/**
+ * @Author:胡杨
+ * @name:SysNoticeUser
+ * @Date:2024/7/20 上午11:32
+ * @Description: com.muyu.system.domain
+ */
+
+@Data
+@ToString
+@NoArgsConstructor
+@AllArgsConstructor
+public class SysNoticeUser {
+
+ /** 用户ID*/
+ private String userId;
+
+ /** 消息ID*/
+ private String noticeId;
+
+ /** 阅读状态 0.未阅读 1.已阅读*/
+ private String sta;
+}
diff --git a/src/main/java/com/muyu/system/domain/SysPost.java b/src/main/java/com/muyu/system/domain/SysPost.java
new file mode 100644
index 0000000..326987c
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysPost.java
@@ -0,0 +1,78 @@
+package com.muyu.system.domain;
+
+import com.muyu.common.core.annotation.Excel;
+import com.muyu.common.core.annotation.Excel.ColumnType;
+import com.muyu.common.core.web.domain.BaseEntity;
+import lombok.*;
+import lombok.experimental.SuperBuilder;
+
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.NotNull;
+import jakarta.validation.constraints.Size;
+
+/**
+ * 岗位表 sys_post
+ *
+ * @author muyu
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+@EqualsAndHashCode(callSuper = true)
+public class SysPost extends BaseEntity {
+ private static final long serialVersionUID = 1L;
+
+ /**
+ * 岗位序号
+ */
+ @Excel(name = "岗位序号", cellType = ColumnType.NUMERIC)
+ private Long postId;
+
+ /**
+ * 岗位编码
+ */
+ @Excel(name = "岗位编码")
+ private String postCode;
+
+ /**
+ * 岗位名称
+ */
+ @Excel(name = "岗位名称")
+ private String postName;
+
+ /**
+ * 岗位排序
+ */
+ @Excel(name = "岗位排序")
+ private Integer postSort;
+
+ /**
+ * 状态(0正常 1停用)
+ */
+ @Excel(name = "状态", readConverterExp = "0=正常,1=停用")
+ private String status;
+
+ /**
+ * 用户是否存在此岗位标识 默认不存在
+ */
+ @Builder.Default
+ private boolean flag = false;
+
+ @NotBlank(message = "岗位编码不能为空")
+ @Size(min = 0, max = 64, message = "岗位编码长度不能超过64个字符")
+ public String getPostCode () {
+ return postCode;
+ }
+
+ @NotBlank(message = "岗位名称不能为空")
+ @Size(min = 0, max = 50, message = "岗位名称长度不能超过50个字符")
+ public String getPostName () {
+ return postName;
+ }
+
+ @NotNull(message = "显示顺序不能为空")
+ public Integer getPostSort () {
+ return postSort;
+ }
+}
diff --git a/src/main/java/com/muyu/system/domain/SysRoleDept.java b/src/main/java/com/muyu/system/domain/SysRoleDept.java
new file mode 100644
index 0000000..ef9f13c
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysRoleDept.java
@@ -0,0 +1,27 @@
+package com.muyu.system.domain;
+
+import lombok.AllArgsConstructor;
+import lombok.Builder;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+/**
+ * 角色和部门关联 sys_role_dept
+ *
+ * @author muyu
+ */
+@Data
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class SysRoleDept {
+ /**
+ * 角色ID
+ */
+ private Long roleId;
+
+ /**
+ * 部门ID
+ */
+ private Long deptId;
+}
diff --git a/src/main/java/com/muyu/system/domain/SysRoleMenu.java b/src/main/java/com/muyu/system/domain/SysRoleMenu.java
new file mode 100644
index 0000000..fe4074b
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysRoleMenu.java
@@ -0,0 +1,28 @@
+package com.muyu.system.domain;
+
+
+import lombok.AllArgsConstructor;
+import lombok.Builder;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+/**
+ * 角色和菜单关联 sys_role_menu
+ *
+ * @author muyu
+ */
+@Data
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class SysRoleMenu {
+ /**
+ * 角色ID
+ */
+ private Long roleId;
+
+ /**
+ * 菜单ID
+ */
+ private Long menuId;
+}
diff --git a/src/main/java/com/muyu/system/domain/SysUserOnline.java b/src/main/java/com/muyu/system/domain/SysUserOnline.java
new file mode 100644
index 0000000..23d1979
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysUserOnline.java
@@ -0,0 +1,52 @@
+package com.muyu.system.domain;
+
+import lombok.AllArgsConstructor;
+import lombok.Builder;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+/**
+ * 当前在线会话
+ *
+ * @author muyu
+ */
+@Data
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class SysUserOnline {
+ /**
+ * 会话编号
+ */
+ private String tokenId;
+
+ /**
+ * 用户名称
+ */
+ private String userName;
+
+ /**
+ * 登录IP地址
+ */
+ private String ipaddr;
+
+ /**
+ * 登录地址
+ */
+ private String loginLocation;
+
+ /**
+ * 浏览器类型
+ */
+ private String browser;
+
+ /**
+ * 操作系统
+ */
+ private String os;
+
+ /**
+ * 登录时间
+ */
+ private Long loginTime;
+}
diff --git a/src/main/java/com/muyu/system/domain/SysUserPost.java b/src/main/java/com/muyu/system/domain/SysUserPost.java
new file mode 100644
index 0000000..229dc70
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysUserPost.java
@@ -0,0 +1,28 @@
+package com.muyu.system.domain;
+
+import lombok.AllArgsConstructor;
+import lombok.Builder;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+/**
+ * 用户和岗位关联 sys_user_post
+ *
+ * @author muyu
+ */
+@Data
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class SysUserPost {
+ /**
+ * 用户ID
+ */
+ private Long userId;
+
+ /**
+ * 岗位ID
+ */
+ private Long postId;
+
+}
diff --git a/src/main/java/com/muyu/system/domain/SysUserRole.java b/src/main/java/com/muyu/system/domain/SysUserRole.java
new file mode 100644
index 0000000..ee9c945
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/SysUserRole.java
@@ -0,0 +1,27 @@
+package com.muyu.system.domain;
+
+import lombok.AllArgsConstructor;
+import lombok.Builder;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+/**
+ * 用户和角色关联 sys_user_role
+ *
+ * @author muyu
+ */
+@Data
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class SysUserRole {
+ /**
+ * 用户ID
+ */
+ private Long userId;
+
+ /**
+ * 角色ID
+ */
+ private Long roleId;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/AuthRoleResp.java b/src/main/java/com/muyu/system/domain/resp/AuthRoleResp.java
new file mode 100644
index 0000000..69294b6
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/AuthRoleResp.java
@@ -0,0 +1,33 @@
+package com.muyu.system.domain.resp;
+
+
+import com.muyu.common.system.domain.SysRole;
+import com.muyu.common.system.domain.SysUser;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import java.util.List;
+
+/**
+ * @author DongZl
+ * @description: 授权角色返回结果集
+ * @Date 2023-6-19 下午 02:50
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+public class AuthRoleResp {
+
+ /**
+ * 用户信息
+ */
+ private SysUser user;
+
+ /**
+ * 角色集合
+ */
+ private List roles;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/DeptTreeResp.java b/src/main/java/com/muyu/system/domain/resp/DeptTreeResp.java
new file mode 100644
index 0000000..cd72807
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/DeptTreeResp.java
@@ -0,0 +1,32 @@
+package com.muyu.system.domain.resp;
+
+
+import com.muyu.system.domain.vo.TreeSelect;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import java.util.List;
+
+/**
+ * @author DongZl
+ * @description: 部门树返回结果集
+ * @Date 2023-6-19 下午 02:52
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+public class DeptTreeResp {
+
+ /**
+ * 授权的ID
+ */
+ private List checkedKeys;
+
+ /**
+ * 部门树
+ */
+ private List depts;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/DeptUserTreeResp.java b/src/main/java/com/muyu/system/domain/resp/DeptUserTreeResp.java
new file mode 100644
index 0000000..fa1f2f3
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/DeptUserTreeResp.java
@@ -0,0 +1,28 @@
+package com.muyu.system.domain.resp;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.ToString;
+
+/**
+ * @Author:胡杨
+ * @name:DeptUserTreeResp
+ * @Date:2024/7/21 上午11:27
+ * @Description: com.muyu.system.domain.resp
+ */
+
+@Data
+@ToString
+@NoArgsConstructor
+@AllArgsConstructor
+public class DeptUserTreeResp {
+ // id
+ private Long id;
+ // 节点名称
+ private String label;
+ // 子节点集合
+ private DeptUserTreeResp[] children;
+ // 节点类型 1.部门 2.用户
+ private Integer treeStatus;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/NoticeResp.java b/src/main/java/com/muyu/system/domain/resp/NoticeResp.java
new file mode 100644
index 0000000..48fba35
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/NoticeResp.java
@@ -0,0 +1,70 @@
+package com.muyu.system.domain.resp;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.muyu.common.core.web.domain.BaseEntity;
+import com.muyu.common.core.xss.Xss;
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.Size;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import java.util.Date;
+
+/**
+ * 通知公告表 sys_notice
+ *
+ * @author muyu
+ */
+@Data
+@NoArgsConstructor
+@AllArgsConstructor
+public class NoticeResp{
+ /**
+ * 公告ID
+ */
+ private Long noticeId;
+
+ /**
+ * 公告标题
+ */
+ private String noticeTitle;
+
+ /**
+ * 公告类型(1通知 2公告)
+ */
+ private String noticeType;
+
+ /**
+ * 公告内容
+ */
+ private String noticeContent;
+
+ /**
+ * 公告状态(0正常 1关闭)
+ */
+ private String status;
+
+ /**
+ * 所有通知数量
+ */
+ private Integer noticeNum;
+
+ /**
+ * 已读通知数量
+ */
+ private Integer readNum;
+
+ /**
+ * 未读通知数量
+ */
+ private Integer unreadNum;
+
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ private Date startData;
+
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ private Date endData;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/NoticeUserResp.java b/src/main/java/com/muyu/system/domain/resp/NoticeUserResp.java
new file mode 100644
index 0000000..2d46c68
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/NoticeUserResp.java
@@ -0,0 +1,64 @@
+package com.muyu.system.domain.resp;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.ToString;
+
+import java.util.Date;
+
+/**
+ * @Author:胡杨
+ * @name:SysNoticeUser
+ * @Date:2024/7/20 上午11:32
+ * @Description: com.muyu.system.domain
+ */
+
+@Data
+@ToString
+@NoArgsConstructor
+@AllArgsConstructor
+public class NoticeUserResp {
+
+ /** 用户ID*/
+ private Long userId;
+
+ /** 阅读状态 0.未阅读 1.已阅读*/
+ private Integer sta;
+
+ /**
+ * 公告ID
+ */
+ private Long noticeId;
+
+ /**
+ * 公告标题
+ */
+ private String noticeTitle;
+
+ /**
+ * 公告类型(1通知 2公告)
+ */
+ private String noticeType;
+
+ /**
+ * 公告内容
+ */
+ private String noticeContent;
+ /**
+ * 创建人
+ */
+ private String createBy;
+ /**
+ * 创建时间
+ */
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ private Date createTime;
+
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ private Date startData;
+
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ private Date endData;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/ProfileResp.java b/src/main/java/com/muyu/system/domain/resp/ProfileResp.java
new file mode 100644
index 0000000..21d9808
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/ProfileResp.java
@@ -0,0 +1,34 @@
+package com.muyu.system.domain.resp;
+
+import com.muyu.common.system.domain.SysUser;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+/**
+ * @author DongZl
+ * @description: 个人信息模型对象
+ * @Date 2023-6-19 下午 02:05
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+public class ProfileResp {
+
+ /**
+ * 系统用户
+ */
+ private SysUser sysUser;
+
+ /**
+ * 用户权限组
+ */
+ private String roleGroup;
+
+ /**
+ * 用户岗位组
+ */
+ private String postGroup;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/RoleMenuTreeResp.java b/src/main/java/com/muyu/system/domain/resp/RoleMenuTreeResp.java
new file mode 100644
index 0000000..696763e
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/RoleMenuTreeResp.java
@@ -0,0 +1,31 @@
+package com.muyu.system.domain.resp;
+
+import com.muyu.system.domain.vo.TreeSelect;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import java.util.List;
+
+/**
+ * @author DongZl
+ * @description: 角色返回菜单树
+ * @Date 2023-6-19 下午 02:40
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+public class RoleMenuTreeResp {
+
+ /**
+ * 拥有的菜单权限
+ */
+ private List checkedKeys;
+
+ /**
+ * 系统所有的菜单
+ */
+ private List menus;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/UserDetailInfoResp.java b/src/main/java/com/muyu/system/domain/resp/UserDetailInfoResp.java
new file mode 100644
index 0000000..4c61832
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/UserDetailInfoResp.java
@@ -0,0 +1,47 @@
+package com.muyu.system.domain.resp;
+
+import com.muyu.common.system.domain.SysRole;
+import com.muyu.common.system.domain.SysUser;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import java.util.List;
+
+/**
+ * @author DongZl
+ * @description: 用户详细信息
+ * @Date 2023-6-19 下午 02:45
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+public class UserDetailInfoResp {
+
+ /**
+ * 角色权限集合
+ */
+ private List roles;
+
+ /**
+ * 岗位集合
+ */
+ private List posts;
+
+ /**
+ * 用户信息
+ */
+ private SysUser sysUser;
+
+ /**
+ * 用户又有的职位ID
+ */
+ private List postIds;
+
+ /**
+ * 用户拥有的角色ID
+ */
+ private List roleIds;
+}
diff --git a/src/main/java/com/muyu/system/domain/resp/UserInfoResp.java b/src/main/java/com/muyu/system/domain/resp/UserInfoResp.java
new file mode 100644
index 0000000..d15a760
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/resp/UserInfoResp.java
@@ -0,0 +1,36 @@
+package com.muyu.system.domain.resp;
+
+import com.muyu.common.system.domain.SysUser;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import java.util.Set;
+
+/**
+ * @author DongZl
+ * @description: 用户信息结果集
+ * @Date 2023-6-19 下午 02:42
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+public class UserInfoResp {
+
+ /**
+ * 用户
+ */
+ private SysUser user;
+
+ /**
+ * 角色集合
+ */
+ private Set roles;
+
+ /**
+ * 权限集合
+ */
+ private Set permissions;
+}
diff --git a/src/main/java/com/muyu/system/domain/vo/MetaVo.java b/src/main/java/com/muyu/system/domain/vo/MetaVo.java
new file mode 100644
index 0000000..c7d5f25
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/vo/MetaVo.java
@@ -0,0 +1,54 @@
+package com.muyu.system.domain.vo;
+
+import lombok.AllArgsConstructor;
+import lombok.Builder;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+/**
+ * 路由显示信息
+ *
+ * @author muyu
+ */
+@Data
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class MetaVo {
+ /**
+ * 设置该路由在侧边栏和面包屑中展示的名字
+ */
+ private String title;
+
+ /**
+ * 设置该路由的图标,对应路径src/assets/icons/svg
+ */
+ private String icon;
+
+ /**
+ * 设置为true,则不会被 缓存
+ */
+ private boolean noCache;
+
+ /**
+ * 内链地址(http(s)://开头)
+ */
+ private String link;
+
+ 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;
+ }
+}
diff --git a/src/main/java/com/muyu/system/domain/vo/RouterVo.java b/src/main/java/com/muyu/system/domain/vo/RouterVo.java
new file mode 100644
index 0000000..6ea8d3f
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/vo/RouterVo.java
@@ -0,0 +1,62 @@
+package com.muyu.system.domain.vo;
+
+import com.fasterxml.jackson.annotation.JsonInclude;
+import lombok.Data;
+import lombok.Setter;
+
+import java.util.List;
+
+/**
+ * 路由配置信息
+ *
+ * @author muyu
+ */
+@Data
+@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 children;
+
+}
diff --git a/src/main/java/com/muyu/system/domain/vo/TreeSelect.java b/src/main/java/com/muyu/system/domain/vo/TreeSelect.java
new file mode 100644
index 0000000..d1ef75f
--- /dev/null
+++ b/src/main/java/com/muyu/system/domain/vo/TreeSelect.java
@@ -0,0 +1,56 @@
+package com.muyu.system.domain.vo;
+
+import com.fasterxml.jackson.annotation.JsonInclude;
+import com.muyu.common.system.domain.SysDept;
+import com.muyu.system.domain.SysMenu;
+import lombok.AllArgsConstructor;
+import lombok.Builder;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+import java.io.Serializable;
+import java.util.List;
+import java.util.stream.Collectors;
+
+/**
+ * Treeselect树结构实体类
+ *
+ * @author muyu
+ */
+@Data
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class TreeSelect implements Serializable {
+ private static final long serialVersionUID = 1L;
+
+ /**
+ * 节点ID
+ */
+ private Long id;
+
+ /**
+ * 节点名称
+ */
+ private String label;
+
+ /**
+ * 子节点
+ */
+ @JsonInclude(JsonInclude.Include.NON_EMPTY)
+ private List children;
+
+
+ public TreeSelect (SysDept dept) {
+ this.id = dept.getDeptId();
+ this.label = dept.getDeptName();
+ this.children = dept.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList());
+ }
+
+ public TreeSelect (SysMenu menu) {
+ this.id = menu.getMenuId();
+ this.label = menu.getMenuName();
+ this.children = menu.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList());
+ }
+
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysConfigMapper.java b/src/main/java/com/muyu/system/mapper/SysConfigMapper.java
new file mode 100644
index 0000000..ced239a
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysConfigMapper.java
@@ -0,0 +1,12 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.system.domain.SysConfig;
+
+/**
+ * @author DongZl
+ * @description: 配置mybatis配置
+ * @Date 2023-11-13 上午 10:05
+ */
+public interface SysConfigMapper extends BaseMapper {
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysDeptMapper.java b/src/main/java/com/muyu/system/mapper/SysDeptMapper.java
new file mode 100644
index 0000000..5ef9ab4
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysDeptMapper.java
@@ -0,0 +1,131 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.common.system.domain.SysDept;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 部门管理 数据层
+ *
+ * @author muyu
+ */
+public interface SysDeptMapper extends BaseMapper {
+ /**
+ * 查询部门管理数据
+ *
+ * @param dept 部门信息
+ *
+ * @return 部门信息集合
+ */
+ public List selectDeptList (SysDept dept);
+
+ /**
+ * 根据角色ID查询部门树信息
+ *
+ * @param roleId 角色ID
+ * @param deptCheckStrictly 部门树选择项是否关联显示
+ *
+ * @return 选中部门列表
+ */
+ public List 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 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 depts);
+
+ /**
+ * 删除部门管理信息
+ *
+ * @param deptId 部门ID
+ *
+ * @return 结果
+ */
+ public int deleteDeptById (Long deptId);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysDictDataMapper.java b/src/main/java/com/muyu/system/mapper/SysDictDataMapper.java
new file mode 100644
index 0000000..1e87a7e
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysDictDataMapper.java
@@ -0,0 +1,106 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.common.system.domain.SysDictData;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 字典表 数据层
+ *
+ * @author muyu
+ */
+public interface SysDictDataMapper extends BaseMapper {
+ /**
+ * 根据条件分页查询字典数据
+ *
+ * @param dictData 字典数据信息
+ *
+ * @return 字典数据集合信息
+ */
+ public List selectDictDataList (SysDictData dictData);
+
+ /**
+ * 根据字典类型查询字典数据
+ *
+ * @param dictType 字典类型
+ *
+ * @return 字典数据集合信息
+ */
+ public List selectDictDataByType (String dictType);
+
+ /**
+ * 根据字典类型和字典键值查询字典数据信息
+ *
+ * @param dictType 字典类型
+ * @param dictValue 字典键值
+ *
+ * @return 字典标签
+ */
+ public String selectDictLabel (@Param("dictType") String dictType, @Param("dictValue") String dictValue);
+
+ /**
+ * 根据字典数据ID查询信息
+ *
+ * @param dictCode 字典数据ID
+ *
+ * @return 字典数据
+ */
+ public SysDictData selectDictDataById (Long dictCode);
+
+ /**
+ * 查询字典数据
+ *
+ * @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);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysDictTypeMapper.java b/src/main/java/com/muyu/system/mapper/SysDictTypeMapper.java
new file mode 100644
index 0000000..0a4ffe6
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysDictTypeMapper.java
@@ -0,0 +1,92 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.common.system.domain.SysDictType;
+
+import java.util.List;
+
+/**
+ * 字典表 数据层
+ *
+ * @author muyu
+ */
+public interface SysDictTypeMapper extends BaseMapper {
+ /**
+ * 根据条件分页查询字典类型
+ *
+ * @param dictType 字典类型信息
+ *
+ * @return 字典类型集合信息
+ */
+ public List selectDictTypeList (SysDictType dictType);
+
+ /**
+ * 根据所有字典类型
+ *
+ * @return 字典类型集合信息
+ */
+ public List selectDictTypeAll ();
+
+ /**
+ * 根据字典类型ID查询信息
+ *
+ * @param dictId 字典类型ID
+ *
+ * @return 字典类型
+ */
+ public SysDictType selectDictTypeById (Long dictId);
+
+ /**
+ * 根据字典类型查询信息
+ *
+ * @param dictType 字典类型
+ *
+ * @return 字典类型
+ */
+ public SysDictType selectDictTypeByType (String dictType);
+
+ /**
+ * 通过字典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 字典类型
+ *
+ * @return 结果
+ */
+ public SysDictType checkDictTypeUnique (String dictType);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysLogininforMapper.java b/src/main/java/com/muyu/system/mapper/SysLogininforMapper.java
new file mode 100644
index 0000000..0f1f86a
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysLogininforMapper.java
@@ -0,0 +1,45 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.common.system.domain.SysLogininfor;
+
+import java.util.List;
+
+/**
+ * 系统访问日志情况信息 数据层
+ *
+ * @author muyu
+ */
+public interface SysLogininforMapper extends BaseMapper {
+ /**
+ * 新增系统登录日志
+ *
+ * @param logininfor 访问日志对象
+ */
+ public int insertLogininfor (SysLogininfor logininfor);
+
+ /**
+ * 查询系统登录日志集合
+ *
+ * @param logininfor 访问日志对象
+ *
+ * @return 登录记录集合
+ */
+ public List selectLogininforList (SysLogininfor logininfor);
+
+ /**
+ * 批量删除系统登录日志
+ *
+ * @param infoIds 需要删除的登录日志ID
+ *
+ * @return 结果
+ */
+ public int deleteLogininforByIds (Long[] infoIds);
+
+ /**
+ * 清空系统登录日志
+ *
+ * @return 结果
+ */
+ public int cleanLogininfor ();
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysMenuMapper.java b/src/main/java/com/muyu/system/mapper/SysMenuMapper.java
new file mode 100644
index 0000000..feea6ab
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysMenuMapper.java
@@ -0,0 +1,140 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.system.domain.SysMenu;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 菜单表 数据层
+ *
+ * @author muyu
+ */
+public interface SysMenuMapper extends BaseMapper {
+ /**
+ * 查询系统菜单列表
+ *
+ * @param menu 菜单信息
+ *
+ * @return 菜单列表
+ */
+ public List selectMenuList (SysMenu menu);
+
+ /**
+ * 根据用户所有权限
+ *
+ * @return 权限列表
+ */
+ public List selectMenuPerms ();
+
+ /**
+ * 根据用户查询系统菜单列表
+ *
+ * @param menu 菜单信息
+ *
+ * @return 菜单列表
+ */
+ public List selectMenuListByUserId (SysMenu menu);
+
+ /**
+ * 根据角色ID查询权限
+ *
+ * @param roleId 角色ID
+ *
+ * @return 权限列表
+ */
+ public List selectMenuPermsByRoleId (Long roleId);
+
+ /**
+ * 根据用户ID查询权限
+ *
+ * @param userId 用户ID
+ *
+ * @return 权限列表
+ */
+ public List selectMenuPermsByUserId (Long userId);
+
+ /**
+ * 根据用户ID查询菜单
+ *
+ * @return 菜单列表
+ */
+ public List selectMenuTreeAll ();
+
+ /**
+ * 根据用户ID查询菜单
+ *
+ * @param userId 用户ID
+ *
+ * @return 菜单列表
+ */
+ public List selectMenuTreeByUserId (Long userId);
+
+ /**
+ * 根据角色ID查询菜单树信息
+ *
+ * @param roleId 角色ID
+ * @param menuCheckStrictly 菜单树选择项是否关联显示
+ *
+ * @return 选中菜单列表
+ */
+ public List selectMenuListByRoleId (@Param("roleId") Long roleId, @Param("menuCheckStrictly") boolean menuCheckStrictly);
+
+ /**
+ * 根据菜单ID查询信息
+ *
+ * @param menuId 菜单ID
+ *
+ * @return 菜单信息
+ */
+ public SysMenu selectMenuById (Long menuId);
+
+ /**
+ * 是否存在菜单子节点
+ *
+ * @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);
+
+ List selectMenuListByParentIds(@Param("menuList") List menuList);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysNoticeMapper.java b/src/main/java/com/muyu/system/mapper/SysNoticeMapper.java
new file mode 100644
index 0000000..db7b36b
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysNoticeMapper.java
@@ -0,0 +1,91 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.system.domain.SysNotice;
+import com.muyu.system.domain.resp.NoticeResp;
+import com.muyu.system.domain.resp.NoticeUserResp;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * 通知公告表 数据层
+ *
+ * @author muyu
+ */
+public interface SysNoticeMapper extends BaseMapper {
+ /**
+ * 查询公告信息
+ *
+ * @param noticeId 公告ID
+ *
+ * @return 公告信息
+ */
+ public SysNotice selectNoticeById (Long noticeId);
+
+ /**
+ * 查询公告列表
+ *
+ * @param notice 公告信息
+ *
+ * @return 公告集合
+ */
+ public List 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);
+
+ /**
+ * 根据用户ID查询用户的通知阅读状态
+ * @param userId
+ * @return
+ */
+ List selNoticeByUserId(@Param("userId") Long userId);
+
+ int updateNoticeSta(@Param("noticeId") Long noticeId, @Param("userId") Long userId);
+
+ NoticeUserResp findNoticeByNoticeIdAndUserId(@Param("noticeId") Long noticeId, @Param("userId") Long userId);
+
+ NoticeResp findNoticeByNoticeId(@Param("noticeId") Long noticeId);
+
+ List selUserByDeptIds(@Param("deptIds") ArrayList deptIds);
+
+ List findUserIdsAll();
+
+ Integer insertNoticeUser(@Param("noticeId") Long noticeId, @Param("userIds") int[] userIds);
+
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysOperLogMapper.java b/src/main/java/com/muyu/system/mapper/SysOperLogMapper.java
new file mode 100644
index 0000000..6ea1bcd
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysOperLogMapper.java
@@ -0,0 +1,52 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.common.system.domain.SysOperLog;
+
+import java.util.List;
+
+/**
+ * 操作日志 数据层
+ *
+ * @author muyu
+ */
+public interface SysOperLogMapper extends BaseMapper {
+ /**
+ * 新增操作日志
+ *
+ * @param operLog 操作日志对象
+ */
+ public int insertOperlog (SysOperLog operLog);
+
+ /**
+ * 查询系统操作日志集合
+ *
+ * @param operLog 操作日志对象
+ *
+ * @return 操作日志集合
+ */
+ public List selectOperLogList (SysOperLog operLog);
+
+ /**
+ * 批量删除系统操作日志
+ *
+ * @param operIds 需要删除的操作日志ID
+ *
+ * @return 结果
+ */
+ public int deleteOperLogByIds (Long[] operIds);
+
+ /**
+ * 查询操作日志详细
+ *
+ * @param operId 操作ID
+ *
+ * @return 操作日志对象
+ */
+ public SysOperLog selectOperLogById (Long operId);
+
+ /**
+ * 清空操作日志
+ */
+ public void cleanOperLog ();
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysPostMapper.java b/src/main/java/com/muyu/system/mapper/SysPostMapper.java
new file mode 100644
index 0000000..4bfd66d
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysPostMapper.java
@@ -0,0 +1,110 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.system.domain.SysPost;
+
+import java.util.List;
+
+/**
+ * 岗位信息 数据层
+ *
+ * @author muyu
+ */
+public interface SysPostMapper extends BaseMapper {
+ /**
+ * 查询岗位数据集合
+ *
+ * @param post 岗位信息
+ *
+ * @return 岗位数据集合
+ */
+ public List selectPostList (SysPost post);
+
+ /**
+ * 查询所有岗位
+ *
+ * @return 岗位列表
+ */
+ public List selectPostAll ();
+
+ /**
+ * 通过岗位ID查询岗位信息
+ *
+ * @param postId 岗位ID
+ *
+ * @return 角色对象信息
+ */
+ public SysPost selectPostById (Long postId);
+
+ /**
+ * 根据用户ID获取岗位选择框列表
+ *
+ * @param userId 用户ID
+ *
+ * @return 选中岗位ID列表
+ */
+ public List selectPostListByUserId (Long userId);
+
+ /**
+ * 查询用户所属岗位组
+ *
+ * @param userName 用户名
+ *
+ * @return 结果
+ */
+ public List 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);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysRoleDeptMapper.java b/src/main/java/com/muyu/system/mapper/SysRoleDeptMapper.java
new file mode 100644
index 0000000..0e6dd4d
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysRoleDeptMapper.java
@@ -0,0 +1,50 @@
+package com.muyu.system.mapper;
+
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.system.domain.SysRoleDept;
+
+import java.util.List;
+
+/**
+ * 角色与部门关联表 数据层
+ *
+ * @author muyu
+ */
+public interface SysRoleDeptMapper extends BaseMapper {
+ /**
+ * 通过角色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 roleDeptList);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysRoleMapper.java b/src/main/java/com/muyu/system/mapper/SysRoleMapper.java
new file mode 100644
index 0000000..2b01dc3
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysRoleMapper.java
@@ -0,0 +1,119 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.common.system.domain.SysRole;
+
+import java.util.List;
+
+/**
+ * 角色表 数据层
+ *
+ * @author muyu
+ */
+public interface SysRoleMapper extends BaseMapper {
+ /**
+ * 根据条件分页查询角色数据
+ *
+ * @param role 角色信息
+ *
+ * @return 角色数据集合信息
+ */
+ public List selectRoleList (SysRole role);
+
+ /**
+ * 根据用户ID查询角色
+ *
+ * @param userId 用户ID
+ *
+ * @return 角色列表
+ */
+ public List selectRolePermissionByUserId (Long userId);
+
+ /**
+ * 查询所有角色
+ *
+ * @return 角色列表
+ */
+ public List selectRoleAll ();
+
+ /**
+ * 根据用户ID获取角色选择框列表
+ *
+ * @param userId 用户ID
+ *
+ * @return 选中角色ID列表
+ */
+ public List selectRoleListByUserId (Long userId);
+
+ /**
+ * 通过角色ID查询角色
+ *
+ * @param roleId 角色ID
+ *
+ * @return 角色对象信息
+ */
+ public SysRole selectRoleById (Long roleId);
+
+ /**
+ * 根据用户ID查询角色
+ *
+ * @param userName 用户名
+ *
+ * @return 角色列表
+ */
+ public List 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);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysRoleMenuMapper.java b/src/main/java/com/muyu/system/mapper/SysRoleMenuMapper.java
new file mode 100644
index 0000000..664ce26
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysRoleMenuMapper.java
@@ -0,0 +1,50 @@
+package com.muyu.system.mapper;
+
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.system.domain.SysRoleMenu;
+
+import java.util.List;
+
+/**
+ * 角色与菜单关联表 数据层
+ *
+ * @author muyu
+ */
+public interface SysRoleMenuMapper extends BaseMapper {
+ /**
+ * 查询菜单使用数量
+ *
+ * @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 roleMenuList);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysUserMapper.java b/src/main/java/com/muyu/system/mapper/SysUserMapper.java
new file mode 100644
index 0000000..2c899a9
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysUserMapper.java
@@ -0,0 +1,148 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.common.system.domain.SysUser;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 用户表 数据层
+ *
+ * @author muyu
+ */
+public interface SysUserMapper extends BaseMapper {
+ /**
+ * 根据条件分页查询用户列表
+ *
+ * @param sysUser 用户信息
+ *
+ * @return 用户信息集合信息
+ */
+ public List selectUserList (SysUser sysUser);
+
+ /**
+ * 根据条件分页查询已配用户角色列表
+ *
+ * @param user 用户信息
+ *
+ * @return 用户信息集合信息
+ */
+ public List selectAllocatedList (SysUser user);
+
+ /**
+ * 根据条件分页查询未分配用户角色列表
+ *
+ * @param user 用户信息
+ *
+ * @return 用户信息集合信息
+ */
+ public List 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);
+
+ List selectUserAll();
+
+ List selNoticeIds();
+
+ void insertUserNotice(@Param("userId") Long userId, @Param("noticeIds") List noticeIds);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysUserPostMapper.java b/src/main/java/com/muyu/system/mapper/SysUserPostMapper.java
new file mode 100644
index 0000000..8d09a47
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysUserPostMapper.java
@@ -0,0 +1,49 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.system.domain.SysUserPost;
+
+import java.util.List;
+
+/**
+ * 用户与岗位关联表 数据层
+ *
+ * @author muyu
+ */
+public interface SysUserPostMapper extends BaseMapper {
+ /**
+ * 通过用户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 userPostList);
+}
diff --git a/src/main/java/com/muyu/system/mapper/SysUserRoleMapper.java b/src/main/java/com/muyu/system/mapper/SysUserRoleMapper.java
new file mode 100644
index 0000000..512adb8
--- /dev/null
+++ b/src/main/java/com/muyu/system/mapper/SysUserRoleMapper.java
@@ -0,0 +1,69 @@
+package com.muyu.system.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.muyu.system.domain.SysUserRole;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 用户与角色关联表 数据层
+ *
+ * @author muyu
+ */
+public interface SysUserRoleMapper extends BaseMapper {
+ /**
+ * 通过用户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 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);
+}
diff --git a/src/main/java/com/muyu/system/service/SysConfigService.java b/src/main/java/com/muyu/system/service/SysConfigService.java
new file mode 100644
index 0000000..f23d67e
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysConfigService.java
@@ -0,0 +1,44 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.system.domain.SysConfig;
+
+import java.util.List;
+
+/**
+ * @author DongZl
+ * @description: 配置plus业务层
+ * @Date 2023-11-13 上午 10:06
+ */
+public interface SysConfigService extends IService {
+ List pageQuery (SysConfig config);
+
+ /**
+ * 通过Key进行查询值
+ * @param configKey
+ * @return
+ */
+ String selectConfigByKey (String configKey);
+
+ /**
+ * 检测参数是否唯一
+ * @param config
+ * @return
+ */
+ boolean checkConfigKeyUnique (SysConfig config);
+
+ /**
+ * 刷新缓存
+ */
+ void resetConfigCache ();
+
+ /**
+ * 清空参数缓存数据
+ */
+ public void clearConfigCache ();
+
+ /**
+ * 加载参数缓存数据
+ */
+ public void loadingConfigCache ();
+}
diff --git a/src/main/java/com/muyu/system/service/SysDeptService.java b/src/main/java/com/muyu/system/service/SysDeptService.java
new file mode 100644
index 0000000..e868204
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysDeptService.java
@@ -0,0 +1,140 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.common.system.domain.SysDept;
+import com.muyu.system.domain.resp.DeptUserTreeResp;
+import com.muyu.system.domain.vo.TreeSelect;
+
+import java.util.List;
+
+/**
+ * 部门管理 服务层
+ *
+ * @author muyu
+ */
+public interface SysDeptService extends IService {
+ /**
+ * 查询部门管理数据
+ *
+ * @param dept 部门信息
+ *
+ * @return 部门信息集合
+ */
+ public List selectDeptList (SysDept dept);
+
+ /**
+ * 查询部门树结构信息
+ *
+ * @param dept 部门信息
+ *
+ * @return 部门树信息集合
+ */
+ public List selectDeptTreeList (SysDept dept);
+
+ /**
+ * 构建前端所需要树结构
+ *
+ * @param depts 部门列表
+ *
+ * @return 树结构列表
+ */
+ public List buildDeptTree (List depts);
+
+ /**
+ * 构建前端所需要下拉树结构
+ *
+ * @param depts 部门列表
+ *
+ * @return 下拉树结构列表
+ */
+ public List buildDeptTreeSelect (List depts);
+
+ /**
+ * 根据角色ID查询部门树信息
+ *
+ * @param roleId 角色ID
+ *
+ * @return 选中部门列表
+ */
+ public List 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 boolean 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);
+
+}
diff --git a/src/main/java/com/muyu/system/service/SysDictDataService.java b/src/main/java/com/muyu/system/service/SysDictDataService.java
new file mode 100644
index 0000000..47aae4b
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysDictDataService.java
@@ -0,0 +1,66 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.common.system.domain.SysDictData;
+
+import java.util.List;
+
+/**
+ * 字典 业务层
+ *
+ * @author muyu
+ */
+public interface SysDictDataService extends IService {
+ /**
+ * 根据条件分页查询字典数据
+ *
+ * @param dictData 字典数据信息
+ *
+ * @return 字典数据集合信息
+ */
+ public List 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);
+}
diff --git a/src/main/java/com/muyu/system/service/SysDictTypeService.java b/src/main/java/com/muyu/system/service/SysDictTypeService.java
new file mode 100644
index 0000000..1b3212d
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysDictTypeService.java
@@ -0,0 +1,106 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.common.system.domain.SysDictData;
+import com.muyu.common.system.domain.SysDictType;
+
+import java.util.List;
+
+/**
+ * 字典 业务层
+ *
+ * @author muyu
+ */
+public interface SysDictTypeService extends IService {
+ /**
+ * 根据条件分页查询字典类型
+ *
+ * @param dictType 字典类型信息
+ *
+ * @return 字典类型集合信息
+ */
+ public List selectDictTypeList (SysDictType dictType);
+
+ /**
+ * 根据所有字典类型
+ *
+ * @return 字典类型集合信息
+ */
+ public List selectDictTypeAll ();
+
+ /**
+ * 根据字典类型查询字典数据
+ *
+ * @param dictType 字典类型
+ *
+ * @return 字典数据集合信息
+ */
+ public List 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 boolean checkDictTypeUnique (SysDictType dictType);
+}
diff --git a/src/main/java/com/muyu/system/service/SysLogininforService.java b/src/main/java/com/muyu/system/service/SysLogininforService.java
new file mode 100644
index 0000000..bb3031e
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysLogininforService.java
@@ -0,0 +1,43 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.common.system.domain.SysLogininfor;
+
+import java.util.List;
+
+/**
+ * 系统访问日志情况信息 服务层
+ *
+ * @author muyu
+ */
+public interface SysLogininforService extends IService {
+ /**
+ * 新增系统登录日志
+ *
+ * @param logininfor 访问日志对象
+ */
+ public int insertLogininfor (SysLogininfor logininfor);
+
+ /**
+ * 查询系统登录日志集合
+ *
+ * @param logininfor 访问日志对象
+ *
+ * @return 登录记录集合
+ */
+ public List selectLogininforList (SysLogininfor logininfor);
+
+ /**
+ * 批量删除系统登录日志
+ *
+ * @param infoIds 需要删除的登录日志ID
+ *
+ * @return 结果
+ */
+ public int deleteLogininforByIds (Long[] infoIds);
+
+ /**
+ * 清空系统登录日志
+ */
+ public void cleanLogininfor ();
+}
diff --git a/src/main/java/com/muyu/system/service/SysMenuService.java b/src/main/java/com/muyu/system/service/SysMenuService.java
new file mode 100644
index 0000000..29bfb07
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysMenuService.java
@@ -0,0 +1,161 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.system.domain.SysMenu;
+import com.muyu.system.domain.vo.RouterVo;
+import com.muyu.system.domain.vo.TreeSelect;
+
+import java.util.List;
+import java.util.Set;
+
+/**
+ * 菜单 业务层
+ *
+ * @author muyu
+ */
+public interface SysMenuService extends IService {
+ /**
+ * 根据用户查询系统菜单列表
+ *
+ * @param userId 用户ID
+ *
+ * @return 菜单列表
+ */
+ public List selectMenuList (Long userId);
+
+ /**
+ * 根据用户查询系统菜单列表
+ *
+ * @param menu 菜单信息
+ * @param userId 用户ID
+ *
+ * @return 菜单列表
+ */
+ public List selectMenuList (SysMenu menu, Long userId);
+
+ /**
+ * 根据用户ID查询权限
+ *
+ * @param userId 用户ID
+ *
+ * @return 权限列表
+ */
+ public Set selectMenuPermsByUserId (Long userId);
+
+ /**
+ * 根据角色ID查询权限
+ *
+ * @param roleId 角色ID
+ *
+ * @return 权限列表
+ */
+ public Set selectMenuPermsByRoleId (Long roleId);
+
+ /**
+ * 根据用户ID查询菜单树信息
+ *
+ * @param userId 用户ID
+ *
+ * @return 菜单列表
+ */
+ public List selectMenuTreeByUserId (Long userId);
+
+ /**
+ * 根据角色ID查询菜单树信息
+ *
+ * @param roleId 角色ID
+ *
+ * @return 选中菜单列表
+ */
+ public List selectMenuListByRoleId (Long roleId);
+
+ /**
+ * 构建前端路由所需要的菜单
+ *
+ * @param menus 菜单列表
+ *
+ * @return 路由列表
+ */
+ public List buildMenus (List menus);
+
+ /**
+ * 构建前端所需要树结构
+ *
+ * @param menus 菜单列表
+ *
+ * @return 树结构列表
+ */
+ public List buildMenuTree (List menus);
+
+ /**
+ * 构建前端所需要下拉树结构
+ *
+ * @param menus 菜单列表
+ *
+ * @return 下拉树结构列表
+ */
+ public List buildMenuTreeSelect (List 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 boolean checkMenuNameUnique (SysMenu menu);
+}
diff --git a/src/main/java/com/muyu/system/service/SysNoticeService.java b/src/main/java/com/muyu/system/service/SysNoticeService.java
new file mode 100644
index 0000000..2bd2fdf
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysNoticeService.java
@@ -0,0 +1,81 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.system.domain.SysNotice;
+import com.muyu.system.domain.resp.NoticeResp;
+import com.muyu.system.domain.resp.NoticeUserResp;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.List;
+
+/**
+ * 公告 服务层
+ *
+ * @author muyu
+ */
+public interface SysNoticeService extends IService {
+ /**
+ * 查询公告信息
+ *
+ * @param noticeId 公告ID
+ *
+ * @return 公告信息
+ */
+ public SysNotice selectNoticeById (Long noticeId);
+
+ /**
+ * 查询公告列表
+ *
+ * @param notice 公告信息
+ *
+ * @return 公告集合
+ */
+ public List selectNoticeList (SysNotice notice);
+
+ /**
+ * 新增公告
+ *
+ * @param notice 公告信息
+ * @param userIdSet
+ * @return 结果
+ */
+ public int insertNotice (SysNotice notice, HashSet userIdSet);
+
+ /**
+ * 修改公告
+ *
+ * @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);
+
+ List selNoticeByUserId(Long userId);
+
+ NoticeUserResp findNoticeByNoticeIdAndUserId(Long noticeId, int sta, Long userId);
+
+ NoticeResp findNoticeByNoticeId(Long noticeId);
+
+ List selUserByDeptIds(ArrayList deptIds);
+
+ List findUserIdsAll();
+}
diff --git a/src/main/java/com/muyu/system/service/SysOperLogService.java b/src/main/java/com/muyu/system/service/SysOperLogService.java
new file mode 100644
index 0000000..70b63ee
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysOperLogService.java
@@ -0,0 +1,54 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.common.system.domain.SysOperLog;
+
+import java.util.List;
+
+/**
+ * 操作日志 服务层
+ *
+ * @author muyu
+ */
+public interface SysOperLogService extends IService {
+ /**
+ * 新增操作日志
+ *
+ * @param operLog 操作日志对象
+ *
+ * @return 结果
+ */
+ public int insertOperlog (SysOperLog operLog);
+
+ /**
+ * 查询系统操作日志集合
+ *
+ * @param operLog 操作日志对象
+ *
+ * @return 操作日志集合
+ */
+ public List selectOperLogList (SysOperLog operLog);
+
+ /**
+ * 批量删除系统操作日志
+ *
+ * @param operIds 需要删除的操作日志ID
+ *
+ * @return 结果
+ */
+ public int deleteOperLogByIds (Long[] operIds);
+
+ /**
+ * 查询操作日志详细
+ *
+ * @param operId 操作ID
+ *
+ * @return 操作日志对象
+ */
+ public SysOperLog selectOperLogById (Long operId);
+
+ /**
+ * 清空操作日志
+ */
+ public void cleanOperLog ();
+}
diff --git a/src/main/java/com/muyu/system/service/SysPermissionService.java b/src/main/java/com/muyu/system/service/SysPermissionService.java
new file mode 100644
index 0000000..02e9d14
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysPermissionService.java
@@ -0,0 +1,30 @@
+package com.muyu.system.service;
+
+import com.muyu.common.system.domain.SysUser;
+
+import java.util.Set;
+
+/**
+ * 权限信息 服务层
+ *
+ * @author muyu
+ */
+public interface SysPermissionService {
+ /**
+ * 获取角色数据权限
+ *
+ * @param userId 用户Id
+ *
+ * @return 角色权限信息
+ */
+ public Set getRolePermission (SysUser user);
+
+ /**
+ * 获取菜单数据权限
+ *
+ * @param userId 用户Id
+ *
+ * @return 菜单权限信息
+ */
+ public Set getMenuPermission (SysUser user);
+}
diff --git a/src/main/java/com/muyu/system/service/SysPostService.java b/src/main/java/com/muyu/system/service/SysPostService.java
new file mode 100644
index 0000000..fbd8677
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysPostService.java
@@ -0,0 +1,110 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.system.domain.SysPost;
+
+import java.util.List;
+
+/**
+ * 岗位信息 服务层
+ *
+ * @author muyu
+ */
+public interface SysPostService extends IService {
+ /**
+ * 查询岗位信息集合
+ *
+ * @param post 岗位信息
+ *
+ * @return 岗位列表
+ */
+ public List selectPostList (SysPost post);
+
+ /**
+ * 查询所有岗位
+ *
+ * @return 岗位列表
+ */
+ public List selectPostAll ();
+
+ /**
+ * 通过岗位ID查询岗位信息
+ *
+ * @param postId 岗位ID
+ *
+ * @return 角色对象信息
+ */
+ public SysPost selectPostById (Long postId);
+
+ /**
+ * 根据用户ID获取岗位选择框列表
+ *
+ * @param userId 用户ID
+ *
+ * @return 选中岗位ID列表
+ */
+ public List selectPostListByUserId (Long userId);
+
+ /**
+ * 校验岗位名称
+ *
+ * @param post 岗位信息
+ *
+ * @return 结果
+ */
+ public boolean checkPostNameUnique (SysPost post);
+
+ /**
+ * 校验岗位编码
+ *
+ * @param post 岗位信息
+ *
+ * @return 结果
+ */
+ public boolean 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);
+}
diff --git a/src/main/java/com/muyu/system/service/SysRoleService.java b/src/main/java/com/muyu/system/service/SysRoleService.java
new file mode 100644
index 0000000..47009f8
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysRoleService.java
@@ -0,0 +1,191 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.common.system.domain.SysRole;
+import com.muyu.system.domain.SysUserRole;
+
+import java.util.List;
+import java.util.Set;
+
+/**
+ * 角色业务层
+ *
+ * @author muyu
+ */
+public interface SysRoleService extends IService {
+ /**
+ * 根据条件分页查询角色数据
+ *
+ * @param role 角色信息
+ *
+ * @return 角色数据集合信息
+ */
+ public List selectRoleList (SysRole role);
+
+ /**
+ * 根据用户ID查询角色列表
+ *
+ * @param userId 用户ID
+ *
+ * @return 角色列表
+ */
+ public List selectRolesByUserId (Long userId);
+
+ /**
+ * 根据用户ID查询角色权限
+ *
+ * @param userId 用户ID
+ *
+ * @return 权限列表
+ */
+ public Set selectRolePermissionByUserId (Long userId);
+
+ /**
+ * 查询所有角色
+ *
+ * @return 角色列表
+ */
+ public List selectRoleAll ();
+
+ /**
+ * 根据用户ID获取角色选择框列表
+ *
+ * @param userId 用户ID
+ *
+ * @return 选中角色ID列表
+ */
+ public List selectRoleListByUserId (Long userId);
+
+ /**
+ * 通过角色ID查询角色
+ *
+ * @param roleId 角色ID
+ *
+ * @return 角色对象信息
+ */
+ public SysRole selectRoleById (Long roleId);
+
+ /**
+ * 校验角色名称是否唯一
+ *
+ * @param role 角色信息
+ *
+ * @return 结果
+ */
+ public boolean checkRoleNameUnique (SysRole role);
+
+ /**
+ * 校验角色权限是否唯一
+ *
+ * @param role 角色信息
+ *
+ * @return 结果
+ */
+ public boolean 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);
+}
diff --git a/src/main/java/com/muyu/system/service/SysUserOnlineService.java b/src/main/java/com/muyu/system/service/SysUserOnlineService.java
new file mode 100644
index 0000000..531735b
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysUserOnlineService.java
@@ -0,0 +1,52 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.common.system.domain.LoginUser;
+import com.muyu.system.domain.SysUserOnline;
+
+/**
+ * 在线用户 服务层
+ *
+ * @author muyu
+ */
+public interface SysUserOnlineService {
+ /**
+ * 通过登录地址查询信息
+ *
+ * @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);
+}
diff --git a/src/main/java/com/muyu/system/service/SysUserService.java b/src/main/java/com/muyu/system/service/SysUserService.java
new file mode 100644
index 0000000..bdf5354
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/SysUserService.java
@@ -0,0 +1,232 @@
+package com.muyu.system.service;
+
+import com.baomidou.mybatisplus.extension.service.IService;
+import com.muyu.common.system.domain.SysUser;
+
+import java.util.List;
+
+/**
+ * 用户 业务层
+ *
+ * @author muyu
+ */
+public interface SysUserService extends IService {
+ /**
+ * 根据条件分页查询用户列表
+ *
+ * @param user 用户信息
+ *
+ * @return 用户信息集合信息
+ */
+ public List selectUserList (SysUser user);
+
+ /**
+ * 根据条件分页查询已分配用户角色列表
+ *
+ * @param user 用户信息
+ *
+ * @return 用户信息集合信息
+ */
+ public List selectAllocatedList (SysUser user);
+
+ /**
+ * 根据条件分页查询未分配用户角色列表
+ *
+ * @param user 用户信息
+ *
+ * @return 用户信息集合信息
+ */
+ public List 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 boolean checkUserNameUnique (SysUser user);
+
+ /**
+ * 校验手机号码是否唯一
+ *
+ * @param user 用户信息
+ *
+ * @return 结果
+ */
+ public boolean checkPhoneUnique (SysUser user);
+
+ /**
+ * 校验email是否唯一
+ *
+ * @param user 用户信息
+ *
+ * @return 结果
+ */
+ public boolean checkEmailUnique (SysUser user);
+
+ /**
+ * 校验用户是否允许操作
+ *
+ * @param user 用户信息
+ */
+ public void checkUserAllowed (SysUser user);
+
+ /**
+ * 校验用户是否有数据权限
+ *
+ * @param userId 用户id
+ */
+ public void checkUserDataScope (Long userId);
+
+ /**
+ * 新增用户信息
+ *
+ * @param user 用户信息
+ * @param noticeIds
+ * @return 结果
+ */
+ public int insertUser (SysUser user, List noticeIds);
+
+ /**
+ * 注册用户信息
+ *
+ * @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 userList, Boolean isUpdateSupport, String operName);
+
+ List selectUserAll();
+
+ List selNoticeIds();
+}
diff --git a/src/main/java/com/muyu/system/service/impl/SysConfigServiceImpl.java b/src/main/java/com/muyu/system/service/impl/SysConfigServiceImpl.java
new file mode 100644
index 0000000..bc07cc8
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/impl/SysConfigServiceImpl.java
@@ -0,0 +1,114 @@
+package com.muyu.system.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.muyu.common.core.constant.CacheConstants;
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.redis.service.RedisService;
+import com.muyu.system.domain.SysConfig;
+import com.muyu.system.mapper.SysConfigMapper;
+import com.muyu.system.service.SysConfigService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.util.Assert;
+
+import java.util.Collection;
+import java.util.Date;
+import java.util.List;
+import java.util.Objects;
+
+/**
+ * @author DongZl
+ * @description: 配置plus业务实现层
+ * @Date 2023-11-13 上午 10:06
+ */
+@Service
+public class SysConfigServiceImpl extends ServiceImpl
+ implements SysConfigService {
+
+ @Autowired
+ private RedisService redisService;
+
+ @Override
+ public List pageQuery (SysConfig config) {
+ LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
+ if (StringUtils.isNotEmpty(config.getConfigName())){
+ queryWrapper.like(SysConfig::getConfigName, config.getConfigName());
+ }
+ if (StringUtils.isNotEmpty(config.getConfigType())){
+ queryWrapper.like(SysConfig::getConfigType, config.getConfigType());
+ }
+ if (StringUtils.isNotEmpty(config.getConfigKey())){
+ queryWrapper.like(SysConfig::getConfigKey, config.getConfigKey());
+ }
+ Object beginTime = config.getParams().get("beginTime");
+ if (Objects.nonNull(beginTime) && beginTime instanceof Date beginDate){
+ queryWrapper.gt(SysConfig::getCreateTime, beginDate);
+ }
+ Object endTime = config.getParams().get("endTime");
+ if (Objects.nonNull(endTime) && endTime instanceof Date endDate){
+ queryWrapper.lt(SysConfig::getCreateTime, endDate);
+ }
+ return this.list(queryWrapper);
+ }
+
+ /**
+ * 通过Key进行查询值
+ *
+ * @param configKey
+ *
+ * @return
+ */
+ @Override
+ public String selectConfigByKey (String configKey) {
+ LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
+ Assert.notNull(configKey, "key不可为空");
+ queryWrapper.eq(SysConfig::getConfigKey, configKey);
+ SysConfig sysConfig = this.getOne(queryWrapper);
+ return sysConfig.getConfigValue();
+ }
+
+ @Override
+ public boolean checkConfigKeyUnique (SysConfig config) {
+ LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
+ queryWrapper.eq(SysConfig::getConfigKey, config.getConfigKey());
+ return this.count(queryWrapper) > 0;
+ }
+
+ @Override
+ public void resetConfigCache () {
+ this.clearConfigCache();
+ this.loadingConfigCache();
+ }
+
+ /**
+ * 清空参数缓存数据
+ */
+ @Override
+ public void clearConfigCache () {
+ Collection keys = redisService.keys(CacheConstants.SYS_CONFIG_KEY + "*");
+ redisService.deleteObject(keys);
+ }
+
+ /**
+ * 加载参数缓存数据
+ */
+ @Override
+ public void loadingConfigCache () {
+ List configsList = this.list();
+ for (SysConfig config : configsList) {
+ redisService.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue());
+ }
+ }
+
+ /**
+ * 设置cache key
+ *
+ * @param configKey 参数键
+ *
+ * @return 缓存键key
+ */
+ private String getCacheKey (String configKey) {
+ return CacheConstants.SYS_CONFIG_KEY + configKey;
+ }
+}
diff --git a/src/main/java/com/muyu/system/service/impl/SysDeptServiceImpl.java b/src/main/java/com/muyu/system/service/impl/SysDeptServiceImpl.java
new file mode 100644
index 0000000..abb94bd
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/impl/SysDeptServiceImpl.java
@@ -0,0 +1,321 @@
+package com.muyu.system.service.impl;
+
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.muyu.common.core.constant.UserConstants;
+import com.muyu.common.core.exception.ServiceException;
+import com.muyu.common.core.text.Convert;
+import com.muyu.common.core.utils.SpringUtils;
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.datascope.annotation.DataScope;
+import com.muyu.common.security.utils.SecurityUtils;
+import com.muyu.common.system.domain.SysDept;
+import com.muyu.common.system.domain.SysRole;
+import com.muyu.common.system.domain.SysUser;
+import com.muyu.system.domain.resp.DeptUserTreeResp;
+import com.muyu.system.domain.vo.TreeSelect;
+import com.muyu.system.mapper.SysDeptMapper;
+import com.muyu.system.mapper.SysRoleMapper;
+import com.muyu.system.service.SysDeptService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.stream.Collectors;
+
+/**
+ * 部门管理 服务实现
+ *
+ * @author muyu
+ */
+@Service
+public class SysDeptServiceImpl extends ServiceImpl implements SysDeptService {
+ @Autowired
+ private SysDeptMapper deptMapper;
+
+ @Autowired
+ private SysRoleMapper roleMapper;
+
+ /**
+ * 查询部门管理数据
+ *
+ * @param dept 部门信息
+ *
+ * @return 部门信息集合
+ */
+ @Override
+ @DataScope(deptAlias = "d")
+ public List selectDeptList (SysDept dept) {
+ return deptMapper.selectDeptList(dept);
+ }
+
+ /**
+ * 查询部门树结构信息
+ *
+ * @param dept 部门信息
+ *
+ * @return 部门树信息集合
+ */
+ @Override
+ public List selectDeptTreeList (SysDept dept) {
+ List depts = SpringUtils.getAopProxy(this).selectDeptList(dept);
+ return buildDeptTreeSelect(depts);
+ }
+
+ /**
+ * 构建前端所需要树结构
+ *
+ * @param depts 部门列表
+ *
+ * @return 树结构列表
+ */
+ @Override
+ public List buildDeptTree (List depts) {
+ List returnList = new ArrayList();
+ List 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 buildDeptTreeSelect (List depts) {
+ List deptTrees = buildDeptTree(depts);
+ return deptTrees.stream().map(TreeSelect::new).collect(Collectors.toList());
+ }
+
+ /**
+ * 根据角色ID查询部门树信息
+ *
+ * @param roleId 角色ID
+ *
+ * @return 选中部门列表
+ */
+ @Override
+ public List selectDeptListByRoleId (Long roleId) {
+ SysRole role = roleMapper.selectRoleById(roleId);
+ return deptMapper.selectDeptListByRoleId(roleId, role.isDeptCheckStrictly());
+ }
+
+ /**
+ * 根据部门ID查询信息
+ *
+ * @param deptId 部门ID
+ *
+ * @return 部门信息
+ */
+ @Override
+ public SysDept selectDeptById (Long deptId) {
+ return deptMapper.selectDeptById(deptId);
+ }
+
+ /**
+ * 根据ID查询所有子部门(正常状态)
+ *
+ * @param deptId 部门ID
+ *
+ * @return 子部门数
+ */
+ @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 boolean 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 depts = SpringUtils.getAopProxy(this).selectDeptList(dept);
+ if (StringUtils.isEmpty(depts)) {
+ throw new ServiceException("没有权限访问部门数据!");
+ }
+ }
+ }
+
+ /**
+ * 新增保存部门信息
+ *
+ * @param dept 部门信息
+ *
+ * @return 结果
+ */
+ @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 结果
+ */
+ @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 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 结果
+ */
+ @Override
+ public int deleteDeptById (Long deptId) {
+ return deptMapper.deleteDeptById(deptId);
+ }
+
+
+
+ /**
+ * 递归列表
+ */
+ private void recursionFn (List list, SysDept t) {
+ // 得到子节点列表
+ List childList = getChildList(list, t);
+ t.setChildren(childList);
+ for (SysDept tChild : childList) {
+ if (hasChild(list, tChild)) {
+ recursionFn(list, tChild);
+ }
+ }
+ }
+
+ /**
+ * 得到子节点列表
+ */
+ private List getChildList (List list, SysDept t) {
+ List tlist = new ArrayList();
+ Iterator 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 list, SysDept t) {
+ return getChildList(list, t).size() > 0 ? true : false;
+ }
+}
diff --git a/src/main/java/com/muyu/system/service/impl/SysDictDataServiceImpl.java b/src/main/java/com/muyu/system/service/impl/SysDictDataServiceImpl.java
new file mode 100644
index 0000000..777ffbd
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/impl/SysDictDataServiceImpl.java
@@ -0,0 +1,108 @@
+package com.muyu.system.service.impl;
+
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.muyu.common.security.utils.DictUtils;
+import com.muyu.common.system.domain.SysDictData;
+import com.muyu.system.mapper.SysDictDataMapper;
+import com.muyu.system.service.SysDictDataService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.util.List;
+
+/**
+ * 字典 业务层处理
+ *
+ * @author muyu
+ */
+@Service
+public class SysDictDataServiceImpl extends ServiceImpl implements SysDictDataService {
+ @Autowired
+ private SysDictDataMapper dictDataMapper;
+
+ /**
+ * 根据条件分页查询字典数据
+ *
+ * @param dictData 字典数据信息
+ *
+ * @return 字典数据集合信息
+ */
+ @Override
+ public List selectDictDataList (SysDictData dictData) {
+ 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);
+ }
+
+ /**
+ * 批量删除字典数据信息
+ *
+ * @param dictCodes 需要删除的字典数据ID
+ */
+ @Override
+ public void deleteDictDataByIds (Long[] dictCodes) {
+ for (Long dictCode : dictCodes) {
+ SysDictData data = selectDictDataById(dictCode);
+ dictDataMapper.deleteDictDataById(dictCode);
+ List 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 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 dictDatas = dictDataMapper.selectDictDataByType(data.getDictType());
+ DictUtils.setDictCache(data.getDictType(), dictDatas);
+ }
+ return row;
+ }
+}
diff --git a/src/main/java/com/muyu/system/service/impl/SysDictTypeServiceImpl.java b/src/main/java/com/muyu/system/service/impl/SysDictTypeServiceImpl.java
new file mode 100644
index 0000000..4117411
--- /dev/null
+++ b/src/main/java/com/muyu/system/service/impl/SysDictTypeServiceImpl.java
@@ -0,0 +1,210 @@
+package com.muyu.system.service.impl;
+
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.muyu.common.core.constant.UserConstants;
+import com.muyu.common.core.exception.ServiceException;
+import com.muyu.common.core.utils.StringUtils;
+import com.muyu.common.security.utils.DictUtils;
+import com.muyu.common.system.domain.SysDictData;
+import com.muyu.common.system.domain.SysDictType;
+import com.muyu.system.mapper.SysDictDataMapper;
+import com.muyu.system.mapper.SysDictTypeMapper;
+import com.muyu.system.service.SysDictTypeService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import javax.annotation.PostConstruct;
+import java.util.Comparator;
+import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
+
+/**
+ * 字典 业务层处理
+ *
+ * @author muyu
+ */
+@Service
+public class SysDictTypeServiceImpl extends ServiceImpl implements SysDictTypeService {
+ @Autowired
+ private SysDictTypeMapper dictTypeMapper;
+
+ @Autowired
+ private SysDictDataMapper dictDataMapper;
+
+ /**
+ * 项目启动时,初始化字典到缓存
+ */
+ @PostConstruct
+ public void init () {
+ loadingDictCache();
+ }
+
+ /**
+ * 根据条件分页查询字典类型
+ *
+ * @param dictType 字典类型信息
+ *
+ * @return 字典类型集合信息
+ */
+ @Override
+ public List selectDictTypeList (SysDictType dictType) {
+ return dictTypeMapper.selectDictTypeList(dictType);
+ }
+
+ /**
+ * 根据所有字典类型
+ *
+ * @return 字典类型集合信息
+ */
+ @Override
+ public List selectDictTypeAll () {
+ return dictTypeMapper.selectDictTypeAll();
+ }
+
+ /**
+ * 根据字典类型查询字典数据
+ *
+ * @param dictType 字典类型
+ *
+ * @return 字典数据集合信息
+ */
+ @Override
+ public List