|  | @@ -22,6 +22,7 @@ import com.genersoft.iot.vmp.utils.DateUtil;
 | 
	
		
			
				|  |  |  import com.genersoft.iot.vmp.utils.JsonUtil;
 | 
	
		
			
				|  |  |  import com.genersoft.iot.vmp.utils.redis.RedisUtil;
 | 
	
		
			
				|  |  |  import com.genersoft.iot.vmp.vmanager.bean.ErrorCode;
 | 
	
		
			
				|  |  | +import com.genersoft.iot.vmp.vmanager.bean.WVPResult;
 | 
	
		
			
				|  |  |  import okhttp3.OkHttpClient;
 | 
	
		
			
				|  |  |  import okhttp3.Request;
 | 
	
		
			
				|  |  |  import okhttp3.Response;
 | 
	
	
		
			
				|  | @@ -74,31 +75,31 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |       * 初始化
 | 
	
		
			
				|  |  |       */
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public void updateVmServer(List<MediaServer> mediaServerItemList) {
 | 
	
		
			
				|  |  | +    public void updateVmServer(List<MediaServer> mediaServerList) {
 | 
	
		
			
				|  |  |          logger.info("[媒体服务节点] 缓存初始化 ");
 | 
	
		
			
				|  |  | -        for (MediaServer mediaServerItem : mediaServerItemList) {
 | 
	
		
			
				|  |  | -            if (ObjectUtils.isEmpty(mediaServerItem.getId())) {
 | 
	
		
			
				|  |  | +        for (MediaServer mediaServer : mediaServerList) {
 | 
	
		
			
				|  |  | +            if (ObjectUtils.isEmpty(mediaServer.getId())) {
 | 
	
		
			
				|  |  |                  continue;
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |              // 更新
 | 
	
		
			
				|  |  | -            if (!ssrcFactory.hasMediaServerSSRC(mediaServerItem.getId())) {
 | 
	
		
			
				|  |  | -                ssrcFactory.initMediaServerSSRC(mediaServerItem.getId(), null);
 | 
	
		
			
				|  |  | +            if (!ssrcFactory.hasMediaServerSSRC(mediaServer.getId())) {
 | 
	
		
			
				|  |  | +                ssrcFactory.initMediaServerSSRC(mediaServer.getId(), null);
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |              // 查询redis是否存在此mediaServer
 | 
	
		
			
				|  |  | -            String key = VideoManagerConstants.MEDIA_SERVER_PREFIX + userSetting.getServerId() + "_" + mediaServerItem.getId();
 | 
	
		
			
				|  |  | +            String key = VideoManagerConstants.MEDIA_SERVER_PREFIX + userSetting.getServerId() + "_" + mediaServer.getId();
 | 
	
		
			
				|  |  |              Boolean hasKey = redisTemplate.hasKey(key);
 | 
	
		
			
				|  |  |              if (hasKey != null && ! hasKey) {
 | 
	
		
			
				|  |  | -                redisTemplate.opsForValue().set(key, mediaServerItem);
 | 
	
		
			
				|  |  | +                redisTemplate.opsForValue().set(key, mediaServer);
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public SSRCInfo openRTPServer(MediaServer mediaServerItem, String streamId, String presetSsrc, boolean ssrcCheck,
 | 
	
		
			
				|  |  | +    public SSRCInfo openRTPServer(MediaServer mediaServer, String streamId, String presetSsrc, boolean ssrcCheck,
 | 
	
		
			
				|  |  |                                    boolean isPlayback, Integer port, Boolean onlyAuto, Boolean reUsePort, Integer tcpMode) {
 | 
	
		
			
				|  |  | -        if (mediaServerItem == null || mediaServerItem.getId() == null) {
 | 
	
		
			
				|  |  | -            logger.info("[openRTPServer] 失败, mediaServerItem == null || mediaServerItem.getId() == null");
 | 
	
		
			
				|  |  | +        if (mediaServer == null || mediaServer.getId() == null) {
 | 
	
		
			
				|  |  | +            logger.info("[openRTPServer] 失败, mediaServer == null || mediaServer.getId() == null");
 | 
	
		
			
				|  |  |              return null;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |          // 获取mediaServer可用的ssrc
 | 
	
	
		
			
				|  | @@ -107,9 +108,9 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |              ssrc = presetSsrc;
 | 
	
		
			
				|  |  |          }else {
 | 
	
		
			
				|  |  |              if (isPlayback) {
 | 
	
		
			
				|  |  | -                ssrc = ssrcFactory.getPlayBackSsrc(mediaServerItem.getId());
 | 
	
		
			
				|  |  | +                ssrc = ssrcFactory.getPlayBackSsrc(mediaServer.getId());
 | 
	
		
			
				|  |  |              }else {
 | 
	
		
			
				|  |  | -                ssrc = ssrcFactory.getPlaySsrc(mediaServerItem.getId());
 | 
	
		
			
				|  |  | +                ssrc = ssrcFactory.getPlaySsrc(mediaServer.getId());
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -121,97 +122,97 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |              logger.warn("[openRTPServer] 平台对接时下级可能自定义ssrc,但是tcp模式zlm收流目前无法更新ssrc,可能收流超时,此时请使用udp收流或者关闭ssrc校验");
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |          int rtpServerPort;
 | 
	
		
			
				|  |  | -        if (mediaServerItem.isRtpEnable()) {
 | 
	
		
			
				|  |  | -            IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +        if (mediaServer.isRtpEnable()) {
 | 
	
		
			
				|  |  | +            IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |              if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -                logger.info("[openRTPServer] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +                logger.info("[openRTPServer] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |                  return null;
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  | -            rtpServerPort = mediaNodeServerService.createRTPServer(mediaServerItem, streamId, ssrcCheck ? Long.parseLong(ssrc) : 0, port, onlyAuto, reUsePort, tcpMode);
 | 
	
		
			
				|  |  | +            rtpServerPort = mediaNodeServerService.createRTPServer(mediaServer, streamId, ssrcCheck ? Long.parseLong(ssrc) : 0, port, onlyAuto, reUsePort, tcpMode);
 | 
	
		
			
				|  |  |          } else {
 | 
	
		
			
				|  |  | -            rtpServerPort = mediaServerItem.getRtpProxyPort();
 | 
	
		
			
				|  |  | +            rtpServerPort = mediaServer.getRtpProxyPort();
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |          return new SSRCInfo(rtpServerPort, ssrc, streamId);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public SSRCInfo openRTPServer(MediaServer mediaServerItem, String streamId, String ssrc, boolean ssrcCheck, boolean isPlayback, Integer port, Boolean onlyAuto) {
 | 
	
		
			
				|  |  | -        return openRTPServer(mediaServerItem, streamId, ssrc, ssrcCheck, isPlayback, port, onlyAuto, null, 0);
 | 
	
		
			
				|  |  | +    public SSRCInfo openRTPServer(MediaServer mediaServer, String streamId, String ssrc, boolean ssrcCheck, boolean isPlayback, Integer port, Boolean onlyAuto) {
 | 
	
		
			
				|  |  | +        return openRTPServer(mediaServer, streamId, ssrc, ssrcCheck, isPlayback, port, onlyAuto, null, 0);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public void closeRTPServer(MediaServer mediaServerItem, String streamId) {
 | 
	
		
			
				|  |  | -        if (mediaServerItem == null) {
 | 
	
		
			
				|  |  | +    public void closeRTPServer(MediaServer mediaServer, String streamId) {
 | 
	
		
			
				|  |  | +        if (mediaServer == null) {
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[closeRTPServer] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[closeRTPServer] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        mediaNodeServerService.closeRtpServer(mediaServerItem, streamId);
 | 
	
		
			
				|  |  | +        mediaNodeServerService.closeRtpServer(mediaServer, streamId);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public void closeRTPServer(MediaServer mediaServerItem, String streamId, CommonCallback<Boolean> callback) {
 | 
	
		
			
				|  |  | -        if (mediaServerItem == null) {
 | 
	
		
			
				|  |  | +    public void closeRTPServer(MediaServer mediaServer, String streamId, CommonCallback<Boolean> callback) {
 | 
	
		
			
				|  |  | +        if (mediaServer == null) {
 | 
	
		
			
				|  |  |              callback.run(false);
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[closeRTPServer] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[closeRTPServer] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        mediaNodeServerService.closeRtpServer(mediaServerItem, streamId, callback);
 | 
	
		
			
				|  |  | +        mediaNodeServerService.closeRtpServer(mediaServer, streamId, callback);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  |      public void closeRTPServer(String mediaServerId, String streamId) {
 | 
	
		
			
				|  |  | -        MediaServer mediaServerItem = this.getOne(mediaServerId);
 | 
	
		
			
				|  |  | -        if (mediaServerItem == null) {
 | 
	
		
			
				|  |  | +        MediaServer mediaServer = this.getOne(mediaServerId);
 | 
	
		
			
				|  |  | +        if (mediaServer == null) {
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        if (mediaServerItem.isRtpEnable()) {
 | 
	
		
			
				|  |  | -            closeRTPServer(mediaServerItem, streamId);
 | 
	
		
			
				|  |  | +        if (mediaServer.isRtpEnable()) {
 | 
	
		
			
				|  |  | +            closeRTPServer(mediaServer, streamId);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[closeRTPServer] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[closeRTPServer] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        mediaNodeServerService.closeStreams(mediaServerItem, "rtp", streamId);
 | 
	
		
			
				|  |  | +        mediaNodeServerService.closeStreams(mediaServer, "rtp", streamId);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public Boolean updateRtpServerSSRC(MediaServer mediaServerItem, String streamId, String ssrc) {
 | 
	
		
			
				|  |  | -        if (mediaServerItem == null) {
 | 
	
		
			
				|  |  | +    public Boolean updateRtpServerSSRC(MediaServer mediaServer, String streamId, String ssrc) {
 | 
	
		
			
				|  |  | +        if (mediaServer == null) {
 | 
	
		
			
				|  |  |              return false;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[updateRtpServerSSRC] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[updateRtpServerSSRC] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return false;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        return mediaNodeServerService.updateRtpServerSSRC(mediaServerItem, streamId, ssrc);
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.updateRtpServerSSRC(mediaServer, streamId, ssrc);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public void releaseSsrc(String mediaServerItemId, String ssrc) {
 | 
	
		
			
				|  |  | -        MediaServer mediaServerItem = getOne(mediaServerItemId);
 | 
	
		
			
				|  |  | -        if (mediaServerItem == null || ssrc == null) {
 | 
	
		
			
				|  |  | +    public void releaseSsrc(String mediaServerId, String ssrc) {
 | 
	
		
			
				|  |  | +        MediaServer mediaServer = getOne(mediaServerId);
 | 
	
		
			
				|  |  | +        if (mediaServer == null || ssrc == null) {
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        ssrcFactory.releaseSsrc(mediaServerItemId, ssrc);
 | 
	
		
			
				|  |  | +        ssrcFactory.releaseSsrc(mediaServerId, ssrc);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      /**
 | 
	
		
			
				|  |  |       * 媒体服务节点 重启后重置他的推流信息, TODO 给正在使用的设备发送停止命令
 | 
	
		
			
				|  |  |       */
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public void clearRTPServer(MediaServer mediaServerItem) {
 | 
	
		
			
				|  |  | -        ssrcFactory.reset(mediaServerItem.getId());
 | 
	
		
			
				|  |  | +    public void clearRTPServer(MediaServer mediaServer) {
 | 
	
		
			
				|  |  | +        ssrcFactory.reset(mediaServer.getId());
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -219,22 +220,22 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |      public void update(MediaServer mediaSerItem) {
 | 
	
		
			
				|  |  |          mediaServerMapper.update(mediaSerItem);
 | 
	
		
			
				|  |  |          MediaServer mediaServerInRedis = getOne(mediaSerItem.getId());
 | 
	
		
			
				|  |  | -        MediaServer mediaServerItemInDataBase = mediaServerMapper.queryOne(mediaSerItem.getId());
 | 
	
		
			
				|  |  | -        if (mediaServerItemInDataBase == null) {
 | 
	
		
			
				|  |  | +        MediaServer mediaServerInDataBase = mediaServerMapper.queryOne(mediaSerItem.getId());
 | 
	
		
			
				|  |  | +        if (mediaServerInDataBase == null) {
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        mediaServerItemInDataBase.setStatus(mediaSerItem.isStatus());
 | 
	
		
			
				|  |  | -        if (mediaServerInRedis == null || !ssrcFactory.hasMediaServerSSRC(mediaServerItemInDataBase.getId())) {
 | 
	
		
			
				|  |  | -            ssrcFactory.initMediaServerSSRC(mediaServerItemInDataBase.getId(),null);
 | 
	
		
			
				|  |  | +        mediaServerInDataBase.setStatus(mediaSerItem.isStatus());
 | 
	
		
			
				|  |  | +        if (mediaServerInRedis == null || !ssrcFactory.hasMediaServerSSRC(mediaServerInDataBase.getId())) {
 | 
	
		
			
				|  |  | +            ssrcFactory.initMediaServerSSRC(mediaServerInDataBase.getId(),null);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        String key = VideoManagerConstants.MEDIA_SERVER_PREFIX + userSetting.getServerId() + "_" + mediaServerItemInDataBase.getId();
 | 
	
		
			
				|  |  | -        redisTemplate.opsForValue().set(key, mediaServerItemInDataBase);
 | 
	
		
			
				|  |  | -        if (mediaServerItemInDataBase.isStatus()) {
 | 
	
		
			
				|  |  | -            resetOnlineServerItem(mediaServerItemInDataBase);
 | 
	
		
			
				|  |  | +        String key = VideoManagerConstants.MEDIA_SERVER_PREFIX + userSetting.getServerId() + "_" + mediaServerInDataBase.getId();
 | 
	
		
			
				|  |  | +        redisTemplate.opsForValue().set(key, mediaServerInDataBase);
 | 
	
		
			
				|  |  | +        if (mediaServerInDataBase.isStatus()) {
 | 
	
		
			
				|  |  | +            resetOnlineServerItem(mediaServerInDataBase);
 | 
	
		
			
				|  |  |          }else {
 | 
	
		
			
				|  |  |              // 发送事件
 | 
	
		
			
				|  |  |              MediaServerChangeEvent event = new MediaServerChangeEvent(this);
 | 
	
		
			
				|  |  | -            event.setMediaServerItemList(mediaServerItemInDataBase);
 | 
	
		
			
				|  |  | +            event.setMediaServerItemList(mediaServerInDataBase);
 | 
	
		
			
				|  |  |              applicationEventPublisher.publishEvent(event);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
	
		
			
				|  | @@ -247,16 +248,16 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |          String onlineKey = VideoManagerConstants.MEDIA_SERVERS_ONLINE_PREFIX + userSetting.getServerId();
 | 
	
		
			
				|  |  |          for (Object mediaServerKey : mediaServerKeys) {
 | 
	
		
			
				|  |  |              String key = (String) mediaServerKey;
 | 
	
		
			
				|  |  | -            MediaServer mediaServerItem = JsonUtil.redisJsonToObject(redisTemplate, key, MediaServer.class);
 | 
	
		
			
				|  |  | -            if (Objects.isNull(mediaServerItem)) {
 | 
	
		
			
				|  |  | +            MediaServer mediaServer = JsonUtil.redisJsonToObject(redisTemplate, key, MediaServer.class);
 | 
	
		
			
				|  |  | +            if (Objects.isNull(mediaServer)) {
 | 
	
		
			
				|  |  |                  continue;
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |              // 检查状态
 | 
	
		
			
				|  |  | -            Double aDouble = redisTemplate.opsForZSet().score(onlineKey, mediaServerItem.getId());
 | 
	
		
			
				|  |  | +            Double aDouble = redisTemplate.opsForZSet().score(onlineKey, mediaServer.getId());
 | 
	
		
			
				|  |  |              if (aDouble != null) {
 | 
	
		
			
				|  |  | -                mediaServerItem.setStatus(true);
 | 
	
		
			
				|  |  | +                mediaServer.setStatus(true);
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  | -            result.add(mediaServerItem);
 | 
	
		
			
				|  |  | +            result.add(mediaServer);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |          result.sort((serverItem1, serverItem2)->{
 | 
	
		
			
				|  |  |              int sortResult = 0;
 | 
	
	
		
			
				|  | @@ -275,10 +276,10 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |          if (mediaServerList.isEmpty()) {
 | 
	
		
			
				|  |  |              return new ArrayList<>();
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        for (MediaServer mediaServerItem : mediaServerList) {
 | 
	
		
			
				|  |  | -            MediaServer mediaServerItemInRedis = getOne(mediaServerItem.getId());
 | 
	
		
			
				|  |  | -            if (mediaServerItemInRedis != null) {
 | 
	
		
			
				|  |  | -                mediaServerItem.setStatus(mediaServerItemInRedis.isStatus());
 | 
	
		
			
				|  |  | +        for (MediaServer mediaServer : mediaServerList) {
 | 
	
		
			
				|  |  | +            MediaServer mediaServerInRedis = getOne(mediaServer.getId());
 | 
	
		
			
				|  |  | +            if (mediaServerInRedis != null) {
 | 
	
		
			
				|  |  | +                mediaServer.setStatus(mediaServerInRedis.isStatus());
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |          return mediaServerList;
 | 
	
	
		
			
				|  | @@ -310,7 +311,7 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |      /**
 | 
	
		
			
				|  |  |       * 获取单个媒体服务节点服务器
 | 
	
		
			
				|  |  |       * @param mediaServerId 服务id
 | 
	
		
			
				|  |  | -     * @return MediaServerItem
 | 
	
		
			
				|  |  | +     * @return mediaServer
 | 
	
		
			
				|  |  |       */
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  |      public MediaServer getOne(String mediaServerId) {
 | 
	
	
		
			
				|  | @@ -334,32 +335,32 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public void add(MediaServer mediaServerItem) {
 | 
	
		
			
				|  |  | -        mediaServerItem.setCreateTime(DateUtil.getNow());
 | 
	
		
			
				|  |  | -        mediaServerItem.setUpdateTime(DateUtil.getNow());
 | 
	
		
			
				|  |  | -        if (mediaServerItem.getHookAliveInterval() == null || mediaServerItem.getHookAliveInterval() == 0F) {
 | 
	
		
			
				|  |  | -            mediaServerItem.setHookAliveInterval(10F);
 | 
	
		
			
				|  |  | +    public void add(MediaServer mediaServer) {
 | 
	
		
			
				|  |  | +        mediaServer.setCreateTime(DateUtil.getNow());
 | 
	
		
			
				|  |  | +        mediaServer.setUpdateTime(DateUtil.getNow());
 | 
	
		
			
				|  |  | +        if (mediaServer.getHookAliveInterval() == null || mediaServer.getHookAliveInterval() == 0F) {
 | 
	
		
			
				|  |  | +            mediaServer.setHookAliveInterval(10F);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        if (mediaServerItem.getType() == null) {
 | 
	
		
			
				|  |  | -            logger.info("[添加媒体节点] 失败, mediaServerItem的类型:为空");
 | 
	
		
			
				|  |  | +        if (mediaServer.getType() == null) {
 | 
	
		
			
				|  |  | +            logger.info("[添加媒体节点] 失败, mediaServer的类型:为空");
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        if (mediaServerMapper.queryOne(mediaServerItem.getId()) != null) {
 | 
	
		
			
				|  |  | -            logger.info("[添加媒体节点] 失败, 媒体服务ID已存在,请修改媒体服务器配置, {}", mediaServerItem.getId());
 | 
	
		
			
				|  |  | -            throw new ControllerException(ErrorCode.ERROR100.getCode(),"保存失败,媒体服务ID [ " + mediaServerItem.getId() + " ] 已存在,请修改媒体服务器配置");
 | 
	
		
			
				|  |  | +        if (mediaServerMapper.queryOne(mediaServer.getId()) != null) {
 | 
	
		
			
				|  |  | +            logger.info("[添加媒体节点] 失败, 媒体服务ID已存在,请修改媒体服务器配置, {}", mediaServer.getId());
 | 
	
		
			
				|  |  | +            throw new ControllerException(ErrorCode.ERROR100.getCode(),"保存失败,媒体服务ID [ " + mediaServer.getId() + " ] 已存在,请修改媒体服务器配置");
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[添加媒体节点] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[添加媒体节点] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        mediaServerMapper.add(mediaServerItem);
 | 
	
		
			
				|  |  | -        if (mediaServerItem.isStatus()) {
 | 
	
		
			
				|  |  | -            mediaNodeServerService.online(mediaServerItem);
 | 
	
		
			
				|  |  | +        mediaServerMapper.add(mediaServer);
 | 
	
		
			
				|  |  | +        if (mediaServer.isStatus()) {
 | 
	
		
			
				|  |  | +            mediaNodeServerService.online(mediaServer);
 | 
	
		
			
				|  |  |          }else {
 | 
	
		
			
				|  |  |              // 发送事件
 | 
	
		
			
				|  |  |              MediaServerChangeEvent event = new MediaServerChangeEvent(this);
 | 
	
		
			
				|  |  | -            event.setMediaServerItemList(mediaServerItem);
 | 
	
		
			
				|  |  | +            event.setMediaServerItemList(mediaServer);
 | 
	
		
			
				|  |  |              applicationEventPublisher.publishEvent(event);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
	
		
			
				|  | @@ -403,7 +404,7 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      /**
 | 
	
		
			
				|  |  |       * 获取负载最低的节点
 | 
	
		
			
				|  |  | -     * @return MediaServerItem
 | 
	
		
			
				|  |  | +     * @return mediaServer
 | 
	
		
			
				|  |  |       */
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  |      public MediaServer getMediaServerForMinimumLoad(Boolean hasAssist) {
 | 
	
	
		
			
				|  | @@ -417,16 +418,16 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |          // 获取分数最低的,及并发最低的
 | 
	
		
			
				|  |  |          Set<Object> objects = redisTemplate.opsForZSet().range(key, 0, -1);
 | 
	
		
			
				|  |  |          ArrayList<Object> mediaServerObjectS = new ArrayList<>(objects);
 | 
	
		
			
				|  |  | -        MediaServer mediaServerItem = null;
 | 
	
		
			
				|  |  | +        MediaServer mediaServer = null;
 | 
	
		
			
				|  |  |          if (hasAssist == null) {
 | 
	
		
			
				|  |  |              String mediaServerId = (String)mediaServerObjectS.get(0);
 | 
	
		
			
				|  |  | -            mediaServerItem = getOne(mediaServerId);
 | 
	
		
			
				|  |  | +            mediaServer = getOne(mediaServerId);
 | 
	
		
			
				|  |  |          }else if (hasAssist) {
 | 
	
		
			
				|  |  |              for (Object mediaServerObject : mediaServerObjectS) {
 | 
	
		
			
				|  |  |                  String mediaServerId = (String)mediaServerObject;
 | 
	
		
			
				|  |  |                  MediaServer serverItem = getOne(mediaServerId);
 | 
	
		
			
				|  |  |                  if (serverItem.getRecordAssistPort() > 0) {
 | 
	
		
			
				|  |  | -                    mediaServerItem = serverItem;
 | 
	
		
			
				|  |  | +                    mediaServer = serverItem;
 | 
	
		
			
				|  |  |                      break;
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              }
 | 
	
	
		
			
				|  | @@ -435,13 +436,13 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |                  String mediaServerId = (String)mediaServerObject;
 | 
	
		
			
				|  |  |                  MediaServer serverItem = getOne(mediaServerId);
 | 
	
		
			
				|  |  |                  if (serverItem.getRecordAssistPort() == 0) {
 | 
	
		
			
				|  |  | -                    mediaServerItem = serverItem;
 | 
	
		
			
				|  |  | +                    mediaServer = serverItem;
 | 
	
		
			
				|  |  |                      break;
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        return mediaServerItem;
 | 
	
		
			
				|  |  | +        return mediaServer;
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
	
		
			
				|  | @@ -452,16 +453,16 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(type);
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[closeRTPServer] 失败, mediaServerItem的类型: {},未找到对应的实现类", type);
 | 
	
		
			
				|  |  | +            logger.info("[closeRTPServer] 失败, mediaServer的类型: {},未找到对应的实现类", type);
 | 
	
		
			
				|  |  |              return null;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        MediaServer mediaServerItem = mediaNodeServerService.checkMediaServer(ip, port, secret);
 | 
	
		
			
				|  |  | -        if (mediaServerItem != null) {
 | 
	
		
			
				|  |  | -            if (mediaServerMapper.queryOne(mediaServerItem.getId()) != null) {
 | 
	
		
			
				|  |  | -                throw new ControllerException(ErrorCode.ERROR100.getCode(), "媒体服务ID [" + mediaServerItem.getId() + " ] 已存在,请修改媒体服务器配置");
 | 
	
		
			
				|  |  | +        MediaServer mediaServer = mediaNodeServerService.checkMediaServer(ip, port, secret);
 | 
	
		
			
				|  |  | +        if (mediaServer != null) {
 | 
	
		
			
				|  |  | +            if (mediaServerMapper.queryOne(mediaServer.getId()) != null) {
 | 
	
		
			
				|  |  | +                throw new ControllerException(ErrorCode.ERROR100.getCode(), "媒体服务ID [" + mediaServer.getId() + " ] 已存在,请修改媒体服务器配置");
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        return mediaServerItem;
 | 
	
		
			
				|  |  | +        return mediaServer;
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
	
		
			
				|  | @@ -504,28 +505,28 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |      public void syncCatchFromDatabase() {
 | 
	
		
			
				|  |  |          List<MediaServer> allInCatch = getAllOnlineList();
 | 
	
		
			
				|  |  |          List<MediaServer> allInDatabase = mediaServerMapper.queryAll();
 | 
	
		
			
				|  |  | -        Map<String, MediaServer> mediaServerItemMap = new HashMap<>();
 | 
	
		
			
				|  |  | +        Map<String, MediaServer> mediaServerMap = new HashMap<>();
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        for (MediaServer mediaServerItem : allInDatabase) {
 | 
	
		
			
				|  |  | -            mediaServerItemMap.put(mediaServerItem.getId(), mediaServerItem);
 | 
	
		
			
				|  |  | +        for (MediaServer mediaServer : allInDatabase) {
 | 
	
		
			
				|  |  | +            mediaServerMap.put(mediaServer.getId(), mediaServer);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        for (MediaServer mediaServerItem : allInCatch) {
 | 
	
		
			
				|  |  | +        for (MediaServer mediaServer : allInCatch) {
 | 
	
		
			
				|  |  |              // 清除数据中不存在但redis缓存数据
 | 
	
		
			
				|  |  | -            if (!mediaServerItemMap.containsKey(mediaServerItem.getId())) {
 | 
	
		
			
				|  |  | -                delete(mediaServerItem.getId());
 | 
	
		
			
				|  |  | +            if (!mediaServerMap.containsKey(mediaServer.getId())) {
 | 
	
		
			
				|  |  | +                delete(mediaServer.getId());
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public MediaServerLoad getLoad(MediaServer mediaServerItem) {
 | 
	
		
			
				|  |  | +    public MediaServerLoad getLoad(MediaServer mediaServer) {
 | 
	
		
			
				|  |  |          MediaServerLoad result = new MediaServerLoad();
 | 
	
		
			
				|  |  | -        result.setId(mediaServerItem.getId());
 | 
	
		
			
				|  |  | -        result.setPush(redisCatchStorage.getPushStreamCount(mediaServerItem.getId()));
 | 
	
		
			
				|  |  | -        result.setProxy(redisCatchStorage.getProxyStreamCount(mediaServerItem.getId()));
 | 
	
		
			
				|  |  | +        result.setId(mediaServer.getId());
 | 
	
		
			
				|  |  | +        result.setPush(redisCatchStorage.getPushStreamCount(mediaServer.getId()));
 | 
	
		
			
				|  |  | +        result.setProxy(redisCatchStorage.getProxyStreamCount(mediaServer.getId()));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        result.setGbReceive(inviteStreamService.getStreamInfoCount(mediaServerItem.getId()));
 | 
	
		
			
				|  |  | -        result.setGbSend(redisCatchStorage.getGbSendCount(mediaServerItem.getId()));
 | 
	
		
			
				|  |  | +        result.setGbReceive(inviteStreamService.getStreamInfoCount(mediaServer.getId()));
 | 
	
		
			
				|  |  | +        result.setGbSend(redisCatchStorage.getGbSendCount(mediaServer.getId()));
 | 
	
		
			
				|  |  |          return result;
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -539,79 +540,149 @@ public class MediaServerServiceImpl implements IMediaServerService {
 | 
	
		
			
				|  |  |      public boolean stopSendRtp(MediaServer mediaInfo, String app, String stream, String ssrc) {
 | 
	
		
			
				|  |  |          IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaInfo.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[stopSendRtp] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaInfo.getType());
 | 
	
		
			
				|  |  | +            logger.info("[stopSendRtp] 失败, mediaServer的类型: {},未找到对应的实现类", mediaInfo.getType());
 | 
	
		
			
				|  |  |              return false;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |          return mediaNodeServerService.stopSendRtp(mediaInfo, app, stream, ssrc);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public boolean deleteRecordDirectory(MediaServer mediaServerItem, String app, String stream, String date, String fileName) {
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +    public boolean deleteRecordDirectory(MediaServer mediaServer, String app, String stream, String date, String fileName) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[stopSendRtp] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[stopSendRtp] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return false;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        return mediaNodeServerService.deleteRecordDirectory(mediaServerItem, app, stream, date, fileName);
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.deleteRecordDirectory(mediaServer, app, stream, date, fileName);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public List<StreamInfo> getMediaList(MediaServer mediaServerItem, String app, String stream, String callId) {
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +    public List<StreamInfo> getMediaList(MediaServer mediaServer, String app, String stream, String callId) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[getMediaList] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[getMediaList] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return new ArrayList<>();
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        return mediaNodeServerService.getMediaList(mediaServerItem, app, stream, callId);
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.getMediaList(mediaServer, app, stream, callId);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public Boolean connectRtpServer(MediaServer mediaServerItem, String address, int port, String stream) {
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +    public Boolean connectRtpServer(MediaServer mediaServer, String address, int port, String stream) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[connectRtpServer] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[connectRtpServer] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return false;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        return mediaNodeServerService.connectRtpServer(mediaServerItem, address, port, stream);
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.connectRtpServer(mediaServer, address, port, stream);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public void getSnap(MediaServer mediaServerItem, String streamUrl, int timeoutSec, int expireSec, String path, String fileName) {
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +    public void getSnap(MediaServer mediaServer, String streamUrl, int timeoutSec, int expireSec, String path, String fileName) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[getSnap] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[getSnap] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        mediaNodeServerService.getSnap(mediaServerItem, streamUrl, timeoutSec, expireSec, path, fileName);
 | 
	
		
			
				|  |  | +        mediaNodeServerService.getSnap(mediaServer, streamUrl, timeoutSec, expireSec, path, fileName);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public MediaInfo getMediaInfo(MediaServer mediaServerItem, String app, String stream) {
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +    public MediaInfo getMediaInfo(MediaServer mediaServer, String app, String stream) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[getMediaInfo] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[getMediaInfo] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return null;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        return mediaNodeServerService.getMediaInfo(mediaServerItem, app, stream);
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.getMediaInfo(mediaServer, app, stream);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public Boolean pauseRtpCheck(MediaServer mediaServerItem, String streamKey) {
 | 
	
		
			
				|  |  | -        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  | +    public Boolean pauseRtpCheck(MediaServer mediaServer, String streamKey) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  | +        if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | +            logger.info("[pauseRtpCheck] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  | +            return false;
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.pauseRtpCheck(mediaServer, streamKey);
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  | +    public boolean resumeRtpCheck(MediaServer mediaServer, String streamKey) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  | +        if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | +            logger.info("[pauseRtpCheck] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  | +            return false;
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.resumeRtpCheck(mediaServer, streamKey);
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  | +    public String getFfmpegCmd(MediaServer mediaServer, String cmdKey) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  | +        if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | +            logger.info("[getFfmpegCmd] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  | +            return null;
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.getFfmpegCmd(mediaServer, cmdKey);
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  | +    public void closeStreams(MediaServer mediaServer, String app, String stream) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[pauseRtpCheck] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[closeStreams] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  | +            return;
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        mediaNodeServerService.closeStreams(mediaServer, app, stream);
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  | +    public WVPResult<String> addFFmpegSource(MediaServer mediaServer, String srcUrl, String dstUrl, int timeoutMs, boolean enableAudio, boolean enableMp4, String ffmpegCmdKey) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  | +        if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | +            logger.info("[addFFmpegSource] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  | +            return WVPResult.fail(ErrorCode.ERROR400);
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.addFFmpegSource(mediaServer, srcUrl, dstUrl, timeoutMs, enableAudio, enableMp4, ffmpegCmdKey);
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  | +    public WVPResult<String> addStreamProxy(MediaServer mediaServer, String app, String stream, String url, boolean enableAudio, boolean enableMp4, String rtpType) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  | +        if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | +            logger.info("[addStreamProxy] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  | +            return WVPResult.fail(ErrorCode.ERROR400);
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.addStreamProxy(mediaServer, app, stream, url, enableAudio, enableMp4, rtpType);
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  | +    public Boolean delFFmpegSource(MediaServer mediaServer, String streamKey) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  | +        if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | +            logger.info("[delFFmpegSource] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  |              return false;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        return mediaNodeServerService.pauseRtpCheck(mediaServerItem, streamKey);
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.delFFmpegSource(mediaServer, streamKey);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @Override
 | 
	
		
			
				|  |  | -    public boolean resumeRtpCheck(MediaServer mediaServerItem, String streamKey) {
 | 
	
		
			
				|  |  | +    public Boolean delStreamProxy(MediaServer mediaServerItem, String streamKey) {
 | 
	
		
			
				|  |  |          IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServerItem.getType());
 | 
	
		
			
				|  |  |          if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | -            logger.info("[pauseRtpCheck] 失败, mediaServerItem的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  | +            logger.info("[delStreamProxy] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServerItem.getType());
 | 
	
		
			
				|  |  |              return false;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        return mediaNodeServerService.resumeRtpCheck(mediaServerItem, streamKey);
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.delStreamProxy(mediaServerItem, streamKey);
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  | +    public Map<String, String> getFFmpegCMDs(MediaServer mediaServer) {
 | 
	
		
			
				|  |  | +        IMediaNodeServerService mediaNodeServerService = nodeServerServiceMap.get(mediaServer.getType());
 | 
	
		
			
				|  |  | +        if (mediaNodeServerService == null) {
 | 
	
		
			
				|  |  | +            logger.info("[getFFmpegCMDs] 失败, mediaServer的类型: {},未找到对应的实现类", mediaServer.getType());
 | 
	
		
			
				|  |  | +            return new HashMap<>();
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        return mediaNodeServerService.getFFmpegCMDs(mediaServer);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  }
 |