From cbaf83881759106a3e4ff1fa784b5ad99137463c Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期一, 08 一月 2024 09:36:37 +0800
Subject: [PATCH] Merge branch 'master' of http://139.186.142.91:10010/r/productDev/dmvisit

---
 server/dmvisit_service/src/main/java/com/doumee/service/business/impl/erp/ErpSyncServiceImpl.java |   89 ++++++++++++++++++++++++++++++--------------
 1 files changed, 60 insertions(+), 29 deletions(-)

diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/erp/ErpSyncServiceImpl.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/erp/ErpSyncServiceImpl.java
index 8d5026f..197b01a 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/erp/ErpSyncServiceImpl.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/erp/ErpSyncServiceImpl.java
@@ -122,6 +122,9 @@
     @Override
     @Transactional
     public String syncCompany(OrgListRequest param){
+        if(!StringUtils.equals(Constants.ONE+"", systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.ORG_USER_ORIGIN).getCode())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "瀵逛笉璧凤紝褰撳墠涓嶆敮鎸佺粍缁囧悓姝ユ搷浣渵");
+        }
         //鑾峰彇ERP缁勭粐淇℃伅锛堝叏閲忓悓姝ワ級
         List<ErpOrgListResponse>  list = ErpTool.getErpOrgList(ErpConstants.orgListUrl,param);
         if(list !=null && list.size()>0){
@@ -206,7 +209,9 @@
         company.setEditDate(date);
         company.setStatus(respone.getStatus());
         company.setCode(respone.getCode());
-        company.setErpParentId(respone.getParentOrgId());
+        if(StringUtils.isNotBlank(respone.getParentOrgId())&&!respone.getParentOrgId().equals("orgRoot")){
+            company.setErpParentId(respone.getParentOrgId());
+        }
         company.setErpDate(date);
         company.setHkStatus(Constants.ZERO);
         return  company;
@@ -219,13 +224,16 @@
      */
     private Company getAddCompanyModel(ErpOrgListResponse respone, Date date) {
         Company    company = new Company();
+        company.setStatus(respone.getStatus());
         company.setIsdeleted(Constants.ZERO);
         company.setName(respone.getName());
         company.setErpId(respone.getId());
         company.setCreateDate(date);
         company.setType(Constants.ONE);
         company.setCode(respone.getCode());
-        company.setErpParentId(respone.getParentOrgId());
+        if(StringUtils.isNotBlank(respone.getParentOrgId())&&!respone.getParentOrgId().equals("orgRoot")){
+            company.setErpParentId(respone.getParentOrgId());
+        }
         company.setErpDate(date);
         company.setHkStatus(Constants.ZERO);
         return  company;
@@ -262,6 +270,9 @@
     @Override
     @Transactional
     public  String syncUsers(UserListRequest param){
+        if(!StringUtils.equals(Constants.ONE+"", systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.ORG_USER_ORIGIN).getCode())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "瀵逛笉璧凤紝褰撳墠涓嶆敮鎸佷汉鍛樺悓姝ユ搷浣渵");
+        }
         List<ErpUserListResponse>  list = ErpTool.getErpUserList(ErpConstants.userListUrl,param);
         if(list !=null && list.size()>0) {
             List<Member> addList = new ArrayList<>();
@@ -273,10 +284,10 @@
                     .eq(Member::getType, Constants.memberType.internal));
             dealUserChangeList(list,addList,updateList,delList,allList);
             if(addList.size()>0){
+                memberMapper.insertBatchSomeColumn(addList);
                 for (Member member:addList) {
                     dealRoleEmpower(member,param.getStartTime(), param.getEndTime());
                 }
-                memberMapper.insertBatchSomeColumn(addList);
             }
             if(updateList.size()>0){
                 for(Member c : updateList){
@@ -298,7 +309,6 @@
         }else{
             throw  new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "鍚屾ERP鏁版嵁涓虹┖锛�");
         }
-
     }
 
     public void dealRoleEmpower(Member member,Date startTime , Date endTime){
@@ -317,7 +327,7 @@
                 company = companyMapper.selectOne(new QueryWrapper<Company>().lambda().eq(Company::getErpId,response.getOrgId()).last("limit 1"));
                 if(Objects.isNull(company)){
                     continue;
-                }    
+                }
             }
             //鏍规嵁 erpId 鏌ヨ鐢ㄦ埛淇℃伅锛屽垽鏂槸鏂板杩樻槸鏇存柊
             Member member = findUserByERPId(allList,response.getId());
