| | |
| | | package com.genersoft.iot.vmp.gb28181.event.online;
|
| | |
|
| | | import com.genersoft.iot.vmp.conf.SipConfig;
|
| | | import com.genersoft.iot.vmp.conf.UserSetup;
|
| | | import com.genersoft.iot.vmp.conf.UserSetting;
|
| | | import com.genersoft.iot.vmp.gb28181.bean.Device;
|
| | | import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
|
| | | import com.genersoft.iot.vmp.gb28181.event.EventPublisher;
|
| | | import com.genersoft.iot.vmp.gb28181.event.subscribe.catalog.CatalogEvent;
|
| | | import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
|
| | | import com.genersoft.iot.vmp.service.IDeviceService;
|
| | | import com.genersoft.iot.vmp.storager.dao.dto.User;
|
| | | import org.slf4j.Logger;
|
| | | import org.slf4j.LoggerFactory;
|
| | | import org.springframework.beans.factory.annotation.Autowired;
|
| | |
| | | import org.springframework.stereotype.Component;
|
| | |
|
| | | import com.genersoft.iot.vmp.common.VideoManagerConstants;
|
| | | import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
|
| | | import com.genersoft.iot.vmp.storager.IVideoManagerStorage;
|
| | | import com.genersoft.iot.vmp.utils.redis.RedisUtil;
|
| | |
|
| | | import java.text.SimpleDateFormat;
|
| | |
| | | private final static Logger logger = LoggerFactory.getLogger(OnlineEventListener.class);
|
| | |
|
| | | @Autowired
|
| | | private IVideoManagerStorager storager;
|
| | | private IVideoManagerStorage storager;
|
| | |
|
| | | @Autowired
|
| | | private IDeviceService deviceService;
|
| | |
|
| | | @Autowired
|
| | | private RedisUtil redis;
|
| | |
| | | private SipConfig sipConfig;
|
| | |
|
| | | @Autowired
|
| | | private UserSetup userSetup;
|
| | | private UserSetting userSetting;
|
| | |
|
| | | @Autowired
|
| | | private EventPublisher eventPublisher;
|
| | |
|
| | | @Autowired
|
| | | private SIPCommander cmder;
|
| | |
|
| | |
|
| | | private SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
|
| | |
|
| | | @Override
|
| | | public void onApplicationEvent(OnlineEvent event) {
|
| | | |
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("设备上线事件触发,deviceId:" + event.getDevice().getDeviceId() + ",from:" + event.getFrom());
|
| | | }
|
| | | Device device = event.getDevice();
|
| | | String key = VideoManagerConstants.KEEPLIVEKEY_PREFIX + userSetup.getServerId() + "_" + event.getDevice().getDeviceId();
|
| | |
|
| | | logger.info("设备上线事件触发,deviceId:" + event.getDevice().getDeviceId() + ",from:" + event.getFrom());
|
| | | Device device = event.getDevice();
|
| | | if (device == null) {
|
| | | return;
|
| | | }
|
| | | String key = VideoManagerConstants.KEEPLIVEKEY_PREFIX + userSetting.getServerId() + "_" + event.getDevice().getDeviceId();
|
| | | Device deviceInStore = storager.queryVideoDevice(device.getDeviceId());
|
| | | device.setOnline(1);
|
| | | switch (event.getFrom()) {
|
| | | // 注册时触发的在线事件,先在redis中增加超时超时监听
|
| | | case VideoManagerConstants.EVENT_ONLINE_REGISTER:
|
| | | // 超时时间
|
| | | redis.set(key, event.getDevice().getDeviceId(), sipConfig.getKeepaliveTimeOut());
|
| | | device.setRegisterTime(format.format(System.currentTimeMillis()));
|
| | | if (deviceInStore == null) { //第一次上线
|
| | | logger.info("[{}] 首次注册,查询设备信息以及通道信息", device.getDeviceId());
|
| | | cmder.deviceInfoQuery(device);
|
| | | deviceService.sync(device);
|
| | | }
|
| | | break;
|
| | | // 设备主动发送心跳触发的在线事件
|
| | | case VideoManagerConstants.EVENT_ONLINE_KEEPLIVE:
|
| | |
| | |
|
| | | break;
|
| | | }
|
| | |
|
| | | device.setOnline(1);
|
| | | Device deviceInstore = storager.queryVideoDevice(device.getDeviceId());
|
| | | if (deviceInstore != null && deviceInstore.getOnline() == 0) {
|
| | | List<DeviceChannel> deviceChannelList = storager.queryOnlineChannelsByDeviceId(device.getDeviceId());
|
| | | eventPublisher.catalogEventPublish(null, deviceChannelList, CatalogEvent.ON);
|
| | | }
|
| | | // 处理上线监听
|
| | | storager.updateDevice(device);
|
| | |
|
| | | // TODO 上线添加订阅
|
| | |
|
| | | // 上线添加订阅
|
| | | if (device.getSubscribeCycleForCatalog() > 0) {
|
| | | // 查询在线设备那些开启了订阅,为设备开启定时的目录订阅
|
| | | deviceService.addCatalogSubscribe(device);
|
| | | }
|
| | | if (device.getSubscribeCycleForMobilePosition() > 0) {
|
| | | deviceService.addMobilePositionSubscribe(device);
|
| | | }
|
| | | }
|
| | | }
|