|  |  |  | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | 
|---|
|  |  |  | if( data.getHPVehicleStatus() ==null  ){ | 
|---|
|  |  |  | continue;//如何推送状态集合为空,不处理跳过 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //各车道车辆状态 | 
|---|
|  |  |  | EventPlatformCarsStatusInfoRequest status = data.getHPVehicleStatus(); | 
|---|
|  |  |  | PlatformEvent event = initPlatformEventModel(request,data,status); | 
|---|
|  |  |  | if(StringUtils.isBlank(status.getPlateNo())){ | 
|---|
|  |  |  | eventList.add(event);//封装事件(已月台通道为维度) | 
|---|
|  |  |  | continue;//如果车辆信息为空,不处理直接跳过 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | PlatformDevice model = platformDeviceMapper.selectOne(new QueryWrapper<PlatformDevice>().lambda() | 
|---|
|  |  |  | .eq(PlatformDevice::getDeviceId,request.getSrcIndex()) | 
|---|
|  |  |  | .eq(PlatformDevice::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .last("limit 1")); | 
|---|
|  |  |  | if(model ==null){ | 
|---|
|  |  |  | eventList.add(event);//封装事件(已月台通道为维度) | 
|---|
|  |  |  | continue;//监控点未同步,跳过处理 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //各车道车辆状态 | 
|---|
|  |  |  | EventPlatformCarsStatusInfoRequest status = data.getHPVehicleStatus(); | 
|---|
|  |  |  | eventList.add(initPlatformEventModel(request,data,status));//封装事件(已月台通道为维度) | 
|---|
|  |  |  | if(StringUtils.isBlank(status.getPlateNo())){ | 
|---|
|  |  |  | continue;//如果车辆信息为空,不处理直接跳过 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | event.setPlatformId(model.getPlatformId());//月台编码 | 
|---|
|  |  |  | eventList.add(event);//封装事件(已月台通道为维度) | 
|---|
|  |  |  | //截掉第一个颜色汉字,去掉“挂”字 | 
|---|
|  |  |  | status.setPlateNo(status.getPlateNo().substring(1,status.getPlateNo().length()).replace("挂","")); | 
|---|
|  |  |  | PlatformJob job = platformJobMapper.selectJoinOne(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() | 
|---|
|  |  |  | .selectAll(PlatformJob.class) | 
|---|
|  |  |  | .selectAs(Platform::getName,PlatformJob::getPlatformName) | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq(!StringUtils.equals(status.getStockStatus(),"front"),PlatformJob::getCarCodeBack,status.getPlateNo() )//后车牌号 | 
|---|
|  |  |  | .eq(PlatformJob::getIsdeleted,Constants.ZERO ) | 
|---|
|  |  |  | .last("limit 1 ")); | 
|---|
|  |  |  | if(job == null){ | 
|---|
|  |  |  | continue;//如果作业为空,跳过处理 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | PlatformJob update = new PlatformJob(); | 
|---|
|  |  |  | update.setId(job.getId()); | 
|---|
|  |  |  | update.setEditDate(new Date()); | 
|---|
|  |  |  | if(StringUtils.equals(status.getMotionStatus(),"leave")){ | 
|---|
|  |  |  | //如果是车辆离开,不做相关自动完成作业业务处理 | 
|---|
|  |  |  | /*   if(job ==null && !Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())){ | 
|---|
|  |  |  | /* if(job ==null && !Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())){ | 
|---|
|  |  |  | continue;//如果没查到对应的作业或者作业并非作业中,不做业务处理 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(Constants.equalsInteger(job.getType(), Constants.THREE) || Constants.equalsInteger(job.getType(), Constants.TWO)){ | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 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.setRemark(device.getName()); | 
|---|
|  |  |  | 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)){ | 
|---|
|  |  |  | 
|---|
|  |  |  | 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.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("发送广播播报内容"); | 
|---|
|  |  |  | PlatformBroadcastLog log = dealBroadcastBiz(model,broadcastList,bNames); | 
|---|
|  |  |  | logList.add(log); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(logList.size()>0){ | 
|---|
|  |  |  | platformBroadcastLogMapper.insert(logList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | public static 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()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public static BaseResponse dealLedContentBiz(String hkNo, String content,int speed,int color) { | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|