|  |  |  | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.event.SipSubscribe; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.cmd.ISIPCommanderForPlatform; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IRedisCatchStorage; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IVideoManagerStorager; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IVideoManagerStorage; | 
|---|
|  |  |  | import org.jetbrains.annotations.NotNull; | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | import org.slf4j.LoggerFactory; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.context.ApplicationListener; | 
|---|
|  |  |  | import org.springframework.stereotype.Component; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.sip.ResponseEvent; | 
|---|
|  |  |  | import javax.sip.message.Response; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @Description: 平台心跳超时事件 | 
|---|
|  |  |  | * @description: 平台心跳超时事件 | 
|---|
|  |  |  | * @author: panll | 
|---|
|  |  |  | * @date: 2020年11月5日 10:00 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | 
|---|
|  |  |  | private final static Logger logger = LoggerFactory.getLogger(PlatformKeepaliveExpireEventLister.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IVideoManagerStorager storager; | 
|---|
|  |  |  | private IVideoManagerStorage storager; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IRedisCatchStorage redisCatchStorage; | 
|---|
|  |  |  | 
|---|
|  |  |  | if (parentPlatformCatch.getKeepAliveReply() >= 3) { | 
|---|
|  |  |  | // 有3次未收到心跳回复, 设置平台状态为离线, 开始重新注册 | 
|---|
|  |  |  | logger.warn("有3次未收到心跳回复,标记设置平台状态为离线, 并重新注册 平台国标ID:" + event.getPlatformGbID()); | 
|---|
|  |  |  | storager.updateParentPlatformStatus(event.getPlatformGbID(), false); | 
|---|
|  |  |  | publisher.platformNotRegisterEventPublish(event.getPlatformGbID()); | 
|---|
|  |  |  | parentPlatformCatch.setKeepAliveReply(0); | 
|---|
|  |  |  | redisCatchStorage.updatePlatformCatchInfo(parentPlatformCatch); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | // 再次发送心跳 | 
|---|
|  |  |  | String callId = sipCommanderForPlatform.keepalive(parentPlatform); | 
|---|
|  |  |  | 
|---|
|  |  |  | redisCatchStorage.updatePlatformKeepalive(parentPlatform); | 
|---|
|  |  |  | redisCatchStorage.updatePlatformCatchInfo(parentPlatformCatch); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | sipSubscribe.addOkSubscribe(callId, (ResponseEvent responseEvent) ->{ | 
|---|
|  |  |  | if (responseEvent.getResponse().getStatusCode() == Response.OK) { | 
|---|
|  |  |  | sipSubscribe.addOkSubscribe(callId, (SipSubscribe.EventResult eventResult) ->{ | 
|---|
|  |  |  | if (eventResult.statusCode == Response.OK) { | 
|---|
|  |  |  | // 收到心跳响应信息, | 
|---|
|  |  |  | parentPlatformCatch.setKeepAliveReply(0); | 
|---|
|  |  |  | redisCatchStorage.updatePlatformCatchInfo(parentPlatformCatch); | 
|---|