|  |  |  | 
|---|
|  |  |  | package com.genersoft.iot.vmp.vmanager.gb28181.platform; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONObject; | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSONObject; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.common.VideoManagerConstants; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.DynamicTask; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.UserSetting; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.exception.ControllerException; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.ParentPlatform; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.ParentPlatformCatch; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.PlatformCatalog; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.SubscribeHolder; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.TreeType; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.cmd.ISIPCommanderForPlatform; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.service.IPlatformChannelService; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.service.*; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IRedisCatchStorage; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IVideoManagerStorage; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.utils.DateUtil; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.vmanager.bean.ErrorCode; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.vmanager.bean.WVPResult; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.ChannelReduce; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.UpdateChannelParam; | 
|---|
|  |  |  | import com.github.pagehelper.PageInfo; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | import org.slf4j.LoggerFactory; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.http.HttpStatus; | 
|---|
|  |  |  | import org.springframework.http.ResponseEntity; | 
|---|
|  |  |  | import org.springframework.util.ObjectUtils; | 
|---|
|  |  |  | import org.springframework.util.StringUtils; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.SipConfig; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.sip.InvalidArgumentException; | 
|---|
|  |  |  | import javax.sip.SipException; | 
|---|
|  |  |  | import java.text.ParseException; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 级联平台管理 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Tag(name  = "级联平台管理") | 
|---|
|  |  |  | @CrossOrigin | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RestController | 
|---|
|  |  |  | @RequestMapping("/api/platform") | 
|---|
|  |  |  | public class PlatformController { | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DynamicTask dynamicTask; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IPlatformService platformService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IDeviceChannelService deviceChannelService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IGbStreamService gbStreamService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取国标服务的配置 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | 
|---|
|  |  |  | @Parameter(name = "id", description = "平台国标编号", required = true) | 
|---|
|  |  |  | @GetMapping("/info/{id}") | 
|---|
|  |  |  | public ParentPlatform getPlatform(@PathVariable String id) { | 
|---|
|  |  |  | ParentPlatform parentPlatform = storager.queryParentPlatByServerGBId(id); | 
|---|
|  |  |  | WVPResult<ParentPlatform> wvpResult = new WVPResult<>(); | 
|---|
|  |  |  | ParentPlatform parentPlatform = platformService.queryPlatformByServerGBId(id); | 
|---|
|  |  |  | if (parentPlatform != null) { | 
|---|
|  |  |  | return  parentPlatform; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | 
|---|
|  |  |  | @Parameter(name = "count", description = "每页条数", required = true) | 
|---|
|  |  |  | public PageInfo<ParentPlatform> platforms(@PathVariable int page, @PathVariable int count) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | PageInfo<ParentPlatform> parentPlatformPageInfo = storager.queryParentPlatformList(page, count); | 
|---|
|  |  |  | PageInfo<ParentPlatform> parentPlatformPageInfo = platformService.queryParentPlatformList(page, count); | 
|---|
|  |  |  | if (parentPlatformPageInfo.getList().size() > 0) { | 
|---|
|  |  |  | for (ParentPlatform platform : parentPlatformPageInfo.getList()) { | 
|---|
|  |  |  | platform.setMobilePositionSubscribe(subscribeHolder.getMobilePositionSubscribe(platform.getServerGBId()) != null); | 
|---|
|  |  |  | 
|---|
|  |  |  | @Operation(summary = "添加上级平台信息") | 
|---|
|  |  |  | @PostMapping("/add") | 
|---|
|  |  |  | @ResponseBody | 
|---|
|  |  |  | public String addPlatform(@RequestBody ParentPlatform parentPlatform) { | 
|---|
|  |  |  | public void addPlatform(@RequestBody ParentPlatform parentPlatform) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (logger.isDebugEnabled()) { | 
|---|
|  |  |  | logger.debug("保存上级平台信息API调用"); | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR400.getCode(), "error severPort"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ParentPlatform parentPlatformOld = storager.queryParentPlatByServerGBId(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | if (parentPlatformOld != null) { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR100.getCode(), "平台 " + parentPlatform.getServerGBId() + " 已存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | parentPlatform.setCreateTime(DateUtil.getNow()); | 
|---|
|  |  |  | parentPlatform.setUpdateTime(DateUtil.getNow()); | 
|---|
|  |  |  | boolean updateResult = storager.updateParentPlatform(parentPlatform); | 
|---|
|  |  |  | boolean updateResult = platformService.add(parentPlatform); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (updateResult) { | 
|---|
|  |  |  | // 保存时启用就发送注册 | 
|---|
|  |  |  | if (parentPlatform.isEnable()) { | 
|---|
|  |  |  | if (parentPlatformOld != null && parentPlatformOld.isStatus()) { | 
|---|
|  |  |  | commanderForPlatform.unregister(parentPlatformOld, null, eventResult -> { | 
|---|
|  |  |  | //  只要保存就发送注册 | 
|---|
|  |  |  | commanderForPlatform.register(parentPlatform, null, null); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | //  只要保存就发送注册 | 
|---|
|  |  |  | commanderForPlatform.register(parentPlatform, null, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else if (parentPlatformOld != null && parentPlatformOld.isEnable()) { | 
|---|
|  |  |  | // 关闭启用时注销 | 
|---|
|  |  |  | commanderForPlatform.unregister(parentPlatform, null, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | if (!updateResult) { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR100.getCode(),"写入数据库失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | ) { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR400); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | parentPlatform.setCharacterSet(parentPlatform.getCharacterSet().toUpperCase()); | 
|---|
|  |  |  | ParentPlatform parentPlatformOld = storager.queryParentPlatByServerGBId(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | parentPlatform.setUpdateTime(DateUtil.getNow()); | 
|---|
|  |  |  | if (!parentPlatformOld.getTreeType().equals(parentPlatform.getTreeType())) { | 
|---|
|  |  |  | // 目录结构发生变化,清空之前的关联关系 | 
|---|
|  |  |  | logger.info("保存平台{}时发现目录结构变化,清空关联关系", parentPlatform.getDeviceGBId()); | 
|---|
|  |  |  | storager.cleanContentForPlatform(parentPlatform.getServerGBId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | boolean updateResult = storager.updateParentPlatform(parentPlatform); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (updateResult) { | 
|---|
|  |  |  | // 保存时启用就发送注册 | 
|---|
|  |  |  | if (parentPlatform.isEnable()) { | 
|---|
|  |  |  | if (parentPlatformOld != null && parentPlatformOld.isStatus()) { | 
|---|
|  |  |  | commanderForPlatform.unregister(parentPlatformOld, null, null); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | Thread.sleep(500); | 
|---|
|  |  |  | } catch (InterruptedException e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //  只要保存就发送注册 | 
|---|
|  |  |  | commanderForPlatform.register(parentPlatform, null, null); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | //  只要保存就发送注册 | 
|---|
|  |  |  | commanderForPlatform.register(parentPlatform, null, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if (parentPlatformOld != null && parentPlatformOld.isEnable() && !parentPlatform.isEnable()) { // 关闭启用时注销 | 
|---|
|  |  |  | commanderForPlatform.unregister(parentPlatformOld, null, null); | 
|---|
|  |  |  | // 停止订阅相关的定时任务 | 
|---|
|  |  |  | subscribeHolder.removeAllSubscribe(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR100.getCode(),"写入数据库失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | platformService.update(parentPlatform); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | @Parameter(name = "serverGBId", description = "上级平台的国标编号") | 
|---|
|  |  |  | @DeleteMapping("/delete/{serverGBId}") | 
|---|
|  |  |  | @ResponseBody | 
|---|
|  |  |  | public String deletePlatform(@PathVariable String serverGBId) { | 
|---|
|  |  |  | public void deletePlatform(@PathVariable String serverGBId) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (logger.isDebugEnabled()) { | 
|---|
|  |  |  | logger.debug("删除上级平台API调用"); | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR400); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ParentPlatform parentPlatform = storager.queryParentPlatByServerGBId(serverGBId); | 
|---|
|  |  |  | ParentPlatformCatch parentPlatformCatch = redisCatchStorage.queryPlatformCatchInfo(serverGBId); | 
|---|
|  |  |  | if (parentPlatform == null) { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR100.getCode(), "平台不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (parentPlatformCatch == null) { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR100.getCode(), "平台不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 发送离线消息,无论是否成功都删除缓存 | 
|---|
|  |  |  | commanderForPlatform.unregister(parentPlatform, (event -> { | 
|---|
|  |  |  | // 清空redis缓存 | 
|---|
|  |  |  | redisCatchStorage.delPlatformCatchInfo(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | redisCatchStorage.delPlatformKeepalive(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | redisCatchStorage.delPlatformRegister(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | }), (event -> { | 
|---|
|  |  |  | // 清空redis缓存 | 
|---|
|  |  |  | redisCatchStorage.delPlatformCatchInfo(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | redisCatchStorage.delPlatformKeepalive(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | redisCatchStorage.delPlatformRegister(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | })); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | commanderForPlatform.unregister(parentPlatform, parentPlatformCatch.getSipTransactionInfo(), (event -> { | 
|---|
|  |  |  | // 清空redis缓存 | 
|---|
|  |  |  | redisCatchStorage.delPlatformCatchInfo(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | redisCatchStorage.delPlatformKeepalive(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | redisCatchStorage.delPlatformRegister(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | }), (event -> { | 
|---|
|  |  |  | // 清空redis缓存 | 
|---|
|  |  |  | redisCatchStorage.delPlatformCatchInfo(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | redisCatchStorage.delPlatformKeepalive(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | redisCatchStorage.delPlatformRegister(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | })); | 
|---|
|  |  |  | } catch (InvalidArgumentException | ParseException | SipException e) { | 
|---|
|  |  |  | logger.error("[命令发送失败] 国标级联 注销: {}", e.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | boolean deleteResult = storager.deleteParentPlatform(parentPlatform); | 
|---|
|  |  |  | storager.delCatalogByPlatformId(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | dynamicTask.stop(key); | 
|---|
|  |  |  | // 删除缓存的订阅信息 | 
|---|
|  |  |  | subscribeHolder.removeAllSubscribe(parentPlatform.getServerGBId()); | 
|---|
|  |  |  | if (deleteResult) { | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | if (!deleteResult) { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR100); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (logger.isDebugEnabled()) { | 
|---|
|  |  |  | logger.debug("给上级平台添加国标通道API调用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | int result = platformChannelService.updateChannelForGB(param.getPlatformId(), param.getChannelReduces(), param.getCatalogId()); | 
|---|
|  |  |  | int result = 0; | 
|---|
|  |  |  | if (param.getChannelReduces() == null || param.getChannelReduces().size() == 0) { | 
|---|
|  |  |  | if (param.isAll()) { | 
|---|
|  |  |  | logger.info("[国标级联]添加所有通道到上级平台, {}", param.getPlatformId()); | 
|---|
|  |  |  | List<ChannelReduce> allChannelForDevice = deviceChannelService.queryAllChannelList(param.getPlatformId()); | 
|---|
|  |  |  | result = platformChannelService.updateChannelForGB(param.getPlatformId(), allChannelForDevice, param.getCatalogId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | result = platformChannelService.updateChannelForGB(param.getPlatformId(), param.getChannelReduces(), param.getCatalogId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (result <= 0) { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR100); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (logger.isDebugEnabled()) { | 
|---|
|  |  |  | logger.debug("给上级平台删除国标通道API调用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | int result = storager.delChannelForGB(param.getPlatformId(), param.getChannelReduces()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int result = 0; | 
|---|
|  |  |  | if (param.getChannelReduces() == null || param.getChannelReduces().size() == 0) { | 
|---|
|  |  |  | if (param.isAll()) { | 
|---|
|  |  |  | logger.info("[国标级联]移除所有通道,上级平台, {}", param.getPlatformId()); | 
|---|
|  |  |  | result = platformChannelService.delAllChannelForGB(param.getPlatformId(), param.getCatalogId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | result = storager.delChannelForGB(param.getPlatformId(), param.getChannelReduces()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (result <= 0) { | 
|---|
|  |  |  | throw new ControllerException(ErrorCode.ERROR100); | 
|---|
|  |  |  | } | 
|---|