From ddf3d6493849d77ae6dd8350eb80ee71fad03c6a Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期四, 07 十二月 2023 17:35:48 +0800
Subject: [PATCH] 海康接口对接开发

---
 server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java |  246 +++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 219 insertions(+), 27 deletions(-)

diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
index 041f876..d41ae86 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
@@ -4,6 +4,13 @@
 import com.doumee.biz.system.SystemDictDataBiz;
 import com.doumee.core.constants.ResponseStatus;
 import com.doumee.core.exception.BusinessException;
+import com.doumee.core.haikang.model.HKConstants;
+import com.doumee.core.haikang.model.HKTools;
+import com.doumee.core.haikang.model.param.BaseResponse;
+import com.doumee.core.haikang.model.param.request.VisitAppointmentCancelRequest;
+import com.doumee.core.haikang.model.param.request.VisitAppointmentRequest;
+import com.doumee.core.haikang.model.param.respose.VisitAppointmentResponse;
+import com.doumee.core.haikang.service.HKService;
 import com.doumee.core.model.PageData;
 import com.doumee.core.model.PageWrap;
 import com.doumee.core.utils.Constants;
@@ -25,9 +32,11 @@
 import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.DigestUtils;
 
+import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.Date;
 import java.util.List;
@@ -63,18 +72,9 @@
      * @return
      */
     @Override
+    @Transactional(rollbackFor = {BusinessException.class,Exception.class})
     public Integer createFk(Visits visits) {
-        if(visits.getStarttime() == null
-                || visits.getEndtime() == null
-                ||  StringUtils.isBlank(visits.getReason())
-                ||  StringUtils.isBlank( visits.getName())
-                ||  StringUtils.isBlank( visits.getPhone())
-                ||  visits.getIdcardType() == null
-                ||  StringUtils.isBlank( visits.getFaceImg() )
-                ||  StringUtils.isBlank( visits.getIdcardNo() )
-                || visits.getReceptMemberId() == null){
-            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝淇℃伅濉啓涓嶆纭紒");
-        }
+        isValidBaseParam(visits);
         //妫�鏌ユ槸鍚﹀繀椤荤瓟棰橈紝骞朵笖绗﹀悎绛旈瑕佹眰
         ProblemLog problemLog = isValidProblemLog(visits);
         //鑾峰彇鐢宠鐨勬捣搴疯闂棬绂佺粍淇℃伅
@@ -88,31 +88,223 @@
             throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝韬唤璇佸彿鐮佹湁璇紝璇锋牳瀹炲悗閲嶈瘯锛�");
         }
         Date date = new Date();
-
-        visits.setBirthday(Constants.getBirthdyByCardNo(visits.getIdcardNo()));
-        //韬唤璇佸彿瀛樺偍瀵嗘枃
-        visits.setIdcardNo(DESUtil.encrypt(Constants.EDS_PWD, visits.getIdcardNo()));//韬唤璇佸彿鍔犲瘑
-        visits.setIdcardDecode(Constants.getTuominStr(visits.getIdcardNo()));//鑴辨晱鎵嬫満鍙�
-        visits.setCreateDate(date);
-
         //璁垮淇℃伅(浣跨敤韬唤璇佸彿鏌ヨ鏄惁宸插瓨鍦ㄦ敼鏅�氳瀹紝娌℃湁鍒欐柊澧烇紝瀛樺湪鍒欐洿鏂皁penid绛変俊鎭�)
-        Member member = getMemberByIdcardno(visits);
+        Member member =dealMemberAndVisits(visits);
+        //鍒濆鍖栬瀹俊鎭�
+        initVisitInfo(visits,date);
+        //鍙戣捣ERP瀹℃壒鐢宠
+        String erpid = startSendErpCheck(visits);
+        if(StringUtils.isNotBlank(erpid)){
+            visits.setErpId(erpid);
+        }else{
+            throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(), "瀵逛笉璧凤紝鍙戣捣鎷滆瀹℃壒鐢宠澶辫触锛�");
+        }
         visitsMapper.insert(visits);
