648540858
2023-06-25 66eda32ab97d6e94e9f274d6faa4df586c452dfb
src/main/java/com/genersoft/iot/vmp/gb28181/session/VideoStreamSessionManager.java
@@ -1,30 +1,23 @@
package com.genersoft.iot.vmp.gb28181.session;
import com.genersoft.iot.vmp.common.InviteSessionType;
import com.genersoft.iot.vmp.common.VideoManagerConstants;
import com.genersoft.iot.vmp.conf.UserSetting;
import com.genersoft.iot.vmp.gb28181.bean.SipTransactionInfo;
import com.genersoft.iot.vmp.gb28181.bean.SsrcTransaction;
import com.genersoft.iot.vmp.utils.JsonUtil;
import com.genersoft.iot.vmp.utils.redis.RedisUtil;
import gov.nist.javax.sip.message.SIPResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import org.springframework.util.ObjectUtils;
import java.util.ArrayList;
import java.util.List;
import javax.sip.ClientTransaction;
import javax.sip.Dialog;
import com.genersoft.iot.vmp.common.VideoManagerConstants;
import com.genersoft.iot.vmp.conf.UserSetting;
import com.genersoft.iot.vmp.gb28181.bean.SipMsgInfo;
import com.genersoft.iot.vmp.gb28181.bean.SipTransactionInfo;
import com.genersoft.iot.vmp.gb28181.bean.SsrcTransaction;
import com.genersoft.iot.vmp.utils.SerializeUtils;
import com.genersoft.iot.vmp.utils.redis.RedisUtil;
import gov.nist.javax.sip.message.SIPRequest;
import gov.nist.javax.sip.message.SIPResponse;
import gov.nist.javax.sip.stack.SIPDialog;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.util.ObjectUtils;
import org.springframework.util.StringUtils;
/**
 * @description:视频流session管理器,管理视频预览、预览回放的通信句柄
 * @author: swwheihei
 * @date:   2020年5月13日 下午4:03:02
/**
 * 视频流session管理器,管理视频预览、预览回放的通信句柄
 */
@Component
public class VideoStreamSessionManager {
@@ -32,11 +25,8 @@
   @Autowired
   private UserSetting userSetting;
   public enum SessionType {
      play,
      playback,
      download
   }
   @Autowired
   private RedisTemplate<Object, Object> redisTemplate;
   /**
    * 添加一个点播/回放的事务信息
@@ -48,7 +38,7 @@
    * @param mediaServerId 所使用的流媒体ID
    * @param response 回复
    */
   public void put(String deviceId, String channelId, String callId, String stream, String ssrc, String mediaServerId, SIPResponse response, SessionType type){
   public void put(String deviceId, String channelId, String callId, String stream, String ssrc, String mediaServerId, SIPResponse response, InviteSessionType type){
      SsrcTransaction ssrcTransaction = new SsrcTransaction();
      ssrcTransaction.setDeviceId(deviceId);
      ssrcTransaction.setChannelId(channelId);
@@ -59,9 +49,7 @@
      ssrcTransaction.setMediaServerId(mediaServerId);
      ssrcTransaction.setType(type);
      RedisUtil.set(VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX + userSetting.getServerId()
            + "_" +  deviceId + "_" + channelId + "_" + callId + "_" + stream, ssrcTransaction);
      RedisUtil.set(VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX + userSetting.getServerId()
      redisTemplate.opsForValue().set(VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX + userSetting.getServerId()
            + "_" +  deviceId + "_" + channelId + "_" + callId + "_" + stream, ssrcTransaction);
   }
@@ -80,11 +68,11 @@
         stream ="*";
      }
      String key = VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX + userSetting.getServerId() + "_" + deviceId + "_" + channelId + "_" + callId+ "_" + stream;
      List<Object> scanResult = RedisUtil.scan(key);
      List<Object> scanResult = RedisUtil.scan(redisTemplate, key);
      if (scanResult.size() == 0) {
         return null;
      }
      return (SsrcTransaction)RedisUtil.get((String) scanResult.get(0));
      return (SsrcTransaction)redisTemplate.opsForValue().get(scanResult.get(0));
   }
   public List<SsrcTransaction> getSsrcTransactionForAll(String deviceId, String channelId, String callId, String stream){
@@ -101,13 +89,13 @@
         stream ="*";
      }
      String key = VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX + userSetting.getServerId() + "_" + deviceId + "_" + channelId + "_" + callId+ "_" + stream;
      List<Object> scanResult = RedisUtil.scan(key);
      List<Object> scanResult = RedisUtil.scan(redisTemplate, key);
      if (scanResult.size() == 0) {
         return null;
      }
      List<SsrcTransaction> result = new ArrayList<>();
      for (Object keyObj : scanResult) {
         result.add((SsrcTransaction)RedisUtil.get((String) keyObj));
         result.add((SsrcTransaction)redisTemplate.opsForValue().get(keyObj));
      }
      return result;
   }
@@ -133,17 +121,17 @@
      if (ssrcTransaction == null) {
         return;
      }
      RedisUtil.del(VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX + userSetting.getServerId() + "_"
      redisTemplate.delete(VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX + userSetting.getServerId() + "_"
            +  deviceId + "_" + channelId + "_" + ssrcTransaction.getCallId() + "_" + ssrcTransaction.getStream());
   }
   public List<SsrcTransaction> getAllSsrc() {
      List<Object> ssrcTransactionKeys = RedisUtil.scan(String.format("%s_*_*_*_*", VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX+ userSetting.getServerId()));
      List<Object> ssrcTransactionKeys = RedisUtil.scan(redisTemplate, String.format("%s_*_*_*_*", VideoManagerConstants.MEDIA_TRANSACTION_USED_PREFIX+ userSetting.getServerId()));
      List<SsrcTransaction> result= new ArrayList<>();
      for (int i = 0; i < ssrcTransactionKeys.size(); i++) {
         String key = (String)ssrcTransactionKeys.get(i);
         SsrcTransaction ssrcTransaction = (SsrcTransaction)RedisUtil.get(key);
      for (Object ssrcTransactionKey : ssrcTransactionKeys) {
         String key = (String) ssrcTransactionKey;
         SsrcTransaction ssrcTransaction = JsonUtil.redisJsonToObject(redisTemplate, key, SsrcTransaction.class);
         result.add(ssrcTransaction);
      }
      return result;