From 889531b6d710e923fce2590f0c2204b8a9a858f8 Mon Sep 17 00:00:00 2001
From: jiangqs <343695869@qq.com>
Date: 星期日, 06 八月 2023 20:12:54 +0800
Subject: [PATCH] bug
---
ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java | 258 +++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 257 insertions(+), 1 deletions(-)
diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java
index e972d6b..03acb69 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/staff/SysStaffServiceImpl.java
@@ -1,14 +1,35 @@
package com.ruoyi.system.service.impl.staff;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.core.exception.ServiceException;
+import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.core.utils.uuid.IdUtils;
+import com.ruoyi.common.redis.service.RedisService;
+import com.ruoyi.common.security.utils.SecurityUtils;
+import com.ruoyi.system.api.constant.AppErrorConstant;
+import com.ruoyi.system.api.constant.SecurityConstant;
+import com.ruoyi.system.api.domain.dto.MerEditUserDto;
+import com.ruoyi.system.api.domain.dto.MgtBaseGetDto;
+import com.ruoyi.system.api.domain.dto.MgtShopStaffEditDto;
+import com.ruoyi.system.api.domain.poji.sys.SysUser;
+import com.ruoyi.system.api.service.RemoteShopService;
+import com.ruoyi.system.domain.dto.MgtStaffEditDto;
+import com.ruoyi.system.domain.dto.MgtStaffPageDto;
import com.ruoyi.system.domain.pojo.staff.SysStaff;
import com.ruoyi.system.domain.vo.MgtDeptStaffListVo;
+import com.ruoyi.system.domain.vo.MgtStaffPageVo;
import com.ruoyi.system.mapper.staff.SysStaffMapper;
import com.ruoyi.system.service.staff.SysStaffService;
-import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.system.service.sys.ISysUserService;
+import com.ruoyi.system.util.QiYeUtils;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;
+import java.util.concurrent.TimeUnit;
/**
* <p>
@@ -24,6 +45,16 @@
@Resource
private SysStaffMapper sysStaffMapper;
+ @Resource
+ private ISysUserService sysUserService;
+
+ @Resource
+ private RedisService redisService;
+
+ @Resource
+ private RemoteShopService remoteShopService;
+
+
/**
* @description 获取部门员工列表
* @author jqs
@@ -35,4 +66,229 @@
public List<MgtDeptStaffListVo> listMgtDeptStaff(){
return sysStaffMapper.listMgtDeptStaff();
}
+
+ /**
+ * @description 通过权限获取部门员工列表
+ * @author jqs
+ * @date 2023/6/21 10:24
+ * @param userId
+ * @return List<MgtDeptStaffListVo>
+ */
+ @Override
+ public List<MgtDeptStaffListVo>listMgtDeptStaffByPermission(Long userId){
+ SysUser sysUser = sysUserService.selectUserById(userId);
+ String dataScope = sysUser.getDataScope();
+ List<MgtDeptStaffListVo> deptStaffListVoList;
+ if(dataScope!=null&&dataScope.equals("4")){
+ deptStaffListVoList = sysStaffMapper.listMgtDeptStaffByDept(sysUser.getDeptId(),null);
+ }else if(dataScope!=null&&dataScope.equals("5")){
+ deptStaffListVoList = sysStaffMapper.listMgtDeptStaffByDept(sysUser.getDeptId(),sysUser.getUserId());
+ }else{
+ deptStaffListVoList = sysStaffMapper.listMgtDeptStaff();
+ }
+ return deptStaffListVoList;
+ }
+
+ /**
+ * @description getBYUserId
+ * @param userId
+ * @return SysStaff
+ * @author jqs34
+ * @date 2023/6/18 21:01
+ */
+ @Override
+ public SysStaff getByUserId(Long userId){
+ LambdaQueryWrapper<SysStaff> queryWrapper = new LambdaQueryWrapper();
+ queryWrapper.eq(SysStaff::getDelFlag,0);
+ queryWrapper.eq(SysStaff::getUserId,userId);
+ return this.getOne(queryWrapper, false);
+ }
+
+
+ /**
+ * @description mgtStaffEdit
+ * @param mgtStaffEditDto
+ * @return void
+ * @author jqs34
+ * @date 2023/6/18 20:59
+ */
+ @Override
+ public void mgtStaffEdit(MgtStaffEditDto mgtStaffEditDto){
+ SysStaff sysStaff;
+ SysUser sysUser;
+ LambdaQueryWrapper<SysStaff> queryWrapper = new LambdaQueryWrapper();
+ queryWrapper.eq(SysStaff::getDelFlag,0);
+ queryWrapper.eq(SysStaff::getStaffMobile,mgtStaffEditDto.getStaffMobile());
+ SysStaff sysStaffSame = this.getOne(queryWrapper, false);
+ if(StringUtils.isBlank(mgtStaffEditDto.getStaffAvatar())){
+ mgtStaffEditDto.setStaffAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png");
+ }
+ if(mgtStaffEditDto.getSysUserId()!=null){
+ if(sysStaffSame!=null&&!sysStaffSame.getUserId().equals(mgtStaffEditDto.getSysUserId())){
+ throw new ServiceException(AppErrorConstant.STAFF_MOBILE_DOUBLE);
+ }
+ sysStaff = this.getByUserId(mgtStaffEditDto.getSysUserId());
+ sysUser = sysUserService.selectUserById(mgtStaffEditDto.getSysUserId());
+ sysUser.setUserName(mgtStaffEditDto.getStaffMobile());
+ sysUser.setPhonenumber(mgtStaffEditDto.getStaffMobile());
+ sysUser.setNickName(mgtStaffEditDto.getStaffName());
+ sysUser.setAvatar(mgtStaffEditDto.getStaffAvatar());
+ sysUser.setEmail(mgtStaffEditDto.getStaffEmail());
+ sysUserService.updateOnlyUser(sysUser);
+ }else{
+ if(sysStaffSame!=null){
+ throw new ServiceException(AppErrorConstant.STAFF_MOBILE_DOUBLE);
+ }
+ sysStaff = new SysStaff();
+ String staffId = IdUtils.simpleUUID();
+ sysStaff.setStaffId(staffId);
+ sysStaff.setDelFlag(0);
+ sysUser = new SysUser();
+ sysUser.setDelFlag("0");
+ sysUser.setUserType("00");
+ sysUser.setUserName(mgtStaffEditDto.getStaffMobile());
+ sysUser.setPhonenumber(mgtStaffEditDto.getStaffMobile());
+ sysUser.setNickName(mgtStaffEditDto.getStaffName());
+ sysUser.setAvatar(mgtStaffEditDto.getStaffAvatar());
+ sysUser.setEmail(mgtStaffEditDto.getStaffEmail());
+ String password = "123456";
+ sysUser.setPassword(SecurityUtils.encryptPassword(password));
+ sysUser.setDeptId(mgtStaffEditDto.getDeptId());
+ sysUser = sysUserService.registerUser(sysUser);
+ sysStaff.setUserId(sysUser.getUserId());
+ }
+ sysStaff.setStaffName(mgtStaffEditDto.getStaffName());
+ sysStaff.setStaffMobile(mgtStaffEditDto.getStaffMobile());
+ sysStaff.setStaffEmail(mgtStaffEditDto.getStaffEmail());
+ sysStaff.setStaffPost(mgtStaffEditDto.getStaffPost());
+ sysStaff.setStaffAvatar(mgtStaffEditDto.getStaffAvatar());
+ sysStaff.setHeadFlag(mgtStaffEditDto.getHeadFlag());
+ this.saveOrUpdate(sysStaff);
+ MgtShopStaffEditDto mgtShopStaffEditDto = new MgtShopStaffEditDto();
+ mgtShopStaffEditDto.setUserId(sysStaff.getUserId());
+ mgtShopStaffEditDto.setStaffName(sysStaff.getStaffName());
+ mgtShopStaffEditDto.setStaffMobile(sysStaff.getStaffMobile());
+ mgtShopStaffEditDto.setStaffAvatar(sysStaff.getStaffAvatar());
+ remoteShopService.editMgtShopStaff(mgtShopStaffEditDto);
+ }
+
+ /**
+ * @description mgtDeleteStaff
+ * @param mgtBaseGetDto
+ * @return void
+ * @author jqs34
+ * @date 2023/6/18 22:00
+ */
+ @Override
+ public void mgtDeleteStaff(MgtBaseGetDto mgtBaseGetDto){
+ Long userId = Long.valueOf(mgtBaseGetDto.getId());
+ SysStaff sysStaff = this.getByUserId(userId);
+ sysStaff.setDelFlag(1);
+ sysStaff.setStaffMobile(sysStaff.getStaffMobile()+":已删除");
+ this.saveOrUpdate(sysStaff);
+ sysUserService.deleteUserById(userId);
+ }
+
+ /**
+ * @description
+ * @author jqs
+ * @date 2023/6/25 17:52
+ * @param page
+ * @param mgtStaffPageDto
+ * @return List<MgtStaffPageVo>
+ */
+ @Override
+ public List<MgtStaffPageVo> pageMgtStaff(Page page, MgtStaffPageDto mgtStaffPageDto){
+ return sysStaffMapper.pageMgtStaff(page, mgtStaffPageDto);
+ }
+
+ /**
+ * @description
+ * @author jqs
+ * @date 2023/7/14 9:52
+ * @param mobile
+ * @return SysStaff
+ */
+ @Override
+ public SysStaff getByMobile(String mobile){
+ LambdaQueryWrapper<SysStaff> queryWrapper = new LambdaQueryWrapper();
+ queryWrapper.eq(SysStaff::getDelFlag,0);
+ queryWrapper.eq(SysStaff::getStaffMobile,mobile);
+ return this.getOne(queryWrapper,false);
+ }
+
+
+ /**
+ * @description 同步组织架构
+ * @author jqs
+ * @date 2023/7/18 19:06
+ * @param
+ * @return void
+ */
+ @Override
+ public void synchronizeOrganizationalStructure(){
+ String accessToken = getQYToken();
+
+
+ }
+
+
+ /**
+ * @description 获取企业微信token
+ * @author jqs
+ * @date 2023/7/18 19:35
+ * @param
+ * @return String
+ */
+ private String getQYToken(){
+ String accessToken = redisService.getCacheObject(SecurityConstant.QY_TOKEN);
+ if(StringUtils.isBlank(accessToken)){
+ try {
+ accessToken = QiYeUtils.getAccessTokenByQY();
+ JSONObject jsonAccessToken = JSONObject.parseObject(accessToken);
+ String errcode = jsonAccessToken.getString("errcode");
+ String errmsg = jsonAccessToken.getString("errmsg");
+ if(errcode.equals("0")){
+ accessToken = jsonAccessToken.getString("access_token");
+ Long expiresIn = jsonAccessToken.getLong("expires_in");
+ expiresIn = expiresIn -100;
+ redisService.setCacheObject(SecurityConstant.QY_TOKEN,accessToken,expiresIn, TimeUnit.SECONDS);
+ }else{
+ throw new ServiceException(errmsg);
+ }
+ } catch (Exception e) {
+ throw new RuntimeException(e);
+ }
+ }
+ return accessToken;
+ }
+
+
+ /**
+ * @description 编辑商户员工
+ * @author jqs
+ * @date 2023/7/19 19:42
+ * @param merEditUserDto
+ * @return void
+ */
+ @Override
+ public void editSysStaffInfo(MerEditUserDto merEditUserDto){
+ SysStaff sysStaff = this.getByUserId(merEditUserDto.getUserId());
+ Integer editType = merEditUserDto.getEditType();
+ switch (editType){
+ case 1:
+ sysStaff.setStaffName(merEditUserDto.getEditValue());
+ break;
+ case 2:
+ sysStaff.setStaffAvatar(merEditUserDto.getEditValue());
+ break;
+ case 3:
+ break;
+ case 4:
+ break;
+ default:
+ break;
+ }
+ this.saveOrUpdate(sysStaff);
+ }
}
--
Gitblit v1.7.1