-
-
+        initWithVisitInfo(visits);
         updateProblemLog(visits,problemLog,member);
-
         return visits.getId();
     }
 
-    private Member getMemberByIdcardno(Visits idcardNo) {
-        Member member = memberMapper.selectOne(new QueryWrapper<Member>().lambda()
-//                .eq(Member::getType,Constants.MEMBER_TYPE)
-                .eq(Member::getIdcardNo,idcardNo.getIdcardNo())
-        );
+    /**
+     * 鏍¢獙蹇呭~椤规暟鎹槸鍚﹀悎娉�
+     * @param visits
+     */
+    private void isValidBaseParam(Visits visits) {
+        if(visits.getStarttime() == null
+                || visits.getEndtime() == null
+                ||  StringUtils.isBlank(visits.getReason())
+                ||  StringUtils.isBlank( visits.getName())
+                ||  StringUtils.isBlank( visits.getPhone())
+                ||  visits.getIdcardType() == null
+                ||  StringUtils.isBlank( visits.getFaceImg() )
+                ||  StringUtils.isBlank( visits.getIdcardNo() )
+                || visits.getReceptMemberId() == null){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝淇℃伅濉啓涓嶆纭紒");
+        }
+        if(visits.getStarttime().getTime() < System.currentTimeMillis()){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝棰勭害寮�濮嬫椂闂村繀椤诲ぇ浜庡綋鍓嶆椂闂达紒");//
+        }
+        if(visits.getEndtime().getTime() <= visits.getStarttime().getTime()){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝棰勭害缁撴潫鏃堕棿蹇呴』澶т簬寮�濮嬫椂闂达紒");//
+        }
+    }
+    private void isValidWithVisitParam(Visits visits,  List<Member> addList,  List<Member> updateList) {
+        if(  StringUtils.isBlank( visits.getName())
+                ||  StringUtils.isBlank( visits.getPhone())
+                ||  visits.getIdcardType() == null
+                ||  StringUtils.isBlank( visits.getFaceImg() )
+                ||  StringUtils.isBlank( visits.getIdcardNo() )
+                ){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝淇℃伅濉啓涓嶆纭紒");
+        }
+        if(visits.getStarttime().getTime() < System.currentTimeMillis()){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝棰勭害寮�濮嬫椂闂村繀椤诲ぇ浜庡綋鍓嶆椂闂达紒");//
+        }
+        if(visits.getEndtime().getTime() <= visits.getStarttime().getTime()){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝棰勭害缁撴潫鏃堕棿蹇呴』澶т簬寮�濮嬫椂闂达紒");//
+        }
+        if(isRepeatedMember(visits,addList,updateList)){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝鎵嬫満鍙锋垨韬唤璇佸彿鍑虹幇閲嶅鏁版嵁锛岃淇敼鍚庨噸鏂版彁浜わ紒");//
+        }
+    }
+
+    private boolean isRepeatedMember(Visits visits, List<Member> addList, List<Member> updateList) {
+        if(addList.size()>0){
+            for(Member m :addList){
+                if(StringUtils.equals(visits.getPhone(), m.getPhone()) || StringUtils.equals(visits.getIdcardNo(), m.getIdcardDecode())){
+                    return true;
+                }
+            }
+        }
+        if(updateList.size()>0){
+            for(Member m :updateList){
+                if(StringUtils.equals(visits.getPhone(), m.getPhone()) || StringUtils.equals(visits.getIdcardNo(), m.getIdcardDecode())){
+                    return true;
+                }
+            }
+        }
+        return  false;
+    }
+
+    private void initWithVisitInfo(Visits visits) {
+        if(visits.getWithUserList()!=null && visits.getLwWithUserList().size()>0){
+            for(Visits v :visits.getWithUserList()){
+                v.setParentId(visits.getId());
+                v.setStarttime(visits.getStarttime());
+                v.setEndtime(visits.getEndtime());
+                v.setIsdeleted(Constants.ZERO);
+                v.setCreateDate(visits.getCreateDate());
+                v.setErpId(visits.getErpId());
+                v.setHkStatus(Constants.ZERO);
+                v.setStatus(Constants.ZERO);
+            }
+            //鎵归噺鎻掑叆鏁版嵁
+            visitsMapper.insertBatchSomeColumn(visits.getWithUserList());
+        }
+    }
+
+    private void initVisitInfo(Visits visits,Date date) {
+        visits.setHkStatus(Constants.ZERO);//鏈悓姝�
+        visits.setBirthday(Constants.getBirthdyByCardNo(visits.getIdcardNo()));
+        visits.setStatus(Constants.ZERO);//寰呭鎵�
+        visits.setIdcardNo(DESUtil.encrypt(Constants.EDS_PWD, visits.getIdcardNo()));//韬唤璇佸彿鍔犲瘑
+        //韬唤璇佸彿瀛樺偍瀵嗘枃
+        visits.setIdcardDecode(Constants.getTuominStr(visits.getIdcardNo()));//鑴辨晱鎵嬫満鍙�
+        visits.setCreateDate(date);
+    }
+
+    private String startSendErpCheck(Visits visits) {
         return  null;
     }
 
+    private String visitAppiontment(Visits visits) {
+        VisitAppointmentRequest param = new VisitAppointmentRequest();
+        param.setVisitStartTime(HKTools.getISO8601Timestamp(visits.getStarttime()));
+        param.setVisitEndTime(HKTools.getISO8601Timestamp(visits.getStarttime()));
+        BaseResponse<VisitAppointmentResponse>  res = HKService.visitAppiontment(param);
+        if(res==null || !StringUtils.equals(res.getCode(), HKConstants.RESPONSE_SUCCEE) || res.getData()==null){
+          //濡傛灉鍙戣捣棰勭害澶辫触
+            visits.setStatus(Constants.VisitStatus.xfFail);
+        }else{
+            visits.setStatus(Constants.VisitStatus.xfSuccess);
+            visits.setHkStatus(Constants.ONE);
+            visits.setHkId(res.getData().getAppointRecordId());
+        }
+        visits.setHkDate(visits.getCheckDate());
+        return  res.getData().getAppointRecordId();
+    }
+
+    /**
+     * 鏍¢鐢宠珛浜轰俊鎭紝鏈夊垯淇敼锛屾棤鍒欐柊澧烇紝骞剁粦瀹氭渶鏂皁penid鏁版嵁
+     * @param visits
+     * @return
+     */
+    private Member  dealMemberAndVisits(Visits visits ) {
+        if(StringUtils.isNotBlank(visits.getOpenid())){
+            //鍏堟竻绌哄師鏈夎瀹㈢殑openid缁戝畾鍏崇郴
+            memberMapper.update(null, new UpdateWrapper<Member>().lambda()
+                    .eq(Member::getType,Constants.memberType.visitor)
+                    .eq(Member::getOpenid,visits.getOpenid())
+                    .set(Member::getOpenid,null)
+            );
+        }
+        List<Member> addList = new ArrayList<>();
+        List<Member> editList = new ArrayList<>();
+        //鐢宠浜轰俊鎭�
+        Member m = getMemberListParam(visits.getIdcardNo(),visits,addList,editList);
+        //闅忚浜哄憳淇℃伅澶勭悊
+        if(visits.getWithUserList()!= null && visits.getWithUserList().size()>0){
+            for(Visits model:visits.getWithUserList()){
+                //鏍¢獙闅忚浜哄憳濉姤鏁版嵁鍚堟硶鎬�
+                isValidWithVisitParam(model,addList,editList);
+                model.setCreateDate(visits.getCreateDate());
+                getMemberListParam(model.getIdcardNo(),visits,addList,editList);
+            }
+        }
+        return  m;
+    }
+
+    private Member getMemberListParam(String cardno, Visits visits, List<Member> addList, List<Member> editList) {
+        if(!Constants.checkCarNo(visits.getCarNos())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀵逛笉璧凤紝杞︾墝鍙枫��"+visits.getCarNos()+"銆戜笉鍚堟硶锛岃鏍稿疄鍚庨噸璇晘");
+        }
+        Member member = memberMapper.selectOne(new QueryWrapper<Member>().lambda()
+                .eq(Member::getType,Constants.memberType.visitor)
+                .eq(Member::getIdcardType,visits.getIdcardType())
+                .eq(Member::getIdcardNo,visits.getIdcardNo()).last("limit 1" )
+        );
+        if(member == null){
+            //濡傛灉鐢ㄦ埛涓嶅瓨鍦紝鍒欐柊澧�
+            member.setCreateDate(visits.getCreateDate());
+            member.setIsdeleted(Constants.ZERO);
+            member.setIdcardNo(visits.getIdcardNo());
+            member.setIdcardDecode(visits.getIdcardDecode());
+            member.setIdcardNo(DESUtil.encrypt(Constants.EDS_PWD, cardno));//韬唤璇佸彿鍔犲瘑
+            member.setIdcardDecode(Constants.getTuominStr(cardno));//鑴辨晱鎵嬫満鍙�
+            member.setName(visits.getName());
+            member.setPhone(visits.getPhone());
+            member.setOpenid(visits.getOpenid());
+            member.setType(Constants.memberType.visitor);
+            member.setStatus(Constants.ZERO);
+            member.setSex(visits.getSex());
+            // 鏂板璁垮璁板綍
+            addList.add(member);
+        }else{
+            if(!Constants.equalsInteger(Constants.ZERO,member.getStatus() )){
+                //濡傛灉鐢ㄦ埛鐘舵�佸紓甯革紝鍒欐彁绀�
+                throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "瀵逛笉璧凤紝璇ヨ韩浠借瘉鍙疯绂佹璁块棶鐢宠锛屽鏈夌枒闂紝璇疯仈绯绘偍鐨勬嫓璁夸汉杩涜鏍稿疄");
+            }
+            //鏍告煡棰勭害鐢ㄦ埛鏄惁瀛樺湪鏈绂荤殑棰勭害璁板綍
+            isExsitNoOutVisisRecord(member);
+            member.setEditDate(visits.getCreateDate());
+            member.setIsdeleted(Constants.ZERO);
+            member.setIdcardNo(visits.getIdcardNo());
+            member.setIdcardDecode(visits.getIdcardDecode());
+            member.setName(visits.getName());
+            member.setPhone(visits.getPhone());
+            member.setOpenid(visits.getOpenid());
+            member.setSex(visits.getSex());
+            // 鏇存柊璁垮淇℃伅,
+            editList.add(member);
+        }
+        return  member;
+    }
+
+    /**
+     * 鏍告煡棰勭害鐢ㄦ埛鏄惁瀛樺湪鏈绂荤殑棰勭害璁板綍
+     * @param member
+     */
+    private void isExsitNoOutVisisRecord(Member member) {
+        Visits v = visitsMapper.selectOne(new QueryWrapper<Visits>().lambda()
+                .eq(Visits::getPhone, member.getPhone())
+                .eq(Visits::getStatus,Constants.VisitStatus.xfSuccess)
+                .last(" limit 1" )
+        );
+        if(v !=null){
+            throw  new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "瀵逛笉璧凤紝鎵嬫満鍙枫��"+member.getPhone()+"銆戝瓨鍦ㄦ湭绛剧棰勭害鐢宠锛屼笉鑳介噸澶嶇敵璇峰摝锛�");
+        }
+    }
+
     private List<Member> isValideWithUsers(List<Visits> withUserList) {
         if(withUserList!= null && withUserList .size()>0){
             for(Visits model:withUserList){

--
Gitblit v1.9.3