From b31091da56446f57d21c41d009ce7b55a70a9789 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期四, 19 六月 2025 11:59:31 +0800
Subject: [PATCH] 优化报警

---
 ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserController.java | 1294 ++++++++++++++++++++++++++--------------------------------
 1 files changed, 575 insertions(+), 719 deletions(-)

diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserController.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserController.java
index 04afe60..d760ee4 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserController.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/SysUserController.java
@@ -3,11 +3,8 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
-import com.ruoyi.admin.api.feignClient.AppUserClient;
-import com.ruoyi.admin.api.feignClient.AppUserShopClient;
-import com.ruoyi.admin.api.model.AppUser;
-import com.ruoyi.admin.api.model.AppUserShop;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.utils.MD5Util;
 import com.ruoyi.common.core.utils.StringUtils;
 import com.ruoyi.common.core.web.controller.BaseController;
 import com.ruoyi.common.core.web.domain.AjaxResult;
@@ -37,7 +34,6 @@
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
-import java.time.LocalDateTime;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -50,721 +46,581 @@
 @RequestMapping("/user")
 @Api(tags = "用户信息")
 public class SysUserController extends BaseController {
-    @Resource
-    private ISysUserService userService;
-
-    @Resource
-    private ISysRoleService roleService;
-
-    @Resource
-    private ISysDeptService deptService;
-
-    @Resource
-    private ISysPostService postService;
-
-    @Resource
-    private ISysPermissionService permissionService;
-
-    @Resource
-    private ISysConfigService configService;
-
-    @Resource
-    private ISysUserRoleService userRoleService;
-
-    @Resource
-    private ISysUserRoleService sysUserRoleService;
-    
-    @Resource
-    private UserShopService userShopService;
-    
-    @Resource
-    private TokenService tokenService;
-    
-    @Autowired
-    private ISysMenuService menuService;
-
-    @Resource
-    private AppUserClient appUserClient;
-
-    @Resource
-    private AppUserShopClient appUserShopClient;
-    
-    
-    
-    
-    
-    /**
-     * 获取用户列表
-     */
-    @GetMapping("/list")
-    @ApiOperation(value = "获取系统用户列表", tags = {"管理后台-账号管理", "门店后台-部门管理"})
-    public AjaxResult list(GetSysUserList getSysUserList) {
-        PageInfo<SysUser> pageInfo = new PageInfo<>(getSysUserList.getPageCurr(), getSysUserList.getPageSize());
-        PageInfo<SysUser> page = userService.getList(pageInfo, getSysUserList);
-        return AjaxResult.success(page);
-    }
-
-    /**
-     * 获取用户选择列表
-     */
-    @PostMapping("/getChangeUserList")
-    @ApiOperation(value = "获取用户选择列表", tags = {"管理后台-获取用户选择列表", "门店后台-部门管理"})
-    public AjaxResult<PageInfo<SysUser>> getChangeUserList(@RequestBody ChangeUserQuery query) {
-        return AjaxResult.success(userService.getChangeUserList(query));
-    }
-
-    /**
-     * 新增用户
-     */
-    @Log(title = "用户管理", businessType = BusinessType.INSERT)
-    @PostMapping("/add")
-    @ApiOperation(value = "添加系统用户", tags = {"管理后台-账号管理", "门店后台-部门管理"})
-    public AjaxResult add(@RequestBody SysUser user) {
-        user.setUserName(user.getPhonenumber());
-        Long userid = tokenService.getLoginUser().getUserid();
-        SysUser sysUser1 = userService.getById(userid);
-        if(!org.springframework.util.StringUtils.hasLength(user.getNickName())){
-            user.setNickName(user.getPhonenumber());
-        }
-        if (StringUtils.isNotEmpty(user.getPhonenumber()) && !userService.checkPhoneUnique(user)) {
-            return error("手机号已开通账号");
-        }
-        if (StringUtils.isNotEmpty(user.getUserName()) && !userService.checkUserNameUnique(user)) {
-            return error("登录账号重复");
-        }
-        //门店员工添加数据,需要判断账号是否存在,共用同一个账号
-        if(2 == sysUser1.getRoleType()){
-            AppUser appUser = appUserClient.getAppUserByPhone1(user.getPhonenumber()).getData();
-            if(null == appUser){
-                return error("请先注册小程序账号");
-            }
-            SysUser one2 = userService.getOne(new LambdaQueryWrapper<SysUser>().eq(SysUser::getUserName, user.getPhonenumber())
-                    .eq(SysUser::getDelFlag, "0").eq(SysUser::getStatus, "0").eq(SysUser::getObjectId, sysUser1.getObjectId())
-                    .eq(SysUser::getRoleType, 2));
-            if(null != one2){
-                return error("登录账号重复");
-            }
-            SysUser one = userService.getOne(new LambdaQueryWrapper<SysUser>().eq(SysUser::getUserName, user.getPhonenumber())
-                    .eq(SysUser::getDelFlag, "0").eq(SysUser::getStatus, "0").eq(SysUser::getRoleType, 2));
-            if(null == one){
-                user.setCreateBy(SecurityUtils.getUsername());
-                user.setPassword(SecurityUtils.encryptPassword(MD5Generator.generateMD5("a123456")));
-
-                user.setRoleType(sysUser1.getRoleType());
-                user.setObjectId(sysUser1.getObjectId());
-                if(null != appUser){
-                    user.setAppUserId(appUser.getId());
-                }
-                userService.insertUser(user);
-                one = user;
-                SysUserRole sysUserRole = new SysUserRole();
-                sysUserRole.setRoleId(user.getRoleId());
-                sysUserRole.setUserId(user.getUserId());
-                userRoleService.insertSysUserRole(sysUserRole);
-
-            }
-            //添加小程序店员关系数据
-            if(null != appUser){
-                List<AppUserShop> data = appUserShopClient.getAppUserShop(appUser.getId()).getData();
-                Optional<AppUserShop> first = data.stream().filter(s -> s.getShopId().equals(sysUser1.getObjectId())).findFirst();
-                if(!first.isPresent()){
-                    AppUserShop appUserShop = new AppUserShop();
-                    appUserShop.setAppUserId(appUser.getId());
-                    appUserShop.setShopId(sysUser1.getObjectId());
-                    appUserShop.setRoleType(2);
-                    appUserShopClient.saveAppUserShop(appUserShop);
-                    appUser.setUserType(2);
-                    appUserClient.editAppUserById(appUser);
-                }
-            }
-
-            //添加门店员工关系数据
-            UserShop one1 = userShopService.getOne(new LambdaQueryWrapper<UserShop>().eq(UserShop::getUserId, one.getUserId()).eq(UserShop::getShopId, sysUser1.getObjectId()));
-            if(null == one1){
-                UserShop userShop = new UserShop();
-                userShop.setUserId(one.getUserId());
-                userShop.setShopId(sysUser1.getObjectId());
-                userShop.setRoleType(2);
-                userShop.setRoleId(user.getRoleId());
-                userShop.setDeptId(user.getDeptId());
-                userShop.setNickName(user.getNickName());
-                userShop.setCreateTime(LocalDateTime.now());
-                userShopService.save(userShop);
-            }
-        }else{
-            user.setCreateBy(SecurityUtils.getUsername());
-            user.setPassword(SecurityUtils.encryptPassword(MD5Generator.generateMD5("a123456")));
-
-            user.setRoleType(sysUser1.getRoleType());
-            userService.insertUser(user);
-            SysUserRole sysUserRole = new SysUserRole();
-            sysUserRole.setRoleId(user.getRoleId());
-            sysUserRole.setUserId(user.getUserId());
-            userRoleService.insertSysUserRole(sysUserRole);
-        }
-        return AjaxResult.success();
-    }
-    
-    
-    @GetMapping("/verifyUserNameRepeat/{username}")
-    @ApiOperation(value = "校验账号是否重复", tags = {"管理后台-账号管理"})
-    public AjaxResult verifyUserNameRepeat(@PathVariable String username){
-        SysUser user = new SysUser();
-        user.setUserName(username);
-        if (StringUtils.isNotEmpty(username) && !userService.checkUserNameUnique(user)) {
-            return error("账号不可重复");
-        }
-        return success();
-    }
-    
-   
-    
-    
-    
-    
-    /**
-     * 根据用户编号获取详细信息
-     */
-    @ApiOperation(value = "获取用户详情", tags = {"管理后台-账号管理", "门店后台-部门管理"})
-    @GetMapping("/getInfo/{userId}")
-    public AjaxResult getInfo(@PathVariable Long userId) {
-        userService.checkUserDataScope(userId);
-        AjaxResult ajax = AjaxResult.success();
-        List<SysRole> roles = roleService.selectRoleAll();
-        ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()));
-        ajax.put("posts", postService.selectPostAll());
-        if (StringUtils.isNotNull(userId)) {
-            SysUser sysUser = userService.selectUserById(userId);
-            if(sysUser.getRoleType() == 2){
-                Long userid = tokenService.getLoginUser().getUserid();
-                SysUser sysUser1 = userService.selectUserById(userid);
-                UserShop one = userShopService.getOne(new LambdaQueryWrapper<UserShop>().eq(UserShop::getUserId, sysUser.getUserId()).eq(UserShop::getShopId, sysUser1.getObjectId()));
-                sysUser.setDeptId(one.getDeptId());
-                sysUser.setNickName(one.getNickName());
-                SysDept sysDept = deptService.selectDeptById(one.getDeptId());
-                sysUser.setDept(sysDept);
-                sysUser.setRoleId(one.getRoleId());
-            }
-
-            ajax.put("data", sysUser);
-            ajax.put("postIds", postService.selectPostListByUserId(userId));
-            ajax.put("roleIds", sysUser.getRoles().stream().map(SysRole::getRoleId).collect(Collectors.toList()));
-        }
-        return AjaxResult.success(ajax);
-    }
-
-
-    /**
-     * 修改用户
-     */
-    @Log(title = "用户管理", businessType = BusinessType.UPDATE)
-    @PutMapping("/update")
-    @ApiOperation(value = "编辑系统用户", tags = {"管理后台-账号管理", "门店后台-部门管理"})
-    public AjaxResult edit(@Validated @RequestBody SysUser user) {
-        user.setUserName(user.getPhonenumber());
-        if(!org.springframework.util.StringUtils.hasLength(user.getNickName())){
-            user.setNickName(user.getPhonenumber());
-        }
-        R<Integer> admin = this.isAdmin(user.getUserId());
-        Integer data = admin.getData();
-        if(data == null || data != 1){
-            SysUserRole one = sysUserRoleService.getOne(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getUserId, user.getUserId()));
-            one.setRoleId(user.getRoleId());
-            sysUserRoleService.updateSysUserRole(one);
-        }
-        userService.checkUserAllowed(user);
-        userService.checkUserDataScope(user.getUserId());
-        SysUser sysUser = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
-                .eq(SysUser::getPhonenumber, user.getPhonenumber())
-                .eq(SysUser::getDelFlag,0)
-                .last("LIMIT 1"));
-
-        if (StringUtils.isNotEmpty(user.getPhonenumber()) && (Objects.nonNull(sysUser) && !user.getUserId().equals(sysUser.getUserId()) )) {
-            return error("手机号已开通账号");
-        }
-        sysUser = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
-                .eq(SysUser::getUserName, user.getUserName())
-                .eq(SysUser::getDelFlag,0)
-                .last("LIMIT 1"));
-        if (StringUtils.isNotEmpty(user.getUserName()) && (Objects.nonNull(sysUser) && !user.getUserId().equals(sysUser.getUserId()) )) {
-            return error("登录账号重复");
-        }
-        user.setUpdateBy(SecurityUtils.getUsername());
-        if (user.getPassword() != null && !"".equals(user.getPassword())) {
-            user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
-            user.setPassword(SecurityUtils.encryptPassword(MD5Generator.generateMD5("a123456")));
-
-            user.setPassWordUpdate(new Date());
-        }
-        if (user.getPhonenumber() != null) {
-            user.setUserName(user.getPhonenumber());
-        }
-        user.setUpdateBy(SecurityUtils.getUsername());
-        user.setUpdateTime(new Date());
-        userService.updateUser(user);
-        user = userService.getById(user.getUserId());
-        //添加门店员工关系数据
-        if(2 == user.getRoleType()){
-            UserShop one = userShopService.getOne(new LambdaQueryWrapper<UserShop>().eq(UserShop::getUserId, user.getUserId()).eq(UserShop::getShopId, user.getObjectId()));
-            one.setUserId(user.getUserId());
-            one.setShopId(user.getObjectId());
-            one.setRoleType(one.getRoleType());
-            one.setRoleId(user.getRoleId());
-            one.setDeptId(user.getDeptId());
-            one.setNickName(user.getNickName());
-            userShopService.updateById(one);
-        }
-        return success();
-    }
-
-
-    /**
-     * 删除用户
-     */
-    @Log(title = "用户管理", businessType = BusinessType.DELETE)
-    @DeleteMapping("/{userIds}")
-    @ApiOperation(value = "删除系统用户", tags = {"管理后台-账号管理", "门店后台-部门管理"})
-    public AjaxResult remove(@PathVariable Long[] userIds) {
-        if (ArrayUtils.contains(userIds, SecurityUtils.getUserId())) {
-            return error("当前用户不能删除");
-        }
-        userService.deleteUserByIds(userIds);
-        return AjaxResult.success();
-    }
-
-    
-
-
-    @PostMapping("/shopUserStart")
-    @ApiOperation(value = "账号管理--禁用/启用", tags = {"管理后台-账号管理", "门店后台-部门管理"})
-    public AjaxResult shopUserStart(@RequestBody ShopUserStart shopUserStart) {
-        if (shopUserStart.getUserId() == null) {
-            return AjaxResult.error("userId不能为空");
-        }
-        SysUser sysUser = userService.selectUserById(shopUserStart.getUserId());
-        if (sysUser.getStatus().equals("0")) {
-            sysUser.setStatus("1");
-            sysUser.setForbiddenRemark(shopUserStart.getRemark());
-        } else {
-            sysUser.setStatus("0");
-            sysUser.setForbiddenRemark("");
-        }
-        return toAjax(userService.updateUser(sysUser));
-    }
-
-
-    @PostMapping("/getUserList")
-    public R<List<SysUser>> getUserList(@RequestBody List<Integer> userIds) {
-        List<SysUser> list = userService.list(new LambdaQueryWrapper<SysUser>().in(SysUser::getUserId, userIds));
-        return R.ok(list);
-    }
-
-    @PostMapping("/isAdmin")
-    public R<Integer> isAdmin(@RequestBody Long userId){
-        SysUserRole one = sysUserRoleService.getOne(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getUserId, userId));
-        Long id =one.getRoleId();
-        return R.ok(id.intValue());
-    }
-
-    @PostMapping("/getSysUser")
-    public R<SysUser> getSysUser(@RequestParam("userId") Long userId) {
-        try {
-            SysUser sysUser = userService.selectUserById(userId);
-            return R.ok(sysUser);
-        } catch (Exception e) {
-            e.printStackTrace();
-            return R.ok();
-        }
-    }
-
-    @PostMapping("/updateSysUser")
-    @Transactional(rollbackFor = Exception.class)
-    public R<Boolean> updateSysUser(@RequestBody SysUser sysUser) {
-        try {
-            sysUser.setUpdateBy(SecurityUtils.getUsername());
-            sysUser.setUpdateTime(new Date());
-            userService.updateUser(sysUser);
-            if(null != sysUser.getRoleId()){
-                userRoleService.deleteSysUserRoleByUserId(sysUser.getUserId());
-                SysUserRole sysUserRole = new SysUserRole();
-                sysUserRole.setRoleId(sysUser.getRoleId());
-                sysUserRole.setUserId(sysUser.getUserId());
-                userRoleService.insertSysUserRole(sysUserRole);
-            }
-            return R.ok(true);
-        } catch (Exception e) {
-            e.printStackTrace();
-            return R.fail();
-        }
-    }
-
-
-
-    /**
-     * 获取当前用户信息
-     */
-    @InnerAuth
-    @GetMapping("/info/{username}")
-    public R<LoginUser> info(@PathVariable("username") String username) {
-        SysUser sysUser = userService.selectUserByUserName(username);
-        if (StringUtils.isNull(sysUser)) {
-            return R.fail("用户名或密码错误");
-        }
-        // 角色集合
-        Set<String> roles = permissionService.getRolePermission(sysUser);
-        // 权限集合getRolePermission
-        Set<String> permissions = permissionService.getMenuPermission(sysUser);
-        LoginUser sysUserVo = new LoginUser();
-        sysUserVo.setSysUser(sysUser);
-        sysUserVo.setRoles(roles);
-        sysUserVo.setPermissions(permissions);
-
-        return R.ok(sysUserVo);
-    }
-
-    /**
-     * 门店登录使用
-     * @param username
-     * @return
-     */
-    @InnerAuth
-    @GetMapping("/infoShop/{username}")
-    public R<LoginUser> infoShop(@PathVariable("username") String username) {
-        SysUser sysUser = userService.selectUserShopByUserName(username);
-        if (StringUtils.isNull(sysUser)) {
-            return R.fail("用户名或密码错误");
-        }
-        // 角色集合
-        Set<String> roles = permissionService.getRolePermission(sysUser);
-        // 权限集合getRolePermission
-        Set<String> permissions = permissionService.getMenuPermission(sysUser);
-        LoginUser sysUserVo = new LoginUser();
-        sysUserVo.setSysUser(sysUser);
-        sysUserVo.setRoles(roles);
-        sysUserVo.setPermissions(permissions);
-
-        return R.ok(sysUserVo);
-    }
-
-    /**
-     * 注册用户信息
-     */
-    @PostMapping("/register")
-    public R<Boolean> register(@RequestBody SysUser sysUser) {
-        String username = sysUser.getUserName();
-        if (!("true".equals(configService.selectConfigByKey("sys.account.registerUser")))) {
-            return R.fail("当前系统没有开启注册功能!");
-        }
-        if (!userService.checkUserNameUnique(sysUser)) {
-            return R.fail("保存用户'" + username + "'失败,注册账号已存在");
-        }
-        return R.ok(userService.registerUser(sysUser));
-    }
-
-    /**
-     * 获取用户信息
-     *
-     * @return 用户信息
-     */
-    @GetMapping("/getInfo")
-    public AjaxResult getInfo() {
-        SysUser user = userService.selectUserById(SecurityUtils.getUserId());
-        // 角色集合
-        Set<String> roles = permissionService.getRolePermission(user);
-        // 权限集合
-        Set<String> permissions = permissionService.getMenuPermission(user);
-        AjaxResult ajax = AjaxResult.success();
-        ajax.put("user", user);
-        ajax.put("roles", roles);
-        ajax.put("permissions", permissions);
-        return ajax;
-    }
-
-
-    /**
-     * 重置密码
-     */
-    @Log(title = "用户管理", businessType = BusinessType.UPDATE)
-    @PutMapping("/resetPwd")
-    @ApiOperation(value = "重置密码", tags = {"管理后台-账号管理", "门店后台-部门管理"})
-    public AjaxResult resetPwd(@RequestBody SysUser user) {
-        userService.checkUserAllowed(user);
-        userService.checkUserDataScope(user.getUserId());
-
-        user.setPassword(SecurityUtils.encryptPassword(MD5Generator.generateMD5("a123456")));
-        user.setUpdateBy(SecurityUtils.getUsername());
-        return toAjax(userService.resetPwd(user));
-    }
-
-    /**
-     * 状态修改
-     */
-    @Log(title = "用户管理", businessType = BusinessType.UPDATE)
-    @PutMapping("/changeStatus")
-    public AjaxResult changeStatus(@RequestBody SysUser user) {
-        userService.checkUserAllowed(user);
-        userService.checkUserDataScope(user.getUserId());
-        user.setUpdateBy(SecurityUtils.getUsername());
-        return toAjax(userService.updateUserStatus(user));
-    }
-
-    /**
-     * 根据用户编号获取授权角色
-     */
-    @GetMapping("/authRole/{userId}")
-    public AjaxResult authRole(@PathVariable("userId") Long userId) {
-        AjaxResult ajax = AjaxResult.success();
-        SysUser user = userService.selectUserById(userId);
-        List<SysRole> roles = roleService.selectRolesByUserId(userId);
-        ajax.put("user", user);
-        ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()));
-        return ajax;
-    }
-
-    /**
-     * 用户授权角色
-     */
-    @Log(title = "用户管理", businessType = BusinessType.GRANT)
-    @PutMapping("/authRole")
-    public AjaxResult insertAuthRole(Long userId, Long[] roleIds) {
-        userService.checkUserDataScope(userId);
-        userService.insertUserAuth(userId, roleIds);
-        return success();
-    }
-
-    /**
-     * 获取部门树列表
-     */
-    @GetMapping("/deptTree")
-    public AjaxResult deptTree(SysDept dept) {
-        return success(deptService.selectDeptTreeList(dept));
-    }
-
-    @PostMapping("/updateUser")
-    public R<Boolean>  updateUser(@RequestBody SysUser sysUser){
-        return R.ok(userService.updateById(sysUser));
-    }
-
-    /**
-     * 通过用户id查询角色对象
-     * @param userId
-     * @return
-     */
-    @PostMapping("/queryRoleByUserId/{userId}")
-    public R<SysRole> queryRoleByUserId(@PathVariable("userId") Long userId){
-        SysUserRole one = sysUserRoleService.getOne(Wrappers.lambdaQuery(SysUserRole.class)
-                .eq(SysUserRole::getUserId, userId)
-                .last("LIMIT 1"));
-        System.out.println("通过用户id查询角色对象"+one);
-        if(Objects.nonNull(one)){
-            SysRole byId = roleService.getOne(Wrappers.lambdaQuery(SysRole.class)
-                    .eq(SysRole::getRoleId,one.getRoleId())
-                    .last("LIMIT 1"));
-            return R.ok(byId);
-        }
-        return R.ok();
-    }
-
-
-    @PostMapping("/queryRoleByRoleId/{roleId}")
-    public R<SysRole> queryRoleByRoleId(@PathVariable("roleId") Long roleId){
-        return R.ok( roleService.getOne(Wrappers.lambdaQuery(SysRole.class)
-                .eq(SysRole::getRoleId, roleId)
-                .last("LIMIT 1")));
-    }
-
-    /**
-     * 通过手机号集合查询用户
-     * @param phoneList
-     * @return
-     */
-    @PostMapping("/queryUserByPhoneList")
-    public R<List<SysUser>> queryUserByPhoneList(@RequestBody List<String> phoneList){
-        List<SysUser> list = userService.list(Wrappers.lambdaQuery(SysUser.class)
-                .in(SysUser::getPhonenumber, phoneList)
-                .ne(SysUser::getDelFlag,2));
-        return R.ok(list);
-    }
-
-
-    /**
-     * 通过手机号查询用户
-     * @param phone
-     * @return
-     */
-    @PostMapping("/queryUserByPhone")
-    public R<SysUser>  queryUserByPhone(@RequestBody String phone){
-        SysUser user = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
-                .eq(SysUser::getPhonenumber, phone)
-                .last("LIMIT 1"));
-        return R.ok(user);
-    }
-
-
-    /**
-     * 通过账号查询用户
-     * @param userName
-     * @return
-     */
-    @ResponseBody
-    @PostMapping("/queryUserByUserName")
-    public R<SysUser> queryUserByUserName(@RequestBody String userName){
-        SysUser user = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
-                .eq(SysUser::getUserName, userName)
-                .eq(SysUser::getDelFlag, "0")
-                .eq(SysUser::getStatus, 0)
-                .last("LIMIT 1"));
-        return R.ok(user);
-    }
-    
-    
-    /**
-     * 添加管理员
-     * @param user
-     */
-    @ResponseBody
-    @PostMapping("/addSysUser")
-    @Transactional(rollbackFor = Exception.class)
-    public R<Long> addSysUser(@RequestBody SysUser user) {
-        if(StringUtils.isEmpty(user.getUserName())){
-            user.setUserName(user.getPhonenumber());
-        }
-        if(!org.springframework.util.StringUtils.hasLength(user.getNickName())){
-            user.setNickName(user.getPhonenumber());
-        }
+	@Resource
+	private ISysUserService userService;
+	
+	@Resource
+	private ISysRoleService roleService;
+	
+	@Resource
+	private ISysDeptService deptService;
+	
+	@Resource
+	private ISysPostService postService;
+	
+	@Resource
+	private ISysPermissionService permissionService;
+	
+	@Resource
+	private ISysConfigService configService;
+	
+	@Resource
+	private ISysUserRoleService userRoleService;
+	
+	@Resource
+	private ISysUserRoleService sysUserRoleService;
+	
+	@Resource
+	private UserShopService userShopService;
+	
+	@Resource
+	private TokenService tokenService;
+	
+	@Autowired
+	private ISysMenuService menuService;
+	
+	
+	/**
+	 * 获取用户列表
+	 */
+	@GetMapping("/list")
+	@ApiOperation(value = "获取系统用户列表", tags = {"用户管理"})
+	public AjaxResult<PageInfo<SysUser>> list(GetSysUserList getSysUserList) {
+		PageInfo<SysUser> pageInfo = new PageInfo<>(getSysUserList.getPageCurr(), getSysUserList.getPageSize());
+		PageInfo<SysUser> page = userService.getList(pageInfo, getSysUserList);
+		return AjaxResult.success(page);
+	}
+	
+	/**
+	 * 获取用户选择列表
+	 */
+	@PostMapping("/getChangeUserList")
+	@ApiOperation(value = "获取用户选择列表", tags = {"管理后台-获取用户选择列表"})
+	public AjaxResult<PageInfo<SysUser>> getChangeUserList(@RequestBody ChangeUserQuery query) {
+		return AjaxResult.success(userService.getChangeUserList(query));
+	}
+	
+	/**
+	 * 新增用户
+	 */
+	@Log(title = "用户管理", businessType = BusinessType.INSERT)
+	@PostMapping("/add")
+	@ApiOperation(value = "添加系统用户", tags = {"用户管理"})
+	public AjaxResult add(@RequestBody SysUser user) {
+		if (StringUtils.isNotEmpty(user.getPhonenumber()) && !userService.checkPhoneUnique(user)) {
+			return error("手机号已开通账号");
+		}
+		if (StringUtils.isNotEmpty(user.getUserName()) && !userService.checkUserNameUnique(user)) {
+			return error("登录账号重复");
+		}
+		user.setPassword(SecurityUtils.encryptPassword(MD5Util.getMD5("123456")));
+		user.setDelFlag("0");
+		user.setCreateTime(new Date());
+		userService.save(user);
+		SysUserRole userRole = new SysUserRole();
+		userRole.setUserId(user.getUserId());
+		userRole.setRoleId(user.getRoleId());
+		sysUserRoleService.save(userRole);
+		return AjaxResult.success();
+	}
+	
+	
+	@GetMapping("/verifyUserNameRepeat/{username}")
+	@ApiOperation(value = "校验账号是否重复", tags = {"管理后台-账号管理"})
+	public AjaxResult verifyUserNameRepeat(@PathVariable String username) {
+		SysUser user = new SysUser();
+		user.setUserName(username);
+		if (StringUtils.isNotEmpty(username) && !userService.checkUserNameUnique(user)) {
+			return error("账号不可重复");
+		}
+		return success();
+	}
+	
+	
+	/**
+	 * 根据用户编号获取详细信息
+	 */
+	@ApiOperation(value = "获取用户详情", tags = {"用户管理"})
+	@GetMapping("/getInfo/{userId}")
+	public AjaxResult getInfo(@PathVariable Long userId) {
+		userService.checkUserDataScope(userId);
+		AjaxResult ajax = AjaxResult.success();
+		List<SysRole> roles = roleService.selectRoleAll();
+		ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()));
+		ajax.put("posts", postService.selectPostAll());
+		if (StringUtils.isNotNull(userId)) {
+			SysUser sysUser = userService.selectUserById(userId);
+			ajax.put("data", sysUser);
+			ajax.put("postIds", postService.selectPostListByUserId(userId));
+			ajax.put("roleIds", sysUser.getRoles().stream().map(SysRole::getRoleId).collect(Collectors.toList()));
+		}
+		return AjaxResult.success(ajax);
+	}
+	
+	
+	/**
+	 * 修改用户
+	 */
+	@Log(title = "用户管理", businessType = BusinessType.UPDATE)
+	@PutMapping("/update")
+	@ApiOperation(value = "编辑系统用户", tags = {"用户管理"})
+	public AjaxResult edit(@Validated @RequestBody SysUser user) {
+		userService.checkUserAllowed(user);
+		userService.checkUserDataScope(user.getUserId());
+		SysUser sysUser = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
+				.eq(SysUser::getPhonenumber, user.getPhonenumber())
+				.eq(SysUser::getDelFlag, 0)
+				.last("LIMIT 1"));
+		
+		if (StringUtils.isNotEmpty(user.getPhonenumber()) && (Objects.nonNull(sysUser) && !user.getUserId().equals(sysUser.getUserId()))) {
+			return error("手机号已开通账号");
+		}
+		sysUser = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
+				.eq(SysUser::getUserName, user.getUserName())
+				.eq(SysUser::getDelFlag, 0)
+				.last("LIMIT 1"));
+		if (StringUtils.isNotEmpty(user.getUserName()) && (Objects.nonNull(sysUser) && !user.getUserId().equals(sysUser.getUserId()))) {
+			return error("登录账号重复");
+		}
+		user.setUpdateBy(SecurityUtils.getUsername());
+		user.setUpdateBy(SecurityUtils.getUsername());
+		user.setUpdateTime(new Date());
+		userService.updateUser(user);
+		
+		SysUserRole one = sysUserRoleService.getOne(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getUserId, user.getUserId()));
+		one.setRoleId(user.getRoleId());
+		sysUserRoleService.updateSysUserRole(one);
+		return success();
+	}
+	
+	
+	/**
+	 * 删除用户
+	 */
+	@Log(title = "用户管理", businessType = BusinessType.DELETE)
+	@DeleteMapping("/{userIds}")
+	@ApiOperation(value = "删除系统用户", tags = {"用户管理"})
+	public AjaxResult remove(@PathVariable Long[] userIds) {
+		if (ArrayUtils.contains(userIds, SecurityUtils.getUserId())) {
+			return error("当前用户不能删除");
+		}
+		userService.deleteUserByIds(userIds);
+		return AjaxResult.success();
+	}
+	
+	
+	@PostMapping("/shopUserStart")
+	@ApiOperation(value = "账号管理--禁用/启用", tags = {"用户管理"})
+	public AjaxResult shopUserStart(@RequestBody ShopUserStart shopUserStart) {
+		if (shopUserStart.getUserId() == null) {
+			return AjaxResult.error("userId不能为空");
+		}
+		SysUser sysUser = userService.selectUserById(shopUserStart.getUserId());
+		if (sysUser.getStatus().equals("0")) {
+			sysUser.setStatus("1");
+			sysUser.setForbiddenRemark(shopUserStart.getRemark());
+		} else {
+			sysUser.setStatus("0");
+			sysUser.setForbiddenRemark("");
+		}
+		return toAjax(userService.updateUser(sysUser));
+	}
+	
+	
+	@PostMapping("/getUserList")
+	public R<List<SysUser>> getUserList(@RequestBody List<Integer> userIds) {
+		List<SysUser> list = userService.list(new LambdaQueryWrapper<SysUser>().in(SysUser::getUserId, userIds));
+		return R.ok(list);
+	}
+	
+	@PostMapping("/isAdmin")
+	public R<Integer> isAdmin(@RequestBody Long userId) {
+		SysUserRole one = sysUserRoleService.getOne(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getUserId, userId));
+		Long id = one.getRoleId();
+		return R.ok(id.intValue());
+	}
+	
+	@PostMapping("/getSysUser")
+	public R<SysUser> getSysUser(@RequestParam("userId") Long userId) {
+		try {
+			SysUser sysUser = userService.selectUserById(userId);
+			return R.ok(sysUser);
+		} catch (Exception e) {
+			e.printStackTrace();
+			return R.ok();
+		}
+	}
+	
+	@PostMapping("/updateSysUser")
+	@Transactional(rollbackFor = Exception.class)
+	public R<Boolean> updateSysUser(@RequestBody SysUser sysUser) {
+		try {
+			sysUser.setUpdateBy(SecurityUtils.getUsername());
+			sysUser.setUpdateTime(new Date());
+			userService.updateUser(sysUser);
+			if (null != sysUser.getRoleId()) {
+				userRoleService.deleteSysUserRoleByUserId(sysUser.getUserId());
+				SysUserRole sysUserRole = new SysUserRole();
+				sysUserRole.setRoleId(sysUser.getRoleId());
+				sysUserRole.setUserId(sysUser.getUserId());
+				userRoleService.insertSysUserRole(sysUserRole);
+			}
+			return R.ok(true);
+		} catch (Exception e) {
+			e.printStackTrace();
+			return R.fail();
+		}
+	}
+	
+	
+	/**
+	 * 获取当前用户信息
+	 */
+	@InnerAuth
+	@GetMapping("/info/{username}")
+	public R<LoginUser> info(@PathVariable("username") String username) {
+		SysUser sysUser = userService.selectUserByUserName(username);
+		if (StringUtils.isNull(sysUser)) {
+			return R.fail("用户名或密码错误");
+		}
+		// 角色集合
+		Set<String> roles = permissionService.getRolePermission(sysUser);
+		// 权限集合getRolePermission
+		Set<String> permissions = permissionService.getMenuPermission(sysUser);
+		LoginUser sysUserVo = new LoginUser();
+		sysUserVo.setSysUser(sysUser);
+		sysUserVo.setRoles(roles);
+		sysUserVo.setPermissions(permissions);
+		return R.ok(sysUserVo);
+	}
+	
+	/**
+	 * 门店登录使用
+	 *
+	 * @param username
+	 * @return
+	 */
+	@InnerAuth
+	@GetMapping("/infoShop/{username}")
+	public R<LoginUser> infoShop(@PathVariable("username") String username) {
+		SysUser sysUser = userService.selectUserShopByUserName(username);
+		if (StringUtils.isNull(sysUser)) {
+			return R.fail("用户名或密码错误");
+		}
+		// 角色集合
+		Set<String> roles = permissionService.getRolePermission(sysUser);
+		// 权限集合getRolePermission
+		Set<String> permissions = permissionService.getMenuPermission(sysUser);
+		LoginUser sysUserVo = new LoginUser();
+		sysUserVo.setSysUser(sysUser);
+		sysUserVo.setRoles(roles);
+		sysUserVo.setPermissions(permissions);
+		
+		return R.ok(sysUserVo);
+	}
+	
+	/**
+	 * 注册用户信息
+	 */
+	@PostMapping("/register")
+	public R<Boolean> register(@RequestBody SysUser sysUser) {
+		String username = sysUser.getUserName();
+		if (!("true".equals(configService.selectConfigByKey("sys.account.registerUser")))) {
+			return R.fail("当前系统没有开启注册功能!");
+		}
+		if (!userService.checkUserNameUnique(sysUser)) {
+			return R.fail("保存用户'" + username + "'失败,注册账号已存在");
+		}
+		return R.ok(userService.registerUser(sysUser));
+	}
+	
+	/**
+	 * 获取用户信息
+	 *
+	 * @return 用户信息
+	 */
+	@GetMapping("/getInfo")
+	public AjaxResult getInfo() {
+		SysUser user = userService.selectUserById(SecurityUtils.getUserId());
+		// 角色集合
+		Set<String> roles = permissionService.getRolePermission(user);
+		// 权限集合
+		Set<String> permissions = permissionService.getMenuPermission(user);
+		AjaxResult ajax = AjaxResult.success();
+		ajax.put("user", user);
+		ajax.put("roles", roles);
+		ajax.put("permissions", permissions);
+		return ajax;
+	}
+	
+	
+	/**
+	 * 重置密码
+	 */
+	@Log(title = "用户管理", businessType = BusinessType.UPDATE)
+	@PutMapping("/resetPwd")
+	@ApiOperation(value = "重置密码", tags = {"用户管理"})
+	public AjaxResult resetPwd(@RequestBody SysUser user) {
+		userService.checkUserAllowed(user);
+		userService.checkUserDataScope(user.getUserId());
+		
+		user.setPassword(SecurityUtils.encryptPassword(MD5Generator.generateMD5("123456")));
+		user.setUpdateBy(SecurityUtils.getUsername());
+		return toAjax(userService.resetPwd(user));
+	}
+	
+	/**
+	 * 状态修改
+	 */
+	@Log(title = "用户管理", businessType = BusinessType.UPDATE)
+	@PutMapping("/changeStatus")
+	public AjaxResult changeStatus(@RequestBody SysUser user) {
+		userService.checkUserAllowed(user);
+		userService.checkUserDataScope(user.getUserId());
+		user.setUpdateBy(SecurityUtils.getUsername());
+		return toAjax(userService.updateUserStatus(user));
+	}
+	
+	/**
+	 * 根据用户编号获取授权角色
+	 */
+	@GetMapping("/authRole/{userId}")
+	public AjaxResult authRole(@PathVariable("userId") Long userId) {
+		AjaxResult ajax = AjaxResult.success();
+		SysUser user = userService.selectUserById(userId);
+		List<SysRole> roles = roleService.selectRolesByUserId(userId);
+		ajax.put("user", user);
+		ajax.put("roles", SysUser.isAdmin(userId) ? roles : roles.stream().filter(r -> !r.isAdmin()).collect(Collectors.toList()));
+		return ajax;
+	}
+	
+	/**
+	 * 用户授权角色
+	 */
+	@Log(title = "用户管理", businessType = BusinessType.GRANT)
+	@PutMapping("/authRole")
+	public AjaxResult insertAuthRole(Long userId, Long[] roleIds) {
+		userService.checkUserDataScope(userId);
+		userService.insertUserAuth(userId, roleIds);
+		return success();
+	}
+	
+	/**
+	 * 获取部门树列表
+	 */
+	@GetMapping("/deptTree")
+	public AjaxResult deptTree(SysDept dept) {
+		return success(deptService.selectDeptTreeList(dept));
+	}
+	
+	@PostMapping("/updateUser")
+	public R<Boolean> updateUser(@RequestBody SysUser sysUser) {
+		return R.ok(userService.updateById(sysUser));
+	}
+	
+	/**
+	 * 通过用户id查询角色对象
+	 *
+	 * @param userId
+	 * @return
+	 */
+	@PostMapping("/queryRoleByUserId/{userId}")
+	public R<SysRole> queryRoleByUserId(@PathVariable("userId") Long userId) {
+		SysUserRole one = sysUserRoleService.getOne(Wrappers.lambdaQuery(SysUserRole.class)
+				.eq(SysUserRole::getUserId, userId)
+				.last("LIMIT 1"));
+		System.out.println("通过用户id查询角色对象" + one);
+		if (Objects.nonNull(one)) {
+			SysRole byId = roleService.getOne(Wrappers.lambdaQuery(SysRole.class)
+					.eq(SysRole::getRoleId, one.getRoleId())
+					.last("LIMIT 1"));
+			return R.ok(byId);
+		}
+		return R.ok();
+	}
+	
+	
+	@PostMapping("/queryRoleByRoleId/{roleId}")
+	public R<SysRole> queryRoleByRoleId(@PathVariable("roleId") Long roleId) {
+		return R.ok(roleService.getOne(Wrappers.lambdaQuery(SysRole.class)
+				.eq(SysRole::getRoleId, roleId)
+				.last("LIMIT 1")));
+	}
+	
+	/**
+	 * 通过手机号集合查询用户
+	 *
+	 * @param phoneList
+	 * @return
+	 */
+	@PostMapping("/queryUserByPhoneList")
+	public R<List<SysUser>> queryUserByPhoneList(@RequestBody List<String> phoneList) {
+		List<SysUser> list = userService.list(Wrappers.lambdaQuery(SysUser.class)
+				.in(SysUser::getPhonenumber, phoneList)
+				.ne(SysUser::getDelFlag, 2));
+		return R.ok(list);
+	}
+	
+	
+	/**
+	 * 通过手机号查询用户
+	 *
+	 * @param phone
+	 * @return
+	 */
+	@PostMapping("/queryUserByPhone")
+	public R<SysUser> queryUserByPhone(@RequestBody String phone) {
+		SysUser user = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
+				.eq(SysUser::getPhonenumber, phone)
+				.last("LIMIT 1"));
+		return R.ok(user);
+	}
+	
+	
+	/**
+	 * 通过账号查询用户
+	 *
+	 * @param userName
+	 * @return
+	 */
+	@ResponseBody
+	@PostMapping("/queryUserByUserName")
+	public R<SysUser> queryUserByUserName(@RequestBody String userName) {
+		SysUser user = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
+				.eq(SysUser::getUserName, userName)
+				.eq(SysUser::getDelFlag, "0")
+				.eq(SysUser::getStatus, 0)
+				.last("LIMIT 1"));
+		return R.ok(user);
+	}
+	
+	
+	/**
+	 * 添加管理员
+	 *
+	 * @param user
+	 */
+	@ResponseBody
+	@PostMapping("/addSysUser")
+	@Transactional(rollbackFor = Exception.class)
+	public R<Long> addSysUser(@RequestBody SysUser user) {
+		if (StringUtils.isEmpty(user.getUserName())) {
+			user.setUserName(user.getPhonenumber());
+		}
+		if (!org.springframework.util.StringUtils.hasLength(user.getNickName())) {
+			user.setNickName(user.getPhonenumber());
+		}
 //        if (StringUtils.isNotEmpty(user.getPhonenumber()) && !userService.checkPhoneUnique(user)) {
 //            throw new RuntimeException("手机号已开通账号");
 //        }
-        if (StringUtils.isNotEmpty(user.getUserName()) && !userService.checkUserNameUnique(user)) {
-            throw new RuntimeException("登录账号已存在");
-        }
-        user.setCreateBy(SecurityUtils.getUsername());
-        user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
-        if(null == user.getRoleType()){
-            user.setRoleType(1);
-        }
-        userService.insertUser(user);
-        SysUserRole sysUserRole = new SysUserRole();
-        sysUserRole.setRoleId(user.getRoleId());
-        sysUserRole.setUserId(user.getUserId());
-        userRoleService.insertSysUserRole(sysUserRole);
-        return R.ok(user.getUserId());
-    }
-    
-    
-    @ResponseBody
-    @PostMapping("/resetPassword")
-    public R resetPassword(@RequestBody SysUser user) {
-        user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
-        user.setUpdateBy(SecurityUtils.getUsername());
-        userService.resetPwd(user);
-        return R.ok();
-    }
-    
-    
-    @ResponseBody
-    @PostMapping("/getSysUserById")
-    public SysUser getSysUserById(@RequestParam("userId") Long userId){
-        return userService.getById(userId);
-    }
-    
-    
-    /**
-     * 保存门店员工管理后台账号
-     * @param user
-     * @return
-     */
-    @ResponseBody
-    @PostMapping("/saveShopUser")
-    public R<Long> saveShopUser(@RequestBody SysUser user){
-        SysUser one = userService.getOne(new LambdaQueryWrapper<SysUser>().eq(SysUser::getPhonenumber, user.getPhonenumber()).eq(SysUser::getDelFlag, "0")
-                .eq(SysUser::getStatus, "0").eq(SysUser::getRoleType, 2));
-        if(null == one){
-            user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
-            userService.save(user);
-            //添加用户角色数据
-            SysUserRole userRole = new SysUserRole();
-            userRole.setUserId(user.getUserId());
-            userRole.setRoleId(2L);
-            userRoleService.save(userRole);
-        }
-        return R.ok(user.getUserId());
-    }
-
-
-    /**
-     * 删除门店管理员账号
-     * @param objectId
-     * @param roleType
-     * @return
-     */
-    @PostMapping("/user/delShopUser")
-    public R delShopUser(@RequestParam("objectId") Integer objectId, @RequestParam("roleType") Integer roleType){
-        List<UserShop> list2 = userShopService.list(new LambdaQueryWrapper<UserShop>().eq(UserShop::getShopId, objectId));
-        for (UserShop userShop : list2) {
-            List<UserShop> list1 = userShopService.list(new LambdaUpdateWrapper<UserShop>().eq(UserShop::getUserId, userShop.getUserId()));
-            if(list1.size() == 1 && list1.get(0).getShopId().equals(objectId)){
-                //删除管理员账号
-                userService.deleteUserById(userShop.getUserId());
-            }else{
-                //修改管理后台账号关联的门店数据
-                SysUser sysUser = userService.getById(userShop.getUserId());
-                if(sysUser.getObjectId().equals(objectId)){
-                    Optional<UserShop> first = list1.stream().filter(s -> !s.getShopId().equals(objectId)).findFirst();
-                    if(first.isPresent()){
-                        sysUser.setObjectId(first.get().getShopId());
-                        userService.updateById(sysUser);
-                    }
-                    
-                }
-            }
-            userShopService.removeById(userShop.getId());
-        }
-        return R.ok();
-    }
-
-
-
-    @ResponseBody
-    @PutMapping("/switchShop/{shopId}")
-    @ApiOperation(value = "切换门店", tags = {"门店后台-首页"})
-    public R<Set<String>> switchShop(@PathVariable("shopId") Integer shopId){
-        Long userid = tokenService.getLoginUser().getUserid();
-        UserShop one = userShopService.getOne(new LambdaQueryWrapper<UserShop>().eq(UserShop::getUserId, userid).eq(UserShop::getShopId, shopId));
-        if(null == one){
-            return R.fail("切换失败");
-        }
-        SysUser sysUser = userService.getById(userid);
-        sysUser.setObjectId(shopId);
-        userService.updateById(sysUser);
-        //查询用户权限列表
-        Long roleId = one.getRoleId();
-        Set<String> rolePerms = menuService.selectMenuPermsByRoleId(roleId);
-        return R.ok(rolePerms);
-    }
-    
-    
-    
-    /**
-     * 通过账号和账号权限查询用户
-     * @param userName
-     * @return
-     */
-    @PostMapping("/queryUserByUserNameAndRoleType")
-    public R<SysUser>  queryUserByUserNameAndRoleType(@RequestParam("userName") String userName, @RequestParam("roleType") Integer roleType){
-        SysUser user = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
-                .eq(SysUser::getUserName, userName)
-                .eq(SysUser::getDelFlag, "0")
-                .eq(SysUser::getStatus, 0)
-                .eq(SysUser::getRoleType, roleType)
-                .last("LIMIT 1"));
-        return R.ok(user);
-    }
-    
-    
-    @PostMapping("/delSysUserById")
-    public R delSysUserById(@RequestParam("userId") Long userId){
-        userService.deleteUserById(userId);
-        return R.ok();
-    }
+		if (StringUtils.isNotEmpty(user.getUserName()) && !userService.checkUserNameUnique(user)) {
+			throw new RuntimeException("登录账号已存在");
+		}
+		user.setCreateBy(SecurityUtils.getUsername());
+		user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
+		userService.insertUser(user);
+		SysUserRole sysUserRole = new SysUserRole();
+		sysUserRole.setRoleId(user.getRoleId());
+		sysUserRole.setUserId(user.getUserId());
+		userRoleService.insertSysUserRole(sysUserRole);
+		return R.ok(user.getUserId());
+	}
+	
+	
+	@ResponseBody
+	@PostMapping("/resetPassword")
+	public R resetPassword(@RequestBody SysUser user) {
+		user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
+		user.setUpdateBy(SecurityUtils.getUsername());
+		userService.resetPwd(user);
+		return R.ok();
+	}
+	
+	
+	@ResponseBody
+	@PostMapping("/getSysUserById")
+	public SysUser getSysUserById(@RequestParam("userId") Long userId) {
+		return userService.getById(userId);
+	}
+	
+	
+	/**
+	 * 保存门店员工管理后台账号
+	 *
+	 * @param user
+	 * @return
+	 */
+	@ResponseBody
+	@PostMapping("/saveShopUser")
+	public R<Long> saveShopUser(@RequestBody SysUser user) {
+		SysUser one = userService.getOne(new LambdaQueryWrapper<SysUser>().eq(SysUser::getPhonenumber, user.getPhonenumber()).eq(SysUser::getDelFlag, "0")
+				.eq(SysUser::getStatus, "0"));
+		if (null == one) {
+			user.setPassword(SecurityUtils.encryptPassword(user.getPassword()));
+			userService.save(user);
+			//添加用户角色数据
+			SysUserRole userRole = new SysUserRole();
+			userRole.setUserId(user.getUserId());
+			userRole.setRoleId(2L);
+			userRoleService.save(userRole);
+		}
+		return R.ok(user.getUserId());
+	}
+	
+	
+	/**
+	 * 删除门店管理员账号
+	 *
+	 * @param objectId
+	 * @param roleType
+	 * @return
+	 */
+	@PostMapping("/user/delShopUser")
+	public R delShopUser(@RequestParam("objectId") Integer objectId, @RequestParam("roleType") Integer roleType) {
+		List<UserShop> list2 = userShopService.list(new LambdaQueryWrapper<UserShop>().eq(UserShop::getShopId, objectId));
+		for (UserShop userShop : list2) {
+			List<UserShop> list1 = userShopService.list(new LambdaUpdateWrapper<UserShop>().eq(UserShop::getUserId, userShop.getUserId()));
+			if (list1.size() == 1 && list1.get(0).getShopId().equals(objectId)) {
+				//删除管理员账号
+				userService.deleteUserById(userShop.getUserId());
+			} else {
+				//修改管理后台账号关联的门店数据
+				SysUser sysUser = userService.getById(userShop.getUserId());
+				if (sysUser.getObjectId().equals(objectId)) {
+					Optional<UserShop> first = list1.stream().filter(s -> !s.getShopId().equals(objectId)).findFirst();
+					if (first.isPresent()) {
+						sysUser.setObjectId(first.get().getShopId());
+						userService.updateById(sysUser);
+					}
+					
+				}
+			}
+			userShopService.removeById(userShop.getId());
+		}
+		return R.ok();
+	}
+	
+	
+	/**
+	 * 通过账号和账号权限查询用户
+	 *
+	 * @param userName
+	 * @return
+	 */
+	@PostMapping("/queryUserByUserNameAndRoleType")
+	public R<SysUser> queryUserByUserNameAndRoleType(@RequestParam("userName") String userName, @RequestParam("roleType") Integer roleType) {
+		SysUser user = userService.getOne(Wrappers.lambdaQuery(SysUser.class)
+				.eq(SysUser::getUserName, userName)
+				.eq(SysUser::getDelFlag, "0")
+				.eq(SysUser::getStatus, 0)
+				.last("LIMIT 1"));
+		return R.ok(user);
+	}
+	
+	
+	@PostMapping("/delSysUserById")
+	public R delSysUserById(@RequestParam("userId") Long userId) {
+		userService.deleteUserById(userId);
+		return R.ok();
+	}
 }

--
Gitblit v1.7.1