old mode 100644
new mode 100755
|  |  |  | 
|---|
|  |  |  | package com.genersoft.iot.vmp.service.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.SipConfig; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.GbStream; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.ParentPlatform; | 
|---|
|  |  |  | import com.baomidou.dynamic.datasource.annotation.DS; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.*; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.event.EventPublisher; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.event.subscribe.catalog.CatalogEvent; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.StreamProxyItem; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.StreamPushItem; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.service.IGbStreamService; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.dao.GbStreamMapper; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.dao.ParentPlatformMapper; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.dao.PlatformCatalogMapper; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.dao.PlatformGbStreamMapper; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.service.IGbStreamService; | 
|---|
|  |  |  | import com.github.pagehelper.PageHelper; | 
|---|
|  |  |  | import com.github.pagehelper.PageInfo; | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.TransactionDefinition; | 
|---|
|  |  |  | import org.springframework.transaction.TransactionStatus; | 
|---|
|  |  |  | import org.springframework.util.StringUtils; | 
|---|
|  |  |  | import org.springframework.util.ObjectUtils; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Service | 
|---|
|  |  |  | @DS("master") | 
|---|
|  |  |  | public class GbStreamServiceImpl implements IGbStreamService { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private final static Logger logger = LoggerFactory.getLogger(GbStreamServiceImpl.class); | 
|---|
|  |  |  | 
|---|
|  |  |  | private PlatformGbStreamMapper platformGbStreamMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SubscribeHolder subscribeHolder; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ParentPlatformMapper platformMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SipConfig sipConfig; | 
|---|
|  |  |  | private PlatformCatalogMapper catalogMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private EventPublisher eventPublisher; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PageInfo<GbStream> getAll(Integer page, Integer count, String platFormId, String catalogId, String query, Boolean pushing, String mediaServerId) { | 
|---|
|  |  |  | public PageInfo<GbStream> getAll(Integer page, Integer count, String platFormId, String catalogId, String query, String mediaServerId) { | 
|---|
|  |  |  | PageHelper.startPage(page, count); | 
|---|
|  |  |  | List<GbStream> all = gbStreamMapper.selectAll(platFormId, catalogId, query, pushing, mediaServerId); | 
|---|
|  |  |  | List<GbStream> all = gbStreamMapper.selectAll(platFormId, catalogId, query, mediaServerId); | 
|---|
|  |  |  | return new PageInfo<>(all); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | boolean result = false; | 
|---|
|  |  |  | TransactionStatus transactionStatus = dataSourceTransactionManager.getTransaction(transactionDefinition); | 
|---|
|  |  |  | ParentPlatform parentPlatform = platformMapper.getParentPlatByServerGBId(platformId); | 
|---|
|  |  |  | if (catalogId == null) catalogId = parentPlatform.getCatalogId(); | 
|---|
|  |  |  | if (catalogId == null) { | 
|---|
|  |  |  | catalogId = parentPlatform.getCatalogId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | List<DeviceChannel> deviceChannelList = new ArrayList<>(); | 
|---|
|  |  |  | for (GbStream gbStream : gbStreams) { | 
|---|
|  |  |  | for (int i = 0; i < gbStreams.size(); i++) { | 
|---|
|  |  |  | GbStream gbStream = gbStreams.get(i); | 
|---|
|  |  |  | gbStream.setCatalogId(catalogId); | 
|---|
|  |  |  | gbStream.setPlatformId(platformId); | 
|---|
|  |  |  | // TODO 修改为批量提交 | 
|---|
|  |  |  | platformGbStreamMapper.add(gbStream); | 
|---|
|  |  |  | DeviceChannel deviceChannelListByStream = getDeviceChannelListByStream(gbStream, catalogId, parentPlatform.getDeviceGBId()); | 
|---|
|  |  |  | logger.info("[关联通道]直播流通道 平台:{}, 共需关联通道数:{}, 已关联:{}", platformId, gbStreams.size(), i + 1); | 
|---|
|  |  |  | DeviceChannel deviceChannelListByStream = getDeviceChannelListByStreamWithStatus(gbStream, catalogId, parentPlatform); | 
|---|
|  |  |  | deviceChannelList.add(deviceChannelListByStream); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | dataSourceTransactionManager.commit(transactionStatus);     //手动提交 | 
|---|
|  |  |  | eventPublisher.catalogEventPublish(platformId, deviceChannelList, CatalogEvent.ADD); | 
|---|
|  |  |  | if (subscribeHolder.getCatalogSubscribe(platformId) != null) { | 
|---|
|  |  |  | eventPublisher.catalogEventPublish(platformId, deviceChannelList, CatalogEvent.ADD); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | result = true; | 
|---|
|  |  |  | }catch (Exception e) { | 
|---|
|  |  |  | logger.error("批量保存流与平台的关系时错误", e); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public DeviceChannel getDeviceChannelListByStream(GbStream gbStream, String catalogId, String deviceGBId) { | 
|---|
|  |  |  | public DeviceChannel getDeviceChannelListByStream(GbStream gbStream, String catalogId, ParentPlatform platform) { | 
|---|
|  |  |  | DeviceChannel deviceChannel = new DeviceChannel(); | 
|---|
|  |  |  | deviceChannel.setChannelId(gbStream.getGbId()); | 
|---|
|  |  |  | deviceChannel.setName(gbStream.getName()); | 
|---|
|  |  |  | deviceChannel.setLongitude(gbStream.getLongitude()); | 
|---|
|  |  |  | deviceChannel.setLatitude(gbStream.getLatitude()); | 
|---|
|  |  |  | deviceChannel.setDeviceId(deviceGBId); | 
|---|
|  |  |  | deviceChannel.setDeviceId(platform.getDeviceGBId()); | 
|---|
|  |  |  | deviceChannel.setManufacture("wvp-pro"); | 
|---|
|  |  |  | //        deviceChannel.setStatus(gbStream.isStatus()?1:0); | 
|---|
|  |  |  | deviceChannel.setStatus(1); | 
|---|
|  |  |  | deviceChannel.setParentId(catalogId ==null?gbStream.getCatalogId():catalogId); | 
|---|
|  |  |  | deviceChannel.setStatus(gbStream.isStatus()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | deviceChannel.setRegisterWay(1); | 
|---|
|  |  |  | deviceChannel.setCivilCode(deviceGBId.substring(0, 6)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | PlatformCatalog catalog = catalogMapper.selectByPlatFormAndCatalogId(platform.getServerGBId(), catalogId); | 
|---|
|  |  |  | if (catalog != null) { | 
|---|
|  |  |  | deviceChannel.setCivilCode(catalog.getCivilCode()); | 
|---|
|  |  |  | deviceChannel.setParentId(catalog.getParentId()); | 
|---|
|  |  |  | deviceChannel.setBusinessGroupId(catalog.getBusinessGroupId()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | deviceChannel.setCivilCode(platform.getAdministrativeDivision()); | 
|---|
|  |  |  | deviceChannel.setParentId(platform.getDeviceGBId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | deviceChannel.setModel("live"); | 
|---|
|  |  |  | deviceChannel.setOwner("wvp-pro"); | 
|---|
|  |  |  | deviceChannel.setParental(0); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void sendCatalogMsg(GbStream gbStream, String type) { | 
|---|
|  |  |  | if (gbStream == null || type == null) { | 
|---|
|  |  |  | logger.warn("[发送目录订阅]类型:流信息或类型为NULL"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<GbStream> gbStreams = new ArrayList<>(); | 
|---|
|  |  |  | if (gbStream.getGbId() != null) { | 
|---|
|  |  |  | gbStreams.add(gbStream); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | StreamProxyItem streamProxyItem = gbStreamMapper.selectOne(gbStream.getApp(), gbStream.getStream()); | 
|---|
|  |  |  | if (streamProxyItem != null && streamProxyItem.getGbId() != null){ | 
|---|
|  |  |  | gbStreams.add(streamProxyItem); | 
|---|
|  |  |  | GbStream gbStreamIndb  = gbStreamMapper.selectOne(gbStream.getApp(), gbStream.getStream()); | 
|---|
|  |  |  | if (gbStreamIndb != null && gbStreamIndb.getGbId() != null){ | 
|---|
|  |  |  | gbStreams.add(gbStreamIndb); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | sendCatalogMsgs(gbStreams, type); | 
|---|
|  |  |  | 
|---|
|  |  |  | public void sendCatalogMsgs(List<GbStream> gbStreams, String type) { | 
|---|
|  |  |  | if (gbStreams.size() > 0) { | 
|---|
|  |  |  | for (GbStream gs : gbStreams) { | 
|---|
|  |  |  | if (StringUtils.isEmpty(gs.getGbId())){ | 
|---|
|  |  |  | if (ObjectUtils.isEmpty(gs.getGbId())){ | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<ParentPlatform> parentPlatforms = platformGbStreamMapper.selectByAppAndStream(gs.getApp(), gs.getStream()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public int updateGbIdOrName(List<StreamPushItem> streamPushItemForUpdate) { | 
|---|
|  |  |  | return gbStreamMapper.updateGbIdOrName(streamPushItemForUpdate); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public DeviceChannel getDeviceChannelListByStreamWithStatus(GbStream gbStream, String catalogId, ParentPlatform platform) { | 
|---|
|  |  |  | DeviceChannel deviceChannel = new DeviceChannel(); | 
|---|
|  |  |  | deviceChannel.setChannelId(gbStream.getGbId()); | 
|---|
|  |  |  | deviceChannel.setName(gbStream.getName()); | 
|---|
|  |  |  | deviceChannel.setLongitude(gbStream.getLongitude()); | 
|---|
|  |  |  | deviceChannel.setLatitude(gbStream.getLatitude()); | 
|---|
|  |  |  | deviceChannel.setDeviceId(platform.getDeviceGBId()); | 
|---|
|  |  |  | deviceChannel.setManufacture("wvp-pro"); | 
|---|
|  |  |  | // todo 目前是每一条查询一次,需要优化 | 
|---|
|  |  |  | Boolean status = null; | 
|---|
|  |  |  | if ("proxy".equals(gbStream.getStreamType())) { | 
|---|
|  |  |  | status = gbStreamMapper.selectStatusForProxy(gbStream.getApp(), gbStream.getStream()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | status = gbStreamMapper.selectStatusForPush(gbStream.getApp(), gbStream.getStream()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | deviceChannel.setStatus(status != null && status); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | deviceChannel.setRegisterWay(1); | 
|---|
|  |  |  | PlatformCatalog catalog = catalogMapper.selectByPlatFormAndCatalogId(platform.getServerGBId(), catalogId); | 
|---|
|  |  |  | if (catalog != null) { | 
|---|
|  |  |  | deviceChannel.setCivilCode(catalog.getCivilCode()); | 
|---|
|  |  |  | deviceChannel.setParentId(catalog.getParentId()); | 
|---|
|  |  |  | deviceChannel.setBusinessGroupId(catalog.getBusinessGroupId()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | deviceChannel.setCivilCode(platform.getAdministrativeDivision()); | 
|---|
|  |  |  | deviceChannel.setParentId(platform.getDeviceGBId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | deviceChannel.setModel("live"); | 
|---|
|  |  |  | deviceChannel.setOwner("wvp-pro"); | 
|---|
|  |  |  | deviceChannel.setParental(0); | 
|---|
|  |  |  | deviceChannel.setSecrecy("0"); | 
|---|
|  |  |  | return deviceChannel; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<GbStream> getAllGBChannels(String platformId) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return gbStreamMapper.selectAll(platformId, null, null, null); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void delAllPlatformInfo(String platformId, String catalogId) { | 
|---|
|  |  |  | if (platformId == null) { | 
|---|
|  |  |  | return ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ParentPlatform platform = platformMapper.getParentPlatByServerGBId(platformId); | 
|---|
|  |  |  | if (platform == null) { | 
|---|
|  |  |  | return ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (ObjectUtils.isEmpty(catalogId)) { | 
|---|
|  |  |  | catalogId = null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<GbStream> gbStreams = platformGbStreamMapper.queryChannelInParentPlatformAndCatalog(platformId, catalogId); | 
|---|
|  |  |  | List<DeviceChannel> deviceChannelList = new ArrayList<>(); | 
|---|
|  |  |  | for (GbStream gbStream : gbStreams) { | 
|---|
|  |  |  | DeviceChannel deviceChannel = new DeviceChannel(); | 
|---|
|  |  |  | deviceChannel.setChannelId(gbStream.getGbId()); | 
|---|
|  |  |  | deviceChannelList.add(deviceChannel); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | eventPublisher.catalogEventPublish(platformId, deviceChannelList, CatalogEvent.DEL); | 
|---|
|  |  |  | platformGbStreamMapper.delByPlatformAndCatalogId(platformId, catalogId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<GbStream> getGbChannelWithGbid(String gbId) { | 
|---|
|  |  |  | return gbStreamMapper.selectByGBId(gbId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Map<String, GbStream> getAllGBId() { | 
|---|
|  |  |  | return gbStreamMapper.getAllGBId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|