From b89c0df6f99cff6a852306da467b053aa4f90df8 Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期二, 09 一月 2024 13:47:23 +0800
Subject: [PATCH] ERP接口

---
 server/dmvisit_service/src/main/java/com/doumee/service/business/impl/erp/ErpSyncServiceImpl.java |   65 +++++++++++++++++++-------------
 1 files changed, 38 insertions(+), 27 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 197b01a..ce6f23e 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
@@ -291,7 +291,7 @@
             }
             if(updateList.size()>0){
                 for(Member c : updateList){
-                    dealRoleEmpower(c,param.getStartTime(), param.getEndTime());
+                     dealRoleEmpower(c,param.getStartTime(), param.getEndTime());
                     c.setHkStatus(Constants.ZERO);
                     memberMapper.updateById(c);
                 }
@@ -620,10 +620,10 @@
             queryWrapper.selectAs(DeviceEvent::getUserType,DoorEventListResponse::getType);
             queryWrapper.selectAs(DeviceEvent::getExtEventInOut,DoorEventListResponse::getEventInOut);
             queryWrapper.selectAs(DeviceEvent::getExtAccessChannel,DoorEventListResponse::getExtAccessChannel);
-            queryWrapper.selectAs(DeviceEvent::getCreateDate,DoorEventListResponse::getCreateTime);
+            queryWrapper.selectAs(DeviceEvent::getHappenTime,DoorEventListResponse::getCreateTime);
             queryWrapper.selectAs(Member::getPhone,DoorEventListResponse::getPhone);
             queryWrapper.selectAs(Member::getErpId,DoorEventListResponse::getUserId);
-            queryWrapper.selectAs(Member::getCompanyId,DoorEventListResponse::getOrgId);
+            queryWrapper.selectAs(Member::getErpOrgId,DoorEventListResponse::getOrgId);
             queryWrapper.leftJoin(Member.class,Member::getHkId,DeviceEvent::getExtEventPersonNo);
 
             if(!Objects.isNull(doorEventListRequest)){
@@ -799,7 +799,7 @@
                     ||Objects.isNull(param.getIdType())//璇佷欢绫诲瀷
                     ||Objects.isNull(param.getSex())//鎬у埆
                     ||Objects.isNull(param.getOrgId())//鎵�灞炵粍缁囩紪鐮�
-                    ||StringUtils.isBlank(param.getFaceImg())//浜鸿劯鐓х墖
+//                    ||StringUtils.isBlank(param.getFaceImg())//浜鸿劯鐓х墖
                     ||StringUtils.isBlank(param.getCode())//宸ュ彿
                     ||StringUtils.isBlank(param.getPhone())//鎵嬫満鍙�
              ){
@@ -824,11 +824,12 @@
                 member.setType(Constants.memberType.internal);
                 String encryptIdNo = DESUtil.encrypt(Constants.EDS_PWD,param.getIdNo());
                 member.setIdcardNo(encryptIdNo);
+                member.setStartTime(param.getValidStartTime());
+                member.setEndTime(param.getValidEndTime());
                 member.setIdcardDecode(Constants.getTuominStr(param.getIdNo()));
                 member.setErpOrgId(param.getOrgId());
                 doorIds = getRoleIdByParam(param.getRoleIds(),member);
                 memberMapper.insert(member);
-                //TODO 娴峰悍鏁版嵁鍒涘缓-------------淇敼-------------------
             }else{
                 Integer id = member.getId();
                 BeanUtils.copyProperties(param,member);
@@ -841,10 +842,11 @@
                 doorIds = getRoleIdByParam(param.getRoleIds(),member);
                 member.setErpDate(new Date());
                 member.setHkStatus(Constants.ZERO);
+                member.setStartTime(param.getValidStartTime());
+                member.setEndTime(param.getValidEndTime());
                 memberMapper.updateById(member);
                 //鍒犻櫎鐢ㄦ埛鍗$墖鏁版嵁  浜哄憳瑙掕壊鍏宠仈
                 memberCardMapper.delete(new QueryWrapper<MemberCard>().lambda().eq(MemberCard::getMemberId,member.getId()));
-                //TODO 娴峰悍鏁版嵁鏇存柊
             }
             //濡傛灉鏈夋巿鏉冮棬绂佹暟鎹紝杩涜鐢ㄦ埛鎺堟潈鏁版嵁涓嬪彂浠诲姟鍒涘缓
             dealMemberRoleEmpower(member,doorIds,param.getValidStartTime(),param.getValidEndTime());
@@ -900,27 +902,30 @@
         if(StringUtils.isBlank(member.getFaceImg())){
           return;
         }
-        List<Empower> list = new ArrayList<>();
-        List<Device> deviceList = deviceMapper.selectList(new QueryWrapper<Device>().lambda().in(Device::getId,doorIds));
-        if(deviceList == null || deviceList.size() == 0){
-            return;
+        if(Constants.equalsObject(member.getHkStatus(),Constants.ONE)){
+            //濡傛灉鐢ㄦ埛鏄悓姝ユ捣搴锋垚鍔燂紝娣诲姞甯︿笅鍙戞潈闄�
+            List<Empower> list = new ArrayList<>();
+            List<Device> deviceList = deviceMapper.selectList(new QueryWrapper<Device>().lambda().in(Device::getId,doorIds));
+            if(deviceList == null || deviceList.size() == 0){
+                return;
+            }
+            for (Device deviceRole:deviceList) {
+                Empower model = new Empower();
+                model.setCreateDate(new Date());
+                model.setMemberId(member.getId());
+                model.setIsdeleted(Constants.ZERO);
+                model.setDeviceId(deviceRole.getId());
+                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);
+            }
+            //瀵煎叆鏂板鐨勬巿鏉冧俊鎭�
+            empowerMapper.insertBatchSomeColumn(list);
         }
-        for (Device deviceRole:deviceList) {
-            Empower model = new Empower();
-            model.setCreateDate(new Date());
-            model.setMemberId(member.getId());
-            model.setIsdeleted(Constants.ZERO);
-            model.setDeviceId(deviceRole.getId());
-            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);
-        }
-        //瀵煎叆鏂板鐨勬巿鏉冧俊鎭�
-        empowerMapper.insertBatchSomeColumn(list);
     }
 
     private   List<Integer>  getRoleIdByParam(Integer[] param, Member member) {
@@ -964,7 +969,6 @@
                 }
                 memberRoleMapper.insertBatchSomeColumn(memberRoleList);
                 member.setRoleId(ids);
-
                 return  r;
             }
         }
@@ -982,6 +986,13 @@
             return;
         }
         List<Integer> doorIds = getRoleIdByParam(param.getRoleIds(),member);
+        //鏇存柊鎺堟潈鏈夋晥鏈�
+        Member update = new Member();
+        update.setId(member.getId());
+        update.setEditDate(new Date());
+        update.setStartTime(param.getValidStartTime());
+        update.setEndTime(param.getValidEndTime());
+        memberMapper.updateById(update);
         //濡傛灉鏈夋巿鏉冮棬绂佹暟鎹紝杩涜鐢ㄦ埛鎺堟潈鏁版嵁涓嬪彂浠诲姟鍒涘缓
         dealMemberRoleEmpower(member,doorIds,param.getValidStartTime(),param.getValidEndTime());
 

--
Gitblit v1.9.3