|  |  |  | 
|---|
|  |  |  | package com.doumee.service.business.impl.hksync; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; | 
|---|
|  |  |  | import com.doumee.biz.system.SystemDictDataBiz; | 
|---|
|  |  |  | import com.doumee.core.constants.ResponseStatus; | 
|---|
|  |  |  | import com.doumee.core.exception.BusinessException; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.BaseListPageResponse; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.BaseResponse; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.request.*; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.request.event.visit.EventVisitInfoRequest; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.respose.*; | 
|---|
|  |  |  | import com.doumee.core.haikang.service.HKService; | 
|---|
|  |  |  | import com.doumee.core.utils.Constants; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.doumee.core.utils.ImageBase64Util; | 
|---|
|  |  |  | import com.doumee.core.wx.wxPlat.WxPlatNotice; | 
|---|
|  |  |  | import com.doumee.dao.business.DeviceRoleMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.RetentionMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.join.VisitsJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.model.DeviceRole; | 
|---|
|  |  |  | import com.doumee.dao.business.model.Member; | 
|---|
|  |  |  | import com.doumee.dao.business.model.Retention; | 
|---|
|  |  |  | import com.doumee.dao.business.model.Visits; | 
|---|
|  |  |  | import com.github.yulichang.wrapper.MPJLambdaWrapper; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | 
|---|
|  |  |  | public class HkSyncVisitServiceImpl extends HkSyncBaseServiceImpl { | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private VisitsJoinMapper visitsMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private RetentionMapper retentionMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SystemDictDataBiz systemDictDataBiz; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | 
|---|
|  |  |  | *      * 10:邀约中(员工发起邀约,访客还未应邀)、 | 
|---|
|  |  |  | *      * 11:邀约失效(员工发起邀约,一直到当前时间超过预计离开时间,访客还未应邀) | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | if (model.getVisitorStatus()!=null && "3,4,11".contains( model.getVisitorStatus()+"" )){ | 
|---|
|  |  |  | if (model.getVisitorStatus()!=null && ",3,4,11,".contains( ","  +model.getVisitorStatus()+"," )){ | 
|---|
|  |  |  | //对相应状态下的数据进行【已失效】处理 | 
|---|
|  |  |  | Visits update = new Visits(); | 
|---|
|  |  |  | //已失效 | 
|---|
|  |  |  | 
|---|
|  |  |  | update.setRemark("超时未登记"); | 
|---|
|  |  |  | visitsMapper.updateById(update); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (model.getVisitorStatus()!=null && "5,6".contains( model.getVisitorStatus()+"" )){ | 
|---|
|  |  |  | if (model.getVisitorStatus()!=null && ",5,6,".contains( ","  +model.getVisitorStatus()+"," )){ | 
|---|
|  |  |  | // 对相应状态下的数据进行【已签离】处理 | 
|---|
|  |  |  | if(!Constants.equalsInteger(c.getStatus(),Constants.VisitStatus.signout)){ | 
|---|
|  |  |  | Visits update = new Visits(); | 
|---|
|  |  |  | 
|---|
|  |  |  | update.setOutDate(DateUtil.getISO8601DateByStr2(model.getVisitEndTime())); | 
|---|
|  |  |  | update.setRemark("已签离"); | 
|---|
|  |  |  | visitsMapper.updateById(update); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //先删除原有的在场人员(普通访客) | 
|---|
|  |  |  | retentionMapper.delete(new UpdateWrapper<Retention>().lambda() | 
|---|
|  |  |  | .eq(Retention::getType,Constants.memberType.visitor) | 
|---|
|  |  |  | .eq(Retention::getMemberId,c.getMemberId())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (model.getVisitorStatus()!=null&& "7,8".contains( model.getVisitorStatus()+"")){ | 
|---|
|  |  |  | if (model.getVisitorStatus()!=null&& ",7,8,".contains( ","  +model.getVisitorStatus()+"," )){ | 
|---|
|  |  |  | //如果已登记 | 
|---|
|  |  |  | if(!Constants.equalsInteger(c.getStatus(),Constants.VisitStatus.signin)){ | 
|---|
|  |  |  | Visits update = new Visits(); | 
|---|
|  |  |  | 
|---|
|  |  |  | update.setOutDate(DateUtil.getISO8601DateByStr2(model.getVisitEndTime())); | 
|---|
|  |  |  | update.setRemark("超时未签到"); | 
|---|
|  |  |  | visitsMapper.updateById(update); | 
|---|
|  |  |  | //先删除原有的在场人员(普通访客) | 
|---|
|  |  |  | retentionMapper.delete(new UpdateWrapper<Retention>().lambda() | 
|---|
|  |  |  | .eq(Retention::getType,Constants.memberType.visitor) | 
|---|
|  |  |  | .eq(Retention::getMemberId,c.getMemberId())); | 
|---|
|  |  |  | //再插入最新的在厂人员 | 
|---|
|  |  |  | retentionMapper.insert(getRetentionModelByVisitRequest(c,update.getInDate())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | Constants.DEALING_HK_VISIT_EXPIRE =false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Retention getRetentionModelByVisitRequest(Visits visits,Date date) { | 
|---|
|  |  |  | Retention retention = new Retention(); | 
|---|
|  |  |  | retention.setIsdeleted(Constants.ZERO); | 
|---|
|  |  |  | retention.setCreateDate(date); | 
|---|
|  |  |  | retention.setClasses(visits.getClasses()); | 
|---|
|  |  |  | retention.setCode(visits.getCode()); | 
|---|
|  |  |  | retention.setIdcardNo(visits.getIdcardNo()); | 
|---|
|  |  |  | retention.setIdcardDecode(visits.getIdcardDecode()); | 
|---|
|  |  |  | retention.setName(visits.getName()); | 
|---|
|  |  |  | retention.setBirthday(visits.getBirthday()); | 
|---|
|  |  |  | retention.setType(visits.getMemberType()); | 
|---|
|  |  |  | retention.setCompanyId(visits.getCompanyId()); | 
|---|
|  |  |  | retention.setCompanyName(visits.getCompanyName()); | 
|---|
|  |  |  | retention.setEventDate(retention.getCreateDate()); | 
|---|
|  |  |  | retention.setFaceImg(visits.getFaceImg()); | 
|---|
|  |  |  | retention.setImgurl(visits.getImgurl()); | 
|---|
|  |  |  | retention.setPhone(visits.getPhone()); | 
|---|
|  |  |  | retention.setMemberId(visits.getMemberId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return retention; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public AppointmentInfoResponse getVisitRecord(String orderId){ | 
|---|
|  |  |  | //分页遍历循环查询所有门禁设备数据 | 
|---|
|  |  |  | if(StringUtils.isBlank(orderId)){ | 
|---|
|  |  |  | 
|---|
|  |  |  | private void getUpdateModelByResponse(  Visits c,Date date,String type,List<DeviceRole> roleList,String path ) { | 
|---|
|  |  |  | String code = null; | 
|---|
|  |  |  | String id = null; | 
|---|
|  |  |  | String qrcode = null; | 
|---|
|  |  |  | //发起海康预约接口 | 
|---|
|  |  |  | if(StringUtils.equals(type,"0")){ | 
|---|
|  |  |  | //(需要登记) | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | BaseResponse<VisitAppointmentResponse> response =  HKService.visitAppiontment(request); | 
|---|
|  |  |  | code =response!=null ?response.getCode():null; | 
|---|
|  |  |  | id = (response!=null && response.getData()!=null | 
|---|
|  |  |  | if((response!=null && response.getData()!=null | 
|---|
|  |  |  | && response.getData().getAppointmentInfoList() !=null | 
|---|
|  |  |  | && response.getData().getAppointmentInfoList().size()>0)?response.getData().getAppointmentInfoList().get(0).getOrderId():null; | 
|---|
|  |  |  | && response.getData().getAppointmentInfoList().size()>0)){ | 
|---|
|  |  |  | id =response.getData().getAppointmentInfoList().get(0).getOrderId(); | 
|---|
|  |  |  | qrcode =response.getData().getAppointmentInfoList().get(0).getQRCode(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //免登记 | 
|---|
|  |  |  | VisitAppointmentMDJRequest request =getHkMDJRequestPara(c,roleList,path); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | BaseResponse<VisitAppointmentMDJResponse> response = HKService.visitAppiontmentMDJ(request ); | 
|---|
|  |  |  | code =response!=null ?response.getCode():null; | 
|---|
|  |  |  | id = (response!=null && response.getData()!=null)?response.getData().getOrderId():null; | 
|---|
|  |  |  | if(response!=null && response.getData()!=null){ | 
|---|
|  |  |  | id = response.getData().getOrderId(); | 
|---|
|  |  |  | qrcode =response.getData().getQRCode(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (code!= null && id!=null) { | 
|---|
|  |  |  | //海康下发成功 | 
|---|
|  |  |  | c.setHkId( id);//预约标识 | 
|---|
|  |  |  | c.setQrcode(qrcode); | 
|---|
|  |  |  | c.setRemark("下发海康成功!【"+type+"】"); | 
|---|
|  |  |  | c.setStatus(Constants.VisitStatus.xfSuccess);//下发海康成功 | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | //海康下发成功 | 
|---|
|  |  |  | //海康下发失败 | 
|---|
|  |  |  | c.setRemark("下发海康失败!【"+type+"】"); | 
|---|
|  |  |  | c.setStatus(Constants.VisitStatus.xfFail);//下发海康失败 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | request.setVisitEndTime(DateUtil.getISO8601Timestamp(c.getEndtime())); | 
|---|
|  |  |  | request.setReceptionistId(c.getReceptMemberHkId());//被访人海康编码 | 
|---|
|  |  |  | request.setVisitPurpose(c.getReason()); | 
|---|
|  |  |  | if(StringUtils.isNotBlank(c.getReason())){ | 
|---|
|  |  |  | char[] charArray = c.getReason().toCharArray(); | 
|---|
|  |  |  | int length = charArray.length; | 
|---|
|  |  |  | if(length>32){ | 
|---|
|  |  |  | request.setVisitPurpose(c.getReason().substring(32)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //获取权限组集合 | 
|---|
|  |  |  | request.setVisitorPermissionSet(getVisitPermissonRequest(roleList,c)); | 
|---|
|  |  |  | List<VisitAppointmentVistorRequest> infolist = new ArrayList<>(); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | private List<Visits> getExpireVisitList() { | 
|---|
|  |  |  | MPJLambdaWrapper<Visits> queryWrapper = new MPJLambdaWrapper<>(); | 
|---|
|  |  |  | queryWrapper.selectAll(Visits.class); | 
|---|
|  |  |  | queryWrapper.selectAll(Visits.class) | 
|---|
|  |  |  | .selectAs(Member::getType,Visits::getMemberType) | 
|---|
|  |  |  | .leftJoin(Member.class,Member::getId,Visits::getMemberId); | 
|---|
|  |  |  | queryWrapper.in(Visits::getStatus, Arrays.asList(new Integer[]{Constants.VisitStatus.xfSuccess,Constants.VisitStatus.signin}) ); | 
|---|
|  |  |  | List<Visits> list = visitsMapper.selectJoinList(Visits.class,queryWrapper); | 
|---|
|  |  |  | return list; | 
|---|