From 3d6db7478d79b824f93708f936c598cc622221f2 Mon Sep 17 00:00:00 2001
From: mk1990 <153958232@qq.com>
Date: 星期一, 20 六月 2022 15:10:31 +0800
Subject: [PATCH] fix设备状态查询接口
---
src/main/java/com/genersoft/iot/vmp/conf/MediaConfig.java | 195 +++++++++++++++++++++++++++++++++++++-----------
1 files changed, 151 insertions(+), 44 deletions(-)
diff --git a/src/main/java/com/genersoft/iot/vmp/conf/MediaConfig.java b/src/main/java/com/genersoft/iot/vmp/conf/MediaConfig.java
index c6b50b0..c24e0ca 100644
--- a/src/main/java/com/genersoft/iot/vmp/conf/MediaConfig.java
+++ b/src/main/java/com/genersoft/iot/vmp/conf/MediaConfig.java
@@ -1,105 +1,139 @@
package com.genersoft.iot.vmp.conf;
-import io.netty.util.internal.StringUtil;
+import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem;
+import com.genersoft.iot.vmp.utils.DateUtil;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
import org.springframework.util.StringUtils;
+import java.net.InetAddress;
+import java.net.UnknownHostException;
+import java.util.regex.Pattern;
+
+
@Configuration("mediaConfig")
-public class MediaConfig {
+public class MediaConfig{
+
+ // 淇敼蹇呴』閰嶇疆锛屼笉鍐嶆敮鎸佽嚜鍔ㄨ幏鍙�
+ @Value("${media.id}")
+ private String id;
@Value("${media.ip}")
private String ip;
- @Value("${media.hookIp:${sip.ip}}")
+ @Value("${media.hook-ip:${sip.ip}}")
private String hookIp;
- @Value("${media.sdpIp:${media.ip}}")
+ @Value("${sip.ip}")
+ private String sipIp;
+
+ @Value("${sip.domain}")
+ private String sipDomain;
+
+ @Value("${media.sdp-ip:${media.ip}}")
private String sdpIp;
- @Value("${media.streamIp:${media.ip}}")
+ @Value("${media.stream-ip:${media.ip}}")
private String streamIp;
- @Value("${media.httpPort}")
- private String httpPort;
+ @Value("${media.http-port}")
+ private Integer httpPort;
- @Value("${media.httpSSlPort:}")
- private String httpSSlPort;
+ @Value("${media.http-ssl-port:0}")
+ private Integer httpSSlPort = 0;
- @Value("${media.rtmpPort:}")
- private String rtmpPort;
+ @Value("${media.rtmp-port:0}")
+ private Integer rtmpPort = 0;
- @Value("${media.rtmpSSlPort:}")
- private String rtmpSSlPort;
+ @Value("${media.rtmp-ssl-port:0}")
+ private Integer rtmpSSlPort = 0;
- @Value("${media.rtpProxyPort:}")
- private String rtpProxyPort;
+ @Value("${media.rtp-proxy-port:0}")
+ private Integer rtpProxyPort = 0;
- @Value("${media.rtspPort:}")
- private String rtspPort;
+ @Value("${media.rtsp-port:0}")
+ private Integer rtspPort = 0;
- @Value("${media.rtspSSLPort:}")
- private String rtspSSLPort;
+ @Value("${media.rtsp-ssl-port:0}")
+ private Integer rtspSSLPort = 0;
- @Value("${media.autoConfig:true}")
- private boolean autoConfig;
+ @Value("${media.auto-config:true}")
+ private boolean autoConfig = true;
@Value("${media.secret}")
private String secret;
- @Value("${media.streamNoneReaderDelayMS:18000}")
- private String streamNoneReaderDelayMS;
+ @Value("${media.stream-none-reader-delay-ms:10000}")
+ private int streamNoneReaderDelayMS = 10000;
@Value("${media.rtp.enable}")
private boolean rtpEnable;
- @Value("${media.rtp.portRange}")
+ @Value("${media.rtp.port-range}")
private String rtpPortRange;
- @Value("${media.recordAssistPort}")
- private int recordAssistPort;
+
+ @Value("${media.rtp.send-port-range}")
+ private String sendRtpPortRange;
+
+ @Value("${media.record-assist-port:0}")
+ private Integer recordAssistPort = 0;
+
+ public String getId() {
+ return id;
+ }
public String getIp() {
return ip;
}
public String getHookIp() {
- return hookIp;
+ if (StringUtils.isEmpty(hookIp)){
+ return sipIp;
+ }else {
+ return hookIp;
+ }
+
}
- public String getSdpIp() {
- return sdpIp;
+ public String getSipIp() {
+ if (sipIp == null) {
+ return this.ip;
+ }else {
+ return sipIp;
+ }
}
- public String getStreamIp() {
- return streamIp;
- }
-
- public String getHttpPort() {
+ public int getHttpPort() {
return httpPort;
}
- public String getHttpSSlPort() {
+ public int getHttpSSlPort() {
return httpSSlPort;
}
- public String getRtmpPort() {
+ public int getRtmpPort() {
return rtmpPort;
}
-
- public String getRtmpSSlPort() {
+
+ public int getRtmpSSlPort() {
return rtmpSSlPort;
}
- public String getRtpProxyPort() {
- return rtpProxyPort;
+ public int getRtpProxyPort() {
+ if (rtpProxyPort == null) {
+ return 0;
+ }else {
+ return rtpProxyPort;
+ }
+
}
- public String getRtspPort() {
+ public int getRtspPort() {
return rtspPort;
}
- public String getRtspSSLPort() {
+ public int getRtspSSLPort() {
return rtspSSLPort;
}
@@ -111,7 +145,7 @@
return secret;
}
- public String getStreamNoneReaderDelayMS() {
+ public int getStreamNoneReaderDelayMS() {
return streamNoneReaderDelayMS;
}
@@ -122,8 +156,81 @@
public String getRtpPortRange() {
return rtpPortRange;
}
-
+
public int getRecordAssistPort() {
return recordAssistPort;
}
+
+ public String getSdpIp() {
+ if (StringUtils.isEmpty(sdpIp)){
+ return ip;
+ }else {
+ if (isValidIPAddress(sdpIp)) {
+ return sdpIp;
+ }else {
+ // 鎸夌収鍩熷悕瑙f瀽
+ String hostAddress = null;
+ try {
+ hostAddress = InetAddress.getByName(sdpIp).getHostAddress();
+ } catch (UnknownHostException e) {
+ throw new RuntimeException(e);
+ }
+ return hostAddress;
+ }
+ }
+ }
+
+ public String getStreamIp() {
+ if (StringUtils.isEmpty(streamIp)){
+ return ip;
+ }else {
+ return streamIp;
+ }
+ }
+
+ public String getSipDomain() {
+ return sipDomain;
+ }
+
+ public String getSendRtpPortRange() {
+ return sendRtpPortRange;
+ }
+
+ public MediaServerItem getMediaSerItem(){
+ MediaServerItem mediaServerItem = new MediaServerItem();
+ mediaServerItem.setId(id);
+ mediaServerItem.setIp(ip);
+ mediaServerItem.setDefaultServer(true);
+ mediaServerItem.setHookIp(getHookIp());
+ mediaServerItem.setSdpIp(getSdpIp());
+ mediaServerItem.setStreamIp(getStreamIp());
+ mediaServerItem.setHttpPort(httpPort);
+ mediaServerItem.setHttpSSlPort(httpSSlPort);
+ mediaServerItem.setRtmpPort(rtmpPort);
+ mediaServerItem.setRtmpSSlPort(rtmpSSlPort);
+ mediaServerItem.setRtpProxyPort(getRtpProxyPort());
+ mediaServerItem.setRtspPort(rtspPort);
+ mediaServerItem.setRtspSSLPort(rtspSSLPort);
+ mediaServerItem.setAutoConfig(autoConfig);
+ mediaServerItem.setSecret(secret);
+ mediaServerItem.setStreamNoneReaderDelayMS(streamNoneReaderDelayMS);
+ mediaServerItem.setRtpEnable(rtpEnable);
+ mediaServerItem.setRtpPortRange(rtpPortRange);
+ mediaServerItem.setSendRtpPortRange(sendRtpPortRange);
+ mediaServerItem.setRecordAssistPort(recordAssistPort);
+ mediaServerItem.setHookAliveInterval(120);
+
+ mediaServerItem.setCreateTime(DateUtil.getNow());
+ mediaServerItem.setUpdateTime(DateUtil.getNow());
+
+ return mediaServerItem;
+ }
+
+ private boolean isValidIPAddress(String ipAddress) {
+ if ((ipAddress != null) && (!ipAddress.isEmpty())) {
+ return Pattern.matches("^([1-9]|[1-9]\\d|1\\d{2}|2[0-4]\\d|25[0-5])(\\.(\\d|[1-9]\\d|1\\d{2}|2[0-4]\\d|25[0-5])){3}$", ipAddress);
+ }
+ return false;
+ }
+
}
--
Gitblit v1.8.0