old mode 100644
new mode 100755
|  |  |  | 
|---|
|  |  |  | package com.genersoft.iot.vmp.gb28181.transmit.event.request.impl.message.notify.cmd; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSONObject; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.UserSetting; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.*; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.event.EventPublisher; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.event.request.SIPRequestProcessorParent; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.event.request.impl.message.IMessageHandler; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.event.request.impl.message.notify.NotifyMessageHandler; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.utils.NumericUtil; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.utils.SipUtils; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.service.IDeviceChannelService; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IRedisCatchStorage; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IVideoManagerStorage; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IDeviceChannelService deviceChannelService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private EventPublisher eventPublisher; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private ConcurrentLinkedQueue<SipMsgInfo> taskQueue = new ConcurrentLinkedQueue<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Qualifier("taskExecutor") | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | mobilePosition.setDeviceId(sipMsgInfo.getDevice().getDeviceId()); | 
|---|
|  |  |  | mobilePosition.setChannelId(getText(rootElementAfterCharset, "DeviceID")); | 
|---|
|  |  |  | mobilePosition.setTime(getText(rootElementAfterCharset, "Time")); | 
|---|
|  |  |  | String time = getText(rootElementAfterCharset, "Time"); | 
|---|
|  |  |  | if (ObjectUtils.isEmpty(time)){ | 
|---|
|  |  |  | mobilePosition.setTime(DateUtil.getNow()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | mobilePosition.setTime(SipUtils.parseTime(time)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | mobilePosition.setLongitude(Double.parseDouble(getText(rootElementAfterCharset, "Longitude"))); | 
|---|
|  |  |  | mobilePosition.setLatitude(Double.parseDouble(getText(rootElementAfterCharset, "Latitude"))); | 
|---|
|  |  |  | if (NumericUtil.isDouble(getText(rootElementAfterCharset, "Speed"))) { | 
|---|
|  |  |  | 
|---|
|  |  |  | mobilePosition.setLongitudeGcj02(deviceChannel.getLongitudeGcj02()); | 
|---|
|  |  |  | mobilePosition.setLatitudeGcj02(deviceChannel.getLatitudeGcj02()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (userSetting.getSavePositionHistory()) { | 
|---|
|  |  |  | storager.insertMobilePosition(mobilePosition); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | storager.updateChannelPosition(deviceChannel); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送redis消息。 通知位置信息的变化 | 
|---|
|  |  |  | JSONObject jsonObject = new JSONObject(); | 
|---|
|  |  |  | jsonObject.put("time", mobilePosition.getTime()); | 
|---|
|  |  |  | jsonObject.put("serial", deviceChannel.getDeviceId()); | 
|---|
|  |  |  | jsonObject.put("code", deviceChannel.getChannelId()); | 
|---|
|  |  |  | jsonObject.put("longitude", mobilePosition.getLongitude()); | 
|---|
|  |  |  | jsonObject.put("latitude", mobilePosition.getLatitude()); | 
|---|
|  |  |  | jsonObject.put("altitude", mobilePosition.getAltitude()); | 
|---|
|  |  |  | jsonObject.put("direction", mobilePosition.getDirection()); | 
|---|
|  |  |  | jsonObject.put("speed", mobilePosition.getSpeed()); | 
|---|
|  |  |  | redisCatchStorage.sendMobilePositionMsg(jsonObject); | 
|---|
|  |  |  | deviceChannelService.updateChannelGPS(device, deviceChannel, mobilePosition); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } catch (DocumentException e) { | 
|---|
|  |  |  | logger.error("未处理的异常 ", e); | 
|---|