From c3aaf28f7316cce12eec007a9f85a96cbcddeec2 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期三, 07 五月 2025 10:34:20 +0800 Subject: [PATCH] 最新版本541200007 --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/hksync/HkSyncPushServiceImpl.java | 778 ++++++++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 679 insertions(+), 99 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/hksync/HkSyncPushServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/hksync/HkSyncPushServiceImpl.java index 99d6c49..82cee9c 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/hksync/HkSyncPushServiceImpl.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/hksync/HkSyncPushServiceImpl.java @@ -1,6 +1,7 @@ package com.doumee.service.business.impl.hksync; import com.alibaba.fastjson.JSONObject; +import com.alibaba.nacos.shaded.org.checkerframework.checker.units.qual.C; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.doumee.biz.system.SystemDictDataBiz; @@ -19,21 +20,31 @@ import com.doumee.core.utils.DateUtil; import com.doumee.core.utils.Utils; import com.doumee.dao.business.*; +import com.doumee.dao.business.dao.MemberMapper; import com.doumee.dao.business.join.VisitsJoinMapper; import com.doumee.dao.business.model.*; +import com.doumee.dao.business.model.Member; import com.doumee.dao.web.reqeust.SavePlatformWarnEventDTO; +import com.doumee.service.business.CategoryService; +import com.doumee.service.business.VisitsService; import com.doumee.service.business.impl.PlatformWarnEventServiceImpl; +import com.doumee.service.business.third.TmsService; +import com.doumee.service.business.third.model.request.TmsOrderInfoRequest; +import com.doumee.service.business.third.model.response.TmsOrderInfoResponse; import com.github.yulichang.wrapper.MPJLambdaWrapper; import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.ObjectUtils; import org.apache.commons.lang3.StringUtils; +import org.apache.commons.net.ftp.FTP; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; +import org.springframework.util.CollectionUtils; import javax.servlet.http.HttpServletResponse; -import java.util.ArrayList; -import java.util.Date; -import java.util.List; +import java.util.*; +import java.util.stream.Collectors; /** * 璁垮鏉冮檺缁勪俊鎭〃Service瀹炵幇 @@ -63,11 +74,15 @@ @Autowired private CarEventMapper carEventMapper; @Autowired + private CategoryMapper categoryMapper; + @Autowired private VisitEventMapper visitEventMapper; @Autowired private VisitsJoinMapper visitsMapper; @Autowired private RetentionMapper retentionMapper; + @Autowired + private InoutRecordMapper inoutRecordMapper; @Autowired private PlatformMapper platformMapper; @Autowired @@ -79,6 +94,10 @@ @Autowired private PlatformJobMapper platformJobMapper; @Autowired + private TmsService tmsService; + @Autowired + private VisitsService visitsService; + @Autowired private PlatformWmsDetailMapper platformWmsDetailMapper; @Autowired private PlatformEventMapper platformEventMapper; @@ -86,6 +105,13 @@ private PlatformLogMapper platformLogMapper; @Autowired private PlatformWarnEventServiceImpl platformWarnEventService; + + + + + + + /** * 娴峰悍闂ㄧ浜嬩欢鎺ㄩ�� * @param param @@ -105,6 +131,7 @@ List<DeviceEvent> list = new ArrayList<>(); List<Integer> delRetentionLis = new ArrayList<>(); List<Retention> retentionList = new ArrayList<>(); + List<InoutRecord> inoutRecordList = new ArrayList<>(); InoutDayCount inoutDayCount = new InoutDayCount(); for(EventAcsInfoRequest request : events){ EventDeviceDataRequest model = request.getData(); @@ -112,7 +139,7 @@ continue; } //鏍规嵁鎺ㄩ�佷汉鍛樼紪鐮侊紝澶勭悊鍦ㄥ満銆佺鍦轰汉鍛樻暟鎹褰� - dealMemberDataByRequest(request,delRetentionLis,retentionList,inoutDayCount); + dealMemberDataByRequest(request,delRetentionLis,retentionList,inoutDayCount,inoutRecordList); //灏佽闂ㄧ浜嬩欢淇℃伅琛ㄥ璞� list.add(getDeviceEventModelByRequest(request)); } @@ -130,9 +157,14 @@ //鍐嶆彃鍏ユ渶鏂扮殑鍦ㄥ巶浜哄憳 retentionMapper.insert(retentionList); } + if(inoutRecordList.size()>0){ + //鍐嶆彃鍏ユ渶鏂扮殑鍦ㄥ巶浜哄憳 + inoutRecordMapper.insert(inoutRecordList); + } dealInoutDayCountBiz(inoutDayCount); log.info("銆愭捣搴烽棬绂佷簨浠舵帹閫併��========鎴愬姛======="); }catch (Exception e) { + e.printStackTrace(); log.error("銆愭捣搴烽棬绂佷簨浠舵帹閫併��========澶辫触=======锛歕n" + e.getMessage()); }finally { saveInterfaceLog(param,"/business/hksync/push/acs",result,false);//涓嶈鏃ュ織 @@ -142,11 +174,15 @@ } private void dealInoutDayCountBiz(InoutDayCount param) { + if(param == null){ + param = new InoutDayCount(); + } param.setTimeInfo(Utils.Date.getStart(new Date())); InoutDayCount model = inoutDayCountMapper.selectOne(new QueryWrapper<InoutDayCount>().lambda() .eq(InoutDayCount::getTimeInfo,param.getTimeInfo()) .eq(InoutDayCount::getIsdeleted,Constants.ZERO) .last("limit 1")); + log.error("============================inoutDayCountMapper:"+JSONObject.toJSONString(param)); if(model == null){ param.setIsdeleted(Constants.ZERO); param.setCreateDate(new Date()); @@ -156,18 +192,18 @@ inoutDayCountMapper.update(null,new UpdateWrapper<InoutDayCount>().lambda() .eq(InoutDayCount::getId,model.getId() ) .set(InoutDayCount::getEditDate,new Date() ) - .setSql(param.getInCarNum()!=null,"IN_CAR_NUM = ifnull(IN_CAR_NUM)"+param.getInCarNum() ) - .setSql(param.getOutCarNum()!=null,"OUT_CAR_NUM = ifnull(OUT_CAR_NUM)"+param.getOutCarNum() ) - .setSql(param.getInMemberNum()!=null,"IN_MEMBER_NUM = ifnull(IN_MEMBER_NUM)"+param.getInMemberNum() ) - .setSql(param.getOutMemberNum()!=null,"OUT_MEMBER_NUM = ifnull(OUT_MEMBER_NUM)"+param.getOutMemberNum() ) - .setSql(param.getInVisitorNum()!=null,"IN_VISITOR_NUM = ifnull(IN_VISITOR_NUM)"+param.getInVisitorNum() ) - .setSql(param.getOutVisitorNum()!=null,"OUT_VISITOR_NUM = ifnull(OUT_VISITOR_NUM)"+param.getOutVisitorNum() ) - .setSql(param.getSigninVisitorNum()!=null,"SIGNIN_VISITOR_NUM = ifnull(SIGNIN_VISITOR_NUM)"+param.getSigninVisitorNum() ) - .setSql(param.getLeaveVisitorNum()!=null,"LEAVE_VISITOR_NUM = ifnull(LEAVE_VISITOR_NUM)"+param.getLeaveVisitorNum() ) - .setSql(param.getInOtherMemberNum()!=null,"IN_OTHER_MEMBER_NUM = ifnull(IN_OTHER_MEMBER_NUM)"+param.getInOtherMemberNum() ) - .setSql(param.getOutOtherMemberNum()!=null,"OUT_OTHER_MEMBER_NUM = ifnull(OUT_OTHER_MEMBER_NUM)"+param.getOutOtherMemberNum() ) - .setSql(param.getInSelfMemberNum()!=null,"IN_SELF_MEMBER_NUM = ifnull(IN_SELF_MEMBER_NUM)"+param.getInSelfMemberNum() ) - .setSql(param.getOutSelfMemberNum()!=null,"OUT_SELF_MEMBER_NUM = ifnull(OUT_SELF_MEMBER_NUM)"+param.getOutSelfMemberNum() ) + .setSql(param.getInCarNum()!=null,"IN_CAR_NUM = ifnull(IN_CAR_NUM,0)+"+param.getInCarNum() ) + .setSql(param.getOutCarNum()!=null,"OUT_CAR_NUM = ifnull(OUT_CAR_NUM,0)+"+param.getOutCarNum() ) + .setSql(param.getInMemberNum()!=null,"IN_MEMBER_NUM = ifnull(IN_MEMBER_NUM,0)+"+param.getInMemberNum() ) + .setSql(param.getOutMemberNum()!=null,"OUT_MEMBER_NUM = ifnull(OUT_MEMBER_NUM,0)+"+param.getOutMemberNum() ) + .setSql(param.getInVisitorNum()!=null,"IN_VISITOR_NUM = ifnull(IN_VISITOR_NUM,0)+"+param.getInVisitorNum() ) + .setSql(param.getOutVisitorNum()!=null,"OUT_VISITOR_NUM = ifnull(OUT_VISITOR_NUM,0)+"+param.getOutVisitorNum() ) + .setSql(param.getSigninVisitorNum()!=null,"SIGNIN_VISITOR_NUM = ifnull(SIGNIN_VISITOR_NUM,0)+"+param.getSigninVisitorNum() ) + .setSql(param.getLeaveVisitorNum()!=null,"LEAVE_VISITOR_NUM = ifnull(LEAVE_VISITOR_NUM,0)+"+param.getLeaveVisitorNum() ) + .setSql(param.getInOtherMemberNum()!=null,"IN_OTHER_MEMBER_NUM = ifnull(IN_OTHER_MEMBER_NUM,0)+"+param.getInOtherMemberNum() ) + .setSql(param.getOutOtherMemberNum()!=null,"OUT_OTHER_MEMBER_NUM = ifnull(OUT_OTHER_MEMBER_NUM,0)+"+param.getOutOtherMemberNum() ) + .setSql(param.getInSelfMemberNum()!=null,"IN_SELF_MEMBER_NUM = ifnull(IN_SELF_MEMBER_NUM,0)+"+param.getInSelfMemberNum() ) + .setSql(param.getOutSelfMemberNum()!=null,"OUT_SELF_MEMBER_NUM = ifnull(OUT_SELF_MEMBER_NUM,0)+"+param.getOutSelfMemberNum() ) ); } } @@ -178,45 +214,78 @@ * @param delRetentionLis * @param retentionList */ - private void dealMemberDataByRequest(EventAcsInfoRequest request, List<Integer> delRetentionLis, List<Retention> retentionList,InoutDayCount inoutDayCount) { + private void dealMemberDataByRequest(EventAcsInfoRequest request + , List<Integer> delRetentionLis + , List<Retention> retentionList + ,InoutDayCount inoutDayCount + ,List<InoutRecord> inoutRecordList) { //娴峰悍浜哄憳缂栫爜 String userNo = request.getData().getExtEventPersonNo(); if(StringUtils.isNotBlank(userNo)){ Member member = memberMapper.selectJoinOne(Member.class,new MPJLambdaWrapper<Member>() .selectAll(Member.class) - .selectAs(Member::getCompanyType,Company::getType) + .selectAs(Company::getCompanyNamePath,Member::getCompanyNamePath) + .selectAs(Company::getType,Member::getCompanyType) .leftJoin(Company.class,Company::getId,Member::getCompanyId) .eq(Member::getHkId,userNo) + .eq(Member::getIsdeleted,Constants.ZERO) .last("limit 1")); //濡傛灉浜哄憳淇℃伅瀛樺湪锛屽垯鍒犻櫎涔嬪墠鐨勬墍鏈夎繘鍦烘暟鎹紙鏃犺姝ゆ鎺ㄩ�佹槸杩涘巶杩樻槸鍑哄満鎺ㄩ�佷簨浠讹級 Device d = deviceMapper.selectOne(new QueryWrapper<Device>().lambda() .eq(Device::getDoorId,request.getSrcIndex()) .eq(Device::getIsdeleted,Constants.ZERO) .last("limit 1" )); - if(d!=null && !(Constants.equalsInteger(d.getIsEntrance(),Constants.ONE) && Constants.formatIntegerNum(request.getData().getExtEventInOut()) != Constants.ONE)){ - //濡傛灉鏄繘闂紝褰曞叆浜哄憳鐨勫湪鍦烘暟鎹褰� - inoutDayCount.setInMemberNum(Constants.formatIntegerNum(inoutDayCount.getInMemberNum())+1);//鍏ュ満浜烘 - }else{ - inoutDayCount.setOutMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutMemberNum())+1);//绂诲満浜烘 + InoutRecord record = new InoutRecord(); + record.setCreateDate(DateUtil.getISO8601DateByStr2(request.getHappenTime())); + record.setTimeInfo(Utils.Date.getStart(record.getCreateDate())); + record.setType(Constants.ONE);//浜哄憳 + record.setMemberType(Constants.RetentionMemberType.fk);//榛樿涓烘湭鐭ヤ汉鍛橈紙璁垮锛� + record.setIsdeleted(Constants.ZERO); + record.setHkEventId(request.getEventId()); + record.setHkId(userNo); + if(d!=null && Constants.equalsInteger(d.getIsEntrance(),Constants.ONE)){ + if(Constants.formatIntegerNum(request.getData().getExtEventInOut()) != Constants.ONE){ + //濡傛灉鏄繘闂紝褰曞叆浜哄憳鐨勫湪鍦烘暟鎹褰� + record.setInOrOut(Constants.ZERO); + inoutDayCount.setInMemberNum(Constants.formatIntegerNum(inoutDayCount.getInMemberNum())+1);//鍏ュ満浜烘 + }else{ + //濡傛灉鏄嚭闂� + record.setInOrOut(Constants.ONE); + inoutDayCount.setOutMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutMemberNum())+1);//绂诲満浜烘 + } } if(member !=null){ - delRetentionLis.add(member.getId()); - if(d!=null && !(Constants.equalsInteger(d.getIsEntrance(),Constants.ONE) && Constants.formatIntegerNum(request.getData().getExtEventInOut()) != Constants.ONE)){ - //濡傛灉鏄繘闂紝褰曞叆浜哄憳鐨勫湪鍦烘暟鎹褰� - retentionList.add(getRetentionModelByRequest(member,request)); - if(Constants.equalsInteger(member.getCompanyType(),Constants.ONE)){ - inoutDayCount.setInSelfMemberNum(Constants.formatIntegerNum(inoutDayCount.getInSelfMemberNum())+1);//鍐呴儴浜哄憳鍏ュ満浜烘 + record.setMemberId(member.getId()); + record.setMemberName(member.getName()); + record.setMemberPhone(member.getPhone()); + record.setObjId(member.getId()); + record.setObjType(Constants.ONE); + record.setCompanyId(member.getCompanyId()); + record.setCompanyName(member.getCompanyNamePath()); + if(d!=null && Constants.equalsInteger(d.getIsEntrance(),Constants.ONE)){ + delRetentionLis.add(member.getId()); + if( Constants.formatIntegerNum(request.getData().getExtEventInOut()) == Constants.ONE){ + //濡傛灉鏄繘闂紝褰曞叆浜哄憳鐨勫湪鍦烘暟鎹褰� + retentionList.add(getRetentionModelByRequest(member,request)); + if(Constants.equalsInteger(member.getCompanyType(),Constants.ONE)){ + record.setMemberType(Constants.RetentionMemberType.internalMember); + inoutDayCount.setInSelfMemberNum(Constants.formatIntegerNum(inoutDayCount.getInSelfMemberNum())+1);//鍐呴儴浜哄憳鍏ュ満浜烘 + }else{ + record.setMemberType(Constants.RetentionMemberType.relMember); + inoutDayCount.setInOtherMemberNum(Constants.formatIntegerNum(inoutDayCount.getInOtherMemberNum())+1);//鐩稿叧鏂瑰叆鍦轰汉娆� + } }else{ - inoutDayCount.setInOtherMemberNum(Constants.formatIntegerNum(inoutDayCount.getInOtherMemberNum())+1);//鐩稿叧鏂瑰叆鍦轰汉娆� - } - }else{ - if(Constants.equalsInteger(member.getCompanyType(),Constants.ONE)){ - inoutDayCount.setOutSelfMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutSelfMemberNum())+1);//鍐呴儴浜哄憳鍑哄満浜烘 - }else{ - inoutDayCount.setOutOtherMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutOtherMemberNum())+1);//鐩稿叧鏂瑰嚭鍦轰汉娆� + if(Constants.equalsInteger(member.getCompanyType(),Constants.ONE)){ + record.setMemberType(Constants.RetentionMemberType.internalMember); + inoutDayCount.setOutSelfMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutSelfMemberNum())+1);//鍐呴儴浜哄憳鍑哄満浜烘 + }else{ + record.setMemberType(Constants.RetentionMemberType.relMember); + inoutDayCount.setOutOtherMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutOtherMemberNum())+1);//鐩稿叧鏂瑰嚭鍦轰汉娆� + } } } } + inoutRecordList.add(record); } } @@ -325,7 +394,6 @@ retention.setMemberId(member.getId()); retention.setDeviceName(request.getSrcName()); retention.setDeviceIndex(request.getSrcIndex()); - return retention; } @@ -403,6 +471,7 @@ List<VisitEvent> list = new ArrayList<>(); List<Integer> delRetentionLis = new ArrayList<>(); List<Retention> retentionList = new ArrayList<>(); + List<InoutRecord> inoutRecordList = new ArrayList<>(); InoutDayCount inoutDayCount = new InoutDayCount(); for(EventVisitIccmInfoRequest request : events){ if(request.getData() ==null || request.getData().getVisitorInvoices() ==null){ @@ -412,7 +481,7 @@ continue; } //娴峰悍璁垮璁板綍缂栫爜 - dealVisitDataByRequstIccm(request,delRetentionLis,retentionList,inoutDayCount); + dealVisitDataByRequstIccm(request,delRetentionLis,retentionList,inoutDayCount,inoutRecordList); list.add(getVisitEventModelByRequestIccm(request,request.getData().getVisitorInformationList().get(0))); } if(list.size()>0){ @@ -429,6 +498,10 @@ //鍐嶆彃鍏ユ渶鏂扮殑鍦ㄥ巶浜哄憳 retentionMapper.insert(retentionList); } + if(inoutRecordList.size()>0){ + //鎵归噺鎻掑叆浜哄憳鍑哄叆璁板綍 + inoutRecordMapper.insert(inoutRecordList); + } dealInoutDayCountBiz(inoutDayCount); log.info("銆愭捣搴疯瀹簨浠舵帹閫併��========鎴愬姛======="); }catch (Exception e){ @@ -436,14 +509,16 @@ } saveInterfaceLog(param,"/business/hksync/push/visitIccm",result,true); return null; - } /** * 鏍规嵁璁垮鎺ㄩ�佽瀹㈣褰曠紪鐮侊紝澶勭悊璁垮璁板綍銆佸湪鍦轰汉鍛樼瓑淇℃伅 */ - private void dealVisitDataByRequstIccm(EventVisitIccmInfoRequest request, List<Integer> delRetentionLis, List<Retention> retentionList, InoutDayCount inoutDayCount) { - + private void dealVisitDataByRequstIccm(EventVisitIccmInfoRequest request + , List<Integer> delRetentionLis + , List<Retention> retentionList + , InoutDayCount inoutDayCount + ,List<InoutRecord> inoutRecordList) { EventVisitIccmDataRequest model = request.getData(); EventVisitIccmInvoiceParamRequest data = request.getData().getVisitorInvoices(); MPJLambdaWrapper<Visits> queryWrapper = new MPJLambdaWrapper<>(); @@ -462,12 +537,14 @@ updateVistis.setId(visits.getId()); if (Constants.formatIntegerNum(request.getEventType()) == HKConstants.EventTypes.VISIT_SIGN_ICCM_IN.getKey()) { //濡傛灉鏄瀹㈢櫥璁帮紝褰曞叆浜哄憳鐨勫湪鍦烘暟鎹褰� -// retentionList.add(getRetentionModelByVisitRequest(visits, request.getHappenTime(),request.getSrcType())); + //retentionList.add(getRetentionModelByVisitRequest(visits, request.getHappenTime(),request.getSrcType())); //鏉ヨ鏃堕棿 - inoutDayCount.setSigninVisitorNum(Constants.formatIntegerNum(inoutDayCount.getSigninVisitorNum())+1); - updateVistis.setStatus(Constants.VisitStatus.signin); - updateVistis.setInDate(DateUtil.getISO8601DateByStr(data.getBeginTime())); - updateVistis.setOutDate(DateUtil.getISO8601DateByStr(data.getFinishTime())); + if(Constants.equalsInteger(visits.getStatus(),Constants.VisitStatus.xfSuccess)){ + inoutDayCount.setSigninVisitorNum(Constants.formatIntegerNum(inoutDayCount.getSigninVisitorNum())+1); + updateVistis.setStatus(Constants.VisitStatus.signin); + updateVistis.setInDate(DateUtil.getISO8601DateByStr(data.getBeginTime())); + updateVistis.setOutDate(DateUtil.getISO8601DateByStr(data.getFinishTime())); + } //鏇存柊鏈�鏂版潵璁挎椂闂� Member member = new Member(); member.setLastVisitDate(updateVistis.getInDate()); @@ -475,18 +552,36 @@ memberMapper.updateById(member); }else if (Constants.formatIntegerNum(request.getEventType()) == HKConstants.EventTypes.VISIT_SIGN_ICCM_OUT.getKey()) { //濡傛灉鏄瀹㈢绂讳簨浠� - inoutDayCount.setLeaveVisitorNum(Constants.formatIntegerNum(inoutDayCount.getLeaveVisitorNum())+1); - updateVistis.setStatus(Constants.VisitStatus.signout); - updateVistis.setInDate(DateUtil.getISO8601DateByStr(data.getBeginTime())); - updateVistis.setOutDate(DateUtil.getISO8601DateByStr(data.getFinishTime())); - updateVistis.setOutType(Constants.ZERO); - updateVistis.setOutInfo("璁垮姝e父绛剧"); + if(Constants.equalsInteger(visits.getStatus(),Constants.VisitStatus.signin)){ + inoutDayCount.setLeaveVisitorNum(Constants.formatIntegerNum(inoutDayCount.getLeaveVisitorNum())+1); + updateVistis.setStatus(Constants.VisitStatus.signout); + updateVistis.setInDate(DateUtil.getISO8601DateByStr(data.getBeginTime())); + updateVistis.setOutDate(DateUtil.getISO8601DateByStr(data.getFinishTime())); + updateVistis.setOutType(Constants.ZERO); + updateVistis.setOutInfo("璁垮姝e父绛剧"); + } + delRetentionLis.add(visits.getMemberId()); }else{ //濡傛灉浜哄憳淇℃伅瀛樺湪锛屽垏鏄瀹㈤�氳锛屽垯鍒犻櫎涔嬪墠鐨勬墍鏈夎繘鍦烘暟鎹紙鏃犺姝ゆ鎺ㄩ�佹槸杩涘巶杩樻槸鍑哄満鎺ㄩ�佷簨浠讹級 delRetentionLis.add(visits.getMemberId()); + InoutRecord record = new InoutRecord(); + record.setCreateDate(DateUtil.getISO8601DateByStr2(request.getHappenTime())); + record.setTimeInfo(Utils.Date.getStart(record.getCreateDate())); + record.setType(Constants.ONE);//浜哄憳 + record.setMemberType(Constants.ZERO); + record.setIsdeleted(Constants.ZERO); + record.setMemberName(visits.getName()); + record.setObjId(visits.getId()); + record.setMemberId(visits.getMemberId()); + record.setObjType(Constants.TWO); + record.setMemberPhone(visits.getPhone()); + record.setCompanyName(visits.getCompanyName()); + record.setInOrOut(Constants.ZERO); + record.setHkEventId(request.getEventId()); + record.setHkId(visits.getHkId()); //濡傛灉鏄瀹㈤�氳 if(request.getData()!=null&&request.getData().getParamValues()!=null && - StringUtils.equals(request.getData().getParamValues().getInOrOut(),"1")){ + StringUtils.equals(request.getData().getParamValues().getInOrOut(),"0")){ //濡傛灉鏄瀹㈢櫥璁帮紝褰曞叆浜哄憳鐨勫湪鍦烘暟鎹褰� Retention r = getRetentionModelByVisitRequest(visits, request.getHappenTime(),request.getSrcType()); r.setCarNo(request.getData().getParamValues().getPlateNos()); @@ -497,9 +592,11 @@ inoutDayCount.setInVisitorNum(Constants.formatIntegerNum(inoutDayCount.getInVisitorNum())+1); } if(request.getData()!=null&&request.getData().getParamValues()!=null && - StringUtils.equals(request.getData().getParamValues().getInOrOut(),"2")){ + !StringUtils.equals(request.getData().getParamValues().getInOrOut(),"0")){ inoutDayCount.setOutVisitorNum(Constants.formatIntegerNum(inoutDayCount.getOutVisitorNum())+1); + record.setInOrOut(Constants.ONE); } + inoutRecordList.add(record); } updateVistis.setEditDate(new Date()); //鏇存柊璁垮鏉ヨ鎴栬�呯绂绘椂闂翠俊鎭� @@ -509,7 +606,8 @@ private Retention getRetentionModelByVisitRequest(Visits visits, String happentTime,String srcType) { Retention retention = new Retention(); retention.setIsdeleted(Constants.ZERO); - retention.setCreateDate(DateUtil.getISO8601DateByStr(happentTime)); + retention.setCreateDate(DateUtil.getISO8601DateByStr2(happentTime)); + retention.setCreateDate(retention.getCreateDate() == null?new Date():retention.getCreateDate()); retention.setClasses(visits.getClasses()); retention.setCode(visits.getCode()); retention.setIdcardNo(visits.getIdcardNo()); @@ -540,6 +638,15 @@ if(event.getCreateDate() == null){ event.setCreateDate(new Date()); } + if (Constants.formatIntegerNum(request.getEventType()) == HKConstants.EventTypes.VISIT_SIGN_ICCM_PASS.getKey()) { + //濡傛灉鏄瀹㈤�氳浜嬩欢,杩涘叆杩涘嚭浜嬩欢 + if(request.getData()!=null&&request.getData().getParamValues()!=null && + StringUtils.equals(request.getData().getParamValues().getInOrOut(),"0")){ + event.setInOrOut("0");//杩� + }else{ + event.setInOrOut("1");//鍑� + } + } event.setVisitorWorkUint(detail.getUnit()); event.setVisitorId(detail.getVisitorId()); event.setVisitorCode(detail.getAppointmentCode()); @@ -551,7 +658,8 @@ event.setStartTime(request.getData().getVisitorInvoices().getBeginTime()); event.setSrcType(request.getSrcType()); event.setSrcParentIndex(request.getSrcParentIndex()); - event.setSrcName(request.getSrcName()); + event.setSrcName((request.getData()!=null &&request.getData().getParamValues()!=null)? + request.getData().getParamValues().getSrcName():request.getSrcName()); event.setSrcIndex(request.getSrcIndex()); event.setSex(detail.getSex()); event.setPurpose(request.getData().getVisitorInvoices().getVisitReason()); @@ -563,6 +671,7 @@ event.setPhotoUrl(getHkImgUrl(detail.getFacePic())); event.setPersonName(detail.getVisitorName()); event.setCarNo(detail.getPlateNo()); + event.setRemark(JSONObject.toJSONString(request)); event.setInvoicesNo(request.getData().getVisitorInvoices().getInvoicesNo());//璁垮鍗曞彿 event.setIdType(detail.getCertType()); String idnum = detail.getCertNo(); @@ -717,13 +826,15 @@ List<CarEvent> list = new ArrayList<>(); List<Retention> retentionList = new ArrayList<>(); List<String> delRetentionList = new ArrayList<>(); + List<Integer> delMemberRetentionList = new ArrayList<>(); InoutDayCount inoutDayCount = new InoutDayCount(); + List<InoutRecord> inoutRecordList = new ArrayList<>(); for(EventParkInfoRequest request : events){ if(request.getData() ==null ||StringUtils.isBlank(request.getData().getPlateNo())){ continue; } //灏佽浜嬩欢淇℃伅琛ㄥ璞� - list.add(getParkEventModelByRequest(request,delRetentionList,retentionList,inoutDayCount)); + list.add(getParkEventModelByRequest(request,delRetentionList,retentionList,delMemberRetentionList,inoutDayCount,inoutRecordList)); } if(list.size()>0){ //鎻掑叆闂ㄧ璁板綍 @@ -735,14 +846,24 @@ .eq(Retention::getType,Constants.THREE) .in(Retention::getCarNo,delRetentionList)); } + if(delMemberRetentionList.size()>0){ + //鍏堝垹闄ゅ師鏈夌殑鍦ㄥ満浜哄憳(鍐呴儴浜哄憳鍜岃瀹級 + retentionMapper.delete(new UpdateWrapper<Retention>().lambda() + .in(Retention::getType,Constants.memberType.internal,Constants.memberType.visitor) + .in(Retention::getMemberId,delMemberRetentionList)); + } if(retentionList.size()>0){ //鍐嶆彃鍏ユ渶鏂扮殑鍦ㄥ巶浜哄憳 retentionMapper.insert(retentionList); } + if(inoutRecordList.size()>0){ + //鍐嶆彃鍏ユ渶鏂扮殑浜鸿溅鍑哄叆鏄庣粏 + inoutRecordMapper.insert(inoutRecordList); + } dealInoutDayCountBiz(inoutDayCount); log.info("銆愭捣搴峰仠杞﹀満浜嬩欢鎺ㄩ�併��========鎴愬姛======="); }catch (Exception e){ - + e.printStackTrace(); log.error("銆愭捣搴峰仠杞﹀満浜嬩欢鎺ㄩ�併��========澶辫触=======锛歕n"+e.getMessage()); } saveInterfaceLog(param,"/business/hksync/push/parks",result,false); @@ -754,7 +875,331 @@ * @param request * @return */ - private CarEvent getParkEventModelByRequest(EventParkInfoRequest request, List<String> delRetentionList , List<Retention> retentionList,InoutDayCount inoutDayCount ) { + private CarEvent getParkEventModelByRequest(EventParkInfoRequest request + , List<String> delRetentionList + , List<Retention> retentionList + , List<Integer> delMemberRetentionList + , InoutDayCount inoutDayCount + , List<InoutRecord> inoutRecordList) { + CarEvent event =initCarEventModelByRequest(request); + if(StringUtils.isNotBlank(event.getPlateNos())){ + //鏍囪杞﹁締杩涘嚭璁板綍 + List<Category> categoryList = categoryMapper.selectJoinList(Category.class, new MPJLambdaWrapper<Category>() + .selectAll(Category.class) + .select("t4.name",Category::getParentName) + .leftJoin("category t4 on t.parent_id=t4.id") + .eq(Category::getIsdeleted,Constants.ZERO) + .isNotNull(Category::getBizType));//鏌ヨ鎵�鏈夊甫鏈変笟鍔$被鍨嬬殑杞﹁締鍒嗙被缂栫爜 + List<Visits> visitsList = null; + InoutRecord carrecord = new InoutRecord(); + carrecord.setCreateDate(DateUtil.getISO8601DateByStr2(request.getHappenTime())); + carrecord.setTimeInfo(Utils.Date.getStart(carrecord.getCreateDate())); + carrecord.setType(Constants.ZERO);//杞﹁締 + carrecord.setIsdeleted(Constants.ZERO); + carrecord.setObjType(Constants.ZERO); + carrecord.setHkEventId(request.getEventId()); + carrecord.setCarCode(event.getPlateNos()); + Cars carModel = carsMapper.selectJoinOne(Cars.class,new MPJLambdaWrapper<Cars>() + .selectAll(Cars.class ) + .selectAs(Company::getType,Cars::getCompanyType) + .selectAs(Member::getName,Cars::getMemberName) + .selectAs(Member::getIdcardDecode,Cars::getIdcardDecode) + .selectAs(Member::getCode,Cars::getMemberCode) + .selectAs(Member::getFaceImg,Cars::getFaceImg) + .selectAs(Member::getIdcardNo,Cars::getIdcardNo) + .selectAs(Member::getName,Cars::getMemberName) + .selectAs(Member::getPhone,Cars::getMemberPhone) + .selectAs(Company::getCompanyNamePath,Cars::getCompanyName) + .selectAs(Category::getBizType,Cars::getBizType) + .selectAs(Category::getName,Cars::getCateName) + .select("t4.id",Cars::getCatePId) + .select("t4.name",Cars::getCatePName) + .leftJoin(Company.class,Company::getId,Cars::getGroupId) + .leftJoin(Member.class,Member::getId,Cars::getMemberId) + .leftJoin(Category.class,Category::getId,Cars::getCateId) + .leftJoin("category t4 on t3.parent_id=t4.id") + .eq(Cars::getCode,event.getPlateNos()) + .eq(Cars::getIsdeleted,Constants.ZERO) + .last(" limit 1")); + if(carModel!=null){ + //0瀹夋嘲鍏姟杞� 1瀹夋嘲鑷湁鐗╂祦杞� 2鍏跺畠 + event.setMemberId(carModel.getMemberId()); + event.setCompanyId(carModel.getGroupId()); + //-----------------20250429鏀归��----start--------------- + event.setCarType(carModel.getBizType());//杞﹁締涓氬姟绫诲瀷 + carrecord.setObjType(Constants.FOUR); + carrecord.setMemberName(carModel.getMemberName());//鍙告満 + carrecord.setMemberPhone(carModel.getMemberPhone());//鍙告満 + carrecord.setObjId(carModel.getId()); + carrecord.setMemberId(carModel.getMemberId()); + carrecord.setObjType(Constants.ZERO); + carrecord.setFaceImg(carModel.getFaceImg()); + carrecord.setIdcardDecode(carModel.getIdcardDecode()); + carrecord.setIdcardNo(carModel.getIdcardNo()); + carrecord.setMemberCode(carModel.getMemberCode()); + carrecord.setCompanyId(carModel.getGroupId()); + carrecord.setCompanyName(carModel.getCompanyName()); + carrecord.setCategoryId(carModel.getCateId()); + carrecord.setCategoryName(carModel.getCateName()); + carrecord.setCategoryParentId(carModel.getCatePId()); + carrecord.setCategoryParentName(carModel.getCatePName()); + carrecord.setType( Constants.RetentionMemberType.car);//鍙槸杞﹁締鐨勮褰� + if(carModel.getMemberId()!=null){ + if(Constants.equalsInteger(carModel.getCompanyType(),Constants.ONE)){ + //鍐呴儴缁勭粐 + carrecord.setMemberType(Constants.RetentionMemberType.internalMember); + }else{ + //鐩稿叧鏂圭粍缁� + carrecord.setMemberType( Constants.RetentionMemberType.relMember); + } + } +// carrecord.setMemberPhone(carTypeJob.getDrivierPhone()); + //-----------------20250429鏀归��----end--------------- + } + if(event.getCarType() ==null || event.getCarType().equals(Constants.RetentionCarType.other)){//濡傛灉涓鸿瘑鍒埌杞﹀瀷 + PlatformJob carTypeJob = platformJobMapper.selectJoinOne(PlatformJob.class, + new MPJLambdaWrapper<PlatformJob>(). selectAll(PlatformJob.class) + .selectAs(PlatformGroup::getType,PlatformJob::getGroupType) + .leftJoin(PlatformGroup.class,PlatformGroup::getId,PlatformJob::getPlatformGroupId) + .eq(PlatformJob::getCarCodeFront,event.getPlateNos()) + .eq(PlatformJob::getIsdeleted,Constants.ZERO) + .orderByAsc(PlatformJob::getCreateDate) + .last(" limit 1")); + if(carTypeJob!=null ) { + /** + * 濡傛灉闈炲浐瀹氳溅杈嗭紝妫�鏌ユ槸鍚﹁揣杩愯溅杈� + * 璐ц繍杞﹁締浼樺厛绾э細 + * 1銆佸畨娉拌嚜鏈夎溅锛氳揣杩愯溅杈�-瀹夋嘲鐗╂祦璐ц繍杞﹁締(鍥哄畾杞﹁締涓婇潰宸插鐞嗭紝姝ゅ涓嶈�冭檻锛� + * 2銆亀ms鎺ㄩ�佺殑鐗╂祦杞﹁締锛堥潪鑷湁杞︼級锛氳揣杩愯溅杈�-澶栧崗杩愯緭杞﹁締 瀵瑰簲grouptype涓猴細瀹夋嘲鐗╂祦鍗歌揣 2 + * 3銆佸畨娉扮殑棰勭害鍏ュ洯杞﹁締锛氳揣杩愯溅杈�-鍔犲伐鐑熷嵏璐ц溅杈� 瀵瑰簲grouptype涓�0瀹夋嘲鐗╂祦鍗歌揣 2甯傚叕鍙稿嵏璐� + * 4銆佸競鍏徃鐨勯绾﹀叆鍥溅杈嗭細璐ц繍杞﹁締-甯傚叕鍙稿嵏璐ц溅杈� + */ + carrecord.setMemberName(carTypeJob.getDriverName());//鍙告満 + carrecord.setMemberPhone(carTypeJob.getDrivierPhone());//鍙告満 + carrecord.setObjId(carTypeJob.getId()); + carrecord.setMemberId(carTypeJob.getDriverId());//鍙告満缂栫爜 + carrecord.setObjType(Constants.FOUR); + carrecord.setCompanyId(carTypeJob.getCompanyId()); + carrecord.setCompanyName(carTypeJob.getCompanyNamePath()); + carrecord.setType(Constants.RetentionMemberType.car); + if(carModel.getMemberPhone()!=null || StringUtils.isNotBlank(carModel.getMemberName())){ + //璐ц繍鍙告満(濡傛灉鍙告満鎵嬫満鍙锋垨鑰呭鍚嶄笉涓虹┖锛� + carrecord.setMemberType(Constants.RetentionMemberType.driver); + } + Category category = null; + String tempName = ""; + String tempPName = ""; + //濡傛灉闈炲浐瀹氳溅杈嗭紝鍒欐煡璇㈡槸鍚﹁揣杩愯溅杈� 浣滀笟绫诲瀷 0鑷湁杞﹀嵏璐� 1鑷湁杞﹁璐� 2澶栧崗杞﹀嵏璐� 3澶栧崗杞﹁璐� 4甯傚叕鍙稿鍗忚溅鍗歌揣 + if(Constants.equalsInteger(carTypeJob.getOrigin(),Constants.ONE)){ + //濡傛灉鏄帹閫佺殑wms闈炶嚜鏈夎溅 + event.setCarType(Constants.RetentionCarType.wxysCar);//澶栧崗杞� + tempName = "澶栧崗杩愯緭杞﹁締"; + tempPName = "璐ц繍杞﹁締"; + }else if(Constants.equalsInteger(carTypeJob.getType(),Constants.FOUR)){ + if(Constants.equalsInteger(carTypeJob.getGroupType(),Constants.TWO)){ + ///瀹夋嘲鐨勯绾﹀叆鍥溅杈嗭細璐ц繍杞﹁締-鍔犲伐鐑熷嵏璐ц溅杈� + tempName = "鍔犲伐鐑熷嵏璐ц溅杈�"; + tempPName = "璐ц繍杞﹁締"; + event.setCarType(Constants.RetentionCarType.jgyxhCar);//鍔犲伐鐑熷嵏璐ц溅杈� + }else if(Constants.equalsInteger(carTypeJob.getGroupType(),Constants.TWO)){ + //甯傚叕鍙哥殑棰勭害鍏ュ洯杞﹁締锛氳揣杩愯溅杈�-甯傚叕鍙稿嵏璐ц溅杈� + tempName = "甯傚叕鍙稿嵏璐ц溅杈�"; + tempPName = "璐ц繍杞﹁締"; + event.setCarType(Constants.RetentionCarType.sgsxhCar);//甯傚叕鍙稿嵏璐ц溅杈� + } + } + category =findCategoryByBizType(event.getCarType(),tempName,tempPName,categoryList); + carrecord.setCategoryId(category.getId()); + carrecord.setCategoryName(category.getName()); + carrecord.setCategoryParentName(category.getParentName()); + carrecord.setCategoryParentId(category.getParentId()); + } + } + //澶勭悊鑷湁杞﹁嚜鍔ㄧ鍒颁笟鍔� + dealSelTruckAutoSignBiz(request,event); + if(Constants.formatIntegerNum(request.getEventType()) == HKConstants.EventTypes.PARK_PASS_IN.getKey()){ + //濡傛灉鏄叆鍘傛斁琛� + delRetentionList.add(event.getPlateNos()); + delMemberRetentionList.add(event.getMemberId()); + retentionList.add(getRetentionModelByParkRequest(request,event));//鍦ㄥ巶杞﹁締淇℃伅 + inoutDayCount.setInCarNum(Constants.formatIntegerNum(inoutDayCount.getInCarNum())+1); + carrecord.setInOrOut(Constants.ZERO); + }else if(Constants.formatIntegerNum(request.getEventType()) == HKConstants.EventTypes.PARK_PASS_OUT.getKey()){ + //濡傛灉鏄嚭鍦烘斁琛� + delRetentionList.add(event.getPlateNos()); + delMemberRetentionList.add(event.getMemberId()); + inoutDayCount.setOutCarNum(Constants.formatIntegerNum(inoutDayCount.getOutCarNum())+1); + carrecord.setInOrOut(Constants.ZERO); + } + //杞﹁締杩涘叆璁板綍瀵瑰簲涓氬姟绫诲瀷 + if(event.getCarType() ==null || event.getCarType().equals(Constants.RetentionCarType.other)){ + //濡傛灉鏈瘑鍒埌杞﹀瀷锛屼笉鏄浐瀹氳溅 涔熶笉鏄揣杩愯溅杈嗭紝鍒欐鏌ユ槸鍚︽槸璁垮杞� + visitsList = visitsMapper.selectList(new QueryWrapper<Visits>().lambda() + .eq(Visits::getCarNos,event.getPlateNos()) + .eq(Visits::getIsdeleted,Constants.ZERO ) + .in(Visits::getStatus,Constants.VisitStatus.signin)//鏈�杩戜竴涓凡鍒拌揪鎴栬�呭凡绛剧 + .isNull(Visits::getParentId) + .orderByDesc(Visits::getId) +// .last("limit 1" ) + ); + if(visitsList!=null && visitsList.size()>0){ + //鏈�杩戜娇鐢ㄨ杞︾殑鐢宠浜猴紙宸插埌杈撅級 + event.setMemberId(visitsList.get(0).getMemberId()); + event.setCarType(Constants.RetentionCarType.fkCar); + int index =0; + carrecord.setCarBizType(Constants.RetentionCarType.fkCar); + Category category =findCategoryByBizType(Constants.RetentionCarType.fkCar,"璁垮杞﹁締","璁垮杞﹁締",categoryList); + carrecord.setCategoryId(category.getId()); + carrecord.setCategoryName(category.getName()); + carrecord.setCategoryParentName(category.getParentName()); + carrecord.setCategoryParentId(category.getParentId()); + for(Visits v :visitsList){ + delMemberRetentionList.add(event.getMemberId()); + InoutRecord copyObj = new InoutRecord(); + BeanUtils.copyProperties(carrecord,copyObj); + copyObj.setMemberId(v.getMemberId()); + copyObj.setMemberName(v.getName()); + copyObj.setMemberPhone(v.getPhone()); + copyObj.setCompanyName(v.getCompanyName()); + copyObj.setType(Constants.ONE); + copyObj.setRemark(carrecord.getCarCode()); + copyObj.setCarCode(index>=0?null:carrecord.getCarCode()); + copyObj.setMemberType(Constants.RetentionMemberType.fk); + inoutRecordList.add(copyObj); + index++; + if(Constants.equalsInteger(carrecord.getInOrOut(),Constants.ONE)){ + //濡傛灉鏄溅杈嗗嚭鍥尯 缁熻璁垮杩涘叆鏁� + inoutDayCount.setOutVisitorNum(Constants.formatIntegerNum(inoutDayCount.getOutVisitorNum())+1); + try { + //璁垮鐢宠鑷姩绛剧 + visitsService.visitLevelForCarOut(v); + //缁熻绛剧鏁� + inoutDayCount.setLeaveVisitorNum(Constants.formatIntegerNum(inoutDayCount.getLeaveVisitorNum())+1); + }catch (Exception e){ + log.error("璁垮璺熼殢杞﹁締鍑哄洯鑷姩绛剧澶辫触锛�==========="+e.getMessage()); + } + }else{ + //濡傛灉鏄繘鍏ュ洯鍖猴紝璁垮褰曞叆鍦ㄥ洯浜哄憳璁板綍 + retentionList.add(getRetentionModelByRequest(copyObj,request)); + //缁熻璁垮鍑鸿鏁� + inoutDayCount.setInVisitorNum(Constants.formatIntegerNum(inoutDayCount.getInVisitorNum())+1); + } + } + } + } + if(event.getCarType() !=null && !event.getCarType().equals(Constants.RetentionCarType.fkCar)){ + //褰曞叆闈炶瀹㈢被鍨嬭溅杈嗚繘鍑鸿褰� + dealNotFkCarMemberBiz(event,request,carrecord,retentionList,inoutDayCount,inoutRecordList); + } + } + return event; + } + + private void dealNotFkCarMemberBiz( CarEvent event ,EventParkInfoRequest request, InoutRecord carrecord,List<Retention> retentionList,InoutDayCount inoutDayCount,List<InoutRecord> inoutRecordList) { + //褰曞叆闈炶瀹㈢被鍨嬭溅杈嗚繘鍑鸿褰� + carrecord.setCarBizType(event.getCarType()==null?Constants.RetentionCarType.other:event.getCarType()); + if(carrecord.getMemberId()!=null + && (Constants.equalsInteger(carrecord.getMemberType(),Constants.RetentionMemberType.internalMember) + ||Constants.equalsInteger(carrecord.getMemberType(),Constants.RetentionMemberType.relMember) + ||Constants.equalsInteger(carrecord.getMemberType(),Constants.RetentionMemberType.driver))){ + if( Constants.equalsInteger(carrecord.getInOrOut(),Constants.ZERO)) { + //濡傛灉鏄繘鍏� + retentionList.add(getRetentionModelByRequest(carrecord,request)); + if(Constants.equalsInteger(carrecord.getMemberType(),Constants.RetentionMemberType.relMember)){ + //濡傛灉鏄浉鍏虫柟浜哄憳锛岀粺璁′粖鏃ョ疮璁℃暟 + inoutDayCount.setInOtherMemberNum(Constants.formatIntegerNum(inoutDayCount.getInOtherMemberNum())+1); + }else if(Constants.equalsInteger(carrecord.getMemberType(),Constants.RetentionMemberType.internalMember)){ + //濡傛灉鏄唴閮ㄤ汉鍛�,缁熻浠婃棩绱鏁� + inoutDayCount.setInSelfMemberNum(Constants.formatIntegerNum(inoutDayCount.getInSelfMemberNum())+1); + } + //缁熻浠婃棩鍏ュ洯鎬讳汉娆� + inoutDayCount.setInMemberNum(Constants.formatIntegerNum(inoutDayCount.getInMemberNum())+1); + }else if(carrecord.getMemberId()!=null && Constants.equalsInteger(carrecord.getInOrOut(),Constants.ONE)) { + //濡傛灉鏄嚭鍥尯 + if(Constants.equalsInteger(carrecord.getMemberType(),Constants.RetentionMemberType.relMember)){ + //濡傛灉鏄浉鍏虫柟锛岀粺璁′粖鏃ョ疮璁℃暟 + inoutDayCount.setOutOtherMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutOtherMemberNum())+1); + }else if(Constants.equalsInteger(carrecord.getMemberType(),Constants.RetentionMemberType.internalMember)){ + //濡傛灉鏄唴閮ㄤ汉鍛橈紝缁熻浠婃棩绱鏁� + inoutDayCount.setOutSelfMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutSelfMemberNum())+1); + } + //缁熻浠婃棩鍑哄洯鎬讳汉娆� + inoutDayCount.setOutMemberNum(Constants.formatIntegerNum(inoutDayCount.getOutMemberNum())+1); + } + } + if(carrecord.getInOrOut() !=null) {//濡傛灉鏄嚭鍏ヨ褰� + if(Constants.equalsInteger(carrecord.getCarBizType(),Constants.RetentionCarType.other)){ + carrecord.setCategoryName("鏈煡杞﹁締");//榛樿鏈煡杞﹁締 + } + inoutRecordList.add(carrecord);//褰曞叆杞﹁締浠ュ強鎼哄甫浜哄憳鐨勫叆鍥槑缁嗚褰曪紙闈炶瀹級 + } + } + + private Category findCategoryByBizType(Integer carType,String tempname, String pName,List<Category> categoryList) { + if(categoryList!=null){ + for(Category category :categoryList){ + if(Constants.equalsInteger(carType,category.getBizType())){ + return category; + } + } + } + Category category = new Category(); + category.setName(tempname); + category.setParentName(pName); + return null; + } + + private void dealSelTruckAutoSignBiz(EventParkInfoRequest request, CarEvent event) { + ParkBook cars = parkBookMapper.selectOne(new QueryWrapper<ParkBook>().lambda() + .eq(ParkBook::getCarCode,event.getPlateNos()) + .eq(ParkBook::getHkStatus,Constants.ONE ) + .eq(ParkBook::getIsdeleted,Constants.ZERO ) + .last("limit 1" )); + if(cars!=null){ + event.setMemberId(cars.getMemberId()); + //鑷湁杞� 鏌ヨ褰撳墠鏄惁鏈夊緟绛惧埌鐨勪换鍔� + if(carsMapper.selectCount(new QueryWrapper<Cars>() + .lambda().eq(Cars::getCode,event.getPlateNos()) + .eq(Cars::getType,Constants.ONE) + .eq(Cars::getIsdeleted,Constants.ZERO) + )>Constants.ZERO){ + //鏌ヨ杞﹁締褰撳墠鏄惁瀛樺湪杩涜涓殑浠诲姟 + if( platformJobMapper.selectCount(new QueryWrapper<PlatformJob>().lambda() + .eq(PlatformJob::getCarCodeFront,event.getPlateNos()) + .eq(PlatformJob::getIsdeleted,Constants.ZERO) + .in(PlatformJob::getStatus, + Constants.PlatformJobStatus.IN_WAIT.getKey(), + Constants.PlatformJobStatus.CALLED.getKey(), + Constants.PlatformJobStatus.WORKING.getKey(), + Constants.PlatformJobStatus.TRANSFERING.getKey(), + Constants.PlatformJobStatus.EXCEPTION.getKey() + ) + )==Constants.ZERO){//濡傛灉娌¤繘琛屼腑浠诲姟 + PlatformJob platformJob = platformJobMapper.selectOne(new QueryWrapper<PlatformJob>().lambda() + .eq(PlatformJob::getCarCodeFront,event.getPlateNos()) + .eq(PlatformJob::getIsdeleted,Constants.ZERO) + .in(PlatformJob::getStatus, + Constants.PlatformJobStatus.WAIT_CONFIRM.getKey(), + Constants.PlatformJobStatus.WART_SIGN_IN.getKey() + ) + .orderByAsc(PlatformJob::getCreateDate) + .last(" limit 1") + ); + if(Objects.nonNull(platformJob)){ + if(Constants.equalsInteger(platformJob.getType(),Constants.ONE)){ + //濡傛灉鏄嚜鏈夎溅瑁呰揣鑷姩绛惧埌 + jobAutoSignBiz(platformJob); + }else if(Constants.equalsInteger(platformJob.getType(),Constants.ZERO)){ + //濡傛灉鏄嚜鏈夎溅鍗歌揣 鏌ヨTMS鍚堝悓鐘舵�侊紝鍐冲畾鏄惁鑷姩绛惧埌 + checkTmsContractStatusBiz(platformJob); + } + } + } + } + } + } + + private CarEvent initCarEventModelByRequest(EventParkInfoRequest request) { CarEvent event = new CarEvent(); event.setIsdeleted(Constants.ZERO); event.setCreateDate(DateUtil.getISO8601DateByStr(request.getHappenTime())); @@ -792,7 +1237,7 @@ event.setEventCmd(request.getData().getEventCmd()); event.setCardNo(request.getData().getCardNo()); event.setCarAttributeName(request.getData().getCarAttributeName()); - + event.setCarType(Constants.RetentionCarType.other);//榛樿鏈櫥璁拌溅杈� if(request.getData().getInResult()!=null && request.getData().getInResult().getRlsResult() !=null ){ //鏀捐鏂瑰紡 event.setReleaseWay(request.getData().getInResult().getRlsResult().getReleaseWay()); @@ -806,48 +1251,83 @@ event.setVehiclePicUrl(getHkImgUrl(request.getData().getPicUrl().getVehiclePicUrl())); event.setPlatePicUrl(getHkImgUrl(request.getData().getPicUrl().getPlatePicUrl())); } - if(StringUtils.isNotBlank(event.getPlateNos())){ - ParkBook cars = parkBookMapper.selectOne(new QueryWrapper<ParkBook>().lambda() - .eq(ParkBook::getCarCode,event.getPlateNos()) - .eq(ParkBook::getIsdeleted,Constants.ZERO ) - .last("limit 1" )); - if(cars!=null){ - event.setMemberId(cars.getMemberId()); - }else{ - Visits visits = visitsMapper.selectOne(new QueryWrapper<Visits>().lambda() - .eq(Visits::getCarNos,event.getPlateNos()) - .eq(Visits::getIsdeleted,Constants.ZERO ) - .in(Visits::getStatus,Constants.VisitStatus.signin,Constants.VisitStatus.signout)//鏈�杩戜竴涓凡鍒拌揪鎴栬�呭凡绛剧 - .isNull(Visits::getParentId) - .orderByDesc(Visits::getId) - .last("limit 1" )); - if(visits!=null){ - //鏈�杩戜娇鐢ㄨ杞︾殑鐢宠浜猴紙宸插埌杈撅級 - event.setMemberId(visits.getMemberId()); - } - } - if(Constants.formatIntegerNum(request.getEventType()) == HKConstants.EventTypes.PARK_PASS_IN.getKey()){ - //濡傛灉鏄叆鍘傛斁琛� - delRetentionList.add(event.getPlateNos()); - retentionList.add(getRetentionModelByParkRequest(request)); - inoutDayCount.setInCarNum(Constants.formatIntegerNum(inoutDayCount.getInCarNum())+1); - }else if(Constants.formatIntegerNum(request.getEventType()) == HKConstants.EventTypes.PARK_PASS_OUT.getKey()){ - //濡傛灉鏄嚭鍦烘斁琛� - delRetentionList.add(event.getPlateNos()); - inoutDayCount.setOutCarNum(Constants.formatIntegerNum(inoutDayCount.getOutCarNum())+1); - } - } return event; } - private Retention getRetentionModelByParkRequest(EventParkInfoRequest request) { + /** + * 锛涘鏋滄槸鍗歌揣浠诲姟锛岄渶瑕侀�氳繃TMS鎻愪緵鐨勨��2.2鍚堝悓鍒楄〃鎺ュ彛鈥濇帴鍙f煡璇㈣溅杈嗗搴旂殑鍚堝悓鐘舵�佹槸鍚︿负鍦ㄩ�旂姸鎬侊紙瀵瑰簲orderStatus鍊间负3/4/5/6锛夛紝 + * 濡傛灉鏄嚜鍔ㄧ鍒帮紝鍚﹀垯涓嶈嚜鍔ㄧ鍒帮紱濡傛灉涓�涓溅杈嗗搴斿涓悎鍚屽彿锛屽垯鍙栬繍鍗曚笅浠讳竴鍚堝悓鏌ヨ瀵瑰簲鍦ㄩ�斾俊鎭� + * @param platformJob + */ + private void checkTmsContractStatusBiz(PlatformJob platformJob) { + PlatformWmsDetail detail = platformWmsDetailMapper.selectOne(new QueryWrapper<PlatformWmsDetail>().lambda() + .eq(PlatformWmsDetail::getIsdeleted, Constants.ZERO) + .eq(PlatformWmsDetail::getJobId, platformJob.getId()) + .isNotNull(PlatformWmsDetail::getContractNum) + .last("limit 1") + ); + if(detail!=null && StringUtils.isNotBlank(detail.getContractNum())){ + TmsOrderInfoRequest param = new TmsOrderInfoRequest(); + param.setContractNumber(detail.getContractNum()); + TmsOrderInfoResponse response = tmsService.orderInfo(param); + if(response!=null &&( StringUtils.equals(response.getOrderStatus(),"3") ) + ||StringUtils.equals(response.getOrderStatus(),"4") + ||StringUtils.equals(response.getOrderStatus(),"5") + ||StringUtils.equals(response.getOrderStatus(),"6")){ + //濡傛灉鍚堝悓鍦ㄩ�旓紝鍒欒嚜鍔ㄧ鍒� + jobAutoSignBiz(platformJob); + } + } + + } + + private void jobAutoSignBiz(PlatformJob platformJob) { + platformJob.setStatus(Constants.PlatformJobStatus.WAIT_CALL.getKey()); + platformJob.setArriveDate(new Date()); + platformJob.setSingType(Constants.TWO); + platformJob.setSignDate(new Date()); + List<PlatformJob> signList = platformJobMapper.selectList(new QueryWrapper<PlatformJob>().lambda().apply(" DATE(SIGN_DATE) = DATE(NOW()) and sign_date is not null ")); + if(CollectionUtils.isEmpty(signList)){ + platformJob.setSignNum(Constants.ONE); + } else{ + int maxNumber = Collections.max(signList.stream().map(i->i.getSignNum()).collect(Collectors.toList())); + platformJob.setSignNum(maxNumber + Constants.ONE); + } + platformJobMapper.updateById(platformJob); + } + private Retention getRetentionModelByRequest(InoutRecord inoutRecord, EventParkInfoRequest request) { + Retention retention = new Retention(); + retention.setIsdeleted(Constants.ZERO); + retention.setCreateDate(DateUtil.getISO8601DateByStr(request.getHappenTime())); + retention.setCode(inoutRecord.getMemberCode()); + retention.setIdcardNo(inoutRecord.getIdcardNo()); + retention.setIdcardDecode(inoutRecord.getIdcardDecode()); + retention.setName(inoutRecord.getMemberName()); + retention.setType(inoutRecord.getMemberType()); + retention.setCompanyId(inoutRecord.getCompanyId()); + retention.setCompanyName(inoutRecord.getCompanyName()); + retention.setEventCode(request.getEventType()+""); + retention.setEventDate(DateUtil.getISO8601DateByStr(request.getHappenTime())); + retention.setFaceImg(inoutRecord.getFaceImg()); + retention.setPhone(inoutRecord.getMemberPhone()); + retention.setMemberId(inoutRecord.getMemberId()); + retention.setDeviceName(request.getSrcName()); + retention.setDeviceIndex(request.getSrcIndex()); + retention.setRemark("璺熼殢杞﹁締鍏ュ洯鍖�"); + return retention; + } + private Retention getRetentionModelByParkRequest(EventParkInfoRequest request,CarEvent event ) { Retention retention = new Retention(); retention.setIsdeleted(Constants.ZERO); retention.setCreateDate(DateUtil.getISO8601DateByStr(request.getHappenTime())); retention.setCarNo(request.getData().getPlateNo()); retention.setType(Constants.THREE); + retention.setMemberId(event.getMemberId()); + retention.setCarType(event.getCarType()); + retention.setCompanyId(event.getCompanyId()); // retention.setDeviceName(request.getSrcName()); // retention.setDeviceIndex(request.getSrcIndex()); + return retention; } @@ -964,14 +1444,26 @@ PlatformJob job = platformJobMapper.selectJoinOne(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() .selectAll(PlatformJob.class) .selectAs(Platform::getName,PlatformJob::getPlatformName) + .selectAs(Platform::getLedContent,PlatformJob::getLedContent) .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) -// .eq(StringUtils.equals(status.getStockStatus(),"front"),PlatformJob::getCarCodeFront,status.getPlateNo() )//鍓嶈溅鐗屽彿 // .eq(!StringUtils.equals(status.getStockStatus(),"front"),PlatformJob::getCarCodeBack,status.getPlateNo() )//鍚庤溅鐗屽彿 +// .eq(StringUtils.equals(status.getStockStatus(),"front"),PlatformJob::getCarCodeFront,status.getPlateNo() )//鍓嶈溅鐗屽彿 .eq(PlatformJob::getIsdeleted,Constants.ZERO ) .eq(PlatformJob::getPlatformId,model.getPlatformId() ) .orderByDesc(PlatformJob::getCallDate) .last("limit 1 ")); if(job == null){ + if(StringUtils.equals(status.getMotionStatus(),"enter")){ + //濡傛灉鏈堝彴褰撳墠娌′綔涓氾紝鐩存帴鎻愮ず杞﹁締鍋滈敊 + Platform platform = platformMapper.selectJoinOne(Platform.class, new MPJLambdaWrapper<Platform>() + .selectAll(Platform.class) + .eq(Platform::getIsdeleted,Constants.ZERO ) + .eq(PlatformJob::getId,model.getPlatformId() ) + .last("limit 1 ")); + if(platform!=null){ + dealCarsAndPlatformErrorBiz(platform,status); + } + } continue;//濡傛灉浣滀笟涓虹┖锛岃烦杩囧鐞� } PlatformJob update = new PlatformJob(); @@ -995,15 +1487,21 @@ update.setStatus(Constants.PlatformJobStatus.DONE.getKey());//浣滀笟宸插畬鎴� update.setDoneDate(update.getEditDate());*/ if(Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.DONE.getKey()) || + Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.TRANSFERING.getKey()) || + Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.EXCEPTION.getKey()) || Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey())){ if(((StringUtils.equals(status.getStockStatus(),"front") && StringUtils.equals(job.getCarCodeFront(),status.getPlateNo())) ||(!StringUtils.equals(status.getStockStatus(),"front") && StringUtils.equals(job.getCarCodeBack(),status.getPlateNo())) )){ //璇存槑杞﹁締杩涢敊鏈堝彴 鎴栬�呰繕鏈彨鍙风姸鎬侊紝鍙戣捣璀﹀憡 // dealCarsInErrorPlatformBiz(job,status); - update.setInOut(Constants.ZERO);//杞﹁締宸茬粡绂诲紑 - platformJobMapper.updateById(update); - } + if(Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.DONE.getKey()) || + Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey())){ + update.setInOut(Constants.ZERO);//杞﹁締宸茬粡绂诲紑 + platformJobMapper.updateById(update); + } + dealPlatformContentForLeave(job); + } } }else if(StringUtils.equals(status.getMotionStatus(),"enter")){ //濡傛灉鏄溅杈嗚繘鍏� @@ -1019,7 +1517,8 @@ platformJobMapper.updateById(update); } } - /*if(job.getStartDate() == null){ + /* + if(job.getStartDate() == null){ update.setStartDate(update.getEditDate()); } update.setStatus(Constants.PlatformJobStatus.WORKING.getKey());//寮�濮嬩綔涓� @@ -1043,6 +1542,37 @@ saveInterfaceLog(param,"/business/hksync/push/platform/workstatus",result,false);//涓嶈鏃ュ織 } return null; + } + + /** + * 鏈堝彴杞﹁締绂诲紑 璁剧疆鏈堝彴鏂囨涓衡�滅┖闂蹭腑 鏂囨鈥� + * @param model + */ + private void dealPlatformContentForLeave(PlatformJob model) { + List<PlatformDevice> deviceList = platformDeviceMapper.selectList(new QueryWrapper<PlatformDevice>().lambda() + .eq(PlatformDevice::getType, Constants.ZERO) + .eq(PlatformDevice::getPlatformId,model.getPlatformId()) + .eq(PlatformDevice::getIsdeleted,Constants.ZERO)); + if(deviceList ==null || deviceList.size() == 0){ + return; + } + int speed = 13; + try { + speed = Integer.parseInt(systemDictDataBiz.queryByCode(Constants.HK_PARAM,Constants.LED_CONTENT_SPEED).getCode()); + }catch (Exception e){ + } + String content = StringUtils.defaultString(model.getLedContent(), Constants.PlatformLedContent.IDEL_CONTNET.getInfo()); + List<PlatformBroadcastLog> logList = new ArrayList<>(); + for(PlatformDevice device : deviceList){ + if(StringUtils.isBlank(device.getHkId())){ + continue; + } + PlatformBroadcastLog log = dealLedContentBiz(model.getId(),device.getHkNo(),device.getName(),content,speed,1); + logList.add(log); + } + if(logList.size()>0){ + platformBroadcastLogMapper.insert(logList); + } } private PlatformEvent initPlatformEventModel(EventPlatformCarsInfoRequest request, EventPlatformCarsDataRequest data, EventPlatformCarsStatusInfoRequest status) { @@ -1162,12 +1692,12 @@ if(StringUtils.isBlank(device.getHkId())){ continue; } - if(Constants.equalsInteger(device.getType(),Constants.ZERO)){ + /*if(Constants.equalsInteger(device.getType(),Constants.ZERO)){ //濡傛灉鏄疞ED PlatformBroadcastLog log = dealLedContentBiz(model.getId(),device.getHkNo(),device.getName(),content,speed,1); logList.add(log); ledList.add(device.getHkId()); - }else if(Constants.equalsInteger(device.getType(),Constants.TWO)){ + }else */if(Constants.equalsInteger(device.getType(),Constants.TWO)){ //濡傛灉鏄箍鎾偣 bNames += device.getName()+";"; broadcastList.add(device.getHkId()); @@ -1181,6 +1711,56 @@ platformBroadcastLogMapper.insert(logList); } } + private void dealCarsAndPlatformErrorBiz( Platform model, EventPlatformCarsStatusInfoRequest status) { + //澶勭悊杞﹁締杩涘叆閿欒鏈堝彴涓氬姟閫昏緫 + SavePlatformWarnEventDTO savePlatformWarnEventDTO = new SavePlatformWarnEventDTO(); + savePlatformWarnEventDTO.setPlatformJobId(model.getId()); + savePlatformWarnEventDTO.setPlatformId(model.getId()); + savePlatformWarnEventDTO.setCarCode(status.getPlateNo()); + savePlatformWarnEventDTO.setEventType(Constants.PlatformWarnEvent.STOP_ERROR.getKey()); + platformWarnEventService.savePlatformWarnEvent(savePlatformWarnEventDTO); + + int speed = 13; + try { + speed = Integer.parseInt(systemDictDataBiz.queryByCode(Constants.HK_PARAM,Constants.LED_CONTENT_SPEED).getCode()); + }catch (Exception e){ + + } + List<PlatformDevice> deviceList = platformDeviceMapper.selectList(new QueryWrapper<PlatformDevice>().lambda() + .eq(PlatformDevice::getPlatformId,model.getId()) + .eq(PlatformDevice::getIsdeleted,Constants.ZERO)); + if(deviceList ==null || deviceList.size() == 0){ + return; + } + String content =Constants.PlatformLedContent.WRONG_IN.getInfo(); + content = content.replace("${param2}",model.getName()); + content = content.replace("${param}",status.getPlateNo()); + List<String> broadcastList = new ArrayList<>(); + List<String> ledList = new ArrayList<>(); + String bNames = ""; + List<PlatformBroadcastLog> logList = new ArrayList<>(); + for(PlatformDevice device : deviceList){ + if(StringUtils.isBlank(device.getHkId())){ + continue; + } + if(Constants.equalsInteger(device.getType(),Constants.TWO)){ + //濡傛灉鏄箍鎾偣 + bNames += device.getName()+";"; + broadcastList.add(device.getHkId()); + } + } + if(broadcastList.size()>0){ + PlatformJob job = new PlatformJob(); + job.setId(-1); + job.setCarCodeFront(status.getPlateNo()); + job.setPlatformId(model.getId()); + PlatformBroadcastLog log = dealBroadcastBiz(job,broadcastList,bNames,Constants.PlatformBroadcastContent.WRONG_IN.getInfo().replace("${param}",status.getPlateNo())); + logList.add(log); + } + if(logList.size()>0){ + platformBroadcastLogMapper.insert(logList); + } + } /** * 骞挎挱閫氱煡 -- Gitblit v1.9.3