@@ -353,17 +363,21 @@
         Member member = new Member();
         BeanUtils.copyProperties(param,member);
         member.setCreateDate(new Date());
-        member.setHkStatus(Constants.ZERO);
+        if(StringUtils.isBlank(param.getFaceImg())){
+            member.setHkStatus(Constants.THREE);
+        }else{
+            member.setHkStatus(Constants.ZERO);
+        }
         member.setErpStatus(Constants.ONE);
         member.setErpDate(new Date());
         member.setErpId(param.getId());
+        member.setIdcardType(param.getIdType());
         member.setFsStatus(Constants.ZERO);
         member.setStatus(param.getStatus());
         member.setType(Constants.memberType.internal);
         String encryptIdNo = DESUtil.encrypt(Constants.EDS_PWD,param.getIdNo());
         member.setIdcardNo(encryptIdNo);
         member.setIdcardDecode(Constants.getTuominStr(param.getIdNo()));
-        member.setHkStatus(Constants.ZERO);
         member.setRoleIds(param.getRoleIds());
         member.setCompanyId(Objects.isNull(company)?null:company.getId());
         member.setErpOrgId(param.getOrgId());
@@ -715,9 +729,9 @@
             if(Objects.isNull(param)
                     ||Objects.isNull(param.getId())
                     ||StringUtils.isBlank(param.getName())
-                    ||StringUtils.isBlank(param.getLinkName())
-                    ||StringUtils.isBlank(param.getLinkPhone())
-                    ||Objects.isNull(param.getEditDate())
+//                    ||StringUtils.isBlank(param.getLinkName())
+//                    ||StringUtils.isBlank(param.getLinkPhone())
+//                    ||Objects.isNull(param.getEditDate())
             ){
                 throw new BusinessException(ResponseStatus.BAD_REQUEST);
             }
@@ -729,6 +743,7 @@
                     throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌涓婄骇缁勭粐鏁版嵁");
                 }
             }
+            String rootOrgId = systemDictDataBiz.queryByCode(Constants.HK_PARAM,Constants.HK_ROOTORG_CODE).getCode();
             if(Objects.isNull(company)){
                 company = new Company();
                 company.setId(null);
@@ -736,9 +751,14 @@
                 company.setHkStatus(Constants.ZERO);
                 company.setErpStatus(Constants.ONE);
                 company.setErpDate(new Date());
+                company.setName(param.getName());
+               /* if(StringUtils.isNotBlank(param.getParentId())){
+                    company.setHkId(rootOrgId);
+                }*/
                 company.setErpId(param.getId());
                 company.setErpParentId(param.getParentId());
                 company.setParentId(Objects.isNull(parentCompany)?null:parentCompany.getId());
+                company.setErpParentId(param.getParentId());
                 company.setFsStatus(Constants.ZERO);
                 company.setType(Constants.ONE);
                 company.setLinkName(param.getLinkName());
@@ -749,8 +769,12 @@
 //                BeanUtils.copyProperties(param,company);
                 company.setEditDate(new Date());
                 company.setErpId(param.getId());
+            /*    if(StringUtils.isNotBlank(param.getParentId())){
+                    company.setHkId(rootOrgId);
+                }*/
                 company.setHkStatus(Constants.ZERO);
                 company.setErpDate(new Date());
+                company.setName(param.getName());
                 company.setErpParentId(param.getParentId());
                 company.setParentId(Objects.isNull(parentCompany)?null:parentCompany.getId());
                 company.setLinkName(param.getLinkName());
@@ -765,22 +789,20 @@
         }
     }
 
