|  |  |  | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; | 
|---|
|  |  |  | import com.doumee.biz.system.SystemDictDataBiz; | 
|---|
|  |  |  | import com.doumee.config.DataSyncConfig; | 
|---|
|  |  |  | import com.doumee.config.SpringContextUtil; | 
|---|
|  |  |  | import com.doumee.core.exception.BusinessException; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.HKConstants; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.BaseResponse; | 
|---|
|  |  |  | import com.doumee.core.haikang.model.param.request.*; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.doumee.dao.business.*; | 
|---|
|  |  |  | import com.doumee.dao.business.join.VisitsJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.model.*; | 
|---|
|  |  |  | import com.doumee.dao.system.model.SystemUser; | 
|---|
|  |  |  | import com.doumee.dao.web.reqeust.SavePlatformWarnEventDTO; | 
|---|
|  |  |  | import com.doumee.service.business.DeviceEventService; | 
|---|
|  |  |  | import com.doumee.service.business.InterfaceLogService; | 
|---|
|  |  |  | import com.doumee.service.business.MemberService; | 
|---|
|  |  |  | import com.doumee.service.business.impl.PlatformWarnEventServiceImpl; | 
|---|
|  |  |  | import com.github.yulichang.interfaces.MPJBaseJoin; | 
|---|
|  |  |  | import com.github.yulichang.wrapper.MPJLambdaWrapper; | 
|---|
|  |  |  | import com.hikvision.artemis.sdk.config.ArtemisConfig; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | 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.yaml.snakeyaml.scanner.Constant; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.servlet.http.HttpServletResponse; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | 
|---|
|  |  |  | //再插入最新的在厂人员 | 
|---|
|  |  |  | retentionMapper.insert(retentionList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.error("【海康门禁事件推送】========成功======="); | 
|---|
|  |  |  | log.info("【海康门禁事件推送】========成功======="); | 
|---|
|  |  |  | }catch (Exception e) { | 
|---|
|  |  |  | log.error("【海康门禁事件推送】========失败=======:\n" + e.getMessage()); | 
|---|
|  |  |  | }finally { | 
|---|
|  |  |  | 
|---|
|  |  |  | //再插入最新的在厂人员 | 
|---|
|  |  |  | retentionMapper.insert(retentionList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.error("【海康访客事件推送】========成功======="); | 
|---|
|  |  |  | log.info("【海康访客事件推送】========成功======="); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | log.error("【海康访客事件推送】========失败=======:\n"+e.getMessage()); | 
|---|
|  |  |  | 
|---|
|  |  |  | //再插入最新的在厂人员 | 
|---|
|  |  |  | retentionMapper.insert(retentionList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.error("【海康访客事件推送】========成功======="); | 
|---|
|  |  |  | log.info("【海康访客事件推送】========成功======="); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | log.error("【海康访客事件推送】========失败=======:\n"+e.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | //再插入最新的在厂人员 | 
|---|
|  |  |  | retentionMapper.insert(retentionList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.error("【海康停车场事件推送】========成功======="); | 
|---|
|  |  |  | log.info("【海康停车场事件推送】========成功======="); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | log.error("【海康停车场事件推送】========失败=======:\n"+e.getMessage()); | 
|---|
|  |  |  | 
|---|
|  |  |  | event.setReleaseResult(request.getData().getInResult().getRlsResult().getReleaseResult()); | 
|---|
|  |  |  | event.setReleaseResultEx(request.getData().getInResult().getRlsResult().getReleaseResultEx()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(request.getData().getPicUrl()!=null){ | 
|---|
|  |  |  | //车辆和和车牌照片 | 
|---|
|  |  |  | event.setVehiclePicUrl(getHkImgUrl(request.getData().getPicUrl().getVehiclePicUrl())); | 
|---|
|  |  |  | 
|---|
|  |  |  | delRetentionList.add(event.getPlateNos()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return event; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Retention getRetentionModelByParkRequest(EventParkInfoRequest request) { | 
|---|
|  |  |  | 
|---|
|  |  |  | retention.setType(Constants.THREE); | 
|---|
|  |  |  | //        retention.setDeviceName(request.getSrcName()); | 
|---|
|  |  |  | //        retention.setDeviceIndex(request.getSrcIndex()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return retention; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | result = "成功"; | 
|---|
|  |  |  | log.error("【海康月台工作状态事件推送】========成功======="); | 
|---|
|  |  |  | log.info("【海康月台工作状态事件推送】========成功======="); | 
|---|
|  |  |  | }catch (Exception e) { | 
|---|
|  |  |  | result = "失败"+e.getMessage(); | 
|---|
|  |  |  | log.error("【海康月台工作状态事件推送】========失败=======:\n" + e.getMessage()); | 
|---|
|  |  |  | 
|---|
|  |  |  | if( data.getHPVehicleStatus() ==null  ){ | 
|---|
|  |  |  | continue;//如何推送状态集合为空,不处理跳过 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //各车道车辆状态 | 
|---|
|  |  |  | EventPlatformCarsStatusInfoRequest status = data.getHPVehicleStatus(); | 
|---|
|  |  |  | eventList.add(initPlatformEventModel(request,data,status));//封装事件(已月台通道为维度) | 
|---|
|  |  |  | PlatformDevice model = platformDeviceMapper.selectOne(new QueryWrapper<PlatformDevice>().lambda() | 
|---|
|  |  |  | .eq(PlatformDevice::getDeviceId,request.getSrcIndex()) | 
|---|
|  |  |  | .eq(PlatformDevice::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .last("limit 1")); | 
|---|
|  |  |  | if(model ==null){ | 
|---|
|  |  |  | continue;//监控点未同步,跳过处理 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //各车道车辆状态 | 
|---|
|  |  |  | EventPlatformCarsStatusInfoRequest status = data.getHPVehicleStatus(); | 
|---|
|  |  |  | eventList.add(initPlatformEventModel(request,data,status));//封装事件(已月台通道为维度) | 
|---|
|  |  |  | if(StringUtils.isBlank(status.getPlateNo())){ | 
|---|
|  |  |  | continue;//如果车辆信息为空,不处理直接跳过 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | platformEventMapper.insert(eventList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | result = "成功"; | 
|---|
|  |  |  | log.error("【海康月台车辆状态事件推送】========成功======="); | 
|---|
|  |  |  | log.info("【海康月台车辆状态事件推送】========成功======="); | 
|---|
|  |  |  | }catch (Exception e) { | 
|---|
|  |  |  | result = "失败"+e.getMessage(); | 
|---|
|  |  |  | log.error("【海康月台车辆状态事件推送】========失败=======:\n" + e.getMessage()); | 
|---|
|  |  |  | 
|---|
|  |  |  | content = content.replace("${param2}",model.getCarCodeFront()); | 
|---|
|  |  |  | List<String> broadcastList = new ArrayList<>(); | 
|---|
|  |  |  | List<String> ledList = new ArrayList<>(); | 
|---|
|  |  |  | String bNames = ""; | 
|---|
|  |  |  | List<PlatformBroadcastLog> logList = new ArrayList<>(); | 
|---|
|  |  |  | for(PlatformDevice device : deviceList){ | 
|---|
|  |  |  | if(StringUtils.isNotBlank(device.getHkId())){ | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(Constants.equalsInteger(device.getType(),Constants.ZERO)){ | 
|---|
|  |  |  | //如果是LED | 
|---|
|  |  |  | PlatformBroadcastLog log = new PlatformBroadcastLog(); | 
|---|
|  |  |  | log.setCreateDate(new Date()); | 
|---|
|  |  |  | log.setBizType(Constants.ONE); | 
|---|
|  |  |  | log.setHkDate(new Date()); | 
|---|
|  |  |  | log.setObjType(Constants.ONE); | 
|---|
|  |  |  | log.setIds(device.getHkNo()); | 
|---|
|  |  |  | log.setInfo(content); | 
|---|
|  |  |  | log.setNum(Constants.ONE); | 
|---|
|  |  |  | BaseResponse response = dealLedContentBiz(device.getHkNo(),content,speed,1); | 
|---|
|  |  |  | if(response == null || !StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE)){ | 
|---|
|  |  |  | log.setHkInfo("请求失败:"+JSONObject.toJSONString(response)); | 
|---|
|  |  |  | log.setHkStatus(Constants.THREE); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | log.setHkInfo("请求成功"); | 
|---|
|  |  |  | log.setHkStatus(Constants.TWO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.setDeviceType(Constants.ONE); | 
|---|
|  |  |  | log.setName("设置LED屏显内容"); | 
|---|
|  |  |  | PlatformBroadcastLog log = dealLedContentBiz(device.getHkNo(),device.getName(),content,speed,1); | 
|---|
|  |  |  | logList.add(log); | 
|---|
|  |  |  | ledList.add(device.getHkId()); | 
|---|
|  |  |  | }else  if(Constants.equalsInteger(device.getType(),Constants.ZERO)){ | 
|---|
|  |  |  | //如果是广播点 | 
|---|
|  |  |  | bNames += device.getName()+";"; | 
|---|
|  |  |  | broadcastList.add(device.getHkId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(broadcastList.size()>0){ | 
|---|
|  |  |  | String content1 =Constants.PlatformBroadcastContent.WRONG_IN.getInfo(); | 
|---|
|  |  |  | content1 = content1.replace("${param}",model.getCarCodeFront()); | 
|---|
|  |  |  | PlatformBroadcastLog log = new PlatformBroadcastLog(); | 
|---|
|  |  |  | log.setCreateDate(new Date()); | 
|---|
|  |  |  | log.setBizType(Constants.ONE); | 
|---|
|  |  |  | log.setHkDate(new Date()); | 
|---|
|  |  |  | log.setObjType(Constants.ONE); | 
|---|
|  |  |  | log.setInfo(content1); | 
|---|
|  |  |  | log.setNum(Constants.ONE); | 
|---|
|  |  |  | log.setIds(String.join(",",broadcastList)); | 
|---|
|  |  |  | CustomBroadcastRequest request = new CustomBroadcastRequest(); | 
|---|
|  |  |  | request.setAudioPointIndexCode(broadcastList); | 
|---|
|  |  |  | request.setPlayDuration(15);//单位秒 | 
|---|
|  |  |  | request.setBroadCastMode("tts"); | 
|---|
|  |  |  | request.setPriority(1); | 
|---|
|  |  |  | request.setState(1);//播放/停止标识 1-播放,0-停止 | 
|---|
|  |  |  | request.setPlayTtsContent(content1); | 
|---|
|  |  |  | BaseResponse response =  HKService.customBroadcast(request); | 
|---|
|  |  |  | if(response == null || !StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE)){ | 
|---|
|  |  |  | log.setHkInfo("请求失败:"+JSONObject.toJSONString(response)); | 
|---|
|  |  |  | log.setHkStatus(Constants.THREE); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | log.setHkInfo("请求成功"); | 
|---|
|  |  |  | log.setHkStatus(Constants.TWO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.setDeviceType(Constants.ONE); | 
|---|
|  |  |  | log.setName("发送广播播报内容"); | 
|---|
|  |  |  | PlatformBroadcastLog log = dealBroadcastBiz(model,broadcastList,bNames); | 
|---|
|  |  |  | logList.add(log); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(logList.size()>0){ | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public static BaseResponse dealLedContentBiz(String hkNo, String content,int speed,int color) { | 
|---|
|  |  |  | private PlatformBroadcastLog dealBroadcastBiz(PlatformJob model, List<String> broadcastList,String bNames) { | 
|---|
|  |  |  | PlatformBroadcastLog log = new PlatformBroadcastLog(); | 
|---|
|  |  |  | String content1 =Constants.PlatformBroadcastContent.WRONG_IN.getInfo(); | 
|---|
|  |  |  | content1 = content1.replace("${param}",model.getCarCodeFront()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | log.setCreateDate(new Date()); | 
|---|
|  |  |  | log.setBizType(Constants.ONE); | 
|---|
|  |  |  | log.setHkDate(new Date()); | 
|---|
|  |  |  | log.setObjType(Constants.ONE); | 
|---|
|  |  |  | log.setInfo(content1); | 
|---|
|  |  |  | log.setRemark(bNames); | 
|---|
|  |  |  | log.setNum(Constants.ONE); | 
|---|
|  |  |  | log.setIds(String.join(",",broadcastList)); | 
|---|
|  |  |  | CustomBroadcastRequest request = new CustomBroadcastRequest(); | 
|---|
|  |  |  | request.setAudioPointIndexCode(broadcastList); | 
|---|
|  |  |  | request.setPlayDuration(15);//单位秒 | 
|---|
|  |  |  | request.setBroadCastMode("tts"); | 
|---|
|  |  |  | request.setPriority(1); | 
|---|
|  |  |  | request.setState(1);//播放/停止标识 1-播放,0-停止 | 
|---|
|  |  |  | request.setPlayTtsContent(content1); | 
|---|
|  |  |  | BaseResponse response =  HKService.customBroadcast(request); | 
|---|
|  |  |  | if(response == null || !StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE)){ | 
|---|
|  |  |  | log.setHkInfo("请求失败:"+JSONObject.toJSONString(response)); | 
|---|
|  |  |  | log.setHkStatus(Constants.THREE); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | log.setHkInfo("请求成功"); | 
|---|
|  |  |  | log.setHkStatus(Constants.TWO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.setDeviceType(Constants.ONE); | 
|---|
|  |  |  | log.setName("发送广播播报内容"); | 
|---|
|  |  |  | return  log; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public static PlatformBroadcastLog dealLedContentBiz(String hkNo,String hkName, String content,int speed,int color) { | 
|---|
|  |  |  | PlatformBroadcastLog log = new PlatformBroadcastLog(); | 
|---|
|  |  |  | log.setCreateDate(new Date()); | 
|---|
|  |  |  | log.setBizType(Constants.ONE); | 
|---|
|  |  |  | log.setHkDate(new Date()); | 
|---|
|  |  |  | log.setObjType(Constants.ONE); | 
|---|
|  |  |  | log.setIds(hkNo); | 
|---|
|  |  |  | log.setRemark(hkName); | 
|---|
|  |  |  | log.setInfo(content); | 
|---|
|  |  |  | log.setNum(Constants.ONE); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | TransparentChannelBodyRequest body = new TransparentChannelBodyRequest(); | 
|---|
|  |  |  | TransparentChannelHeadRequest head = new TransparentChannelHeadRequest(); | 
|---|
|  |  |  | TransparentChannelBodyParamRequest request = new TransparentChannelBodyParamRequest(); | 
|---|
|  |  |  | 
|---|
|  |  |  | request.getRegions().add(regions); | 
|---|
|  |  |  | regions.setSpeed(speed>0?speed:13); | 
|---|
|  |  |  | body.setParams(request); | 
|---|
|  |  |  | return HKService.transparentchannel(head,body); | 
|---|
|  |  |  | BaseResponse response =  HKService.transparentchannel(head,body); | 
|---|
|  |  |  | if(response == null || !StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE)){ | 
|---|
|  |  |  | log.setHkInfo("请求失败:"+JSONObject.toJSONString(response)); | 
|---|
|  |  |  | log.setHkStatus(Constants.THREE); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | log.setHkInfo("请求成功"); | 
|---|
|  |  |  | log.setHkStatus(Constants.TWO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.setDeviceType(Constants.ONE); | 
|---|
|  |  |  | log.setName("设置LED屏显内容"); | 
|---|
|  |  |  | return log; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|