From 6c40e04eb7c2060feb2533735cd3089d438965e5 Mon Sep 17 00:00:00 2001 From: nidapeng <jp@doumee.com> Date: 星期二, 19 三月 2024 17:19:36 +0800 Subject: [PATCH] 整理 --- server/dmvisit_service/src/main/java/com/doumee/service/business/impl/DeviceRoleServiceImpl.java | 303 ++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 291 insertions(+), 12 deletions(-) diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/DeviceRoleServiceImpl.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/DeviceRoleServiceImpl.java index 9409027..a8dcc10 100644 --- a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/DeviceRoleServiceImpl.java +++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/DeviceRoleServiceImpl.java @@ -1,20 +1,43 @@ package com.doumee.service.business.impl; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.extension.api.R; +import com.doumee.core.constants.ResponseStatus; +import com.doumee.core.exception.BusinessException; +import com.doumee.core.model.LoginUserInfo; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; +import com.doumee.core.erp.model.openapi.request.RoleListRequest; +import com.doumee.core.erp.model.openapi.response.DeviceListResponse; +import com.doumee.core.erp.model.openapi.response.RoleListResponse; +import com.doumee.core.utils.Constants; import com.doumee.core.utils.Utils; -import com.doumee.dao.business.DeviceRoleMapper; -import com.doumee.dao.business.model.DeviceRole; +import com.doumee.dao.admin.response.MemberInfoDTO; +import com.doumee.dao.business.*; +import com.doumee.dao.business.join.MemberRoleJoinMapper; +import com.doumee.dao.business.model.*; +import com.doumee.dao.web.response.DeviceRoleVO; import com.doumee.service.business.DeviceRoleService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.doumee.service.business.MemberService; +import com.doumee.service.business.impl.hksync.ferp.HkSyncOrgUserToHKServiceImpl; +import com.github.yulichang.wrapper.MPJLambdaWrapper; +import io.swagger.models.auth.In; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections.CollectionUtils; +import org.apache.commons.lang3.StringUtils; +import org.apache.shiro.SecurityUtils; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.annotation.Bean; import org.springframework.stereotype.Service; -import org.springframework.util.CollectionUtils; -import java.util.List; + +import java.util.*; +import java.util.stream.Collectors; /** * 闂ㄧ瑙掕壊淇℃伅琛⊿ervice瀹炵幇 @@ -22,15 +45,69 @@ * @date 2023/11/30 15:33 */ @Service +@Slf4j public class DeviceRoleServiceImpl implements DeviceRoleService { @Autowired private DeviceRoleMapper deviceRoleMapper; + @Autowired + private MemberCardMapper memberCardMapper; + @Autowired + private EmpowerMapper empowerMapper; + + @Autowired + private DeviceMapper deviceMapper; + @Autowired + private MemberRoleJoinMapper memberRoleMapper; + @Autowired + private MemberMapper memberMapper; + @Override public Integer create(DeviceRole deviceRole) { - deviceRoleMapper.insert(deviceRole); - return deviceRole.getId(); + if(Objects.isNull(deviceRole) + || StringUtils.isBlank(deviceRole.getName()) + || Objects.isNull(deviceRole.getType()) + || Objects.isNull(deviceRole.getIsDefault()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + // 鑾峰彇涔嬪墠鏄惁瀛樺湪榛樿闂ㄧ缁� + DeviceRole newDeviceRole = null; + if(null != deviceRole.getType()) { + newDeviceRole = getDeviceRole(deviceRole.getType()); + } + LoginUserInfo loginUserInfo = (LoginUserInfo)SecurityUtils.getSubject().getPrincipal(); + if(null != newDeviceRole && deviceRole.getIsDefault().equals(Constants.ZERO)) { + DeviceRole updateDeviceRole = new DeviceRole(); + // 鑻ョ幇鍦ㄦ柊澧炴暟鎹缃粯璁ら棬绂佺粍锛涢偅涔堝厛鎶婁箣鍓嶇殑榛樿闂ㄧ缁勭姸鎬佹敼涓轰笉鏄粯璁ょ殑 + updateDeviceRole.setId(newDeviceRole.getId()); + updateDeviceRole.setEdirot(loginUserInfo.getId().toString()); + updateDeviceRole.setEditDate(new Date()); + updateDeviceRole.setIsDefault(Constants.ONE); + deviceRoleMapper.updateById(updateDeviceRole); + } + DeviceRole insert = new DeviceRole(); + insert.setCreator(loginUserInfo.getId().toString()); + insert.setCreateDate(new Date()); + insert.setEdirot(loginUserInfo.getId().toString()); + insert.setEditDate(new Date()); + insert.setIsdeleted(Constants.ZERO); + insert.setRemark(deviceRole.getRemark()); + insert.setName(deviceRole.getName()); + insert.setIsDefault(deviceRole.getIsDefault()); + insert.setType(deviceRole.getType()); + insert.setDoorIds(deviceRole.getDoorIds()); + insert.setDoorNames(deviceRole.getDoorNames()); + insert.setParkIds(deviceRole.getParkIds()); + insert.setParkNames(deviceRole.getParkNames()); + insert.setStatus(deviceRole.getStatus()); + insert.setHkId(deviceRole.getHkId()); + insert.setHkStatus(deviceRole.getHkStatus()); + insert.setHkDate(deviceRole.getHkDate()); + + deviceRoleMapper.insert(insert); + return insert.getId(); } @Override @@ -54,7 +131,166 @@ @Override public void updateById(DeviceRole deviceRole) { - deviceRoleMapper.updateById(deviceRole); + DeviceRole model = deviceRoleMapper.selectById(deviceRole.getId()); + if(model == null){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + DeviceRole newDeviceRole = null; + if(null != deviceRole.getType()) { + newDeviceRole = getDeviceRole(deviceRole.getType()); + } + LoginUserInfo loginUserInfo = (LoginUserInfo)SecurityUtils.getSubject().getPrincipal(); + if(null != newDeviceRole && deviceRole.getIsDefault().equals(Constants.ZERO)) { + DeviceRole update = new DeviceRole(); + update.setEdirot(loginUserInfo.getId().toString()); + update.setEditDate(new Date()); + update.setId(newDeviceRole.getId()); + update.setIsDefault(Constants.ONE); + deviceRoleMapper.updateById(update); + } + int t = deviceRoleMapper.updateById(deviceRole); + if(t>0){ + Thread tt = new Thread(new Runnable() { + @Override + public void run() { + try { + startUpdateMemberEmpower(model,deviceRole); + }catch (Exception e){ + log.error("======闂ㄧ鍒嗙粍淇敼锛屾洿鏂颁汉鍛樻潈闄愬け璐�==="+e.getMessage()); + } + } + }); + tt.start(); + } + } + + /** + * 鏇存柊璇ユ潈闄愪笅鐩稿叧鐨勪汉鍛樻渶鏂板叏鏂颁笅鍙� + * @param model + * @param deviceRole + */ + private void startUpdateMemberEmpower(DeviceRole model, DeviceRole deviceRole) { + String[] ids = StringUtils.defaultString(model.getDoorIds()).split(","); + String[] newIds =StringUtils.defaultString(deviceRole.getDoorIds()).split(","); + List<Integer> delIds = getChangeIdsByArray(newIds,ids);//鍒犻櫎鐨勮澶� + List<Integer> addIds = getChangeIdsByArray(ids,newIds);//鏈�鏂拌澶� + if((addIds==null ||addIds.size()==0)&&( delIds ==null || delIds.size() == 0 )){ + //濡傛灉娌℃湁鍙樺寲锛屼笉鍋氬鐞� + return; + } + List<Integer> allids = getChangeIdsByArray(new String[]{},newIds);//鏈�鏂拌澶� + List<MemberRole> memberRoleList = memberRoleMapper.selectList(new QueryWrapper<MemberRole>().lambda() + .eq(MemberRole::getRoleId,model.getId()) + .eq(MemberRole::getIsdeleted,Constants.ZERO) + ); + if(memberRoleList!=null && memberRoleList.size()>0){ + for(MemberRole memberRole : memberRoleList){ + //濡傛灉鏈変汉鍛樻巿鏉冧簡璇ユ潈闄� + Member member = memberMapper.selectById(memberRole.getMemberId()); + if(member==null || member.getIsdeleted().equals(Constants.ONE)){ + continue; + } + MPJLambdaWrapper<MemberRole> queryWrapper = new MPJLambdaWrapper<>(); + queryWrapper.leftJoin(DeviceRole.class,DeviceRole::getId,MemberRole::getRoleId ); + queryWrapper.selectAll(MemberRole.class) + .selectAs(DeviceRole::getDoorIds, MemberRole::getDoorIds) + .eq(MemberRole::getMemberId,memberRole.getMemberId()) + .eq(MemberRole::getIsdeleted,Constants.ZERO) + .ne(MemberRole::getRoleId,deviceRole.getId()); + List<MemberRole> tLis = memberRoleMapper.selectJoinList(MemberRole.class,queryWrapper); + List<Integer> actDelIds = getActChangeDoorIds(tLis,delIds); + List<Integer> actAddIds = getActChangeDoorIds(tLis,allids); + HkSyncOrgUserToHKServiceImpl.dealChangeDeviceRoleEmpower(member,actAddIds,actDelIds,deviceRoleMapper,empowerMapper,deviceMapper); + } + } + } + + /** + * 鏍规嵁鐢ㄦ埛褰撳墠鏈�鏂扮殑闂ㄧ瑙掕壊锛屾煡璇㈠疄闄呭簲璇ュ垹闄ゆ垨鑰呭鍔犵殑闂ㄧ鐐规潈闄� + * @param tLis + * @param changeIds + * @return + */ + private List<Integer> getActChangeDoorIds(List<MemberRole> tLis, List<Integer> changeIds) { + List<Integer> list = new ArrayList<>(); + for(MemberRole memberRole : tLis){ + String[] ids = StringUtils.defaultString(memberRole.getDoorIds()).split(","); + if(ids!=null && ids.length>0){ + for (String s:ids){ + list.add(Integer.parseInt(s)); + } + } + } + List<Integer> actList = new ArrayList<>(); + if(list.size()>0){ + Flag: + for (Integer t : changeIds){ + for (Integer tt : list){ + if(Constants.equalsInteger(t,tt)){ + continue Flag; + } + } + actList.add(t); + } + } + return actList; + } + + private List<Integer> getChangeIdsByArray(String[] ids, String[] newIds) { + List<Integer> list = new ArrayList<>(); + if(newIds!=null){ + FLAG : + for(String s :newIds){ + for(String s1 :ids){ + if(StringUtils.equals(s,s1)){ + continue FLAG; + } + } + list.add(Integer.parseInt(s)); + } + } + return list; + } + @Override + public void updateStatusById(DeviceRole deviceRole) { + // 鑾峰彇涔嬪墠鏄惁瀛樺湪榛樿闂ㄧ缁� + DeviceRole newDeviceRole = null; + if(null != deviceRole.getType()) { + newDeviceRole = getDeviceRole(deviceRole.getType()); + } + LoginUserInfo loginUserInfo = (LoginUserInfo)SecurityUtils.getSubject().getPrincipal(); + List<DeviceRole> deviceRoleList = new ArrayList<>(); + if(null != newDeviceRole) { + DeviceRole update = new DeviceRole(); + update.setEdirot(loginUserInfo.getId().toString()); + update.setEditDate(new Date()); + update.setId(newDeviceRole.getId()); + update.setStatus(newDeviceRole.getStatus()); + update.setIsDefault(Constants.ONE); + deviceRoleList.add(update); + } + DeviceRole updateTwo = new DeviceRole(); + updateTwo.setEdirot(loginUserInfo.getId().toString()); + updateTwo.setEditDate(new Date()); + updateTwo.setId(deviceRole.getId()); + updateTwo.setStatus(deviceRole.getStatus()); + updateTwo.setIsDefault(deviceRole.getIsDefault()); + deviceRoleList.add(updateTwo); + // 鏈�澶�2鏉★紝鎵�鏈夊氨娌℃湁鍐欐壒閲忎慨鏀逛簡 + for (DeviceRole data:deviceRoleList) { + deviceRoleMapper.updateById(data); + } + } + + private DeviceRole getDeviceRole(String type) { + LambdaQueryWrapper<DeviceRole> query = new LambdaQueryWrapper<>(); + query.eq(DeviceRole::getIsdeleted,Constants.ZERO) + .eq(DeviceRole::getIsDefault,Constants.ZERO) + .eq(DeviceRole::getType,type) + .last(" limit 1"); + // 鏌ヨ鏄惁鏈夐粯璁ら棬绂佺粍锛屽彧鑳芥湁涓�缁勯粯璁ら棬绂佺粍 + DeviceRole getDeviceRole = deviceRoleMapper.selectOne(query); + return getDeviceRole; } @Override @@ -83,12 +319,13 @@ QueryWrapper<DeviceRole> wrapper = new QueryWrapper<>(deviceRole); return deviceRoleMapper.selectList(wrapper); } - + @Override public PageData<DeviceRole> findPage(PageWrap<DeviceRole> pageWrap) { IPage<DeviceRole> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); QueryWrapper<DeviceRole> queryWrapper = new QueryWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); + pageWrap.getModel().setIsdeleted(Constants.ZERO); if (pageWrap.getModel().getId() != null) { queryWrapper.lambda().eq(DeviceRole::getId, pageWrap.getModel().getId()); } @@ -113,13 +350,20 @@ queryWrapper.lambda().eq(DeviceRole::getRemark, pageWrap.getModel().getRemark()); } if (pageWrap.getModel().getName() != null) { - queryWrapper.lambda().eq(DeviceRole::getName, pageWrap.getModel().getName()); + queryWrapper.lambda().like(DeviceRole::getName, pageWrap.getModel().getName()); } if (pageWrap.getModel().getIsDefault() != null) { queryWrapper.lambda().eq(DeviceRole::getIsDefault, pageWrap.getModel().getIsDefault()); } - if (pageWrap.getModel().getType() != null) { - queryWrapper.lambda().eq(DeviceRole::getType, pageWrap.getModel().getType()); + if (StringUtils.isNotBlank(pageWrap.getModel().getType())) { + if(pageWrap.getModel().getType().length() > 1) { + String[] types = pageWrap.getModel().getType().split(","); + queryWrapper.lambda().and(p-> p.eq(DeviceRole::getType, types[0]) + .or() + .eq(DeviceRole::getType, types[1])); + }else { + queryWrapper.lambda().eq(DeviceRole::getType, pageWrap.getModel().getType()); + } } if (pageWrap.getModel().getDoorIds() != null) { queryWrapper.lambda().eq(DeviceRole::getDoorIds, pageWrap.getModel().getDoorIds()); @@ -143,7 +387,19 @@ queryWrapper.orderByAsc(sortData.getProperty()); } } - return PageData.from(deviceRoleMapper.selectPage(page, queryWrapper)); + queryWrapper.lambda().orderByAsc( DeviceRole::getName); + IPage<DeviceRole> newPage = deviceRoleMapper.selectPage(page, queryWrapper); + if(null != newPage && newPage.getRecords().size() > 0) { + List<DeviceRole> deviceRoleList = newPage.getRecords(); + for (DeviceRole dto:deviceRoleList) { + Member member = new Member(); + member.setIsdeleted(Constants.ZERO); + member.setRoleIdParam("["+dto.getId()+"]"); + dto.setMemberNum( memberMapper.selectCount(new QueryWrapper<>(member))); + } + newPage.setRecords(deviceRoleList); + } + return PageData.from(newPage); } @Override @@ -151,4 +407,27 @@ QueryWrapper<DeviceRole> wrapper = new QueryWrapper<>(deviceRole); return deviceRoleMapper.selectCount(wrapper); } + + @Override + public List<DeviceRoleVO> findListByType(Integer type) { + List<DeviceRole> deviceRoleList = deviceRoleMapper.selectList(new QueryWrapper<DeviceRole>().lambda() + .eq(DeviceRole::getType,type) + .eq(DeviceRole::getIsdeleted, Constants.ZERO) + .eq(DeviceRole::getStatus, Constants.ONE) + ); + List<DeviceRoleVO> deviceRoleVOList = new ArrayList<>(); + for (DeviceRole deviceRole:deviceRoleList) { + DeviceRoleVO deviceRoleVO = new DeviceRoleVO(); + BeanUtils.copyProperties(deviceRole,deviceRoleVO); + deviceRoleVOList.add(deviceRoleVO); + } + return deviceRoleVOList; + } + + + + + + + } -- Gitblit v1.9.3