-
-
     @Override
     public void userUpdate(UserUpdateRequest param){
         try{
             if(Objects.isNull(param)
-                    ||Objects.isNull(param.getId())
-                    ||StringUtils.isBlank(param.getName())
-                    ||StringUtils.isBlank(param.getIdNo())
-                    ||Objects.isNull(param.getIdType())
-                    ||Objects.isNull(param.getSex())
-                    ||Objects.isNull(param.getOrgId())
-                    ||StringUtils.isNotBlank(param.getFaceImg())
-                    ||StringUtils.isNotBlank(param.getCode())
-                    ||StringUtils.isNotBlank(param.getPhone())
-                    ||Objects.isNull(param.getEditDate())){
+                    ||Objects.isNull(param.getId())//缂栫爜
+                    ||StringUtils.isBlank(param.getName())//鍚嶇О
+                    ||StringUtils.isBlank(param.getIdNo())//璇佷欢鍙�
+                    ||Objects.isNull(param.getIdType())//璇佷欢绫诲瀷
+                    ||Objects.isNull(param.getSex())//鎬у埆
+                    ||Objects.isNull(param.getOrgId())//鎵�灞炵粍缁囩紪鐮�
+                    ||StringUtils.isBlank(param.getFaceImg())//浜鸿劯鐓х墖
+                    ||StringUtils.isBlank(param.getCode())//宸ュ彿
+                    ||StringUtils.isBlank(param.getPhone())//鎵嬫満鍙�
+             ){
                 throw new BusinessException(ResponseStatus.BAD_REQUEST);
             }
             Member member = memberMapper.selectOne(new QueryWrapper<Member>().lambda().eq(Member::getErpId,param.getId()).last("limit 1"));
@@ -856,21 +878,26 @@
             }
         }
     }
-
     /**
      * //濡傛灉鏈夋巿鏉冮棬绂佹暟鎹紝杩涜鐢ㄦ埛鎺堟潈鏁版嵁涓嬪彂浠诲姟鍒涘缓
      * @param member
      */
     private void dealMemberRoleEmpower(Member member, List<Integer> doorIds,Date startTime,Date endTime ) {
         //鍒犻櫎鎵�鏈夎�佺殑鎺堟潈淇℃伅
-        empowerMapper.update(null,new UpdateWrapper<Empower>().lambda()
-                .eq(Empower::getMemberId,member.getId())
-                .set(Empower::getIsdeleted,Constants.ONE)
-                .set(Empower::getSendStatus,Constants.ZERO));
+        if(!Objects.isNull(member)&&!Objects.isNull(member.getId())){
+            empowerMapper.update(null,new UpdateWrapper<Empower>().lambda()
+                    .eq(Empower::getMemberId,member.getId())
+                    .set(Empower::getIsdeleted,Constants.ONE)
+                    .set(Empower::getSendStatus,Constants.ZERO));
+        }
+
 //        empowerMapper.delete(new UpdateWrapper<Empower>().lambda()
 //                .eq(Empower::getMemberId,member.getId())
 //                );
         if(doorIds==null || doorIds.size() == 0){
+          return;
+        }
+        if(StringUtils.isBlank(member.getFaceImg())){
           return;
         }
         List<Empower> list = new ArrayList<>();
@@ -887,6 +914,8 @@
             model.setSendStatus(Constants.ZERO);
             model.setStartTime(startTime);
             model.setEndTime(endTime);
+            //榛樿缁欎簬铏氭嫙鍗�
+            model.setCardNos(Constants.VIRTUAL_CARD_INDEX+member.getId());
             model.setSendType(Constants.ZERO);
             list.add(model);
         }
@@ -896,7 +925,9 @@
 
     private   List<Integer>  getRoleIdByParam(Integer[] param, Member member) {
         //娣诲姞浜哄憳瑙掕壊鍏宠仈鏁版嵁
-        memberRoleMapper.delete(new QueryWrapper<MemberRole>().lambda().eq(MemberRole::getMemberId,member.getId()));
+        if(!Objects.isNull(member)&&!Objects.isNull(member.getId())){
+            memberRoleMapper.delete(new QueryWrapper<MemberRole>().lambda().eq(MemberRole::getMemberId,member.getId()));
+        }
         if(!Objects.isNull(param)&&param.length>Constants.ZERO){
             //鏌ヨ鏁版嵁搴撳瓨鍦ㄧ殑鏉冮檺
             List<DeviceRole> deviceRoleList= deviceRoleMapper.selectList(new QueryWrapper<DeviceRole>().lambda()
@@ -972,7 +1003,7 @@
                 .set(ParkBook::getHkStatus,Constants.ZERO)
         );
         //鏌ヨ杞﹀簱淇℃伅
-        List<Parks> parksList = parksMapper.selectList(new QueryWrapper<Parks>().lambda().in(Parks::getId,param.getPartIdList()));
+        List<Parks> parksList = parksMapper.selectList(new QueryWrapper<Parks>().lambda().in(Parks::getId,param.getParkIdList()));
         if(CollectionUtils.isNotEmpty(parksList)){
             List<ParkBook> parkBookList = new ArrayList<>();
             for (Parks parks:parksList) {

--
Gitblit v1.9.3