|  |  |  | 
|---|
|  |  |  | package com.genersoft.iot.vmp.gb28181.transmit.event.request.impl.message.notify.cmd; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.genersoft.iot.vmp.common.VideoManagerConstants; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.Device; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.ParentPlatform; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.event.EventPublisher; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.event.request.impl.message.notify.NotifyMessageHandler; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.service.IDeviceService; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IRedisCatchStorage; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IVideoManagerStorager; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IVideoManagerStorage; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.utils.DateUtil; | 
|---|
|  |  |  | import org.dom4j.Element; | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | import org.slf4j.LoggerFactory; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.stereotype.Component; | 
|---|
|  |  |  | import org.springframework.util.StringUtils; | 
|---|
|  |  |  | import springfox.documentation.service.Header; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.sip.InvalidArgumentException; | 
|---|
|  |  |  | import javax.sip.RequestEvent; | 
|---|
|  |  |  | 
|---|
|  |  |  | public class KeepaliveNotifyMessageHandler extends SIPRequestProcessorParent implements InitializingBean, IMessageHandler { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Logger logger = LoggerFactory.getLogger(KeepaliveNotifyMessageHandler.class); | 
|---|
|  |  |  | private final String cmdType = "Keepalive"; | 
|---|
|  |  |  | private final static String cmdType = "Keepalive"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private NotifyMessageHandler notifyMessageHandler; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private EventPublisher publisher; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IVideoManagerStorager videoManagerStorager; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IRedisCatchStorage redisCatchStorage; | 
|---|
|  |  |  | private IDeviceService deviceService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void afterPropertiesSet() throws Exception { | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void handForDevice(RequestEvent evt, Device device, Element element) { | 
|---|
|  |  |  | // 检查设备是否存在并在线, 不在线则设置为在线 | 
|---|
|  |  |  | if (device == null) { | 
|---|
|  |  |  | // 未注册的设备不做处理 | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | if (device != null ) { | 
|---|
|  |  |  | // 回复200 OK | 
|---|
|  |  |  | responseAck(evt, Response.OK); | 
|---|
|  |  |  | // 判断RPort是否改变,改变则说明路由nat信息变化,修改设备信息 | 
|---|
|  |  |  | // 获取到通信地址等信息 | 
|---|
|  |  |  | ViaHeader viaHeader = (ViaHeader) evt.getRequest().getHeader(ViaHeader.NAME); | 
|---|
|  |  |  | String received = viaHeader.getReceived(); | 
|---|
|  |  |  | int rPort = viaHeader.getRPort(); | 
|---|
|  |  |  | // 解析本地地址替代 | 
|---|
|  |  |  | if (StringUtils.isEmpty(received) || rPort == -1) { | 
|---|
|  |  |  | received = viaHeader.getHost(); | 
|---|
|  |  |  | rPort = viaHeader.getPort(); | 
|---|
|  |  |  | // 判断RPort是否改变,改变则说明路由nat信息变化,修改设备信息 | 
|---|
|  |  |  | // 获取到通信地址等信息 | 
|---|
|  |  |  | ViaHeader viaHeader = (ViaHeader) evt.getRequest().getHeader(ViaHeader.NAME); | 
|---|
|  |  |  | String received = viaHeader.getReceived(); | 
|---|
|  |  |  | int rPort = viaHeader.getRPort(); | 
|---|
|  |  |  | // 解析本地地址替代 | 
|---|
|  |  |  | if (StringUtils.isEmpty(received) || rPort == -1) { | 
|---|
|  |  |  | received = viaHeader.getHost(); | 
|---|
|  |  |  | rPort = viaHeader.getPort(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (device.getPort() != rPort) { | 
|---|
|  |  |  | device.setPort(rPort); | 
|---|
|  |  |  | device.setHostAddress(received.concat(":").concat(String.valueOf(rPort))); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | device.setKeepaliveTime(DateUtil.getNow()); | 
|---|
|  |  |  | // 回复200 OK | 
|---|
|  |  |  | responseAck(evt, Response.OK); | 
|---|
|  |  |  | if (device.getOnline() == 1) { | 
|---|
|  |  |  | deviceService.updateDevice(device); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | // 对于已经离线的设备判断他的注册是否已经过期 | 
|---|
|  |  |  | if (!deviceService.expire(device)){ | 
|---|
|  |  |  | deviceService.online(device); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (device.getPort() != rPort) { | 
|---|
|  |  |  | device.setPort(rPort); | 
|---|
|  |  |  | device.setHostAddress(received.concat(":").concat(String.valueOf(rPort))); | 
|---|
|  |  |  | videoManagerStorager.updateDevice(device); | 
|---|
|  |  |  | redisCatchStorage.updateDevice(device); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | publisher.onlineEventPublish(device, VideoManagerConstants.EVENT_ONLINE_KEEPLIVE); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (SipException e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|