From 3110a0a803fc593f26b59859ee857f8b083da232 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Mon, 11 Dec 2023 15:41:05 +0800 Subject: [PATCH 01/17] =?UTF-8?q?:memo:=20=E6=9C=89=E8=B6=85=E6=97=B6?= =?UTF-8?q?=E9=94=99=E8=AF=AF=E8=AE=A2=E9=98=85=E5=A4=84=E7=90=86=E4=BA=86?= =?UTF-8?q?=E3=80=82=E4=B8=8D=E9=9C=80=E8=A6=81=E5=8D=95=E7=8B=ACpusher?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../eventbus/event/RequestTimeoutEvent.java | 25 ----- .../common/transmit/SipProcessorObserver.java | 92 +++++++++---------- .../common/transmit/event/EventPublisher.java | 12 --- .../common/transmit/event/EventResult.java | 2 +- .../transmit/event/EventResultType.java | 4 +- 5 files changed, 45 insertions(+), 90 deletions(-) delete mode 100755 sip-common/src/main/java/io/github/lunasaw/sip/common/eventbus/event/RequestTimeoutEvent.java delete mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventPublisher.java diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/eventbus/event/RequestTimeoutEvent.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/eventbus/event/RequestTimeoutEvent.java deleted file mode 100755 index c9a1dc1e..00000000 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/eventbus/event/RequestTimeoutEvent.java +++ /dev/null @@ -1,25 +0,0 @@ -package io.github.lunasaw.sip.common.eventbus.event; - -import javax.sip.TimeoutEvent; - -import org.springframework.context.ApplicationEvent; - -/** - * @author lin - */ -public class RequestTimeoutEvent extends ApplicationEvent { - public RequestTimeoutEvent(Object source) { - super(source); - } - - - private TimeoutEvent timeoutEvent; - - public TimeoutEvent getTimeoutEvent() { - return timeoutEvent; - } - - public void setTimeoutEvent(TimeoutEvent timeoutEvent) { - this.timeoutEvent = timeoutEvent; - } -} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java index d175c279..0f32efc3 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java @@ -14,10 +14,10 @@ import org.apache.commons.collections4.CollectionUtils; import org.springframework.scheduling.annotation.Async; +import com.alibaba.fastjson.JSON; import com.luna.common.thread.AsyncEngineUtils; import io.github.lunasaw.sip.common.transmit.event.Event; -import io.github.lunasaw.sip.common.transmit.event.EventPublisher; import io.github.lunasaw.sip.common.transmit.event.EventResult; import io.github.lunasaw.sip.common.transmit.event.SipSubscribe; import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessor; @@ -46,8 +46,6 @@ public class SipProcessorObserver implements SipListener { */ private static final Map TIMEOUT_PROCESSOR_MAP = new ConcurrentHashMap<>(); - private static final List eventPublishers = new ArrayList<>(); - /** * 添加 request订阅 * @@ -161,71 +159,63 @@ public void processResponse(ResponseEvent responseEvent) { */ @Override public void processTimeout(TimeoutEvent timeoutEvent) { - log.info("[消息发送超时]"); ClientTransaction clientTransaction = timeoutEvent.getClientTransaction(); - if (clientTransaction != null) { - log.info("[发送错误订阅] clientTransaction != null"); - Request request = clientTransaction.getRequest(); - if (request != null) { - log.info("[发送错误订阅] request != null"); - CallIdHeader callIdHeader = (CallIdHeader) request.getHeader(CallIdHeader.NAME); - if (callIdHeader != null) { - log.info("[发送错误订阅]"); - Event subscribe = SipSubscribe.getErrorSubscribe(callIdHeader.getCallId()); - EventResult eventResult = new EventResult(timeoutEvent); - if (subscribe != null) { - subscribe.response(eventResult); - } - SipSubscribe.removeOkSubscribe(callIdHeader.getCallId()); - SipSubscribe.removeErrorSubscribe(callIdHeader.getCallId()); - } - } + if (clientTransaction == null) { + return; + } + + Request request = clientTransaction.getRequest(); + if (request == null) { + return; } - if (CollectionUtils.isNotEmpty(eventPublishers)) { - for (EventPublisher eventPublisher : eventPublishers) { - eventPublisher.requestTimeOut(timeoutEvent); + CallIdHeader callIdHeader = (CallIdHeader)request.getHeader(CallIdHeader.NAME); + if (callIdHeader != null) { + Event subscribe = SipSubscribe.getErrorSubscribe(callIdHeader.getCallId()); + EventResult eventResult = new EventResult(timeoutEvent); + if (subscribe != null) { + subscribe.response(eventResult); } + SipSubscribe.removeOkSubscribe(callIdHeader.getCallId()); + SipSubscribe.removeErrorSubscribe(callIdHeader.getCallId()); } } @Override public void processIOException(IOExceptionEvent exceptionEvent) { - System.out.println("processIOException"); + log.error("processIOException::exceptionEvent = {} ", JSON.toJSONString(exceptionEvent)); } + /** + * 事物结束 + * + * @param timeoutEvent -- an event that indicates that the + * transaction has transitioned into the terminated state. + */ @Override - public void processTransactionTerminated(TransactionTerminatedEvent transactionTerminatedEvent) { - // if (transactionTerminatedEvent.isServerTransaction()) { - // ServerTransaction serverTransaction = transactionTerminatedEvent.getServerTransaction(); - // serverTransaction.get - // } - - // Transaction transaction = null; - // System.out.println("processTransactionTerminated"); - // if (transactionTerminatedEvent.isServerTransaction()) { - // transaction = transactionTerminatedEvent.getServerTransaction(); - // }else { - // transaction = transactionTerminatedEvent.getClientTransaction(); - // } - // - // System.out.println(transaction.getBranchId()); - // System.out.println(transaction.getState()); - // System.out.println(transaction.getRequest().getMethod()); - // CallIdHeader header = (CallIdHeader)transaction.getRequest().getHeader(CallIdHeader.NAME); - // SipSubscribe.EventResult terminatedEventEventResult = new - // SipSubscribe.EventResult<>(transactionTerminatedEvent); - - // SipSubscribe.getErrorSubscribe(header.getCallId()).response(terminatedEventEventResult); + public void processTransactionTerminated(TransactionTerminatedEvent timeoutEvent) { + EventResult eventResult = new EventResult(timeoutEvent); + + Event timeOutSubscribe = SipSubscribe.getErrorSubscribe(eventResult.getCallId()); + if (timeOutSubscribe != null) { + timeOutSubscribe.response(eventResult); + } } + /** + * 会话结束 + * + * @param dialogTerminatedEvent -- an event that indicates that the + * dialog has transitioned into the terminated state. + */ @Override public void processDialogTerminated(DialogTerminatedEvent dialogTerminatedEvent) { - CallIdHeader callId = dialogTerminatedEvent.getDialog().getCallId(); - } + EventResult eventResult = new EventResult(dialogTerminatedEvent); - public void addPusher(EventPublisher eventPublisher) { - eventPublishers.add(eventPublisher); + Event timeOutSubscribe = SipSubscribe.getErrorSubscribe(eventResult.getCallId()); + if (timeOutSubscribe != null) { + timeOutSubscribe.response(eventResult); + } } } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventPublisher.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventPublisher.java deleted file mode 100644 index dc37967a..00000000 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventPublisher.java +++ /dev/null @@ -1,12 +0,0 @@ -package io.github.lunasaw.sip.common.transmit.event; - -import javax.sip.TimeoutEvent; - -import org.springframework.stereotype.Component; - -public interface EventPublisher { - - - - public void requestTimeOut(TimeoutEvent timeoutEvent); -} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventResult.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventResult.java index af780535..2f895527 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventResult.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventResult.java @@ -34,8 +34,8 @@ public EventResult(T event) { this.msg = response.getReasonPhrase(); this.statusCode = response.getStatusCode(); } + assert response != null; this.callId = ((CallIdHeader)response.getHeader(CallIdHeader.NAME)).getCallId(); - } else if (event instanceof TimeoutEvent) { TimeoutEvent timeoutEvent = (TimeoutEvent)event; this.type = EventResultType.timeout; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventResultType.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventResultType.java index 6e9511fe..5de38b03 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventResultType.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/EventResultType.java @@ -1,5 +1,7 @@ package io.github.lunasaw.sip.common.transmit.event; +import javax.sip.IOExceptionEvent; + /** * 事件类型 * @author luna @@ -18,5 +20,5 @@ public enum EventResultType { // 设备未找到 deviceNotFoundEvent, // 设备未找到 - cmdSendFailEvent + cmdSendFailEvent, } From 556383e42ad381d4637459c99313f4c5311e70f4 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Mon, 11 Dec 2023 17:31:03 +0800 Subject: [PATCH 02/17] =?UTF-8?q?:memo:=20=E4=B8=B4=E6=97=B6=E6=8F=90?= =?UTF-8?q?=E4=BA=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../ClientSubscribeRequestProcessor.java | 118 ++++++++++++++++++ .../subscribe/SubscribeProcessorClient.java | 13 ++ .../catalog/CatalogNotifyMessageHandler.java | 64 ++++++++++ .../info/ServerInfoRequestProcessor.java | 2 +- .../message/BaseMessageServerHandler.java | 2 + .../ServerMessageRequestProcessor.java | 1 - .../notify/ServerNotifyRequestProcessor.java | 35 ++++++ .../invite/InviteResponseProcessor.java | 14 +-- ...ava => InviteResponseProcessorServer.java} | 2 +- .../subscribe/SubscribeResponseProcessor.java | 56 +++++++++ .../SubscribeResponseProcessorServer.java | 13 ++ ...DefaultInviteResponseProcessorServer.java} | 4 +- .../entity/response/DeviceSubscribe.java | 41 ++++++ .../SipMessageRequestProcessorAbstract.java | 1 + .../event/subscribe/SubscribeHandler.java | 54 ++++++++ .../subscribe/SubscribeHandlerAbstract.java | 86 +++++++++++++ .../lunasaw/sip/common/utils/SipUtils.java | 27 ++-- 17 files changed, 512 insertions(+), 21 deletions(-) create mode 100644 gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java create mode 100644 gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java create mode 100644 gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java create mode 100644 gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java rename gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/{InviteProcessorServer.java => InviteResponseProcessorServer.java} (74%) create mode 100644 gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessor.java create mode 100644 gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java rename gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/{DefaultInviteProcessorServer.java => DefaultInviteResponseProcessorServer.java} (87%) create mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceSubscribe.java create mode 100755 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java create mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java new file mode 100644 index 00000000..ec684918 --- /dev/null +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java @@ -0,0 +1,118 @@ +package io.github.lunasaw.gbproxy.client.transmit.request.subscribe; + +import java.nio.charset.Charset; +import java.util.Map; +import java.util.Optional; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; + +import javax.sip.RequestEvent; + +import io.github.lunasaw.sip.common.transmit.event.subscribe.SubscribeHandler; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.MapUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; + +import com.google.common.collect.Maps; +import com.luna.common.text.StringTools; + +import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.sip.common.constant.Constant; +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.sip.common.entity.FromDevice; +import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; +import io.github.lunasaw.sip.common.utils.SipUtils; +import io.github.lunasaw.sip.common.utils.XmlUtils; +import lombok.Getter; +import lombok.Setter; + +/** + * SIP命令类型: 收到Subscribe请求 + * + * @author luna + */ +@Component +@Getter +@Setter +@Slf4j +public class ClientSubscribeRequestProcessor extends SipRequestProcessorAbstract { + + public static final String METHOD = "SUBSCRIBE"; + + private String method = METHOD; + + @Autowired + private SubscribeProcessorClient subscribeProcessorClient; + + /** + * 收到SUBSCRIBE请求 处理 + * + * @param evt + */ + @Override + public void process(RequestEvent evt) { + + SIPRequest request = (SIPRequest)evt.getRequest(); + + // 在服务端看来 收到请求的时候fromHeader还是客户端的 toHeader才是自己的,这里是要查询自己的信息 + String userId = SipUtils.getUserIdFromToHeader(request); + + // 获取设备 + FromDevice fromDevice = (FromDevice)subscribeProcessorClient.getFromDevice(); + if (!userId.equals(fromDevice.getUserId())) { + return; + } + + doSubscribeHandForEvt(evt, fromDevice); + } + + public static final Map> SUBSCRIBE_HANDLER_CMD_MAP = new ConcurrentHashMap<>(); + + public static void addHandler(SubscribeHandler SubscribeHandler) { + if (SubscribeHandler == null) { + return; + } + + if (SUBSCRIBE_HANDLER_CMD_MAP.containsKey(SubscribeHandler.getRootType())) { + SUBSCRIBE_HANDLER_CMD_MAP.get(SubscribeHandler.getRootType()).put(SubscribeHandler.getCmdType(), SubscribeHandler); + } else { + ConcurrentMap newedConcurrentMap = Maps.newConcurrentMap(); + newedConcurrentMap.put(SubscribeHandler.getCmdType(), SubscribeHandler); + SUBSCRIBE_HANDLER_CMD_MAP.put(SubscribeHandler.getRootType(), newedConcurrentMap); + } + } + + public void doSubscribeHandForEvt(RequestEvent evt, FromDevice fromDevice) { + SIPRequest request = (SIPRequest)evt.getRequest(); + + String charset = Optional.of(fromDevice).map(Device::getCharset).orElse(Constant.UTF_8); + + // 解析xml + byte[] rawContent = request.getRawContent(); + String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); + + String cmdType = XmlUtils.getCmdType(xmlStr); + String rootType = XmlUtils.getRootType(xmlStr); + + Map SubscribeHandlerMap = SUBSCRIBE_HANDLER_CMD_MAP.get(rootType); + + if (MapUtils.isEmpty(SubscribeHandlerMap)) { + return; + } + + SubscribeHandler SubscribeHandler = SubscribeHandlerMap.get(cmdType); + if (SubscribeHandler == null) { + return; + } + try { + SubscribeHandler.setXmlStr(xmlStr); + SubscribeHandler.handForEvt(evt); + SubscribeHandler.responseAck(evt); + } catch (Exception e) { + log.error("process::evt = {}, e = {}", evt, e.getMessage()); + SubscribeHandler.responseError(evt); + } + } + +} diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java new file mode 100644 index 00000000..5600d4db --- /dev/null +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java @@ -0,0 +1,13 @@ +package io.github.lunasaw.gbproxy.client.transmit.request.subscribe; + +import io.github.lunasaw.sip.common.service.SipUserGenerate; + +/** + * @author weidian + * @version 1.0 + * @date 2023/12/11 + * @description: + */ +public interface SubscribeProcessorClient extends SipUserGenerate { + +} diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java new file mode 100644 index 00000000..dab4beb3 --- /dev/null +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java @@ -0,0 +1,64 @@ +package io.github.lunasaw.gbproxy.client.transmit.request.subscribe.catalog; + +import javax.sip.RequestEvent; + +import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.sip.common.entity.query.DeviceQuery; +import io.github.lunasaw.sip.common.subscribe.SubscribeHolder; +import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; + +import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeProcessorClient; +import io.github.lunasaw.sip.common.entity.base.DeviceSession; +import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.sip.common.enums.CmdTypeEnum; +import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; +import io.github.lunasaw.sip.common.transmit.event.subscribe.SubscribeHandlerAbstract; +import lombok.Getter; +import lombok.Setter; +import lombok.extern.slf4j.Slf4j; + +/** + * 处理设备通道订阅消息 回复OK + * + * @author luna + * @date 2023/10/19 + */ +@Component +@Slf4j +@Getter +@Setter +public class CatalogNotifyMessageHandler extends SubscribeHandlerAbstract { + + public static final String CMD_TYPE = CmdTypeEnum.CATALOG.getType(); + + @Autowired + private SubscribeProcessorClient subscribeProcessorClient; + + @Autowired + private SubscribeHolder subscribeHolder; + + @Override + public String getRootType() { + return MessageHandler.NOTIFY; + } + + @Override + public void handForEvt(RequestEvent event) { + DeviceSession deviceSession = getDeviceSession(event); + // 订阅消息过来 + String sipId = deviceSession.getSipId(); + SIPRequest request = (SIPRequest)event.getRequest(); + SubscribeInfo subscribeInfo = new SubscribeInfo(request, sipId); + subscribeHolder.putCatalogSubscribe(sipId, subscribeInfo); + + DeviceQuery deviceQuery = parseXml(DeviceQuery.class); + + } + + @Override + public String getCmdType() { + return CMD_TYPE; + } +} diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/info/ServerInfoRequestProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/info/ServerInfoRequestProcessor.java index 2e6e43bf..38de4ec4 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/info/ServerInfoRequestProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/info/ServerInfoRequestProcessor.java @@ -23,7 +23,7 @@ public class ServerInfoRequestProcessor extends SipRequestProcessorAbstract { private String method = METHOD; /** - * 收到Bye请求 处理 + * 收到Info请求 处理 * * @param evt */ diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/BaseMessageServerHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/BaseMessageServerHandler.java index 51647e27..deaef783 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/BaseMessageServerHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/BaseMessageServerHandler.java @@ -9,6 +9,8 @@ import lombok.extern.slf4j.Slf4j; /** + * 复制类 无实际使用 + * * @author luna * @date 2023/10/19 */ diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/ServerMessageRequestProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/ServerMessageRequestProcessor.java index ea685cb8..99496907 100755 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/ServerMessageRequestProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/ServerMessageRequestProcessor.java @@ -27,7 +27,6 @@ public class ServerMessageRequestProcessor extends SipMessageRequestProcessorAbstract { public static final String METHOD = "MESSAGE"; - public static final Map MESSAGE_HANDLER_MAP = new ConcurrentHashMap<>(); @Resource private MessageProcessorServer messageProcessorServer; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java new file mode 100644 index 00000000..02bc1211 --- /dev/null +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java @@ -0,0 +1,35 @@ +package io.github.lunasaw.gbproxy.server.transimit.request.notify; + +import javax.sip.RequestEvent; + +import org.springframework.stereotype.Component; + +import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; +import lombok.Getter; +import lombok.Setter; + +/** + * SIP命令类型: 收到Notify请求 + * + * @author luna + */ +@Component +@Getter +@Setter +public class ServerNotifyRequestProcessor extends SipRequestProcessorAbstract { + + public static final String METHOD = "NOTIFY"; + + private String method = METHOD; + + /** + * 收到Notify请求 处理 + * + * @param evt + */ + @Override + public void process(RequestEvent evt) { + + } + +} diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessor.java index 5bf7e733..03def9e7 100755 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessor.java @@ -5,13 +5,10 @@ import javax.sdp.SdpParseException; import javax.sdp.SessionDescription; import javax.sip.ResponseEvent; -import javax.sip.SipFactory; import javax.sip.address.SipURI; -import javax.sip.header.CallIdHeader; import javax.sip.message.Response; import io.github.lunasaw.sip.common.entity.SdpSessionDescription; -import io.github.lunasaw.sip.common.transmit.ResponseCmd; import io.github.lunasaw.sip.common.utils.SipRequestUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @@ -20,7 +17,6 @@ import gov.nist.javax.sip.message.SIPResponse; import io.github.lunasaw.gbproxy.server.transimit.cmd.ServerSendCmd; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.sip.common.transmit.event.response.SipResponseProcessorAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Getter; @@ -43,10 +39,10 @@ public class InviteResponseProcessor extends SipResponseProcessorAbstract { private String method = METHOD; @Autowired - public InviteProcessorServer inviteProcessorServer; + public InviteResponseProcessorServer inviteResponseProcessorServer; - public InviteResponseProcessor(InviteProcessorServer inviteProcessorServer) { - this.inviteProcessorServer = inviteProcessorServer; + public InviteResponseProcessor(InviteResponseProcessorServer inviteResponseProcessorServer) { + this.inviteResponseProcessorServer = inviteResponseProcessorServer; } /** @@ -61,7 +57,7 @@ public void process(ResponseEvent evt) { SIPResponse response = (SIPResponse) evt.getResponse(); int statusCode = response.getStatusCode(); if (statusCode == Response.TRYING) { - inviteProcessorServer.responseTrying(); + inviteResponseProcessorServer.responseTrying(); } if (statusCode == Response.OK) { @@ -77,7 +73,7 @@ public void responseAck(ResponseEventExt evt) throws SdpParseException { // 成功响应 SIPResponse response = (SIPResponse) evt.getResponse(); - FromDevice fromDevice = (FromDevice)inviteProcessorServer.getFromDevice(); + FromDevice fromDevice = (FromDevice)inviteResponseProcessorServer.getFromDevice(); String contentString = new String(response.getRawContent()); SdpSessionDescription gb28181Sdp = SipUtils.parseSdp(contentString); diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteProcessorServer.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessorServer.java similarity index 74% rename from gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteProcessorServer.java rename to gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessorServer.java index ac733bb2..1cd19bf8 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteProcessorServer.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessorServer.java @@ -6,7 +6,7 @@ * @author weidian * @date 2023/10/21 */ -public interface InviteProcessorServer extends SipUserGenerate { +public interface InviteResponseProcessorServer extends SipUserGenerate { void responseTrying(); } diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessor.java new file mode 100644 index 00000000..6125f0f2 --- /dev/null +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessor.java @@ -0,0 +1,56 @@ +package io.github.lunasaw.gbproxy.server.transimit.response.subscribe; + +import javax.sip.ResponseEvent; +import javax.sip.message.Response; + +import gov.nist.javax.sip.message.SIPResponse; +import io.github.lunasaw.sip.common.entity.query.DeviceQuery; +import io.github.lunasaw.sip.common.entity.response.DeviceResponse; +import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.sip.common.utils.SipUtils; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; + +import io.github.lunasaw.sip.common.transmit.event.response.SipResponseProcessorAbstract; +import lombok.Getter; +import lombok.Setter; + +/** + * SIP命令类型: 收到SUBSCRIBE响应* + * + * @author luna + */ +@Component +@Getter +@Setter +@Slf4j +public class SubscribeResponseProcessor extends SipResponseProcessorAbstract { + + public static final String METHOD = "SUBSCRIBE"; + + private String method = METHOD; + + @Autowired + private SubscribeResponseProcessorServer subscribeResponseProcessorServer; + + public SubscribeResponseProcessor(SubscribeResponseProcessorServer subscribeResponseProcessorServer) { + this.subscribeResponseProcessorServer = subscribeResponseProcessorServer; + } + + /** + * 收到SUBSCRIBE响应处理 + * + * @param evt + */ + @Override + public void process(ResponseEvent evt) { + SIPResponse response = (SIPResponse)evt.getResponse(); + if (response.getStatusCode() != Response.OK) { + log.error("process::evt = {} ", evt); + return; + } + DeviceSubscribe deviceSubscribe = SipUtils.parseResponse(evt, DeviceSubscribe.class); + subscribeResponseProcessorServer.subscribeResult(deviceSubscribe); + } +} diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java new file mode 100644 index 00000000..c16cd461 --- /dev/null +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java @@ -0,0 +1,13 @@ +package io.github.lunasaw.gbproxy.server.transimit.response.subscribe; + +import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.sip.common.service.SipUserGenerate; + +/** + * @author weidian + * @date 2023/10/21 + */ +public interface SubscribeResponseProcessorServer extends SipUserGenerate { + void subscribeResult(DeviceSubscribe deviceSubscribe); + +} diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java similarity index 87% rename from gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteProcessorServer.java rename to gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java index fb64614b..dbc74646 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteProcessorServer.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java @@ -5,7 +5,7 @@ import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; -import io.github.lunasaw.gbproxy.server.transimit.response.invite.InviteProcessorServer; +import io.github.lunasaw.gbproxy.server.transimit.response.invite.InviteResponseProcessorServer; import io.github.lunasaw.sip.common.entity.Device; /** @@ -14,7 +14,7 @@ */ @Component @Slf4j -public class DefaultInviteProcessorServer implements InviteProcessorServer { +public class DefaultInviteResponseProcessorServer implements InviteResponseProcessorServer { @Autowired @Qualifier("serverFrom") diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceSubscribe.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceSubscribe.java new file mode 100644 index 00000000..2267b0ef --- /dev/null +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceSubscribe.java @@ -0,0 +1,41 @@ +package io.github.lunasaw.sip.common.entity.response; + +import javax.xml.bind.annotation.XmlAccessType; +import javax.xml.bind.annotation.XmlAccessorType; +import javax.xml.bind.annotation.XmlElement; +import javax.xml.bind.annotation.XmlRootElement; + +import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import lombok.Getter; +import lombok.NoArgsConstructor; +import lombok.Setter; + +/** + * + * + * Catalog + * sn + * channelId + * OK + * + * + * @author luna + */ +@Getter +@Setter +@NoArgsConstructor +@XmlRootElement(name = "Response") +@XmlAccessorType(XmlAccessType.FIELD) +public class DeviceSubscribe extends DeviceBase { + + /** + * OK + */ + @XmlElement(name = "Result") + private String Result = "OK"; + + public DeviceSubscribe(String cmdType, String sn, String deviceId) { + super(cmdType, sn, deviceId); + } + +} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/request/SipMessageRequestProcessorAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/request/SipMessageRequestProcessorAbstract.java index f03f0b2a..b8f1fd5b 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/request/SipMessageRequestProcessorAbstract.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/request/SipMessageRequestProcessorAbstract.java @@ -6,6 +6,7 @@ import io.github.lunasaw.sip.common.constant.Constant; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; +import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.extern.slf4j.Slf4j; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java new file mode 100755 index 00000000..4ad0d02d --- /dev/null +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java @@ -0,0 +1,54 @@ +package io.github.lunasaw.sip.common.transmit.event.subscribe; + +import javax.sip.RequestEvent; + +/** + * 对Subscribe类型的请求单独抽象,根据cmdType进行处理 + */ +public interface SubscribeHandler { + + String QUERY = "Query"; + String CONTROL = "Control"; + String NOTIFY = "Notify"; + String RESPONSE = "Response"; + + /** + * 响应ack + * + * @param event 请求事件 + */ + void responseAck(RequestEvent event); + + /** + * 响应error + * + * @param event 请求事件 + */ + void responseError(RequestEvent event); + + /** + * 处理消息 + * + * @param event + */ + void handForEvt(RequestEvent event); + + /** + * 处理标签 + * + * @return + */ + String getRootType(); + + /** + * 处理消息类型 + * + * @return + */ + String getCmdType(); + + /** + * 当前接受到的原始消息 + */ + void setXmlStr(String xmlStr); +} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java new file mode 100644 index 00000000..3543e9cf --- /dev/null +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java @@ -0,0 +1,86 @@ +package io.github.lunasaw.sip.common.transmit.event.subscribe; + +import java.nio.charset.Charset; + +import javax.sip.RequestEvent; +import javax.sip.message.Response; + +import org.apache.commons.lang3.StringUtils; + +import com.luna.common.text.StringTools; + +import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.sip.common.constant.Constant; +import io.github.lunasaw.sip.common.entity.base.DeviceSession; +import io.github.lunasaw.sip.common.transmit.ResponseCmd; +import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; +import io.github.lunasaw.sip.common.utils.XmlUtils; +import lombok.Getter; +import lombok.Setter; + +@Getter +@Setter +public class SubscribeHandlerAbstract implements SubscribeHandler { + + private String xmlStr; + + @Override + public void handForEvt(RequestEvent event) { + + } + + @Override + public String getRootType() { + return null; + } + + @Override + public String getCmdType() { + return null; + } + + @Override + public void setXmlStr(String xmlStr) { + this.xmlStr = xmlStr; + } + + public DeviceSession getDeviceSession(RequestEvent event) { + + return null; + } + + public void responseAck(RequestEvent event) { + ResponseCmd.doResponseCmd(Response.OK, "OK", event); + } + + public void responseError(RequestEvent event) { + ResponseCmd.doResponseCmd(Response.SERVER_INTERNAL_ERROR, "SERVER ERROR", event); + } + + public T parseXml(Class clazz) { + if (StringUtils.isBlank(xmlStr)) { + return null; + } + return (T)XmlUtils.parseObj(xmlStr, clazz); + } + + public static T parseRequest(RequestEvent event, String charset, Class clazz) { + SIPRequest sipRequest = (SIPRequest)event.getRequest(); + byte[] rawContent = sipRequest.getRawContent(); + if (StringUtils.isBlank(charset)) { + charset = Constant.UTF_8; + } + String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); + Object o = XmlUtils.parseObj(xmlStr, clazz); + return (T)o; + } + + public static String parseRequest(RequestEvent event, String charset) { + SIPRequest sipRequest = (SIPRequest)event.getRequest(); + byte[] rawContent = sipRequest.getRawContent(); + if (StringUtils.isBlank(charset)) { + charset = Constant.UTF_8; + } + return StringTools.toEncodedString(rawContent, Charset.forName(charset)); + } +} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/utils/SipUtils.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/utils/SipUtils.java index 8bd31c2e..dea85ad6 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/utils/SipUtils.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/utils/SipUtils.java @@ -4,6 +4,7 @@ import javax.sdp.SessionDescription; import javax.sip.RequestEvent; +import javax.sip.ResponseEvent; import javax.sip.header.FromHeader; import javax.sip.header.HeaderAddress; import javax.sip.header.SubjectHeader; @@ -180,13 +181,7 @@ public static SdpSessionDescription parseSdp(String sdpStr) { public static T parseRequest(RequestEvent event, String charset, Class clazz) { SIPRequest sipRequest = (SIPRequest) event.getRequest(); - byte[] rawContent = sipRequest.getRawContent(); - if (StringUtils.isBlank(charset)) { - charset = Constant.UTF_8; - } - String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); - Object o = XmlUtils.parseObj(xmlStr, clazz); - return (T) o; + return getObj(charset, clazz, sipRequest.getRawContent()); } public static String parseRequest(RequestEvent event, String charset) { @@ -197,4 +192,22 @@ public static String parseRequest(RequestEvent event, String charset) { } return StringTools.toEncodedString(rawContent, Charset.forName(charset)); } + + public static T getObj(String charset, Class clazz, byte[] rawContent) { + if (StringUtils.isBlank(charset)) { + charset = Constant.UTF_8; + } + String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); + Object o = XmlUtils.parseObj(xmlStr, clazz); + return (T)o; + } + + public static T parseResponse(ResponseEvent evt, Class tClass) { + return parseResponse(evt, null, tClass); + } + + public static T parseResponse(ResponseEvent evt, String charset, Class clazz) { + Response response = evt.getResponse(); + return getObj(charset, clazz, response.getRawContent()); + } } \ No newline at end of file From 887320d5f66bb209e6b04992daafb3436d439b3b Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Mon, 11 Dec 2023 17:49:01 +0800 Subject: [PATCH 03/17] =?UTF-8?q?:memo:=20=E4=B8=B4=E6=97=B6=E6=8F=90?= =?UTF-8?q?=E4=BA=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../subscribe/SubscribeProcessorClient.java | 2 +- .../gbproxy/server/entity/InviteRequest.java | 2 +- .../message/MessageProcessorServer.java | 2 +- .../invite/InviteResponseProcessorServer.java | 2 +- .../SubscribeResponseProcessorServer.java | 2 +- .../DefaultInviteResponseProcessorServer.java | 2 +- ...faultSubscribeResponseProcessorServer.java | 41 +++++++++++++++++++ .../lunasaw/sip/common/conf/package-info.java | 2 +- .../sip/common/constant/package-info.java | 2 +- .../sip/common/entity/base/package-info.java | 2 +- .../common/entity/control/package-info.java | 2 +- .../common/entity/notify/package-info.java | 2 +- .../sip/common/entity/query/package-info.java | 2 +- .../common/entity/response/package-info.java | 2 +- .../sip/common/entity/xml/package-info.java | 2 +- .../sip/common/layer/package-info.java | 2 +- 16 files changed, 56 insertions(+), 15 deletions(-) create mode 100644 gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java index 5600d4db..78844baa 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java @@ -3,7 +3,7 @@ import io.github.lunasaw.sip.common.service.SipUserGenerate; /** - * @author weidian + * @author luna * @version 1.0 * @date 2023/12/11 * @description: diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/entity/InviteRequest.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/entity/InviteRequest.java index 968825fd..b76cc03f 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/entity/InviteRequest.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/entity/InviteRequest.java @@ -6,7 +6,7 @@ import lombok.Data; /** - * @author weidian + * @author luna * @date 2023/11/16 */ @Data diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageProcessorServer.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageProcessorServer.java index edce2f9e..b130c595 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageProcessorServer.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageProcessorServer.java @@ -10,7 +10,7 @@ import io.github.lunasaw.sip.common.service.SipUserGenerate; /** - * @author weidian + * @author luna * @date 2023/10/21 */ public interface MessageProcessorServer extends SipUserGenerate { diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessorServer.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessorServer.java index 1cd19bf8..35914806 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessorServer.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/invite/InviteResponseProcessorServer.java @@ -3,7 +3,7 @@ import io.github.lunasaw.sip.common.service.SipUserGenerate; /** - * @author weidian + * @author luna * @date 2023/10/21 */ public interface InviteResponseProcessorServer extends SipUserGenerate { diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java index c16cd461..c5ee8d3f 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java @@ -4,7 +4,7 @@ import io.github.lunasaw.sip.common.service.SipUserGenerate; /** - * @author weidian + * @author luna * @date 2023/10/21 */ public interface SubscribeResponseProcessorServer extends SipUserGenerate { diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java index dbc74646..f6da5b7b 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java @@ -9,7 +9,7 @@ import io.github.lunasaw.sip.common.entity.Device; /** - * @author weidian + * @author luna * @date 2023/10/21 */ @Component diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java new file mode 100644 index 00000000..7b16209f --- /dev/null +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java @@ -0,0 +1,41 @@ +package io.github.lunasaw.gbproxy.test.user.server; + +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Qualifier; +import org.springframework.stereotype.Component; + +import io.github.lunasaw.gbproxy.server.transimit.response.subscribe.SubscribeResponseProcessorServer; +import io.github.lunasaw.gbproxy.test.config.DeviceConfig; +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; + +/** + * @author luna + * @version 1.0 + * @date 2023/12/11 + * @description: + */ +@Component +@Slf4j +public class DefaultSubscribeResponseProcessorServer implements SubscribeResponseProcessorServer { + + @Autowired + @Qualifier("serverFrom") + private Device fromDevice; + + @Override + public void subscribeResult(DeviceSubscribe deviceSubscribe) { + log.error("收到订阅消息响应 subscribeResult::deviceSubscribe = {} ", deviceSubscribe); + } + + @Override + public Device getToDevice(String userId) { + return DeviceConfig.DEVICE_SERVER_VIEW_MAP.get(userId); + } + + @Override + public Device getFromDevice() { + return fromDevice; + } +} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/package-info.java index b4f59cfa..95754025 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/package-info.java @@ -2,7 +2,7 @@ * Contains classes for configuring the SIP stack. * 包含配置SIP栈的类 * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.conf; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/constant/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/constant/package-info.java index 52cad376..198e1777 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/constant/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/constant/package-info.java @@ -2,7 +2,7 @@ * Contains constants used in the SIP protocol. * 包含SIP协议中使用的常量 * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.constant; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/package-info.java index 76122cc6..5c930af2 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/package-info.java @@ -2,7 +2,7 @@ * Base classes for SIP entities. * 包含设备基础的实体类的xml bean * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.entity.base; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/package-info.java index e404d3db..0c1f565e 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/package-info.java @@ -2,7 +2,7 @@ * Contains classes that represent SIP control entities. * 包含设备控制的实体类的xml bean * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.entity.control; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/package-info.java index 8675eadb..829630f3 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/package-info.java @@ -2,7 +2,7 @@ * Contains all the SIP NOTIFY message related classes. * 包含设备通知的实体类的xml bean * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.entity.notify; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/package-info.java index 0404cdba..1254df0a 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/package-info.java @@ -2,7 +2,7 @@ * Contains classes that represent XML elements. * 包含设备查询的实体类的xml bean * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.entity.query; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/package-info.java index 3ebe6849..c04b87a8 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/package-info.java @@ -2,7 +2,7 @@ * Contains all the response classes. * 包含设备响应的实体类的xml bean * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.entity.response; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/package-info.java index 9a4d0003..746f817a 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/package-info.java @@ -1,7 +1,7 @@ /** * Contains classes that represent XML elements. * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.entity.xml; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/layer/package-info.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/layer/package-info.java index 4b4634cc..03619845 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/layer/package-info.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/layer/package-info.java @@ -2,7 +2,7 @@ * SIP layers. * 添加SIP监听端口 * - * @author weidian + * @author luna * @date 2023/11/20 */ package io.github.lunasaw.sip.common.layer; \ No newline at end of file From f9968acd52716dcdbbf20ff12d96e9137fbf8a95 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Tue, 12 Dec 2023 15:57:17 +0800 Subject: [PATCH 04/17] =?UTF-8?q?:memo:=20=E4=B8=B4=E6=97=B6=E6=8F=90?= =?UTF-8?q?=E4=BA=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../config/SipProxyClientAutoConfig.java | 9 ++- .../ClientMessageRequestProcessor.java | 2 +- .../ClientSubscribeRequestProcessor.java | 67 +--------------- .../SubscribeClientHandlerAbstract.java | 45 +++++++++++ .../catalog/CatalogNotifyMessageHandler.java | 11 ++- .../ServerMessageRequestProcessor.java | 6 +- .../DefaultSubscribeProcessorClient.java | 32 ++++++++ .../test/subscribe/SubscribeClientTest.java | 67 ++++++++++++++++ .../test/subscribe/SubscribeServerTest.java | 79 +++++++++++++++++++ .../SipMessageRequestProcessorAbstract.java | 3 +- .../SipSubscribeRequestProcessorAbstract.java | 78 ++++++++++++++++++ .../subscribe/SubscribeHandlerAbstract.java | 5 +- 12 files changed, 328 insertions(+), 76 deletions(-) create mode 100755 gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java create mode 100644 gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java create mode 100644 gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java create mode 100644 gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java rename sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/{request => message}/SipMessageRequestProcessorAbstract.java (94%) create mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/config/SipProxyClientAutoConfig.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/config/SipProxyClientAutoConfig.java index 671ea875..cff593ab 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/config/SipProxyClientAutoConfig.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/config/SipProxyClientAutoConfig.java @@ -2,7 +2,6 @@ import java.util.Map; -import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageClientHandlerAbstract; import org.springframework.beans.BeansException; import org.springframework.beans.factory.InitializingBean; import org.springframework.context.ApplicationContext; @@ -11,7 +10,9 @@ import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.client.transmit.request.message.ClientMessageRequestProcessor; -import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; +import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageClientHandlerAbstract; +import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.ClientSubscribeRequestProcessor; +import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeClientHandlerAbstract; import lombok.extern.slf4j.Slf4j; /** @@ -29,6 +30,10 @@ public class SipProxyClientAutoConfig implements InitializingBean, ApplicationCo public void afterPropertiesSet() { Map clientMessageHandlerMap = applicationContext.getBeansOfType(MessageClientHandlerAbstract.class); clientMessageHandlerMap.forEach((k, v) -> ClientMessageRequestProcessor.addHandler(v)); + + Map clientSubscribeHandlerMap = + applicationContext.getBeansOfType(SubscribeClientHandlerAbstract.class); + clientSubscribeHandlerMap.forEach((k, v) -> ClientSubscribeRequestProcessor.addHandler(v)); } @Override diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/ClientMessageRequestProcessor.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/ClientMessageRequestProcessor.java index ec9d02bb..5f4be999 100755 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/ClientMessageRequestProcessor.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/ClientMessageRequestProcessor.java @@ -2,7 +2,7 @@ import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.transmit.event.request.SipMessageRequestProcessorAbstract; +import io.github.lunasaw.sip.common.transmit.event.message.SipMessageRequestProcessorAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Getter; import lombok.Setter; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java index ec684918..2f225a45 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java @@ -1,31 +1,19 @@ package io.github.lunasaw.gbproxy.client.transmit.request.subscribe; -import java.nio.charset.Charset; -import java.util.Map; -import java.util.Optional; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; - import javax.sip.RequestEvent; -import io.github.lunasaw.sip.common.transmit.event.subscribe.SubscribeHandler; -import lombok.extern.slf4j.Slf4j; -import org.apache.commons.collections4.MapUtils; +import io.github.lunasaw.sip.common.transmit.event.subscribe.SipSubscribeRequestProcessorAbstract; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; -import com.google.common.collect.Maps; -import com.luna.common.text.StringTools; - import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.constant.Constant; -import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; +import io.github.lunasaw.sip.common.transmit.event.subscribe.SubscribeHandlerAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; -import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.Getter; import lombok.Setter; +import lombok.extern.slf4j.Slf4j; /** * SIP命令类型: 收到Subscribe请求 @@ -36,7 +24,7 @@ @Getter @Setter @Slf4j -public class ClientSubscribeRequestProcessor extends SipRequestProcessorAbstract { +public class ClientSubscribeRequestProcessor extends SipSubscribeRequestProcessorAbstract { public static final String METHOD = "SUBSCRIBE"; @@ -67,52 +55,5 @@ public void process(RequestEvent evt) { doSubscribeHandForEvt(evt, fromDevice); } - public static final Map> SUBSCRIBE_HANDLER_CMD_MAP = new ConcurrentHashMap<>(); - - public static void addHandler(SubscribeHandler SubscribeHandler) { - if (SubscribeHandler == null) { - return; - } - - if (SUBSCRIBE_HANDLER_CMD_MAP.containsKey(SubscribeHandler.getRootType())) { - SUBSCRIBE_HANDLER_CMD_MAP.get(SubscribeHandler.getRootType()).put(SubscribeHandler.getCmdType(), SubscribeHandler); - } else { - ConcurrentMap newedConcurrentMap = Maps.newConcurrentMap(); - newedConcurrentMap.put(SubscribeHandler.getCmdType(), SubscribeHandler); - SUBSCRIBE_HANDLER_CMD_MAP.put(SubscribeHandler.getRootType(), newedConcurrentMap); - } - } - - public void doSubscribeHandForEvt(RequestEvent evt, FromDevice fromDevice) { - SIPRequest request = (SIPRequest)evt.getRequest(); - - String charset = Optional.of(fromDevice).map(Device::getCharset).orElse(Constant.UTF_8); - - // 解析xml - byte[] rawContent = request.getRawContent(); - String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); - - String cmdType = XmlUtils.getCmdType(xmlStr); - String rootType = XmlUtils.getRootType(xmlStr); - - Map SubscribeHandlerMap = SUBSCRIBE_HANDLER_CMD_MAP.get(rootType); - - if (MapUtils.isEmpty(SubscribeHandlerMap)) { - return; - } - - SubscribeHandler SubscribeHandler = SubscribeHandlerMap.get(cmdType); - if (SubscribeHandler == null) { - return; - } - try { - SubscribeHandler.setXmlStr(xmlStr); - SubscribeHandler.handForEvt(evt); - SubscribeHandler.responseAck(evt); - } catch (Exception e) { - log.error("process::evt = {}, e = {}", evt, e.getMessage()); - SubscribeHandler.responseError(evt); - } - } } diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java new file mode 100755 index 00000000..a6769b41 --- /dev/null +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java @@ -0,0 +1,45 @@ +package io.github.lunasaw.gbproxy.client.transmit.request.subscribe; + +import javax.sip.RequestEvent; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; + +import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; +import io.github.lunasaw.sip.common.entity.base.DeviceSession; +import io.github.lunasaw.sip.common.transmit.event.subscribe.SubscribeHandlerAbstract; +import io.github.lunasaw.sip.common.utils.SipUtils; +import lombok.Data; + +/** + * @author luna + */ +@Data +@Component +public abstract class SubscribeClientHandlerAbstract extends SubscribeHandlerAbstract { + + @Autowired + private SubscribeProcessorClient subscribeProcessorClient; + + public SubscribeClientHandlerAbstract(SubscribeProcessorClient subscribeProcessorClient) { + this.subscribeProcessorClient = subscribeProcessorClient; + } + + @Override + public String getRootType() { + return "Root"; + } + + public DeviceSession getDeviceSession(RequestEvent event) { + SIPRequest sipRequest = (SIPRequest)event.getRequest(); + + // 特别注意。这里的userId和sipId是反的,因为是客户端收到消息,所以这里的from是服务端,to是客户端 + String userId = SipUtils.getUserIdFromToHeader(sipRequest); + // 客户端收到消息 fromHeader是服务端,toHeader是客户端 + String sipId = SipUtils.getUserIdFromFromHeader(sipRequest); + + return new DeviceSession(userId, sipId); + } + +} diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java index dab4beb3..76779570 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java @@ -3,6 +3,8 @@ import javax.sip.RequestEvent; import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; +import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeClientHandlerAbstract; import io.github.lunasaw.sip.common.entity.query.DeviceQuery; import io.github.lunasaw.sip.common.subscribe.SubscribeHolder; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; @@ -29,16 +31,18 @@ @Slf4j @Getter @Setter -public class CatalogNotifyMessageHandler extends SubscribeHandlerAbstract { +public class CatalogNotifyMessageHandler extends SubscribeClientHandlerAbstract { public static final String CMD_TYPE = CmdTypeEnum.CATALOG.getType(); - @Autowired - private SubscribeProcessorClient subscribeProcessorClient; @Autowired private SubscribeHolder subscribeHolder; + public CatalogNotifyMessageHandler(SubscribeProcessorClient subscribeProcessorClient) { + super(subscribeProcessorClient); + } + @Override public String getRootType() { return MessageHandler.NOTIFY; @@ -55,6 +59,7 @@ public void handForEvt(RequestEvent event) { DeviceQuery deviceQuery = parseXml(DeviceQuery.class); + // 放入本地Map 回复成功 } @Override diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/ServerMessageRequestProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/ServerMessageRequestProcessor.java index 99496907..c5fc4f5f 100755 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/ServerMessageRequestProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/ServerMessageRequestProcessor.java @@ -1,17 +1,13 @@ package io.github.lunasaw.gbproxy.server.transimit.request.message; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; - import javax.annotation.Resource; import javax.sip.RequestEvent; -import io.github.lunasaw.sip.common.transmit.event.request.SipMessageRequestProcessorAbstract; +import io.github.lunasaw.sip.common.transmit.event.message.SipMessageRequestProcessorAbstract; import org.springframework.stereotype.Component; import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Getter; import lombok.Setter; diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java new file mode 100644 index 00000000..c51dbfe4 --- /dev/null +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java @@ -0,0 +1,32 @@ +package io.github.lunasaw.gbproxy.test.user.client; + +import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeProcessorClient; +import io.github.lunasaw.gbproxy.test.config.DeviceConfig; +import io.github.lunasaw.sip.common.entity.Device; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Qualifier; +import org.springframework.stereotype.Component; + +/** + * @author weidian + * @version 1.0 + * @date 2023/12/11 + * @description: + */ +@Component +public class DefaultSubscribeProcessorClient implements SubscribeProcessorClient { + + @Autowired + @Qualifier("clientFrom") + private Device fromDevice; + + @Override + public Device getToDevice(String userId) { + return DeviceConfig.DEVICE_CLIENT_VIEW_MAP.get(userId); + } + + @Override + public Device getFromDevice() { + return fromDevice; + } +} diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java new file mode 100644 index 00000000..c74e921a --- /dev/null +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java @@ -0,0 +1,67 @@ +package io.github.lunasaw.gbproxy.test.subscribe; + +import javax.sip.message.Request; + +import org.junit.jupiter.api.AfterAll; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Qualifier; +import org.springframework.boot.test.context.SpringBootTest; + +import io.github.lunasaw.gbproxy.client.transmit.cmd.ClientSendCmd; +import io.github.lunasaw.gbproxy.test.Gb28181ApplicationTest; +import io.github.lunasaw.gbproxy.test.config.DeviceConfig; +import io.github.lunasaw.gbproxy.test.user.client.DefaultRegisterProcessorClient; +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.sip.common.entity.FromDevice; +import io.github.lunasaw.sip.common.entity.ToDevice; +import io.github.lunasaw.sip.common.layer.SipLayer; +import io.github.lunasaw.sip.common.transmit.SipSender; +import io.github.lunasaw.sip.common.transmit.event.Event; +import io.github.lunasaw.sip.common.transmit.event.EventResult; +import io.github.lunasaw.sip.common.transmit.request.SipRequestProvider; +import io.github.lunasaw.sip.common.utils.SipRequestUtils; +import lombok.extern.slf4j.Slf4j; + +/** + * @author luna + * @date 2023/10/12 + */ +@Slf4j +@SpringBootTest(classes = Gb28181ApplicationTest.class) +public class SubscribeClientTest { + + @Autowired + @Qualifier("clientFrom") + private Device fromDevice; + + @Autowired + @Qualifier("clientTo") + private Device toDevice; + + @AfterAll + public static void after() { + while (true) { + + } + } + + @BeforeEach + public void before() { + // 本地端口监听 + log.info("before::客户端初始化 fromDevice.ip : {} , fromDevice.port : {}", fromDevice.getIp(), fromDevice.getPort()); + SipLayer.addListeningPoint(DeviceConfig.LOOP_IP, fromDevice.getPort(), true); + + DeviceConfig.DEVICE_CLIENT_VIEW_MAP.put(toDevice.getUserId(), toDevice); + + } + + @Test + public void atest() { + String callId = SipRequestUtils.getNewCallId(); + Request registerRequest = SipRequestProvider.createRegisterRequest((FromDevice)fromDevice, (ToDevice)toDevice, 300, callId); + + SipSender.transmitRequest(fromDevice.getIp(), registerRequest); + } +} diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java new file mode 100644 index 00000000..98411e0c --- /dev/null +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java @@ -0,0 +1,79 @@ +package io.github.lunasaw.gbproxy.test.subscribe; + +import java.util.Date; + +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Qualifier; +import org.springframework.boot.test.context.SpringBootTest; + +import com.alibaba.fastjson2.JSON; +import com.luna.common.date.DateUtils; + +import io.github.lunasaw.gbproxy.server.transimit.cmd.ServerSendCmd; +import io.github.lunasaw.gbproxy.test.Gb28181ApplicationTest; +import io.github.lunasaw.gbproxy.test.config.DeviceConfig; +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.sip.common.entity.FromDevice; +import io.github.lunasaw.sip.common.entity.ToDevice; +import io.github.lunasaw.sip.common.entity.control.DragZoom; +import io.github.lunasaw.sip.common.layer.SipLayer; +import io.github.lunasaw.sip.common.utils.DynamicTask; +import lombok.SneakyThrows; +import lombok.extern.slf4j.Slf4j; + +/** + * @author luna + * @date 2023/10/12 + */ +@Slf4j +@SpringBootTest(classes = Gb28181ApplicationTest.class) +public class SubscribeServerTest { + + @Autowired + @Qualifier("serverFrom") + private Device fromDevice; + + @Autowired + @Qualifier("serverTo") + private Device toDevice; + + @Autowired + private DynamicTask dynamicTask; + + @BeforeEach + public void before() { + // 本地端口监听 + log.info("before::服务端初始化 fromDevice.ip : {} , fromDevice.port : {}", fromDevice.getIp(), fromDevice.getPort()); + SipLayer.addListeningPoint(DeviceConfig.LOOP_IP, 8117, true); + } + + @Test + public void test_register_server() throws Exception { + + } + + @Test + public void test_subscribe() { + dynamicTask.startCron("test_subscribe", () -> { + Device device = DeviceConfig.DEVICE_SERVER_VIEW_MAP.get("33010602011187000001"); + if (device == null) { + test_subscribe(); + return; + } + String invitePlay = + ServerSendCmd.deviceCatalogSubscribe((FromDevice)fromDevice, (ToDevice)device, 30, "", "2023-11-29 00:00:00"); + System.out.println(invitePlay); + }, 30 * 1000); + } + + @SneakyThrows + @AfterEach + public void after() { + while (true) { + + } + } +} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/request/SipMessageRequestProcessorAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java similarity index 94% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/request/SipMessageRequestProcessorAbstract.java rename to sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java index b8f1fd5b..7890b980 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/request/SipMessageRequestProcessorAbstract.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.transmit.event.request; +package io.github.lunasaw.sip.common.transmit.event.message; import com.google.common.collect.Maps; import com.luna.common.text.StringTools; @@ -8,6 +8,7 @@ import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; +import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.extern.slf4j.Slf4j; import org.apache.commons.collections4.MapUtils; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java new file mode 100644 index 00000000..d21e668d --- /dev/null +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java @@ -0,0 +1,78 @@ +package io.github.lunasaw.sip.common.transmit.event.subscribe; + +import java.nio.charset.Charset; +import java.util.Map; +import java.util.Optional; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; + +import javax.sip.RequestEvent; + +import org.apache.commons.collections4.MapUtils; + +import com.google.common.collect.Maps; +import com.luna.common.text.StringTools; + +import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.sip.common.constant.Constant; +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.sip.common.entity.FromDevice; +import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; +import io.github.lunasaw.sip.common.utils.XmlUtils; +import lombok.extern.slf4j.Slf4j; + +/** + * @author luna + */ +@Slf4j +public abstract class SipSubscribeRequestProcessorAbstract extends SipRequestProcessorAbstract { + + public static final Map> SUBSCRIBE_HANDLER_CMD_MAP = new ConcurrentHashMap<>(); + + public static void addHandler(SubscribeHandler SubscribeHandler) { + if (SubscribeHandler == null) { + return; + } + + if (SUBSCRIBE_HANDLER_CMD_MAP.containsKey(SubscribeHandler.getRootType())) { + SUBSCRIBE_HANDLER_CMD_MAP.get(SubscribeHandler.getRootType()).put(SubscribeHandler.getCmdType(), SubscribeHandler); + } else { + ConcurrentMap newedConcurrentMap = Maps.newConcurrentMap(); + newedConcurrentMap.put(SubscribeHandler.getCmdType(), SubscribeHandler); + SUBSCRIBE_HANDLER_CMD_MAP.put(SubscribeHandler.getRootType(), newedConcurrentMap); + } + } + + public void doSubscribeHandForEvt(RequestEvent evt, FromDevice fromDevice) { + SIPRequest request = (SIPRequest)evt.getRequest(); + + String charset = Optional.of(fromDevice).map(Device::getCharset).orElse(Constant.UTF_8); + + // 解析xml + byte[] rawContent = request.getRawContent(); + String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); + + String cmdType = XmlUtils.getCmdType(xmlStr); + String rootType = XmlUtils.getRootType(xmlStr); + + Map SubscribeHandlerMap = SUBSCRIBE_HANDLER_CMD_MAP.get(rootType); + + if (MapUtils.isEmpty(SubscribeHandlerMap)) { + return; + } + + SubscribeHandler SubscribeHandler = SubscribeHandlerMap.get(cmdType); + if (SubscribeHandler == null) { + return; + } + try { + SubscribeHandler.setXmlStr(xmlStr); + SubscribeHandler.handForEvt(evt); + SubscribeHandler.responseAck(evt); + } catch (Exception e) { + log.error("process::evt = {}, e = {}", evt, e.getMessage()); + SubscribeHandler.responseError(evt); + } + } + +} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java index 3543e9cf..cc063419 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java @@ -6,6 +6,7 @@ import javax.sip.message.Response; import org.apache.commons.lang3.StringUtils; +import org.springframework.stereotype.Component; import com.luna.common.text.StringTools; @@ -13,13 +14,15 @@ import io.github.lunasaw.sip.common.constant.Constant; import io.github.lunasaw.sip.common.entity.base.DeviceSession; import io.github.lunasaw.sip.common.transmit.ResponseCmd; -import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.Getter; import lombok.Setter; +import lombok.extern.slf4j.Slf4j; @Getter @Setter +@Slf4j +@Component public class SubscribeHandlerAbstract implements SubscribeHandler { private String xmlStr; From 8e347ef74696f94337977a3654edb36793a4c761 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Tue, 12 Dec 2023 16:19:06 +0800 Subject: [PATCH 05/17] =?UTF-8?q?:memo:=20=E4=B8=B4=E6=97=B6=E6=8F=90?= =?UTF-8?q?=E4=BA=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../ClientSubscribeRequestProcessor.java | 8 +- .../SubscribeClientHandlerAbstract.java | 5 +- .../catalog/CatalogNotifyMessageHandler.java | 18 +- .../event/handler/RequestHandler.java | 51 ++++++ .../event/message/MessageHandler.java | 4 +- .../subscribe/RequestHandlerAbstract.java | 90 ++++++++++ .../SipSubscribeRequestProcessorAbstract.java | 156 +++++++++--------- .../event/subscribe/SubscribeHandler.java | 110 ++++++------ .../subscribe/SubscribeHandlerAbstract.java | 89 ---------- 9 files changed, 290 insertions(+), 241 deletions(-) create mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/handler/RequestHandler.java create mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/RequestHandlerAbstract.java delete mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java index 2f225a45..661a600c 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java @@ -2,14 +2,12 @@ import javax.sip.RequestEvent; -import io.github.lunasaw.sip.common.transmit.event.subscribe.SipSubscribeRequestProcessorAbstract; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; -import io.github.lunasaw.sip.common.transmit.event.subscribe.SubscribeHandlerAbstract; +import io.github.lunasaw.sip.common.transmit.event.message.SipMessageRequestProcessorAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Getter; import lombok.Setter; @@ -24,7 +22,7 @@ @Getter @Setter @Slf4j -public class ClientSubscribeRequestProcessor extends SipSubscribeRequestProcessorAbstract { +public class ClientSubscribeRequestProcessor extends SipMessageRequestProcessorAbstract { public static final String METHOD = "SUBSCRIBE"; @@ -52,7 +50,7 @@ public void process(RequestEvent evt) { return; } - doSubscribeHandForEvt(evt, fromDevice); + doMessageHandForEvt(evt, fromDevice); } diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java index a6769b41..cd1eb545 100755 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java @@ -6,9 +6,8 @@ import org.springframework.stereotype.Component; import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.transmit.event.subscribe.SubscribeHandlerAbstract; +import io.github.lunasaw.sip.common.transmit.event.message.MessageHandlerAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Data; @@ -17,7 +16,7 @@ */ @Data @Component -public abstract class SubscribeClientHandlerAbstract extends SubscribeHandlerAbstract { +public abstract class SubscribeClientHandlerAbstract extends MessageHandlerAbstract { @Autowired private SubscribeProcessorClient subscribeProcessorClient; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java index 76779570..8037b8fa 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java @@ -2,21 +2,18 @@ import javax.sip.RequestEvent; -import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; -import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeClientHandlerAbstract; -import io.github.lunasaw.sip.common.entity.query.DeviceQuery; -import io.github.lunasaw.sip.common.subscribe.SubscribeHolder; -import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; +import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeClientHandlerAbstract; import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeProcessorClient; import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.sip.common.entity.query.DeviceQuery; import io.github.lunasaw.sip.common.enums.CmdTypeEnum; +import io.github.lunasaw.sip.common.subscribe.SubscribeHolder; +import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; -import io.github.lunasaw.sip.common.transmit.event.subscribe.SubscribeHandlerAbstract; import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; @@ -33,11 +30,10 @@ @Setter public class CatalogNotifyMessageHandler extends SubscribeClientHandlerAbstract { - public static final String CMD_TYPE = CmdTypeEnum.CATALOG.getType(); - + public static final String CMD_TYPE = CmdTypeEnum.CATALOG.getType(); @Autowired - private SubscribeHolder subscribeHolder; + private SubscribeHolder subscribeHolder; public CatalogNotifyMessageHandler(SubscribeProcessorClient subscribeProcessorClient) { super(subscribeProcessorClient); diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/handler/RequestHandler.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/handler/RequestHandler.java new file mode 100644 index 00000000..80d738ae --- /dev/null +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/handler/RequestHandler.java @@ -0,0 +1,51 @@ +package io.github.lunasaw.sip.common.transmit.event.handler; + +import javax.sip.RequestEvent; + +/** + * @author weidian + * @version 1.0 + * @date 2023/12/12 + * @description: + */ +public interface RequestHandler { + /** + * 响应ack + * + * @param event 请求事件 + */ + void responseAck(RequestEvent event); + + /** + * 响应error + * + * @param event 请求事件 + */ + void responseError(RequestEvent event); + + /** + * 处理消息 + * + * @param event + */ + void handForEvt(RequestEvent event); + + /** + * 处理标签 + * + * @return + */ + String getRootType(); + + /** + * 处理消息类型 + * + * @return + */ + String getCmdType(); + + /** + * 当前接受到的原始消息 + */ + void setXmlStr(String xmlStr); +} \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandler.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandler.java index bbba5548..93660cd1 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandler.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandler.java @@ -1,11 +1,13 @@ package io.github.lunasaw.sip.common.transmit.event.message; +import io.github.lunasaw.sip.common.transmit.event.handler.RequestHandler; + import javax.sip.RequestEvent; /** * 对message类型的请求单独抽象,根据cmdType进行处理 */ -public interface MessageHandler { +public interface MessageHandler extends RequestHandler { String QUERY = "Query"; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/RequestHandlerAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/RequestHandlerAbstract.java new file mode 100644 index 00000000..87e6ea78 --- /dev/null +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/RequestHandlerAbstract.java @@ -0,0 +1,90 @@ +// package io.github.lunasaw.sip.common.transmit.event.subscribe; +// +// import java.nio.charset.Charset; +// +// import javax.sip.RequestEvent; +// import javax.sip.message.Response; +// +// import io.github.lunasaw.sip.common.transmit.event.handler.RequestHandler; +// import org.apache.commons.lang3.StringUtils; +// import org.springframework.stereotype.Component; +// +// import com.luna.common.text.StringTools; +// +// import gov.nist.javax.sip.message.SIPRequest; +// import io.github.lunasaw.sip.common.constant.Constant; +// import io.github.lunasaw.sip.common.entity.base.DeviceSession; +// import io.github.lunasaw.sip.common.transmit.ResponseCmd; +// import io.github.lunasaw.sip.common.utils.XmlUtils; +// import lombok.Getter; +// import lombok.Setter; +// import lombok.extern.slf4j.Slf4j; +// +// @Getter +// @Setter +// @Slf4j +// @Component +// public class RequestHandlerAbstract implements RequestHandler { +// +// private String xmlStr; +// +// @Override +// public void handForEvt(RequestEvent event) { +// +// } +// +// @Override +// public String getRootType() { +// return null; +// } +// +// @Override +// public String getCmdType() { +// return null; +// } +// +// @Override +// public void setXmlStr(String xmlStr) { +// this.xmlStr = xmlStr; +// } +// +// public DeviceSession getDeviceSession(RequestEvent event) { +// +// return null; +// } +// +// public void responseAck(RequestEvent event) { +// ResponseCmd.doResponseCmd(Response.OK, "OK", event); +// } +// +// public void responseError(RequestEvent event) { +// ResponseCmd.doResponseCmd(Response.SERVER_INTERNAL_ERROR, "SERVER ERROR", event); +// } +// +// public T parseXml(Class clazz) { +// if (StringUtils.isBlank(xmlStr)) { +// return null; +// } +// return (T)XmlUtils.parseObj(xmlStr, clazz); +// } +// +// public static T parseRequest(RequestEvent event, String charset, Class clazz) { +// SIPRequest sipRequest = (SIPRequest)event.getRequest(); +// byte[] rawContent = sipRequest.getRawContent(); +// if (StringUtils.isBlank(charset)) { +// charset = Constant.UTF_8; +// } +// String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); +// Object o = XmlUtils.parseObj(xmlStr, clazz); +// return (T)o; +// } +// +// public static String parseRequest(RequestEvent event, String charset) { +// SIPRequest sipRequest = (SIPRequest)event.getRequest(); +// byte[] rawContent = sipRequest.getRawContent(); +// if (StringUtils.isBlank(charset)) { +// charset = Constant.UTF_8; +// } +// return StringTools.toEncodedString(rawContent, Charset.forName(charset)); +// } +// } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java index d21e668d..94a9dc08 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java @@ -1,78 +1,78 @@ -package io.github.lunasaw.sip.common.transmit.event.subscribe; - -import java.nio.charset.Charset; -import java.util.Map; -import java.util.Optional; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; - -import javax.sip.RequestEvent; - -import org.apache.commons.collections4.MapUtils; - -import com.google.common.collect.Maps; -import com.luna.common.text.StringTools; - -import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.constant.Constant; -import io.github.lunasaw.sip.common.entity.Device; -import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; -import io.github.lunasaw.sip.common.utils.XmlUtils; -import lombok.extern.slf4j.Slf4j; - -/** - * @author luna - */ -@Slf4j -public abstract class SipSubscribeRequestProcessorAbstract extends SipRequestProcessorAbstract { - - public static final Map> SUBSCRIBE_HANDLER_CMD_MAP = new ConcurrentHashMap<>(); - - public static void addHandler(SubscribeHandler SubscribeHandler) { - if (SubscribeHandler == null) { - return; - } - - if (SUBSCRIBE_HANDLER_CMD_MAP.containsKey(SubscribeHandler.getRootType())) { - SUBSCRIBE_HANDLER_CMD_MAP.get(SubscribeHandler.getRootType()).put(SubscribeHandler.getCmdType(), SubscribeHandler); - } else { - ConcurrentMap newedConcurrentMap = Maps.newConcurrentMap(); - newedConcurrentMap.put(SubscribeHandler.getCmdType(), SubscribeHandler); - SUBSCRIBE_HANDLER_CMD_MAP.put(SubscribeHandler.getRootType(), newedConcurrentMap); - } - } - - public void doSubscribeHandForEvt(RequestEvent evt, FromDevice fromDevice) { - SIPRequest request = (SIPRequest)evt.getRequest(); - - String charset = Optional.of(fromDevice).map(Device::getCharset).orElse(Constant.UTF_8); - - // 解析xml - byte[] rawContent = request.getRawContent(); - String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); - - String cmdType = XmlUtils.getCmdType(xmlStr); - String rootType = XmlUtils.getRootType(xmlStr); - - Map SubscribeHandlerMap = SUBSCRIBE_HANDLER_CMD_MAP.get(rootType); - - if (MapUtils.isEmpty(SubscribeHandlerMap)) { - return; - } - - SubscribeHandler SubscribeHandler = SubscribeHandlerMap.get(cmdType); - if (SubscribeHandler == null) { - return; - } - try { - SubscribeHandler.setXmlStr(xmlStr); - SubscribeHandler.handForEvt(evt); - SubscribeHandler.responseAck(evt); - } catch (Exception e) { - log.error("process::evt = {}, e = {}", evt, e.getMessage()); - SubscribeHandler.responseError(evt); - } - } - -} +// package io.github.lunasaw.sip.common.transmit.event.subscribe; +// +// import java.nio.charset.Charset; +// import java.util.Map; +// import java.util.Optional; +// import java.util.concurrent.ConcurrentHashMap; +// import java.util.concurrent.ConcurrentMap; +// +// import javax.sip.RequestEvent; +// +// import org.apache.commons.collections4.MapUtils; +// +// import com.google.common.collect.Maps; +// import com.luna.common.text.StringTools; +// +// import gov.nist.javax.sip.message.SIPRequest; +// import io.github.lunasaw.sip.common.constant.Constant; +// import io.github.lunasaw.sip.common.entity.Device; +// import io.github.lunasaw.sip.common.entity.FromDevice; +// import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; +// import io.github.lunasaw.sip.common.utils.XmlUtils; +// import lombok.extern.slf4j.Slf4j; +// +/// ** +// * @author luna +// */ +// @Slf4j +// public abstract class SipSubscribeRequestProcessorAbstract extends SipRequestProcessorAbstract { +// +// public static final Map> SUBSCRIBE_HANDLER_CMD_MAP = new ConcurrentHashMap<>(); +// +// public static void addHandler(SubscribeHandler SubscribeHandler) { +// if (SubscribeHandler == null) { +// return; +// } +// +// if (SUBSCRIBE_HANDLER_CMD_MAP.containsKey(SubscribeHandler.getRootType())) { +// SUBSCRIBE_HANDLER_CMD_MAP.get(SubscribeHandler.getRootType()).put(SubscribeHandler.getCmdType(), SubscribeHandler); +// } else { +// ConcurrentMap newedConcurrentMap = Maps.newConcurrentMap(); +// newedConcurrentMap.put(SubscribeHandler.getCmdType(), SubscribeHandler); +// SUBSCRIBE_HANDLER_CMD_MAP.put(SubscribeHandler.getRootType(), newedConcurrentMap); +// } +// } +// +// public void doSubscribeHandForEvt(RequestEvent evt, FromDevice fromDevice) { +// SIPRequest request = (SIPRequest)evt.getRequest(); +// +// String charset = Optional.of(fromDevice).map(Device::getCharset).orElse(Constant.UTF_8); +// +// // 解析xml +// byte[] rawContent = request.getRawContent(); +// String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); +// +// String cmdType = XmlUtils.getCmdType(xmlStr); +// String rootType = XmlUtils.getRootType(xmlStr); +// +// Map SubscribeHandlerMap = SUBSCRIBE_HANDLER_CMD_MAP.get(rootType); +// +// if (MapUtils.isEmpty(SubscribeHandlerMap)) { +// return; +// } +// +// SubscribeHandler SubscribeHandler = SubscribeHandlerMap.get(cmdType); +// if (SubscribeHandler == null) { +// return; +// } +// try { +// SubscribeHandler.setXmlStr(xmlStr); +// SubscribeHandler.handForEvt(evt); +// SubscribeHandler.responseAck(evt); +// } catch (Exception e) { +// log.error("process::evt = {}, e = {}", evt, e.getMessage()); +// SubscribeHandler.responseError(evt); +// } +// } +// +// } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java index 4ad0d02d..1a76d97c 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java @@ -1,54 +1,56 @@ -package io.github.lunasaw.sip.common.transmit.event.subscribe; - -import javax.sip.RequestEvent; - -/** - * 对Subscribe类型的请求单独抽象,根据cmdType进行处理 - */ -public interface SubscribeHandler { - - String QUERY = "Query"; - String CONTROL = "Control"; - String NOTIFY = "Notify"; - String RESPONSE = "Response"; - - /** - * 响应ack - * - * @param event 请求事件 - */ - void responseAck(RequestEvent event); - - /** - * 响应error - * - * @param event 请求事件 - */ - void responseError(RequestEvent event); - - /** - * 处理消息 - * - * @param event - */ - void handForEvt(RequestEvent event); - - /** - * 处理标签 - * - * @return - */ - String getRootType(); - - /** - * 处理消息类型 - * - * @return - */ - String getCmdType(); - - /** - * 当前接受到的原始消息 - */ - void setXmlStr(String xmlStr); -} +// package io.github.lunasaw.sip.common.transmit.event.subscribe; +// +// import io.github.lunasaw.sip.common.transmit.event.handler.RequestHandler; +// +// import javax.sip.RequestEvent; +// +/// ** +// * 对Subscribe类型的请求单独抽象,根据cmdType进行处理 +// */ +// public interface SubscribeHandler extends RequestHandler { +// +// String QUERY = "Query"; +// String CONTROL = "Control"; +// String NOTIFY = "Notify"; +// String RESPONSE = "Response"; +// +// /** +// * 响应ack +// * +// * @param event 请求事件 +// */ +// void responseAck(RequestEvent event); +// +// /** +// * 响应error +// * +// * @param event 请求事件 +// */ +// void responseError(RequestEvent event); +// +// /** +// * 处理消息 +// * +// * @param event +// */ +// void handForEvt(RequestEvent event); +// +// /** +// * 处理标签 +// * +// * @return +// */ +// String getRootType(); +// +// /** +// * 处理消息类型 +// * +// * @return +// */ +// String getCmdType(); +// +// /** +// * 当前接受到的原始消息 +// */ +// void setXmlStr(String xmlStr); +// } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java deleted file mode 100644 index cc063419..00000000 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandlerAbstract.java +++ /dev/null @@ -1,89 +0,0 @@ -package io.github.lunasaw.sip.common.transmit.event.subscribe; - -import java.nio.charset.Charset; - -import javax.sip.RequestEvent; -import javax.sip.message.Response; - -import org.apache.commons.lang3.StringUtils; -import org.springframework.stereotype.Component; - -import com.luna.common.text.StringTools; - -import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.constant.Constant; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.transmit.ResponseCmd; -import io.github.lunasaw.sip.common.utils.XmlUtils; -import lombok.Getter; -import lombok.Setter; -import lombok.extern.slf4j.Slf4j; - -@Getter -@Setter -@Slf4j -@Component -public class SubscribeHandlerAbstract implements SubscribeHandler { - - private String xmlStr; - - @Override - public void handForEvt(RequestEvent event) { - - } - - @Override - public String getRootType() { - return null; - } - - @Override - public String getCmdType() { - return null; - } - - @Override - public void setXmlStr(String xmlStr) { - this.xmlStr = xmlStr; - } - - public DeviceSession getDeviceSession(RequestEvent event) { - - return null; - } - - public void responseAck(RequestEvent event) { - ResponseCmd.doResponseCmd(Response.OK, "OK", event); - } - - public void responseError(RequestEvent event) { - ResponseCmd.doResponseCmd(Response.SERVER_INTERNAL_ERROR, "SERVER ERROR", event); - } - - public T parseXml(Class clazz) { - if (StringUtils.isBlank(xmlStr)) { - return null; - } - return (T)XmlUtils.parseObj(xmlStr, clazz); - } - - public static T parseRequest(RequestEvent event, String charset, Class clazz) { - SIPRequest sipRequest = (SIPRequest)event.getRequest(); - byte[] rawContent = sipRequest.getRawContent(); - if (StringUtils.isBlank(charset)) { - charset = Constant.UTF_8; - } - String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); - Object o = XmlUtils.parseObj(xmlStr, clazz); - return (T)o; - } - - public static String parseRequest(RequestEvent event, String charset) { - SIPRequest sipRequest = (SIPRequest)event.getRequest(); - byte[] rawContent = sipRequest.getRawContent(); - if (StringUtils.isBlank(charset)) { - charset = Constant.UTF_8; - } - return StringTools.toEncodedString(rawContent, Charset.forName(charset)); - } -} From 5aacb7d4aeaf7e47ec8824435e610b24d9e37507 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Tue, 12 Dec 2023 16:32:46 +0800 Subject: [PATCH 06/17] =?UTF-8?q?:memo:=20=E4=B8=B4=E6=97=B6=E6=8F=90?= =?UTF-8?q?=E4=BA=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...ssageHandler.java => CatalogQueryMessageHandler.java} | 7 ++++--- .../gbproxy/server/transimit/cmd/ServerSendCmd.java | 9 ++++++++- .../gbproxy/test/subscribe/SubscribeServerTest.java | 5 ++++- 3 files changed, 16 insertions(+), 5 deletions(-) rename gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/{CatalogNotifyMessageHandler.java => CatalogQueryMessageHandler.java} (89%) diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java similarity index 89% rename from gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java rename to gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java index 8037b8fa..1049c103 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogNotifyMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java @@ -28,20 +28,20 @@ @Slf4j @Getter @Setter -public class CatalogNotifyMessageHandler extends SubscribeClientHandlerAbstract { +public class CatalogQueryMessageHandler extends SubscribeClientHandlerAbstract { public static final String CMD_TYPE = CmdTypeEnum.CATALOG.getType(); @Autowired private SubscribeHolder subscribeHolder; - public CatalogNotifyMessageHandler(SubscribeProcessorClient subscribeProcessorClient) { + public CatalogQueryMessageHandler(SubscribeProcessorClient subscribeProcessorClient) { super(subscribeProcessorClient); } @Override public String getRootType() { - return MessageHandler.NOTIFY; + return MessageHandler.QUERY; } @Override @@ -62,4 +62,5 @@ public void handForEvt(RequestEvent event) { public String getCmdType() { return CMD_TYPE; } + } diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java index c29ad2cf..26af86c0 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java @@ -7,6 +7,7 @@ import io.github.lunasaw.gbproxy.server.entity.InviteEntity; import io.github.lunasaw.gbproxy.server.enums.PlayActionEnums; +import org.apache.commons.lang3.StringUtils; import org.springframework.util.Assert; import com.luna.common.date.DateUtils; @@ -166,6 +167,10 @@ public static String deviceRecordInfoQuery(FromDevice fromDevice, ToDevice toDev return deviceRecordInfoQuery(fromDevice, toDevice, startTimeStr, endTimeStr, secrecy, type); } + public static String deviceCatalogSubscribe(FromDevice fromDevice, ToDevice toDevice, + Integer expires, String eventType) { + return deviceCatalogSubscribe(fromDevice, toDevice, expires, eventType, RandomStrUtil.getUUID()); + } /** * 会话订阅 * @@ -180,7 +185,9 @@ public static String deviceCatalogSubscribe(FromDevice fromDevice, ToDevice toDe DeviceQuery recordQuery = new DeviceQuery(CmdTypeEnum.CATALOG.getType(), RandomStrUtil.getValidationCode(), toDevice.getUserId()); SubscribeInfo subscribeInfo = new SubscribeInfo(); - subscribeInfo.setEventId(eventId); + if (StringUtils.isEmpty(eventId)) { + subscribeInfo.setEventId(RandomStrUtil.getUUID()); + } subscribeInfo.setEventType(eventType); subscribeInfo.setExpires(expires); diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java index 98411e0c..ac5ccd59 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java @@ -2,6 +2,8 @@ import java.util.Date; +import com.luna.common.text.RandomStrUtil; +import io.github.lunasaw.sip.common.enums.CmdTypeEnum; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; @@ -64,7 +66,8 @@ public void test_subscribe() { return; } String invitePlay = - ServerSendCmd.deviceCatalogSubscribe((FromDevice)fromDevice, (ToDevice)device, 30, "", "2023-11-29 00:00:00"); + ServerSendCmd.deviceCatalogSubscribe((FromDevice)fromDevice, (ToDevice)device, 30, CmdTypeEnum.CATALOG.getType(), + RandomStrUtil.getUUID()); System.out.println(invitePlay); }, 30 * 1000); } From e10489412db09686f9cb4ac8063c849d5b8d7897 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Tue, 12 Dec 2023 16:38:48 +0800 Subject: [PATCH 07/17] =?UTF-8?q?:memo:=20=E4=B8=B4=E6=97=B6=E6=8F=90?= =?UTF-8?q?=E4=BA=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../event/message/SipMessageRequestProcessorAbstract.java | 2 +- .../sip/common/transmit/request/SipRequestProvider.java | 4 +++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java index 7890b980..ba49caab 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java @@ -68,7 +68,7 @@ public void doMessageHandForEvt(RequestEvent evt, FromDevice fromDevice) { messageHandler.handForEvt(evt); messageHandler.responseAck(evt); } catch (Exception e) { - log.error("process::evt = {}, e = {}", evt, e.getMessage()); + log.error("process::evt = {}, e", evt, e); messageHandler.responseError(evt); } } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/request/SipRequestProvider.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/request/SipRequestProvider.java index 960b49c6..997413f4 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/request/SipRequestProvider.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/request/SipRequestProvider.java @@ -303,6 +303,7 @@ public static Request createRegisterRequestWithAuth(FromDevice fromDevice, ToDev * @return Request */ public static Request createSubscribeRequest(FromDevice fromDevice, ToDevice toDevice, String content, SubscribeInfo subscribeInfo, String callId) { + Assert.notNull(subscribeInfo, "subscribeInfo is null"); SipMessage sipMessage = SipMessage.getSubscribeBody(); sipMessage.setMethod(Request.SUBSCRIBE); sipMessage.setContent(content); @@ -310,8 +311,9 @@ public static Request createSubscribeRequest(FromDevice fromDevice, ToDevice toD UserAgentHeader userAgentHeader = SipRequestUtils.createUserAgentHeader(fromDevice.getAgent()); ContactHeader contactHeader = SipRequestUtils.createContactHeader(fromDevice.getUserId(), fromDevice.getHostAddress()); + EventHeader eventHeader = SipRequestUtils.createEventHeader(subscribeInfo.getEventType(), subscribeInfo.getEventId()); - sipMessage.addHeader(userAgentHeader).addHeader(contactHeader); + sipMessage.addHeader(userAgentHeader).addHeader(contactHeader).addHeader(eventHeader); return createSipRequest(fromDevice, toDevice, sipMessage, subscribeInfo); } From 98f74eeeff964e0cfc7aba0561cbab3491b6d46d Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Tue, 12 Dec 2023 17:45:46 +0800 Subject: [PATCH 08/17] =?UTF-8?q?:memo:=20=E8=AE=A2=E9=98=85=E6=B6=88?= =?UTF-8?q?=E6=81=AF=E5=A4=84=E7=90=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../notify/BroadcastNotifyMessageHandler.java | 3 + .../SubscribeClientHandlerAbstract.java | 2 +- .../subscribe/SubscribeProcessorClient.java | 6 ++ .../catalog/CatalogQueryMessageHandler.java | 24 +++-- .../server/transimit/cmd/ServerSendCmd.java | 6 +- .../DefaultSubscribeProcessorClient.java | 29 +++++- .../src/main/resources/log/logback.xml | 4 +- .../test/subscribe/SubscribeServerTest.java | 4 +- .../sip/common/subscribe/SubscribeHolder.java | 6 +- .../common/transmit/SipProcessorObserver.java | 31 ++++--- .../event/handler/RequestHandler.java | 40 --------- .../event/message/MessageHandler.java | 18 ++++ .../event/message/MessageHandlerAbstract.java | 17 ++-- .../SipMessageRequestProcessorAbstract.java | 28 +++--- .../subscribe/RequestHandlerAbstract.java | 90 ------------------- .../SipSubscribeRequestProcessorAbstract.java | 78 ---------------- .../event/subscribe/SubscribeHandler.java | 56 ------------ 17 files changed, 125 insertions(+), 317 deletions(-) delete mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/RequestHandlerAbstract.java delete mode 100644 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java delete mode 100755 sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/notify/BroadcastNotifyMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/notify/BroadcastNotifyMessageHandler.java index 4d951f11..68e5d5f2 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/notify/BroadcastNotifyMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/notify/BroadcastNotifyMessageHandler.java @@ -43,6 +43,9 @@ public void handForEvt(RequestEvent event) { // 设备查询 FromDevice fromDevice = (FromDevice) messageProcessorClient.getFromDevice(); + if (fromDevice == null || !fromDevice.getUserId().equals(userId)) { + throw new RuntimeException("查询设备失败"); + } DeviceBroadcastNotify broadcastNotify = parseXml(DeviceBroadcastNotify.class); diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java index cd1eb545..4c66ad9e 100755 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java @@ -19,7 +19,7 @@ public abstract class SubscribeClientHandlerAbstract extends MessageHandlerAbstract { @Autowired - private SubscribeProcessorClient subscribeProcessorClient; + public SubscribeProcessorClient subscribeProcessorClient; public SubscribeClientHandlerAbstract(SubscribeProcessorClient subscribeProcessorClient) { this.subscribeProcessorClient = subscribeProcessorClient; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java index 78844baa..36865edd 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java @@ -1,6 +1,9 @@ package io.github.lunasaw.gbproxy.client.transmit.request.subscribe; +import io.github.lunasaw.sip.common.entity.query.DeviceQuery; +import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; import io.github.lunasaw.sip.common.service.SipUserGenerate; +import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; /** * @author luna @@ -10,4 +13,7 @@ */ public interface SubscribeProcessorClient extends SipUserGenerate { + void putSubscribe(String userId, SubscribeInfo subscribeInfo); + + DeviceSubscribe getDeviceSubscribe(DeviceQuery deviceQuery); } diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java index 1049c103..99dc94a3 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java @@ -1,7 +1,13 @@ package io.github.lunasaw.gbproxy.client.transmit.request.subscribe.catalog; import javax.sip.RequestEvent; +import javax.sip.header.ExpiresHeader; +import javax.sip.message.Response; +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.sip.common.transmit.ResponseCmd; +import io.github.lunasaw.sip.common.utils.SipRequestUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @@ -32,9 +38,6 @@ public class CatalogQueryMessageHandler extends SubscribeClientHandlerAbstract { public static final String CMD_TYPE = CmdTypeEnum.CATALOG.getType(); - @Autowired - private SubscribeHolder subscribeHolder; - public CatalogQueryMessageHandler(SubscribeProcessorClient subscribeProcessorClient) { super(subscribeProcessorClient); } @@ -49,13 +52,20 @@ public void handForEvt(RequestEvent event) { DeviceSession deviceSession = getDeviceSession(event); // 订阅消息过来 String sipId = deviceSession.getSipId(); + String userId = deviceSession.getUserId(); SIPRequest request = (SIPRequest)event.getRequest(); SubscribeInfo subscribeInfo = new SubscribeInfo(request, sipId); - subscribeHolder.putCatalogSubscribe(sipId, subscribeInfo); + Device fromDevice = subscribeProcessorClient.getFromDevice(); + if (!userId.equals(fromDevice.getUserId())) { + return; + } DeviceQuery deviceQuery = parseXml(DeviceQuery.class); + subscribeProcessorClient.putSubscribe(deviceQuery.getDeviceId(), subscribeInfo); - // 放入本地Map 回复成功 + DeviceSubscribe deviceSubscribe = subscribeProcessorClient.getDeviceSubscribe(deviceQuery); + ExpiresHeader expiresHeader = SipRequestUtils.createExpiresHeader(subscribeInfo.getExpires()); + ResponseCmd.doResponseCmd(Response.OK, deviceSubscribe.toString(), event, expiresHeader); } @Override @@ -63,4 +73,8 @@ public String getCmdType() { return CMD_TYPE; } + @Override + public boolean needResponseAck() { + return false; + } } diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java index 26af86c0..e5accbb3 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java @@ -169,7 +169,7 @@ public static String deviceRecordInfoQuery(FromDevice fromDevice, ToDevice toDev public static String deviceCatalogSubscribe(FromDevice fromDevice, ToDevice toDevice, Integer expires, String eventType) { - return deviceCatalogSubscribe(fromDevice, toDevice, expires, eventType, RandomStrUtil.getUUID()); + return deviceCatalogSubscribe(fromDevice, toDevice, expires, eventType, RandomStrUtil.generateNonceStr()); } /** * 会话订阅 @@ -185,9 +185,7 @@ public static String deviceCatalogSubscribe(FromDevice fromDevice, ToDevice toDe DeviceQuery recordQuery = new DeviceQuery(CmdTypeEnum.CATALOG.getType(), RandomStrUtil.getValidationCode(), toDevice.getUserId()); SubscribeInfo subscribeInfo = new SubscribeInfo(); - if (StringUtils.isEmpty(eventId)) { - subscribeInfo.setEventId(RandomStrUtil.getUUID()); - } + subscribeInfo.setEventId(eventId); subscribeInfo.setEventType(eventType); subscribeInfo.setExpires(expires); diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java index c51dbfe4..da405034 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java @@ -1,12 +1,18 @@ package io.github.lunasaw.gbproxy.test.user.client; -import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeProcessorClient; -import io.github.lunasaw.gbproxy.test.config.DeviceConfig; -import io.github.lunasaw.sip.common.entity.Device; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; +import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeProcessorClient; +import io.github.lunasaw.gbproxy.test.config.DeviceConfig; +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.sip.common.entity.query.DeviceQuery; +import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.sip.common.enums.CmdTypeEnum; +import io.github.lunasaw.sip.common.subscribe.SubscribeHolder; +import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; + /** * @author weidian * @version 1.0 @@ -20,6 +26,9 @@ public class DefaultSubscribeProcessorClient implements SubscribeProcessorClient @Qualifier("clientFrom") private Device fromDevice; + @Autowired + private SubscribeHolder subscribeHolder; + @Override public Device getToDevice(String userId) { return DeviceConfig.DEVICE_CLIENT_VIEW_MAP.get(userId); @@ -29,4 +38,18 @@ public Device getToDevice(String userId) { public Device getFromDevice() { return fromDevice; } + + @Override + public void putSubscribe(String userId, SubscribeInfo subscribeInfo) { + subscribeHolder.putCatalogSubscribe(userId, subscribeInfo); + } + + @Override + public DeviceSubscribe getDeviceSubscribe(DeviceQuery deviceQuery) { + DeviceSubscribe deviceSubscribe = new DeviceSubscribe(); + deviceSubscribe.setDeviceId(deviceQuery.getDeviceId()); + deviceSubscribe.setCmdType(CmdTypeEnum.CATALOG.getType()); + deviceSubscribe.setSn(deviceQuery.getSn()); + return deviceSubscribe; + } } diff --git a/gb28181-test/src/main/resources/log/logback.xml b/gb28181-test/src/main/resources/log/logback.xml index 41e51870..81ac9907 100644 --- a/gb28181-test/src/main/resources/log/logback.xml +++ b/gb28181-test/src/main/resources/log/logback.xml @@ -4,8 +4,10 @@ + + value="%clr(%d{yyyy-MM-dd HH:mm:ss.SSS,GMT+8}){faint} %clr(%5p) %clr(---){faint} %clr(%-1.30logger{0}){cyan} %clr(:){faint} %X{traceId} %X{deviceId} %clr(%t){magenta} %m%n%wEx"/> + diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java index ac5ccd59..97d485f3 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java @@ -66,9 +66,7 @@ public void test_subscribe() { return; } String invitePlay = - ServerSendCmd.deviceCatalogSubscribe((FromDevice)fromDevice, (ToDevice)device, 30, CmdTypeEnum.CATALOG.getType(), - RandomStrUtil.getUUID()); - System.out.println(invitePlay); + ServerSendCmd.deviceCatalogSubscribe((FromDevice)fromDevice, (ToDevice)device, 30, CmdTypeEnum.CATALOG.getType()); }, 30 * 1000); } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/subscribe/SubscribeHolder.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/subscribe/SubscribeHolder.java index ee9b16a1..2357edc7 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/subscribe/SubscribeHolder.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/subscribe/SubscribeHolder.java @@ -35,10 +35,10 @@ public SubscribeInfo getCatalogSubscribe(String platformId) { return catalogMap.get(platformId); } - public void removeCatalogSubscribe(String platformId) { + public void removeCatalogSubscribe(String sipId) { - catalogMap.remove(platformId); - String taskOverdueKey = taskOverduePrefix + "catalog_" + platformId; + catalogMap.remove(sipId); + String taskOverdueKey = taskOverduePrefix + "catalog_" + sipId; Runnable runnable = dynamicTask.get(taskOverdueKey); if (runnable instanceof SubscribeTask) { SubscribeTask subscribeTask = (SubscribeTask) runnable; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java index 0f32efc3..2756b2c5 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java @@ -88,23 +88,22 @@ public synchronized static void addTimeoutProcessor(String method, ITimeoutProce * @param requestEvent RequestEvent事件 */ @Override + @Async("sipTaskExecutor") public void processRequest(RequestEvent requestEvent) { - AsyncEngineUtils.execute(() -> { - String method = requestEvent.getRequest().getMethod(); - List sipRequestProcessors = REQUEST_PROCESSOR_MAP.get(method); - if (CollectionUtils.isEmpty(sipRequestProcessors)) { - log.warn("暂不支持方法 {} 的请求", method); - // TODO 回复错误玛 - return; - } - try { - for (SipRequestProcessor sipRequestProcessor : sipRequestProcessors) { - sipRequestProcessor.process(requestEvent); - } - } catch (Exception e) { - log.error("processRequest::requestEvent = {} ", requestEvent, e); + String method = requestEvent.getRequest().getMethod(); + List sipRequestProcessors = REQUEST_PROCESSOR_MAP.get(method); + if (CollectionUtils.isEmpty(sipRequestProcessors)) { + log.warn("暂不支持方法 {} 的请求", method); + // TODO 回复错误玛 + return; + } + try { + for (SipRequestProcessor sipRequestProcessor : sipRequestProcessors) { + sipRequestProcessor.process(requestEvent); } - }); + } catch (Exception e) { + log.error("processRequest::requestEvent = {} ", requestEvent, e); + } } /** @@ -113,7 +112,7 @@ public void processRequest(RequestEvent requestEvent) { * @param responseEvent responseEvent事件 */ @Override - @Async("sipTaskExecutor") + // @Async("sipTaskExecutor") public void processResponse(ResponseEvent responseEvent) { Response response = responseEvent.getResponse(); int status = response.getStatusCode(); diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/handler/RequestHandler.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/handler/RequestHandler.java index 80d738ae..834b9ce5 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/handler/RequestHandler.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/handler/RequestHandler.java @@ -1,7 +1,5 @@ package io.github.lunasaw.sip.common.transmit.event.handler; -import javax.sip.RequestEvent; - /** * @author weidian * @version 1.0 @@ -9,43 +7,5 @@ * @description: */ public interface RequestHandler { - /** - * 响应ack - * - * @param event 请求事件 - */ - void responseAck(RequestEvent event); - - /** - * 响应error - * - * @param event 请求事件 - */ - void responseError(RequestEvent event); - - /** - * 处理消息 - * - * @param event - */ - void handForEvt(RequestEvent event); - - /** - * 处理标签 - * - * @return - */ - String getRootType(); - - /** - * 处理消息类型 - * - * @return - */ - String getCmdType(); - /** - * 当前接受到的原始消息 - */ - void setXmlStr(String xmlStr); } \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandler.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandler.java index 93660cd1..dc13b044 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandler.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandler.java @@ -29,6 +29,15 @@ public interface MessageHandler extends RequestHandler { */ void responseError(RequestEvent event); + /** + * 自定义错误回复 + * + * @param event + * @param code + * @param error + */ + void responseError(RequestEvent event, Integer code, String error); + /** * 处理消息 * @@ -54,4 +63,13 @@ public interface MessageHandler extends RequestHandler { * 当前接受到的原始消息 */ void setXmlStr(String xmlStr); + + /** + * 是否需要响应ack + * + * @return + */ + default boolean needResponseAck() { + return true; + }; } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandlerAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandlerAbstract.java index 7b5cf789..e446fe75 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandlerAbstract.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandlerAbstract.java @@ -1,6 +1,14 @@ package io.github.lunasaw.sip.common.transmit.event.message; +import java.nio.charset.Charset; + +import javax.sip.RequestEvent; +import javax.sip.message.Response; + +import org.apache.commons.lang3.StringUtils; + import com.luna.common.text.StringTools; + import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.sip.common.constant.Constant; import io.github.lunasaw.sip.common.entity.base.DeviceSession; @@ -8,11 +16,6 @@ import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.Getter; import lombok.Setter; -import org.apache.commons.lang3.StringUtils; - -import javax.sip.RequestEvent; -import javax.sip.message.Response; -import java.nio.charset.Charset; @Getter @Setter @@ -54,6 +57,10 @@ public void responseError(RequestEvent event) { ResponseCmd.doResponseCmd(Response.SERVER_INTERNAL_ERROR, "SERVER ERROR", event); } + public void responseError(RequestEvent event, Integer code, String error) { + ResponseCmd.doResponseCmd(code, error, event); + } + public T parseXml(Class clazz) { if (StringUtils.isBlank(xmlStr)) { return null; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java index ba49caab..77eb8275 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/SipMessageRequestProcessorAbstract.java @@ -1,24 +1,26 @@ package io.github.lunasaw.sip.common.transmit.event.message; +import java.nio.charset.Charset; +import java.util.Map; +import java.util.Optional; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; + +import javax.sip.RequestEvent; +import javax.sip.message.Response; + +import org.apache.commons.collections4.MapUtils; + import com.google.common.collect.Maps; import com.luna.common.text.StringTools; + import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.sip.common.constant.Constant; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; -import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.extern.slf4j.Slf4j; -import org.apache.commons.collections4.MapUtils; - -import javax.sip.RequestEvent; -import java.nio.charset.Charset; -import java.util.Map; -import java.util.Optional; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; /** * @author luna @@ -66,10 +68,12 @@ public void doMessageHandForEvt(RequestEvent evt, FromDevice fromDevice) { try { messageHandler.setXmlStr(xmlStr); messageHandler.handForEvt(evt); - messageHandler.responseAck(evt); + if (messageHandler.needResponseAck()) { + messageHandler.responseAck(evt); + } } catch (Exception e) { log.error("process::evt = {}, e", evt, e); - messageHandler.responseError(evt); + messageHandler.responseError(evt, Response.SERVER_INTERNAL_ERROR, e.getMessage()); } } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/RequestHandlerAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/RequestHandlerAbstract.java deleted file mode 100644 index 87e6ea78..00000000 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/RequestHandlerAbstract.java +++ /dev/null @@ -1,90 +0,0 @@ -// package io.github.lunasaw.sip.common.transmit.event.subscribe; -// -// import java.nio.charset.Charset; -// -// import javax.sip.RequestEvent; -// import javax.sip.message.Response; -// -// import io.github.lunasaw.sip.common.transmit.event.handler.RequestHandler; -// import org.apache.commons.lang3.StringUtils; -// import org.springframework.stereotype.Component; -// -// import com.luna.common.text.StringTools; -// -// import gov.nist.javax.sip.message.SIPRequest; -// import io.github.lunasaw.sip.common.constant.Constant; -// import io.github.lunasaw.sip.common.entity.base.DeviceSession; -// import io.github.lunasaw.sip.common.transmit.ResponseCmd; -// import io.github.lunasaw.sip.common.utils.XmlUtils; -// import lombok.Getter; -// import lombok.Setter; -// import lombok.extern.slf4j.Slf4j; -// -// @Getter -// @Setter -// @Slf4j -// @Component -// public class RequestHandlerAbstract implements RequestHandler { -// -// private String xmlStr; -// -// @Override -// public void handForEvt(RequestEvent event) { -// -// } -// -// @Override -// public String getRootType() { -// return null; -// } -// -// @Override -// public String getCmdType() { -// return null; -// } -// -// @Override -// public void setXmlStr(String xmlStr) { -// this.xmlStr = xmlStr; -// } -// -// public DeviceSession getDeviceSession(RequestEvent event) { -// -// return null; -// } -// -// public void responseAck(RequestEvent event) { -// ResponseCmd.doResponseCmd(Response.OK, "OK", event); -// } -// -// public void responseError(RequestEvent event) { -// ResponseCmd.doResponseCmd(Response.SERVER_INTERNAL_ERROR, "SERVER ERROR", event); -// } -// -// public T parseXml(Class clazz) { -// if (StringUtils.isBlank(xmlStr)) { -// return null; -// } -// return (T)XmlUtils.parseObj(xmlStr, clazz); -// } -// -// public static T parseRequest(RequestEvent event, String charset, Class clazz) { -// SIPRequest sipRequest = (SIPRequest)event.getRequest(); -// byte[] rawContent = sipRequest.getRawContent(); -// if (StringUtils.isBlank(charset)) { -// charset = Constant.UTF_8; -// } -// String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); -// Object o = XmlUtils.parseObj(xmlStr, clazz); -// return (T)o; -// } -// -// public static String parseRequest(RequestEvent event, String charset) { -// SIPRequest sipRequest = (SIPRequest)event.getRequest(); -// byte[] rawContent = sipRequest.getRawContent(); -// if (StringUtils.isBlank(charset)) { -// charset = Constant.UTF_8; -// } -// return StringTools.toEncodedString(rawContent, Charset.forName(charset)); -// } -// } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java deleted file mode 100644 index 94a9dc08..00000000 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SipSubscribeRequestProcessorAbstract.java +++ /dev/null @@ -1,78 +0,0 @@ -// package io.github.lunasaw.sip.common.transmit.event.subscribe; -// -// import java.nio.charset.Charset; -// import java.util.Map; -// import java.util.Optional; -// import java.util.concurrent.ConcurrentHashMap; -// import java.util.concurrent.ConcurrentMap; -// -// import javax.sip.RequestEvent; -// -// import org.apache.commons.collections4.MapUtils; -// -// import com.google.common.collect.Maps; -// import com.luna.common.text.StringTools; -// -// import gov.nist.javax.sip.message.SIPRequest; -// import io.github.lunasaw.sip.common.constant.Constant; -// import io.github.lunasaw.sip.common.entity.Device; -// import io.github.lunasaw.sip.common.entity.FromDevice; -// import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; -// import io.github.lunasaw.sip.common.utils.XmlUtils; -// import lombok.extern.slf4j.Slf4j; -// -/// ** -// * @author luna -// */ -// @Slf4j -// public abstract class SipSubscribeRequestProcessorAbstract extends SipRequestProcessorAbstract { -// -// public static final Map> SUBSCRIBE_HANDLER_CMD_MAP = new ConcurrentHashMap<>(); -// -// public static void addHandler(SubscribeHandler SubscribeHandler) { -// if (SubscribeHandler == null) { -// return; -// } -// -// if (SUBSCRIBE_HANDLER_CMD_MAP.containsKey(SubscribeHandler.getRootType())) { -// SUBSCRIBE_HANDLER_CMD_MAP.get(SubscribeHandler.getRootType()).put(SubscribeHandler.getCmdType(), SubscribeHandler); -// } else { -// ConcurrentMap newedConcurrentMap = Maps.newConcurrentMap(); -// newedConcurrentMap.put(SubscribeHandler.getCmdType(), SubscribeHandler); -// SUBSCRIBE_HANDLER_CMD_MAP.put(SubscribeHandler.getRootType(), newedConcurrentMap); -// } -// } -// -// public void doSubscribeHandForEvt(RequestEvent evt, FromDevice fromDevice) { -// SIPRequest request = (SIPRequest)evt.getRequest(); -// -// String charset = Optional.of(fromDevice).map(Device::getCharset).orElse(Constant.UTF_8); -// -// // 解析xml -// byte[] rawContent = request.getRawContent(); -// String xmlStr = StringTools.toEncodedString(rawContent, Charset.forName(charset)); -// -// String cmdType = XmlUtils.getCmdType(xmlStr); -// String rootType = XmlUtils.getRootType(xmlStr); -// -// Map SubscribeHandlerMap = SUBSCRIBE_HANDLER_CMD_MAP.get(rootType); -// -// if (MapUtils.isEmpty(SubscribeHandlerMap)) { -// return; -// } -// -// SubscribeHandler SubscribeHandler = SubscribeHandlerMap.get(cmdType); -// if (SubscribeHandler == null) { -// return; -// } -// try { -// SubscribeHandler.setXmlStr(xmlStr); -// SubscribeHandler.handForEvt(evt); -// SubscribeHandler.responseAck(evt); -// } catch (Exception e) { -// log.error("process::evt = {}, e = {}", evt, e.getMessage()); -// SubscribeHandler.responseError(evt); -// } -// } -// -// } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java deleted file mode 100755 index 1a76d97c..00000000 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/subscribe/SubscribeHandler.java +++ /dev/null @@ -1,56 +0,0 @@ -// package io.github.lunasaw.sip.common.transmit.event.subscribe; -// -// import io.github.lunasaw.sip.common.transmit.event.handler.RequestHandler; -// -// import javax.sip.RequestEvent; -// -/// ** -// * 对Subscribe类型的请求单独抽象,根据cmdType进行处理 -// */ -// public interface SubscribeHandler extends RequestHandler { -// -// String QUERY = "Query"; -// String CONTROL = "Control"; -// String NOTIFY = "Notify"; -// String RESPONSE = "Response"; -// -// /** -// * 响应ack -// * -// * @param event 请求事件 -// */ -// void responseAck(RequestEvent event); -// -// /** -// * 响应error -// * -// * @param event 请求事件 -// */ -// void responseError(RequestEvent event); -// -// /** -// * 处理消息 -// * -// * @param event -// */ -// void handForEvt(RequestEvent event); -// -// /** -// * 处理标签 -// * -// * @return -// */ -// String getRootType(); -// -// /** -// * 处理消息类型 -// * -// * @return -// */ -// String getCmdType(); -// -// /** -// * 当前接受到的原始消息 -// */ -// void setXmlStr(String xmlStr); -// } From 996e46772a2e1fd5b0a4ea683b0b170f1f28c83c Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Tue, 12 Dec 2023 17:56:25 +0800 Subject: [PATCH 09/17] =?UTF-8?q?:memo:=20=E8=AE=A2=E9=98=85=E6=B6=88?= =?UTF-8?q?=E6=81=AF=E5=A4=84=E7=90=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../subscribe/catalog/CatalogQueryMessageHandler.java | 6 +++++- .../server/DefaultSubscribeResponseProcessorServer.java | 3 ++- .../io/github/lunasaw/sip/common/transmit/ResponseCmd.java | 3 +++ 3 files changed, 10 insertions(+), 2 deletions(-) diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java index 99dc94a3..cd73acd3 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java @@ -1,11 +1,13 @@ package io.github.lunasaw.gbproxy.client.transmit.request.subscribe.catalog; import javax.sip.RequestEvent; +import javax.sip.header.ContentTypeHeader; import javax.sip.header.ExpiresHeader; import javax.sip.message.Response; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.sip.common.enums.ContentTypeEnum; import io.github.lunasaw.sip.common.transmit.ResponseCmd; import io.github.lunasaw.sip.common.utils.SipRequestUtils; import org.springframework.beans.factory.annotation.Autowired; @@ -65,7 +67,9 @@ public void handForEvt(RequestEvent event) { DeviceSubscribe deviceSubscribe = subscribeProcessorClient.getDeviceSubscribe(deviceQuery); ExpiresHeader expiresHeader = SipRequestUtils.createExpiresHeader(subscribeInfo.getExpires()); - ResponseCmd.doResponseCmd(Response.OK, deviceSubscribe.toString(), event, expiresHeader); + + ContentTypeHeader contentTypeHeader = ContentTypeEnum.APPLICATION_XML.getContentTypeHeader(); + ResponseCmd.doResponseCmd(Response.OK, deviceSubscribe.toString(), contentTypeHeader, event, expiresHeader); } @Override diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java index 7b16209f..f6257913 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java @@ -1,5 +1,6 @@ package io.github.lunasaw.gbproxy.test.user.server; +import com.alibaba.fastjson2.JSON; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; @@ -26,7 +27,7 @@ public class DefaultSubscribeResponseProcessorServer implements SubscribeRespons @Override public void subscribeResult(DeviceSubscribe deviceSubscribe) { - log.error("收到订阅消息响应 subscribeResult::deviceSubscribe = {} ", deviceSubscribe); + log.error("收到订阅消息响应 subscribeResult::deviceSubscribe = {} ", JSON.toJSONString(deviceSubscribe)); } @Override diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/ResponseCmd.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/ResponseCmd.java index eee9a952..f7da98e6 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/ResponseCmd.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/ResponseCmd.java @@ -55,6 +55,9 @@ public static void doResponseCmd(int statusCode, String phrase, RequestEvent eve doResponseCmd(statusCode, phrase, null, null, event, headers); } + public static void doResponseCmd(int statusCode, String content, ContentTypeHeader contentTypeHeader, RequestEvent event, Header... headers) { + doResponseCmd(statusCode, null, content, contentTypeHeader, event, Arrays.asList(headers)); + } public static void doResponseCmd(int statusCode, String phrase, String content, ContentTypeHeader contentTypeHeader, RequestEvent event, List
headers) { From c76b3b98522d5f7c59704123660e344deb886eb9 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Tue, 12 Dec 2023 19:20:09 +0800 Subject: [PATCH 10/17] =?UTF-8?q?:memo:=20=E8=AE=A2=E9=98=85=E6=B6=88?= =?UTF-8?q?=E6=81=AF=E5=A4=84=E7=90=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../user/server/DefaultSubscribeResponseProcessorServer.java | 2 +- .../lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java | 3 ++- .../lunasaw/sip/common/transmit/SipProcessorObserver.java | 4 ---- 3 files changed, 3 insertions(+), 6 deletions(-) diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java index f6257913..2c59b270 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java @@ -27,7 +27,7 @@ public class DefaultSubscribeResponseProcessorServer implements SubscribeRespons @Override public void subscribeResult(DeviceSubscribe deviceSubscribe) { - log.error("收到订阅消息响应 subscribeResult::deviceSubscribe = {} ", JSON.toJSONString(deviceSubscribe)); + log.info("收到订阅消息响应 subscribeResult::deviceSubscribe = {} ", JSON.toJSONString(deviceSubscribe)); } @Override diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java index 97d485f3..ebdef4f5 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java @@ -59,7 +59,7 @@ public void test_register_server() throws Exception { @Test public void test_subscribe() { - dynamicTask.startCron("test_subscribe", () -> { + dynamicTask.startDelay("test_subscribe", () -> { Device device = DeviceConfig.DEVICE_SERVER_VIEW_MAP.get("33010602011187000001"); if (device == null) { test_subscribe(); @@ -67,6 +67,7 @@ public void test_subscribe() { } String invitePlay = ServerSendCmd.deviceCatalogSubscribe((FromDevice)fromDevice, (ToDevice)device, 30, CmdTypeEnum.CATALOG.getType()); + log.info("test_subscribe:: callId = {}", invitePlay); }, 30 * 1000); } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java index 2756b2c5..920c73a9 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipProcessorObserver.java @@ -12,10 +12,8 @@ import javax.sip.message.Response; import org.apache.commons.collections4.CollectionUtils; -import org.springframework.scheduling.annotation.Async; import com.alibaba.fastjson.JSON; -import com.luna.common.thread.AsyncEngineUtils; import io.github.lunasaw.sip.common.transmit.event.Event; import io.github.lunasaw.sip.common.transmit.event.EventResult; @@ -88,7 +86,6 @@ public synchronized static void addTimeoutProcessor(String method, ITimeoutProce * @param requestEvent RequestEvent事件 */ @Override - @Async("sipTaskExecutor") public void processRequest(RequestEvent requestEvent) { String method = requestEvent.getRequest().getMethod(); List sipRequestProcessors = REQUEST_PROCESSOR_MAP.get(method); @@ -112,7 +109,6 @@ public void processRequest(RequestEvent requestEvent) { * @param responseEvent responseEvent事件 */ @Override - // @Async("sipTaskExecutor") public void processResponse(ResponseEvent responseEvent) { Response response = responseEvent.getResponse(); int status = response.getStatusCode(); From 9858dd743e8a88b5a2375083f14b1baf53163708 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Wed, 13 Dec 2023 16:41:19 +0800 Subject: [PATCH 11/17] :memo: code reformat --- gb28181-client/pom.xml | 5 ++ .../event/subscribe/CatalogEvent.java | 50 +++++++++++++++++++ .../client/transmit/cmd/ClientSendCmd.java | 30 +++++------ .../invite/InviteRequestProcessor.java | 10 ++-- .../message/MessageClientHandlerAbstract.java | 2 +- .../message/MessageProcessorClient.java | 13 +++-- .../control/DeviceControlMessageHandler.java | 2 - .../notify/BroadcastNotifyMessageHandler.java | 4 +- .../query/AlarmQueryMessageClientHandler.java | 6 +-- .../CatalogQueryMessageClientHandler.java | 6 +-- .../query/ConfigDownloadMessageHandler.java | 6 +-- .../DeviceInfoQueryMessageClientHandler.java | 6 +-- ...DeviceStatusQueryMessageClientHandler.java | 6 +-- .../RecordInfoQueryMessageClientHandler.java | 6 +-- .../SubscribeClientHandlerAbstract.java | 2 +- .../subscribe/SubscribeProcessorClient.java | 4 +- .../catalog/CatalogQueryMessageHandler.java | 8 ++- .../register/RegisterResponseProcessor.java | 1 - gb28181-common/pom.xml | 26 ++++++++++ .../gb28181}/common/entity/DeviceAlarm.java | 2 +- .../gb28181}/common/entity/GbSipDate.java | 2 +- .../common/entity/base/DeviceBase.java | 4 +- .../common/entity/base/package-info.java | 2 +- .../common/entity/control/ControlBase.java | 4 +- .../entity/control/DeviceConfigControl.java | 3 +- .../entity/control/DeviceControlAlarm.java | 4 +- .../entity/control/DeviceControlBase.java | 7 +-- .../entity/control/DeviceControlDragIn.java | 3 +- .../entity/control/DeviceControlDragOut.java | 3 +- .../entity/control/DeviceControlGuard.java | 3 +- .../entity/control/DeviceControlIFame.java | 3 +- .../entity/control/DeviceControlPosition.java | 4 +- .../entity/control/DeviceControlPtz.java | 2 +- .../control/DeviceControlRecordCmd.java | 2 +- .../entity/control/DeviceControlTeleBoot.java | 2 +- .../common/entity/control/DragZoom.java | 2 +- .../common/entity/control/package-info.java | 2 +- .../entity/notify/DeviceAlarmNotify.java | 8 +-- .../entity/notify/DeviceBroadcastNotify.java | 4 +- .../entity/notify/DeviceKeepLiveNotify.java | 4 +- .../notify/DeviceOtherUpdateNotify.java | 4 +- .../entity/notify/DeviceUpdateItem.java | 4 +- .../entity/notify/DeviceUpdateNotify.java | 4 +- .../entity/notify/MediaStatusNotify.java | 4 +- .../entity/notify/MobilePositionNotify.java | 4 +- .../common/entity/notify/package-info.java | 2 +- .../gb28181}/common/entity/package-info.java | 2 +- .../common/entity/query/DeviceAlarmQuery.java | 4 +- .../entity/query/DeviceConfigDownload.java | 4 +- .../entity/query/DeviceMobileQuery.java | 4 +- .../common/entity/query/DeviceQuery.java | 4 +- .../entity/query/DeviceRecordQuery.java | 4 +- .../common/entity/query/package-info.java | 2 +- .../common/entity/response/DeviceCatalog.java | 2 +- .../entity/response/DeviceConfigResponse.java | 4 +- .../common/entity/response/DeviceInfo.java | 4 +- .../common/entity/response/DeviceItem.java | 2 +- .../entity/response/DevicePresetResponse.java | 4 +- .../common/entity/response/DeviceRecord.java | 4 +- .../entity/response/DeviceResponse.java | 4 +- .../common/entity/response/DeviceStatus.java | 4 +- .../entity/response/DeviceSubscribe.java | 4 +- .../common/entity/response/package-info.java | 2 +- .../gb28181}/common/entity/xml/XmlBean.java | 2 +- .../common/entity/xml/package-info.java | 2 +- gb28181-server/pom.xml | 5 ++ .../server/transimit/cmd/ServerSendCmd.java | 50 +++++++++---------- .../message/MessageProcessorServer.java | 12 ++--- .../message/MessageServerHandlerAbstract.java | 2 +- .../notify/AlarmNotifyMessageHandler.java | 4 +- .../notify/KeepaliveNotifyMessageHandler.java | 5 +- .../MediaStatusNotifyMessageHandler.java | 5 +- .../MobilePositionNotifyMessageHandler.java | 5 +- .../RecordInfoMessageServerHandler.java | 5 +- .../ResponseCatalogMessageServerHandler.java | 4 +- .../ServerRegisterRequestProcessor.java | 2 +- .../subscribe/SubscribeResponseProcessor.java | 5 +- .../SubscribeResponseProcessorServer.java | 2 +- .../gbproxy/server/cmd/Applicationtest.java | 1 - gb28181-test/pom.xml | 5 ++ .../gbproxy/test/config/DeviceConfig.java | 8 ++- .../client/DefaultInfoProcessorClient.java | 1 - .../client/DefaultMessageProcessorClient.java | 12 ++--- .../DefaultSubscribeProcessorClient.java | 4 +- .../DefaultInviteResponseProcessorServer.java | 1 - .../server/DefaultMessageProcessorServer.java | 14 +++--- ...faultSubscribeResponseProcessorServer.java | 9 ++-- .../lunasaw/gbproxy/test/Gb28181Test.java | 1 - .../gbproxy/test/Gb28181TestServer.java | 12 +---- .../gbproxy/test/invite/ServerInviteTest.java | 2 +- .../test/register/RegisterClientTest.java | 1 - .../test/subscribe/SubscribeClientTest.java | 4 -- .../test/subscribe/SubscribeServerTest.java | 7 --- pom.xml | 6 +++ .../sip/common/conf/msg/StringMsgParser.java | 7 +-- .../entity/{base => }/DeviceSession.java | 2 +- .../lunasaw/sip/common/entity/SipMessage.java | 6 +-- .../sip/common/entity/SipTransaction.java | 2 - .../sip/common/enums/DeviceControlType.java | 1 - .../sip/common/transmit/SipSender.java | 48 +++++++++--------- .../event/message/MessageHandlerAbstract.java | 2 +- .../transmit/request/SipRequestProvider.java | 31 ++++++------ .../response/SipResponseProvider.java | 1 - .../sip/common/test/ApplicationTest.java | 1 - 104 files changed, 338 insertions(+), 304 deletions(-) create mode 100755 gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/eventbus/event/subscribe/CatalogEvent.java create mode 100644 gb28181-common/pom.xml rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/DeviceAlarm.java (97%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/GbSipDate.java (98%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/base/DeviceBase.java (85%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/base/package-info.java (70%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/ControlBase.java (76%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceConfigControl.java (94%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlAlarm.java (91%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlBase.java (61%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlDragIn.java (95%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlDragOut.java (93%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlGuard.java (86%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlIFame.java (85%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlPosition.java (92%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlPtz.java (94%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlRecordCmd.java (93%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DeviceControlTeleBoot.java (93%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/DragZoom.java (92%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/control/package-info.java (72%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/DeviceAlarmNotify.java (92%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/DeviceBroadcastNotify.java (86%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/DeviceKeepLiveNotify.java (88%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/DeviceOtherUpdateNotify.java (93%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/DeviceUpdateItem.java (80%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/DeviceUpdateNotify.java (95%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/MediaStatusNotify.java (88%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/MobilePositionNotify.java (92%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/notify/package-info.java (73%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/package-info.java (71%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/query/DeviceAlarmQuery.java (93%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/query/DeviceConfigDownload.java (92%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/query/DeviceMobileQuery.java (88%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/query/DeviceQuery.java (84%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/query/DeviceRecordQuery.java (95%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/query/package-info.java (72%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DeviceCatalog.java (97%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DeviceConfigResponse.java (94%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DeviceInfo.java (94%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DeviceItem.java (98%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DevicePresetResponse.java (93%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DeviceRecord.java (94%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DeviceResponse.java (95%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DeviceStatus.java (90%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/DeviceSubscribe.java (87%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/response/package-info.java (69%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/xml/XmlBean.java (96%) rename {sip-common/src/main/java/io/github/lunasaw/sip => gb28181-common/src/main/java/io/github/lunasaw/gb28181}/common/entity/xml/package-info.java (65%) rename sip-common/src/main/java/io/github/lunasaw/sip/common/entity/{base => }/DeviceSession.java (82%) diff --git a/gb28181-client/pom.xml b/gb28181-client/pom.xml index 98ed8285..ab4b1d85 100644 --- a/gb28181-client/pom.xml +++ b/gb28181-client/pom.xml @@ -27,6 +27,11 @@ io.github.lunasaw sip-common + + + io.github.lunasaw + gb28181-common + diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/eventbus/event/subscribe/CatalogEvent.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/eventbus/event/subscribe/CatalogEvent.java new file mode 100755 index 00000000..94519654 --- /dev/null +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/eventbus/event/subscribe/CatalogEvent.java @@ -0,0 +1,50 @@ +package io.github.lunasaw.gbproxy.client.eventbus.event.subscribe; + +import org.springframework.context.ApplicationEvent; + +import lombok.Getter; +import lombok.Setter; + +@Getter +@Setter +public class CatalogEvent extends ApplicationEvent { + public CatalogEvent(Object source) { + super(source); + } + + /** + * 上线 + */ + public static final String ON = "ON"; + + /** + * 离线 + */ + public static final String OFF = "OFF"; + + /** + * 视频丢失 + */ + public static final String VIDEO_LOST = "VIDEO_LOST"; + + /** + * 故障 + */ + public static final String DEFECT = "DEFECT"; + + /** + * 增加 + */ + public static final String ADD = "ADD"; + + /** + * 删除 + */ + public static final String DEL = "DEL"; + + /** + * 更新 + */ + public static final String UPDATE = "UPDATE"; + +} diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java index f1696eb7..8485b713 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java @@ -5,11 +5,11 @@ import com.luna.common.check.Assert; import com.luna.common.text.RandomStrUtil; -import io.github.lunasaw.sip.common.entity.DeviceAlarm; +import io.github.lunasaw.gb28181.common.entity.DeviceAlarm; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.notify.*; -import io.github.lunasaw.sip.common.entity.response.*; +import io.github.lunasaw.gb28181.common.entity.notify.*; +import io.github.lunasaw.gb28181.common.entity.response.*; import io.github.lunasaw.sip.common.enums.CmdTypeEnum; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.SipSender; @@ -29,7 +29,7 @@ public class ClientSendCmd { * @return */ public static String deviceAlarmNotify(FromDevice fromDevice, ToDevice toDevice, DeviceAlarmNotify deviceAlarmNotify) { - return SipSender.doMessageRequest(fromDevice, toDevice, deviceAlarmNotify); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceAlarmNotify.toString()); } /** @@ -45,7 +45,7 @@ public static String deviceAlarmNotify(FromDevice fromDevice, ToDevice toDevice, deviceAlarmNotify.setAlarm(deviceAlarm); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceAlarmNotify); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceAlarmNotify.toString()); } /** @@ -70,7 +70,7 @@ public static String deviceKeepLiveNotify(FromDevice fromDevice, ToDevice toDevi deviceKeepLiveNotify.setStatus(status); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceKeepLiveNotify, errorEvent, okEvent); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceKeepLiveNotify.toString(), errorEvent, okEvent); } /** @@ -82,7 +82,7 @@ public static String deviceKeepLiveNotify(FromDevice fromDevice, ToDevice toDevi * @return */ public static String deviceChannelCatalogResponse(FromDevice fromDevice, ToDevice toDevice, DeviceResponse deviceResponse) { - return SipSender.doMessageRequest(fromDevice, toDevice, deviceResponse); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceResponse.toString()); } public static String deviceChannelCatalogResponse(FromDevice fromDevice, ToDevice toDevice, List deviceItems, String sn) { @@ -120,7 +120,7 @@ public static String deviceInfoResponse(FromDevice fromDevice, ToDevice toDevice deviceInfo.setCmdType(CmdTypeEnum.DEVICE_INFO.getType()); deviceInfo.setSn(RandomStrUtil.getValidationCode()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceInfo); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceInfo.toString()); } /** @@ -138,7 +138,7 @@ public static String deviceStatusResponse(FromDevice fromDevice, ToDevice toDevi deviceStatus.setOnline(online); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceStatus); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceStatus.toString()); } /** @@ -154,7 +154,7 @@ public static String MobilePositionNotify(FromDevice fromDevice, ToDevice toDevi mobilePositionNotify.setCmdType(CmdTypeEnum.DEVICE_INFO.getType()); mobilePositionNotify.setSn(RandomStrUtil.getValidationCode()); mobilePositionNotify.setDeviceId(fromDevice.getUserId()); - return SipSender.doNotifyRequest(fromDevice, toDevice, mobilePositionNotify, subscribeInfo); + return SipSender.doNotifyRequest(fromDevice, toDevice, mobilePositionNotify.toString(), subscribeInfo); } /** @@ -173,7 +173,7 @@ public static String deviceChannelUpdateCatlog(FromDevice fromDevice, ToDevice t deviceUpdateNotify.setSumNum(deviceItems.size()); deviceUpdateNotify.setDeviceItemList(deviceItems); - return SipSender.doNotifyRequest(fromDevice, toDevice, deviceUpdateNotify, subscribeInfo); + return SipSender.doNotifyRequest(fromDevice, toDevice, deviceUpdateNotify.toString(), subscribeInfo); } /** @@ -192,7 +192,7 @@ public static String deviceOtherUpdateCatlog(FromDevice fromDevice, ToDevice toD deviceUpdateNotify.setSumNum(deviceItems.size()); deviceUpdateNotify.setDeviceItemList(deviceItems); - return SipSender.doNotifyRequest(fromDevice, toDevice, deviceUpdateNotify, subscribeInfo); + return SipSender.doNotifyRequest(fromDevice, toDevice, deviceUpdateNotify.toString(), subscribeInfo); } /** @@ -205,7 +205,7 @@ public static String deviceOtherUpdateCatlog(FromDevice fromDevice, ToDevice toD */ public static String deviceRecordResponse(FromDevice fromDevice, ToDevice toDevice, DeviceRecord deviceRecord) { - return SipSender.doMessageRequest(fromDevice, toDevice, deviceRecord); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceRecord.toString()); } /** @@ -235,7 +235,7 @@ public static String deviceRecordResponse(FromDevice fromDevice, ToDevice toDevi * @return */ public static String deviceConfigResponse(FromDevice fromDevice, ToDevice toDevice, DeviceConfigResponse deviceConfigResponse) { - return SipSender.doMessageRequest(fromDevice, toDevice, deviceConfigResponse); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceConfigResponse.toString()); } public static String deviceConfigResponse(FromDevice fromDevice, ToDevice toDevice, DeviceConfigResponse.BasicParam basicParam) { @@ -262,7 +262,7 @@ public static String deviceMediaStatusNotify(FromDevice fromDevice, ToDevice toD mediaStatusNotify.setNotifyType(notifyType); - return SipSender.doMessageRequest(fromDevice, toDevice, mediaStatusNotify); + return SipSender.doMessageRequest(fromDevice, toDevice, mediaStatusNotify.toString()); } /** diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/invite/InviteRequestProcessor.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/invite/InviteRequestProcessor.java index 66221521..c70b31be 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/invite/InviteRequestProcessor.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/invite/InviteRequestProcessor.java @@ -5,14 +5,16 @@ import javax.sip.header.ContentTypeHeader; import javax.sip.message.Response; +import org.springframework.stereotype.Component; + import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.entity.*; +import io.github.lunasaw.sip.common.entity.GbSessionDescription; +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.enums.ContentTypeEnum; import io.github.lunasaw.sip.common.transmit.ResponseCmd; -import io.github.lunasaw.sip.common.utils.SipUtils; -import org.springframework.stereotype.Component; - import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; +import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageClientHandlerAbstract.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageClientHandlerAbstract.java index 3bb1c284..3db3b46c 100755 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageClientHandlerAbstract.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageClientHandlerAbstract.java @@ -1,7 +1,7 @@ package io.github.lunasaw.gbproxy.client.transmit.request.message; import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; import io.github.lunasaw.sip.common.transmit.event.message.MessageHandlerAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Data; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageProcessorClient.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageProcessorClient.java index 21dd2856..a92a60e4 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageProcessorClient.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageProcessorClient.java @@ -1,16 +1,15 @@ package io.github.lunasaw.gbproxy.client.transmit.request.message; +import io.github.lunasaw.gb28181.common.entity.response.*; import io.github.lunasaw.gbproxy.client.transmit.request.message.handler.notify.BroadcastNotifyMessageHandler; import io.github.lunasaw.gbproxy.client.transmit.request.message.handler.query.CatalogQueryMessageClientHandler; import io.github.lunasaw.gbproxy.client.transmit.request.message.handler.query.DeviceInfoQueryMessageClientHandler; import io.github.lunasaw.gbproxy.client.transmit.request.message.handler.query.DeviceStatusQueryMessageClientHandler; -import io.github.lunasaw.sip.common.entity.control.DeviceControlBase; -import io.github.lunasaw.sip.common.entity.notify.DeviceAlarmNotify; -import io.github.lunasaw.sip.common.entity.notify.DeviceBroadcastNotify; -import io.github.lunasaw.sip.common.entity.query.DeviceAlarmQuery; -import io.github.lunasaw.sip.common.entity.query.DeviceConfigDownload; -import io.github.lunasaw.sip.common.entity.query.DeviceRecordQuery; -import io.github.lunasaw.sip.common.entity.response.*; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceAlarmNotify; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceBroadcastNotify; +import io.github.lunasaw.gb28181.common.entity.query.DeviceAlarmQuery; +import io.github.lunasaw.gb28181.common.entity.query.DeviceConfigDownload; +import io.github.lunasaw.gb28181.common.entity.query.DeviceRecordQuery; import io.github.lunasaw.sip.common.service.SipUserGenerate; /** diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/control/DeviceControlMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/control/DeviceControlMessageHandler.java index c3665a70..b875599f 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/control/DeviceControlMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/control/DeviceControlMessageHandler.java @@ -2,8 +2,6 @@ import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageClientHandlerAbstract; import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; -import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; import io.github.lunasaw.sip.common.enums.DeviceControlType; import lombok.Getter; import lombok.Setter; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/notify/BroadcastNotifyMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/notify/BroadcastNotifyMessageHandler.java index 68e5d5f2..24c14dc5 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/notify/BroadcastNotifyMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/notify/BroadcastNotifyMessageHandler.java @@ -3,8 +3,8 @@ import javax.sip.RequestEvent; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.notify.DeviceBroadcastNotify; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceBroadcastNotify; import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageClientHandlerAbstract; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/AlarmQueryMessageClientHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/AlarmQueryMessageClientHandler.java index 13495e95..42aa63e8 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/AlarmQueryMessageClientHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/AlarmQueryMessageClientHandler.java @@ -6,9 +6,9 @@ import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageClientHandlerAbstract; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.notify.DeviceAlarmNotify; -import io.github.lunasaw.sip.common.entity.query.DeviceAlarmQuery; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceAlarmNotify; +import io.github.lunasaw.gb28181.common.entity.query.DeviceAlarmQuery; import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/CatalogQueryMessageClientHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/CatalogQueryMessageClientHandler.java index 10fdbe7c..1966d441 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/CatalogQueryMessageClientHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/CatalogQueryMessageClientHandler.java @@ -2,7 +2,7 @@ import javax.sip.RequestEvent; -import io.github.lunasaw.sip.common.entity.response.DeviceResponse; +import io.github.lunasaw.gb28181.common.entity.response.DeviceResponse; import lombok.Setter; import org.springframework.stereotype.Component; @@ -11,8 +11,8 @@ import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.query.DeviceQuery; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.query.DeviceQuery; import lombok.Getter; import lombok.extern.slf4j.Slf4j; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/ConfigDownloadMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/ConfigDownloadMessageHandler.java index 0c9f806e..3b909521 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/ConfigDownloadMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/ConfigDownloadMessageHandler.java @@ -5,9 +5,9 @@ import io.github.lunasaw.gbproxy.client.transmit.cmd.ClientSendCmd; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.query.DeviceConfigDownload; -import io.github.lunasaw.sip.common.entity.response.DeviceConfigResponse; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.query.DeviceConfigDownload; +import io.github.lunasaw.gb28181.common.entity.response.DeviceConfigResponse; import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageClientHandlerAbstract; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/DeviceInfoQueryMessageClientHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/DeviceInfoQueryMessageClientHandler.java index f5df4f5a..3e3e8db3 100755 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/DeviceInfoQueryMessageClientHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/DeviceInfoQueryMessageClientHandler.java @@ -11,9 +11,9 @@ import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.query.DeviceQuery; -import io.github.lunasaw.sip.common.entity.response.DeviceInfo; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.query.DeviceQuery; +import io.github.lunasaw.gb28181.common.entity.response.DeviceInfo; import lombok.extern.slf4j.Slf4j; /** diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/DeviceStatusQueryMessageClientHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/DeviceStatusQueryMessageClientHandler.java index 1497c901..e5184530 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/DeviceStatusQueryMessageClientHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/DeviceStatusQueryMessageClientHandler.java @@ -9,9 +9,9 @@ import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.query.DeviceQuery; -import io.github.lunasaw.sip.common.entity.response.DeviceStatus; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.query.DeviceQuery; +import io.github.lunasaw.gb28181.common.entity.response.DeviceStatus; import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/RecordInfoQueryMessageClientHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/RecordInfoQueryMessageClientHandler.java index 7a557d8d..07c319d7 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/RecordInfoQueryMessageClientHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/query/RecordInfoQueryMessageClientHandler.java @@ -6,9 +6,9 @@ import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageClientHandlerAbstract; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.query.DeviceRecordQuery; -import io.github.lunasaw.sip.common.entity.response.DeviceRecord; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.query.DeviceRecordQuery; +import io.github.lunasaw.gb28181.common.entity.response.DeviceRecord; import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java index 4c66ad9e..a8c84fba 100755 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeClientHandlerAbstract.java @@ -6,7 +6,7 @@ import org.springframework.stereotype.Component; import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; import io.github.lunasaw.sip.common.transmit.event.message.MessageHandlerAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Data; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java index 36865edd..54b858e9 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/SubscribeProcessorClient.java @@ -1,7 +1,7 @@ package io.github.lunasaw.gbproxy.client.transmit.request.subscribe; -import io.github.lunasaw.sip.common.entity.query.DeviceQuery; -import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.gb28181.common.entity.query.DeviceQuery; +import io.github.lunasaw.gb28181.common.entity.response.DeviceSubscribe; import io.github.lunasaw.sip.common.service.SipUserGenerate; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java index cd73acd3..a44d0f8c 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java @@ -6,20 +6,18 @@ import javax.sip.message.Response; import io.github.lunasaw.sip.common.entity.Device; -import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.gb28181.common.entity.response.DeviceSubscribe; import io.github.lunasaw.sip.common.enums.ContentTypeEnum; import io.github.lunasaw.sip.common.transmit.ResponseCmd; import io.github.lunasaw.sip.common.utils.SipRequestUtils; -import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeClientHandlerAbstract; import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeProcessorClient; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.query.DeviceQuery; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.query.DeviceQuery; import io.github.lunasaw.sip.common.enums.CmdTypeEnum; -import io.github.lunasaw.sip.common.subscribe.SubscribeHolder; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; import lombok.Getter; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/response/register/RegisterResponseProcessor.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/response/register/RegisterResponseProcessor.java index 30efc699..3bd3f94a 100755 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/response/register/RegisterResponseProcessor.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/response/register/RegisterResponseProcessor.java @@ -15,7 +15,6 @@ import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.sip.common.transmit.SipSender; -import io.github.lunasaw.sip.common.transmit.event.EventResult; import io.github.lunasaw.sip.common.transmit.event.response.SipResponseProcessorAbstract; import io.github.lunasaw.sip.common.transmit.request.SipRequestProvider; import io.github.lunasaw.sip.common.utils.SipUtils; diff --git a/gb28181-common/pom.xml b/gb28181-common/pom.xml new file mode 100644 index 00000000..b2f07439 --- /dev/null +++ b/gb28181-common/pom.xml @@ -0,0 +1,26 @@ + + + 4.0.0 + + io.github.lunasaw + sip-proxy + 1.1.3 + + + ${gb28181-proxy.version} + gb28181-common + jar + gb28181-common + 轻量级Gb28181框架模型 + https://github.com/lunasaw/gb28181-proxy + + + + 8 + 8 + UTF-8 + + + \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/DeviceAlarm.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/DeviceAlarm.java similarity index 97% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/DeviceAlarm.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/DeviceAlarm.java index a0cd6664..ff0b244c 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/DeviceAlarm.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/DeviceAlarm.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity; +package io.github.lunasaw.gb28181.common.entity; import java.util.Date; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/GbSipDate.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/GbSipDate.java similarity index 98% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/GbSipDate.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/GbSipDate.java index 55c4989d..9ef44c2e 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/GbSipDate.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/GbSipDate.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity; +package io.github.lunasaw.gb28181.common.entity; import java.util.*; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/DeviceBase.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/base/DeviceBase.java similarity index 85% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/DeviceBase.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/base/DeviceBase.java index 614179e1..a1dc721c 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/DeviceBase.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/base/DeviceBase.java @@ -1,10 +1,10 @@ -package io.github.lunasaw.sip.common.entity.base; +package io.github.lunasaw.gb28181.common.entity.base; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; +import io.github.lunasaw.gb28181.common.entity.xml.XmlBean; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/package-info.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/base/package-info.java similarity index 70% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/package-info.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/base/package-info.java index 5c930af2..688bc103 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/package-info.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/base/package-info.java @@ -5,4 +5,4 @@ * @author luna * @date 2023/11/20 */ -package io.github.lunasaw.sip.common.entity.base; \ No newline at end of file +package io.github.lunasaw.gb28181.common.entity.base; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/ControlBase.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/ControlBase.java similarity index 76% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/ControlBase.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/ControlBase.java index e01dba6e..ecd9f3c7 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/ControlBase.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/ControlBase.java @@ -1,11 +1,9 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; -import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceConfigControl.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceConfigControl.java similarity index 94% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceConfigControl.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceConfigControl.java index 3d946846..9fb47110 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceConfigControl.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceConfigControl.java @@ -1,11 +1,10 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlAlarm.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlAlarm.java similarity index 91% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlAlarm.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlAlarm.java index 5975578c..57b32f5d 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlAlarm.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlAlarm.java @@ -1,12 +1,10 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlBase.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlBase.java similarity index 61% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlBase.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlBase.java index 91f97b0e..8b9db632 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlBase.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlBase.java @@ -1,13 +1,10 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.Getter; import lombok.Setter; -import javax.xml.bind.annotation.XmlAccessType; -import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; -import javax.xml.bind.annotation.XmlRootElement; /** * @author luna diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlDragIn.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragIn.java similarity index 95% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlDragIn.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragIn.java index eed24ef2..92510e64 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlDragIn.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragIn.java @@ -1,8 +1,7 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.*; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.AllArgsConstructor; import lombok.Getter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlDragOut.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragOut.java similarity index 93% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlDragOut.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragOut.java index 27369b7d..60aa2fd9 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlDragOut.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragOut.java @@ -1,11 +1,10 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlGuard.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlGuard.java similarity index 86% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlGuard.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlGuard.java index 4b2ec742..dbd473bb 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlGuard.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlGuard.java @@ -1,11 +1,10 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlIFame.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlIFame.java similarity index 85% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlIFame.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlIFame.java index 1fb17033..598c7360 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlIFame.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlIFame.java @@ -1,11 +1,10 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; import lombok.*; /** diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlPosition.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlPosition.java similarity index 92% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlPosition.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlPosition.java index ad5b6516..dd1af129 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlPosition.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlPosition.java @@ -1,12 +1,10 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlPtz.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlPtz.java similarity index 94% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlPtz.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlPtz.java index 60791f53..a94badc2 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlPtz.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlPtz.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlRecordCmd.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlRecordCmd.java similarity index 93% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlRecordCmd.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlRecordCmd.java index b76d21a1..59a0b1c2 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlRecordCmd.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlRecordCmd.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlTeleBoot.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlTeleBoot.java similarity index 93% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlTeleBoot.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlTeleBoot.java index 95d54f01..b749e1dd 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DeviceControlTeleBoot.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlTeleBoot.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DragZoom.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DragZoom.java similarity index 92% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DragZoom.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DragZoom.java index e4d9a96a..8dfda124 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/DragZoom.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DragZoom.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.control; +package io.github.lunasaw.gb28181.common.entity.control; import lombok.AllArgsConstructor; import lombok.Getter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/package-info.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/package-info.java similarity index 72% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/package-info.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/package-info.java index 0c1f565e..ac44a28f 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/control/package-info.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/package-info.java @@ -5,4 +5,4 @@ * @author luna * @date 2023/11/20 */ -package io.github.lunasaw.sip.common.entity.control; \ No newline at end of file +package io.github.lunasaw.gb28181.common.entity.control; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceAlarmNotify.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceAlarmNotify.java similarity index 92% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceAlarmNotify.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceAlarmNotify.java index 1bf444bb..1781aef6 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceAlarmNotify.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceAlarmNotify.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.notify; +package io.github.lunasaw.gb28181.common.entity.notify; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; @@ -6,9 +6,9 @@ import javax.xml.bind.annotation.XmlRootElement; import com.luna.common.date.DateUtils; -import io.github.lunasaw.sip.common.entity.response.DeviceItem; -import io.github.lunasaw.sip.common.entity.DeviceAlarm; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; +import io.github.lunasaw.gb28181.common.entity.response.DeviceItem; +import io.github.lunasaw.gb28181.common.entity.DeviceAlarm; +import io.github.lunasaw.gb28181.common.entity.xml.XmlBean; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceBroadcastNotify.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceBroadcastNotify.java similarity index 86% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceBroadcastNotify.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceBroadcastNotify.java index 59aed568..085e53ee 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceBroadcastNotify.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceBroadcastNotify.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.notify; +package io.github.lunasaw.gb28181.common.entity.notify; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; +import io.github.lunasaw.gb28181.common.entity.xml.XmlBean; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceKeepLiveNotify.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceKeepLiveNotify.java similarity index 88% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceKeepLiveNotify.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceKeepLiveNotify.java index ad7b6c4b..96c21393 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceKeepLiveNotify.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceKeepLiveNotify.java @@ -1,8 +1,8 @@ -package io.github.lunasaw.sip.common.entity.notify; +package io.github.lunasaw.gb28181.common.entity.notify; import javax.xml.bind.annotation.*; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceOtherUpdateNotify.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceOtherUpdateNotify.java similarity index 93% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceOtherUpdateNotify.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceOtherUpdateNotify.java index 9b7a79fb..813dbf86 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceOtherUpdateNotify.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceOtherUpdateNotify.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.notify; +package io.github.lunasaw.gb28181.common.entity.notify; import java.util.List; @@ -6,7 +6,7 @@ import org.assertj.core.util.Lists; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceUpdateItem.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceUpdateItem.java similarity index 80% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceUpdateItem.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceUpdateItem.java index 32d59340..6e42a1ce 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceUpdateItem.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceUpdateItem.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.notify; +package io.github.lunasaw.gb28181.common.entity.notify; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.response.DeviceCatalog; +import io.github.lunasaw.gb28181.common.entity.response.DeviceCatalog; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceUpdateNotify.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceUpdateNotify.java similarity index 95% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceUpdateNotify.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceUpdateNotify.java index 249a449a..12c6ee3b 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/DeviceUpdateNotify.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/DeviceUpdateNotify.java @@ -1,8 +1,8 @@ -package io.github.lunasaw.sip.common.entity.notify; +package io.github.lunasaw.gb28181.common.entity.notify; import javax.xml.bind.annotation.*; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/MediaStatusNotify.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/MediaStatusNotify.java similarity index 88% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/MediaStatusNotify.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/MediaStatusNotify.java index 7e7434be..c9d4a564 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/MediaStatusNotify.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/MediaStatusNotify.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.notify; +package io.github.lunasaw.gb28181.common.entity.notify; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/MobilePositionNotify.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/MobilePositionNotify.java similarity index 92% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/MobilePositionNotify.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/MobilePositionNotify.java index a469b8b1..b883b35b 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/MobilePositionNotify.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/MobilePositionNotify.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.notify; +package io.github.lunasaw.gb28181.common.entity.notify; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/package-info.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/package-info.java similarity index 73% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/package-info.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/package-info.java index 829630f3..04861558 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/notify/package-info.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/notify/package-info.java @@ -5,4 +5,4 @@ * @author luna * @date 2023/11/20 */ -package io.github.lunasaw.sip.common.entity.notify; \ No newline at end of file +package io.github.lunasaw.gb28181.common.entity.notify; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/package-info.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/package-info.java similarity index 71% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/package-info.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/package-info.java index 6c8f458f..18af5090 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/package-info.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/package-info.java @@ -4,4 +4,4 @@ * @author luna * 2021/8/18 */ -package io.github.lunasaw.sip.common.entity; +package io.github.lunasaw.gb28181.common.entity; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceAlarmQuery.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceAlarmQuery.java similarity index 93% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceAlarmQuery.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceAlarmQuery.java index 2575e8cd..1271fb97 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceAlarmQuery.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceAlarmQuery.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.query; +package io.github.lunasaw.gb28181.common.entity.query; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; +import io.github.lunasaw.gb28181.common.entity.xml.XmlBean; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceConfigDownload.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceConfigDownload.java similarity index 92% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceConfigDownload.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceConfigDownload.java index 84a2872c..c1ec90bf 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceConfigDownload.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceConfigDownload.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.query; +package io.github.lunasaw.gb28181.common.entity.query; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceMobileQuery.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceMobileQuery.java similarity index 88% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceMobileQuery.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceMobileQuery.java index 4251ed3b..7d72d588 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceMobileQuery.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceMobileQuery.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.query; +package io.github.lunasaw.gb28181.common.entity.query; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; +import io.github.lunasaw.gb28181.common.entity.xml.XmlBean; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceQuery.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceQuery.java similarity index 84% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceQuery.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceQuery.java index 07de01dd..2831027d 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceQuery.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceQuery.java @@ -1,10 +1,10 @@ -package io.github.lunasaw.sip.common.entity.query; +package io.github.lunasaw.gb28181.common.entity.query; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceRecordQuery.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceRecordQuery.java similarity index 95% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceRecordQuery.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceRecordQuery.java index 34da6c77..0743d656 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/DeviceRecordQuery.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/DeviceRecordQuery.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.query; +package io.github.lunasaw.gb28181.common.entity.query; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; @@ -6,7 +6,7 @@ import javax.xml.bind.annotation.XmlRootElement; import com.luna.common.date.DateUtils; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; +import io.github.lunasaw.gb28181.common.entity.xml.XmlBean; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/package-info.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/package-info.java similarity index 72% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/package-info.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/package-info.java index 1254df0a..0dfbd397 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/query/package-info.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/query/package-info.java @@ -5,4 +5,4 @@ * @author luna * @date 2023/11/20 */ -package io.github.lunasaw.sip.common.entity.query; \ No newline at end of file +package io.github.lunasaw.gb28181.common.entity.query; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceCatalog.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceCatalog.java similarity index 97% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceCatalog.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceCatalog.java index c9a40d1f..7104db9f 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceCatalog.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceCatalog.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceConfigResponse.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceConfigResponse.java similarity index 94% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceConfigResponse.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceConfigResponse.java index d9dd2bef..d7ecf4b2 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceConfigResponse.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceConfigResponse.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.Getter; import lombok.NoArgsConstructor; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceInfo.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceInfo.java similarity index 94% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceInfo.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceInfo.java index 67564952..d2391b71 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceInfo.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceInfo.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceItem.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceItem.java similarity index 98% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceItem.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceItem.java index d649bca6..3f7e153c 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceItem.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceItem.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import javax.xml.bind.annotation.*; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DevicePresetResponse.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DevicePresetResponse.java similarity index 93% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DevicePresetResponse.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DevicePresetResponse.java index 5e0c8cbb..7ff89af9 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DevicePresetResponse.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DevicePresetResponse.java @@ -1,10 +1,10 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import java.util.List; import javax.xml.bind.annotation.*; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.Getter; import lombok.NoArgsConstructor; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceRecord.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceRecord.java similarity index 94% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceRecord.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceRecord.java index e6774a9e..40337f79 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceRecord.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceRecord.java @@ -1,10 +1,10 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import java.util.List; import javax.xml.bind.annotation.*; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.Getter; import lombok.NoArgsConstructor; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceResponse.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceResponse.java similarity index 95% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceResponse.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceResponse.java index ced04568..b6306ca2 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceResponse.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceResponse.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import java.util.List; @@ -8,7 +8,7 @@ import lombok.NoArgsConstructor; import org.assertj.core.util.Lists; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceStatus.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceStatus.java similarity index 90% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceStatus.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceStatus.java index cf157b9b..66619503 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceStatus.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceStatus.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.Getter; import lombok.NoArgsConstructor; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceSubscribe.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceSubscribe.java similarity index 87% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceSubscribe.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceSubscribe.java index 2267b0ef..7559d7e9 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/DeviceSubscribe.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceSubscribe.java @@ -1,11 +1,11 @@ -package io.github.lunasaw.sip.common.entity.response; +package io.github.lunasaw.gb28181.common.entity.response; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.entity.base.DeviceBase; +import io.github.lunasaw.gb28181.common.entity.base.DeviceBase; import lombok.Getter; import lombok.NoArgsConstructor; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/package-info.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/package-info.java similarity index 69% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/package-info.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/package-info.java index c04b87a8..fefb4cca 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/response/package-info.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/package-info.java @@ -5,4 +5,4 @@ * @author luna * @date 2023/11/20 */ -package io.github.lunasaw.sip.common.entity.response; \ No newline at end of file +package io.github.lunasaw.gb28181.common.entity.response; \ No newline at end of file diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/XmlBean.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/xml/XmlBean.java similarity index 96% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/XmlBean.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/xml/XmlBean.java index 00c8ec6c..75ba0f06 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/XmlBean.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/xml/XmlBean.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.xml; +package io.github.lunasaw.gb28181.common.entity.xml; import java.io.StringReader; import java.io.StringWriter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/package-info.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/xml/package-info.java similarity index 65% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/package-info.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/xml/package-info.java index 746f817a..15d7924d 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/xml/package-info.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/xml/package-info.java @@ -4,4 +4,4 @@ * @author luna * @date 2023/11/20 */ -package io.github.lunasaw.sip.common.entity.xml; \ No newline at end of file +package io.github.lunasaw.gb28181.common.entity.xml; \ No newline at end of file diff --git a/gb28181-server/pom.xml b/gb28181-server/pom.xml index a1eca522..108b5e64 100644 --- a/gb28181-server/pom.xml +++ b/gb28181-server/pom.xml @@ -27,6 +27,11 @@ io.github.lunasaw sip-common + + + io.github.lunasaw + gb28181-common + diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java index e5accbb3..4170efe0 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java @@ -5,9 +5,9 @@ import javax.sip.address.SipURI; -import io.github.lunasaw.gbproxy.server.entity.InviteEntity; +import io.github.lunasaw.gb28181.common.entity.control.*; +import io.github.lunasaw.gb28181.common.entity.query.*; import io.github.lunasaw.gbproxy.server.enums.PlayActionEnums; -import org.apache.commons.lang3.StringUtils; import org.springframework.util.Assert; import com.luna.common.date.DateUtils; @@ -17,9 +17,7 @@ import io.github.lunasaw.gbproxy.server.entity.InviteRequest; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.control.*; -import io.github.lunasaw.sip.common.entity.notify.DeviceBroadcastNotify; -import io.github.lunasaw.sip.common.entity.query.*; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceBroadcastNotify; import io.github.lunasaw.sip.common.enums.CmdTypeEnum; import io.github.lunasaw.sip.common.enums.PtzCmdEnum; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; @@ -41,7 +39,7 @@ public class ServerSendCmd { */ public static String deviceInfo(FromDevice fromDevice, ToDevice toDevice) { DeviceQuery deviceQuery = new DeviceQuery(CmdTypeEnum.DEVICE_INFO.getType(), RandomStrUtil.getValidationCode(), toDevice.getUserId()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceQuery); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceQuery.toString()); } /** @@ -53,7 +51,7 @@ public static String deviceInfo(FromDevice fromDevice, ToDevice toDevice) { */ public static String devicePresetQuery(FromDevice fromDevice, ToDevice toDevice) { DeviceQuery deviceQuery = new DeviceQuery(CmdTypeEnum.PRESET_QUERY.getType(), RandomStrUtil.getValidationCode(), toDevice.getUserId()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceQuery); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceQuery.toString()); } /** @@ -68,7 +66,7 @@ public static String devicePresetQuery(FromDevice fromDevice, ToDevice toDevice, new DeviceMobileQuery(CmdTypeEnum.MOBILE_POSITION.getType(), RandomStrUtil.getValidationCode(), toDevice.getUserId()); deviceMobileQuery.setInterval(interval); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceMobileQuery); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceMobileQuery.toString()); } /** @@ -89,7 +87,7 @@ public static String devicePresetSubscribe(FromDevice fromDevice, ToDevice toDev subscribeInfo.setEventType(eventType); subscribeInfo.setExpires(expires); - return SipSender.doSubscribeRequest(fromDevice, toDevice, deviceMobileQuery, subscribeInfo); + return SipSender.doSubscribeRequest(fromDevice, toDevice, deviceMobileQuery.toString(), subscribeInfo); } /** @@ -101,7 +99,7 @@ public static String devicePresetSubscribe(FromDevice fromDevice, ToDevice toDev */ public static String deviceStatusQuery(FromDevice fromDevice, ToDevice toDevice) { DeviceQuery deviceQuery = new DeviceQuery(CmdTypeEnum.DEVICE_STATUS.getType(), RandomStrUtil.getValidationCode(), toDevice.getUserId()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceQuery); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceQuery.toString()); } /** @@ -113,7 +111,7 @@ public static String deviceStatusQuery(FromDevice fromDevice, ToDevice toDevice) */ public static String deviceCatalogQuery(FromDevice fromDevice, ToDevice toDevice) { DeviceQuery deviceQuery = new DeviceQuery(CmdTypeEnum.CATALOG.getType(), RandomStrUtil.getValidationCode(), toDevice.getUserId()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceQuery); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceQuery.toString()); } public static String deviceRecordInfoQuery(FromDevice fromDevice, ToDevice toDevice, String startTime, String endTime) { @@ -145,7 +143,7 @@ public static String deviceRecordInfoQuery(FromDevice fromDevice, ToDevice toDev recordQuery.setSecrecy(secrecy); recordQuery.setType(type); - return SipSender.doMessageRequest(fromDevice, toDevice, recordQuery); + return SipSender.doMessageRequest(fromDevice, toDevice, recordQuery.toString()); } public static String deviceRecordInfoQuery(FromDevice fromDevice, ToDevice toDevice, Date startTime, Date endTime) { @@ -189,7 +187,7 @@ public static String deviceCatalogSubscribe(FromDevice fromDevice, ToDevice toDe subscribeInfo.setEventType(eventType); subscribeInfo.setExpires(expires); - return SipSender.doSubscribeRequest(fromDevice, toDevice, recordQuery, subscribeInfo); + return SipSender.doSubscribeRequest(fromDevice, toDevice, recordQuery.toString(), subscribeInfo); } /** @@ -216,7 +214,7 @@ public static String deviceAlarmQuery(FromDevice fromDevice, ToDevice toDevice, deviceAlarmQuery.setEndAlarmPriority(endPriority); deviceAlarmQuery.setAlarmType(alarmType); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceAlarmQuery); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceAlarmQuery.toString()); } /** @@ -261,7 +259,7 @@ public static String deviceBroadcast(FromDevice fromDevice, ToDevice toDevice) { new DeviceBroadcastNotify(CmdTypeEnum.BROADCAST.getType(), RandomStrUtil.getValidationCode(), fromDevice.getUserId(), toDevice.getUserId()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceBroadcastNotify); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceBroadcastNotify.toString()); } /** @@ -276,7 +274,7 @@ public static String deviceControlGuardCmd(FromDevice fromDevice, ToDevice toDev DeviceControlGuard deviceControl = new DeviceControlGuard(CmdTypeEnum.DEVICE_CONTROL.getType(), RandomStrUtil.getValidationCode(), fromDevice.getUserId()); deviceControl.setGuardCmd(guardCmdStr); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceControl); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceControl.toString()); } /** @@ -296,14 +294,14 @@ public static String deviceControlAlarm(FromDevice fromDevice, ToDevice toDevice deviceControlAlarm.setAlarmCmd("ResetAlarm"); deviceControlAlarm.setAlarmInfo(new DeviceControlAlarm.AlarmInfo(alarmMethod, alarmType)); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlAlarm); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlAlarm.toString()); } public static String deviceControlAlarm(FromDevice fromDevice, ToDevice toDevice, DeviceControlPosition.HomePosition homePosition) { DeviceControlPosition deviceControlPosition = new DeviceControlPosition(CmdTypeEnum.DEVICE_CONTROL.getType(), RandomStrUtil.getValidationCode(), fromDevice.getUserId()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlPosition); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlPosition.toString()); } /** @@ -343,7 +341,7 @@ public static String deviceConfig(FromDevice fromDevice, ToDevice toDevice, Stri deviceConfigControl.setBasicParam(new DeviceConfigControl.BasicParam(name, expiration, heartBeatInterval, heartBeatCount)); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceConfigControl); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceConfigControl.toString()); } /** @@ -362,7 +360,7 @@ public static String deviceConfigDownload(FromDevice fromDevice, ToDevice toDevi deviceConfig.setConfigType(configType); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceConfig); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceConfig.toString()); } /** @@ -377,7 +375,7 @@ public static String deviceControlIdr(FromDevice fromDevice, ToDevice toDevice, new DeviceControlIFame(CmdTypeEnum.DEVICE_CONTROL.getType(), RandomStrUtil.getValidationCode(), fromDevice.getUserId()); String cmd = Optional.ofNullable(cmdStr).orElse("Send"); deviceControlIFame.setIFameCmd(cmd); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlIFame); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlIFame.toString()); } /** @@ -394,7 +392,7 @@ public static String deviceControlDragOut(FromDevice fromDevice, ToDevice toDevi dragZoomOut.setDragZoomOut(dragZoom); - return SipSender.doMessageRequest(fromDevice, toDevice, dragZoomOut); + return SipSender.doMessageRequest(fromDevice, toDevice, dragZoomOut.toString()); } /** @@ -411,7 +409,7 @@ public static String deviceControlDragIn(FromDevice fromDevice, ToDevice toDevic dragZoomIn.setDragZoomIn(dragZoom); - return SipSender.doMessageRequest(fromDevice, toDevice, dragZoomIn); + return SipSender.doMessageRequest(fromDevice, toDevice, dragZoomIn.toString()); } /** @@ -443,7 +441,7 @@ public static String deviceControlPtzCmd(FromDevice fromDevice, ToDevice toDevic deviceControlPtz.setPtzCmd(ptzCmd); deviceControlPtz.setPtzInfo(new DeviceControlPtz.PtzInfo()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlPtz); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlPtz.toString()); } /** @@ -457,7 +455,7 @@ public static String deviceControlTeleBoot(FromDevice fromDevice, ToDevice toDev DeviceControlTeleBoot deviceControlTeleBoot = new DeviceControlTeleBoot(CmdTypeEnum.DEVICE_CONTROL.getType(), RandomStrUtil.getValidationCode(), fromDevice.getUserId()); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlTeleBoot); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlTeleBoot.toString()); } /** @@ -474,7 +472,7 @@ public static String deviceControlTeleBoot(FromDevice fromDevice, ToDevice toDev deviceControlRecordCmd.setRecordCmd(recordCmd); - return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlRecordCmd); + return SipSender.doMessageRequest(fromDevice, toDevice, deviceControlRecordCmd.toString()); } /** diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageProcessorServer.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageProcessorServer.java index b130c595..34233a52 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageProcessorServer.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageProcessorServer.java @@ -1,12 +1,12 @@ package io.github.lunasaw.gbproxy.server.transimit.request.message; import io.github.lunasaw.sip.common.entity.RemoteAddressInfo; -import io.github.lunasaw.sip.common.entity.notify.DeviceAlarmNotify; -import io.github.lunasaw.sip.common.entity.notify.DeviceKeepLiveNotify; -import io.github.lunasaw.sip.common.entity.notify.MediaStatusNotify; -import io.github.lunasaw.sip.common.entity.notify.MobilePositionNotify; -import io.github.lunasaw.sip.common.entity.response.DeviceRecord; -import io.github.lunasaw.sip.common.entity.response.DeviceResponse; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceAlarmNotify; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceKeepLiveNotify; +import io.github.lunasaw.gb28181.common.entity.notify.MediaStatusNotify; +import io.github.lunasaw.gb28181.common.entity.notify.MobilePositionNotify; +import io.github.lunasaw.gb28181.common.entity.response.DeviceRecord; +import io.github.lunasaw.gb28181.common.entity.response.DeviceResponse; import io.github.lunasaw.sip.common.service.SipUserGenerate; /** diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageServerHandlerAbstract.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageServerHandlerAbstract.java index 02c4529c..598cd428 100755 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageServerHandlerAbstract.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/MessageServerHandlerAbstract.java @@ -1,7 +1,7 @@ package io.github.lunasaw.gbproxy.server.transimit.request.message; import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; import io.github.lunasaw.sip.common.transmit.event.message.MessageHandlerAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Data; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/AlarmNotifyMessageHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/AlarmNotifyMessageHandler.java index 8021baee..284a4ac9 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/AlarmNotifyMessageHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/AlarmNotifyMessageHandler.java @@ -2,13 +2,13 @@ import javax.sip.RequestEvent; -import io.github.lunasaw.sip.common.entity.notify.DeviceAlarmNotify; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceAlarmNotify; import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageProcessorServer; import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageServerHandlerAbstract; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/KeepaliveNotifyMessageHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/KeepaliveNotifyMessageHandler.java index 4b38fd52..146efe40 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/KeepaliveNotifyMessageHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/KeepaliveNotifyMessageHandler.java @@ -4,11 +4,10 @@ import javax.sip.message.Response; import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.RemoteAddressInfo; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.notify.DeviceKeepLiveNotify; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceKeepLiveNotify; import io.github.lunasaw.sip.common.transmit.ResponseCmd; import io.github.lunasaw.sip.common.utils.SipUtils; import org.springframework.stereotype.Component; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/MediaStatusNotifyMessageHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/MediaStatusNotifyMessageHandler.java index b350f204..75265fd0 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/MediaStatusNotifyMessageHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/MediaStatusNotifyMessageHandler.java @@ -6,10 +6,9 @@ import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageProcessorServer; import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageServerHandlerAbstract; -import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.notify.MediaStatusNotify; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.notify.MediaStatusNotify; import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/MobilePositionNotifyMessageHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/MobilePositionNotifyMessageHandler.java index 5ac3d330..4744db5c 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/MobilePositionNotifyMessageHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/notify/MobilePositionNotifyMessageHandler.java @@ -2,10 +2,9 @@ import javax.sip.RequestEvent; -import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.notify.MobilePositionNotify; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.notify.MobilePositionNotify; import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageProcessorServer; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageServerHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageServerHandler.java index 1e916b0b..7bcff709 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageServerHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageServerHandler.java @@ -3,9 +3,8 @@ import javax.sip.RequestEvent; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.response.DeviceRecord; -import io.github.lunasaw.sip.common.utils.SipUtils; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.response.DeviceRecord; import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageProcessorServer; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageServerHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageServerHandler.java index 15ed4dc6..964e0142 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageServerHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageServerHandler.java @@ -3,8 +3,8 @@ import javax.sip.RequestEvent; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; -import io.github.lunasaw.sip.common.entity.response.DeviceResponse; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.response.DeviceResponse; import org.springframework.stereotype.Component; import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageProcessorServer; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/register/ServerRegisterRequestProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/register/ServerRegisterRequestProcessor.java index e3597106..0cb81bea 100755 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/register/ServerRegisterRequestProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/register/ServerRegisterRequestProcessor.java @@ -20,7 +20,7 @@ import gov.nist.javax.sip.header.SIPDateHeader; import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.entity.GbSipDate; +import io.github.lunasaw.gb28181.common.entity.GbSipDate; import io.github.lunasaw.sip.common.entity.RemoteAddressInfo; import io.github.lunasaw.sip.common.entity.SipTransaction; import io.github.lunasaw.sip.common.transmit.ResponseCmd; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessor.java index 6125f0f2..7bf012fb 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessor.java @@ -4,9 +4,7 @@ import javax.sip.message.Response; import gov.nist.javax.sip.message.SIPResponse; -import io.github.lunasaw.sip.common.entity.query.DeviceQuery; -import io.github.lunasaw.sip.common.entity.response.DeviceResponse; -import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.gb28181.common.entity.response.DeviceSubscribe; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; @@ -47,7 +45,6 @@ public SubscribeResponseProcessor(SubscribeResponseProcessorServer subscribeResp public void process(ResponseEvent evt) { SIPResponse response = (SIPResponse)evt.getResponse(); if (response.getStatusCode() != Response.OK) { - log.error("process::evt = {} ", evt); return; } DeviceSubscribe deviceSubscribe = SipUtils.parseResponse(evt, DeviceSubscribe.class); diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java index c5ee8d3f..deca35cc 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/response/subscribe/SubscribeResponseProcessorServer.java @@ -1,6 +1,6 @@ package io.github.lunasaw.gbproxy.server.transimit.response.subscribe; -import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.gb28181.common.entity.response.DeviceSubscribe; import io.github.lunasaw.sip.common.service.SipUserGenerate; /** diff --git a/gb28181-server/src/test/java/io/github/lunasaw/gbproxy/server/cmd/Applicationtest.java b/gb28181-server/src/test/java/io/github/lunasaw/gbproxy/server/cmd/Applicationtest.java index d6ea7dfa..ba1265ee 100644 --- a/gb28181-server/src/test/java/io/github/lunasaw/gbproxy/server/cmd/Applicationtest.java +++ b/gb28181-server/src/test/java/io/github/lunasaw/gbproxy/server/cmd/Applicationtest.java @@ -1,6 +1,5 @@ package io.github.lunasaw.gbproxy.server.cmd; -import com.luna.common.os.SystemInfoUtil; import io.github.lunasaw.gbproxy.server.Gb28181Server; import io.github.lunasaw.gbproxy.server.transimit.cmd.ServerSendCmd; import io.github.lunasaw.sip.common.entity.FromDevice; diff --git a/gb28181-test/pom.xml b/gb28181-test/pom.xml index 137b3d3c..ebbc2361 100644 --- a/gb28181-test/pom.xml +++ b/gb28181-test/pom.xml @@ -28,6 +28,11 @@ sip-common + + io.github.lunasaw + gb28181-common + + io.github.lunasaw gb28181-client diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/config/DeviceConfig.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/config/DeviceConfig.java index 54a586c4..b7736573 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/config/DeviceConfig.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/config/DeviceConfig.java @@ -3,17 +3,15 @@ import java.util.Map; import java.util.concurrent.ConcurrentHashMap; -import com.luna.common.os.SystemInfoUtil; +import io.github.lunasaw.sip.common.entity.Device; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; -import io.github.lunasaw.gbproxy.test.user.client.DefaultRegisterProcessorClient; -import io.github.lunasaw.gbproxy.test.user.server.DefaultRegisterProcessorServer; -import io.github.lunasaw.sip.common.entity.Device; +import com.luna.common.os.SystemInfoUtil; + import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import oshi.SystemInfo; /** * @author luna diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultInfoProcessorClient.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultInfoProcessorClient.java index bf57b637..ef927469 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultInfoProcessorClient.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultInfoProcessorClient.java @@ -8,7 +8,6 @@ import io.github.lunasaw.gbproxy.test.config.DeviceConfig; import io.github.lunasaw.sip.common.entity.Device; - /** * @author luna * @date 2023/11/7 diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultMessageProcessorClient.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultMessageProcessorClient.java index 54ca2002..1d9f8b48 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultMessageProcessorClient.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultMessageProcessorClient.java @@ -1,11 +1,11 @@ package io.github.lunasaw.gbproxy.test.user.client; +import io.github.lunasaw.gb28181.common.entity.response.*; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; -import io.github.lunasaw.sip.common.entity.notify.DeviceAlarmNotify; -import io.github.lunasaw.sip.common.entity.notify.DeviceBroadcastNotify; -import io.github.lunasaw.sip.common.entity.query.DeviceAlarmQuery; -import io.github.lunasaw.sip.common.entity.query.DeviceConfigDownload; -import io.github.lunasaw.sip.common.entity.response.*; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceAlarmNotify; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceBroadcastNotify; +import io.github.lunasaw.gb28181.common.entity.query.DeviceAlarmQuery; +import io.github.lunasaw.gb28181.common.entity.query.DeviceConfigDownload; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; @@ -13,7 +13,7 @@ import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; import io.github.lunasaw.sip.common.entity.Device; -import io.github.lunasaw.sip.common.entity.query.DeviceRecordQuery; +import io.github.lunasaw.gb28181.common.entity.query.DeviceRecordQuery; import io.github.lunasaw.sip.common.utils.XmlUtils; /** diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java index da405034..28e1f411 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java @@ -7,8 +7,8 @@ import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeProcessorClient; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; import io.github.lunasaw.sip.common.entity.Device; -import io.github.lunasaw.sip.common.entity.query.DeviceQuery; -import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import io.github.lunasaw.gb28181.common.entity.query.DeviceQuery; +import io.github.lunasaw.gb28181.common.entity.response.DeviceSubscribe; import io.github.lunasaw.sip.common.enums.CmdTypeEnum; import io.github.lunasaw.sip.common.subscribe.SubscribeHolder; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java index f6da5b7b..92877d77 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultInviteResponseProcessorServer.java @@ -7,7 +7,6 @@ import io.github.lunasaw.gbproxy.server.transimit.response.invite.InviteResponseProcessorServer; import io.github.lunasaw.sip.common.entity.Device; - /** * @author luna * @date 2023/10/21 diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultMessageProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultMessageProcessorServer.java index 758068f2..8a9f0528 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultMessageProcessorServer.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultMessageProcessorServer.java @@ -1,22 +1,22 @@ package io.github.lunasaw.gbproxy.test.user.server; +import io.github.lunasaw.sip.common.entity.Device; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; import com.alibaba.fastjson.JSON; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceAlarmNotify; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceKeepLiveNotify; +import io.github.lunasaw.gb28181.common.entity.notify.MediaStatusNotify; +import io.github.lunasaw.gb28181.common.entity.notify.MobilePositionNotify; +import io.github.lunasaw.gb28181.common.entity.response.DeviceRecord; +import io.github.lunasaw.gb28181.common.entity.response.DeviceResponse; import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageProcessorServer; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; -import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.RemoteAddressInfo; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.notify.DeviceAlarmNotify; -import io.github.lunasaw.sip.common.entity.notify.DeviceKeepLiveNotify; -import io.github.lunasaw.sip.common.entity.notify.MediaStatusNotify; -import io.github.lunasaw.sip.common.entity.notify.MobilePositionNotify; -import io.github.lunasaw.sip.common.entity.response.DeviceRecord; -import io.github.lunasaw.sip.common.entity.response.DeviceResponse; import lombok.extern.slf4j.Slf4j; /** diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java index 2c59b270..53200160 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultSubscribeResponseProcessorServer.java @@ -1,15 +1,16 @@ package io.github.lunasaw.gbproxy.test.user.server; -import com.alibaba.fastjson2.JSON; -import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; +import com.alibaba.fastjson2.JSON; + +import io.github.lunasaw.sip.common.entity.Device; +import io.github.lunasaw.gb28181.common.entity.response.DeviceSubscribe; import io.github.lunasaw.gbproxy.server.transimit.response.subscribe.SubscribeResponseProcessorServer; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; -import io.github.lunasaw.sip.common.entity.Device; -import io.github.lunasaw.sip.common.entity.response.DeviceSubscribe; +import lombok.extern.slf4j.Slf4j; /** * @author luna diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/Gb28181Test.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/Gb28181Test.java index 16ab05d3..1e2a70cc 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/Gb28181Test.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/Gb28181Test.java @@ -11,7 +11,6 @@ import org.springframework.boot.test.context.SpringBootTest; import com.alibaba.fastjson2.JSON; -import com.luna.common.text.RandomStrUtil; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/Gb28181TestServer.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/Gb28181TestServer.java index db7b0a7e..3ce90954 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/Gb28181TestServer.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/Gb28181TestServer.java @@ -1,15 +1,10 @@ package io.github.lunasaw.gbproxy.test; -import javax.sip.message.Request; - import com.luna.common.date.DateUtils; import io.github.lunasaw.gbproxy.server.transimit.cmd.ServerSendCmd; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; -import io.github.lunasaw.gbproxy.test.user.client.DefaultRegisterProcessorClient; -import io.github.lunasaw.gbproxy.test.user.server.DefaultRegisterProcessorServer; -import io.github.lunasaw.sip.common.entity.control.DragZoom; +import io.github.lunasaw.gb28181.common.entity.control.DragZoom; import io.github.lunasaw.sip.common.utils.DynamicTask; -import io.github.lunasaw.sip.common.utils.SipRequestUtils; import lombok.SneakyThrows; import lombok.extern.slf4j.Slf4j; import org.junit.jupiter.api.AfterEach; @@ -20,16 +15,11 @@ import org.springframework.boot.test.context.SpringBootTest; import com.alibaba.fastjson2.JSON; -import com.luna.common.text.RandomStrUtil; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.sip.common.layer.SipLayer; -import io.github.lunasaw.sip.common.transmit.SipSender; -import io.github.lunasaw.sip.common.transmit.event.Event; -import io.github.lunasaw.sip.common.transmit.event.EventResult; -import io.github.lunasaw.sip.common.transmit.request.SipRequestProvider; import java.util.Date; diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/invite/ServerInviteTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/invite/ServerInviteTest.java index 4b3e1eae..928bd6c1 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/invite/ServerInviteTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/invite/ServerInviteTest.java @@ -1,5 +1,6 @@ package io.github.lunasaw.gbproxy.test.invite; +import io.github.lunasaw.sip.common.entity.Device; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; @@ -10,7 +11,6 @@ import io.github.lunasaw.gbproxy.server.transimit.cmd.ServerSendCmd; import io.github.lunasaw.gbproxy.test.Gb28181ApplicationTest; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; -import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.sip.common.layer.SipLayer; diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/register/RegisterClientTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/register/RegisterClientTest.java index 77722d4b..07c98493 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/register/RegisterClientTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/register/RegisterClientTest.java @@ -11,7 +11,6 @@ import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.test.context.SpringBootTest; -import io.github.lunasaw.gbproxy.test.user.client.DefaultRegisterProcessorClient; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java index c74e921a..13a1331a 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java @@ -9,17 +9,13 @@ import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.test.context.SpringBootTest; -import io.github.lunasaw.gbproxy.client.transmit.cmd.ClientSendCmd; import io.github.lunasaw.gbproxy.test.Gb28181ApplicationTest; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; -import io.github.lunasaw.gbproxy.test.user.client.DefaultRegisterProcessorClient; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.sip.common.layer.SipLayer; import io.github.lunasaw.sip.common.transmit.SipSender; -import io.github.lunasaw.sip.common.transmit.event.Event; -import io.github.lunasaw.sip.common.transmit.event.EventResult; import io.github.lunasaw.sip.common.transmit.request.SipRequestProvider; import io.github.lunasaw.sip.common.utils.SipRequestUtils; import lombok.extern.slf4j.Slf4j; diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java index ebdef4f5..7606854d 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java @@ -1,8 +1,5 @@ package io.github.lunasaw.gbproxy.test.subscribe; -import java.util.Date; - -import com.luna.common.text.RandomStrUtil; import io.github.lunasaw.sip.common.enums.CmdTypeEnum; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.BeforeEach; @@ -11,16 +8,12 @@ import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.test.context.SpringBootTest; -import com.alibaba.fastjson2.JSON; -import com.luna.common.date.DateUtils; - import io.github.lunasaw.gbproxy.server.transimit.cmd.ServerSendCmd; import io.github.lunasaw.gbproxy.test.Gb28181ApplicationTest; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.control.DragZoom; import io.github.lunasaw.sip.common.layer.SipLayer; import io.github.lunasaw.sip.common.utils.DynamicTask; import lombok.SneakyThrows; diff --git a/pom.xml b/pom.xml index 555f223f..0bb3b894 100644 --- a/pom.xml +++ b/pom.xml @@ -13,6 +13,7 @@ gb28181-client gb28181-server gb28181-test + gb28181-common sip-proxy 轻量级SIP框架封装 @@ -83,6 +84,11 @@ ${sip-proxy-common.version} + + io.github.lunasaw + gb28181-common + ${sip-proxy-common.version} + diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/msg/StringMsgParser.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/msg/StringMsgParser.java index 465bfac7..d0c47286 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/msg/StringMsgParser.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/msg/StringMsgParser.java @@ -1,6 +1,7 @@ package io.github.lunasaw.sip.common.conf.msg; import java.io.UnsupportedEncodingException; +import java.nio.charset.StandardCharsets; import java.text.ParseException; import gov.nist.core.CommonLogger; @@ -82,11 +83,7 @@ public SIPMessage parseSIPMessage(byte[] msgBuffer, boolean readBody, boolean st int lineLength = i - lineStart; // Make it a String. - try { - currentLine = new String(msgBuffer, lineStart, lineLength, "UTF-8"); - } catch (UnsupportedEncodingException e) { - throw new ParseException("Bad message encoding!", 0); - } + currentLine = new String(msgBuffer, lineStart, lineLength, StandardCharsets.UTF_8); currentLine = trimEndOfLine(currentLine); diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/DeviceSession.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/DeviceSession.java similarity index 82% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/DeviceSession.java rename to sip-common/src/main/java/io/github/lunasaw/sip/common/entity/DeviceSession.java index 53da696c..e27c9863 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/base/DeviceSession.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/DeviceSession.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.entity.base; +package io.github.lunasaw.gb28181.common.entity.base; import lombok.AllArgsConstructor; import lombok.Data; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/SipMessage.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/SipMessage.java index 142f331a..7b28fbb3 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/SipMessage.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/SipMessage.java @@ -6,13 +6,13 @@ import javax.sip.header.Header; import javax.sip.message.Request; +import org.apache.commons.collections4.CollectionUtils; +import org.assertj.core.util.Lists; + import gov.nist.javax.sip.message.SIPResponse; import io.github.lunasaw.sip.common.enums.ContentTypeEnum; import io.github.lunasaw.sip.common.sequence.GenerateSequenceImpl; import io.github.lunasaw.sip.common.utils.SipRequestUtils; -import org.apache.commons.collections4.CollectionUtils; -import org.assertj.core.util.Lists; - import lombok.Data; /** diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/SipTransaction.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/SipTransaction.java index 219ad490..3d511deb 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/SipTransaction.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/SipTransaction.java @@ -1,7 +1,5 @@ package io.github.lunasaw.sip.common.entity; -import gov.nist.javax.sip.message.SIPRequest; -import gov.nist.javax.sip.message.SIPResponse; import lombok.Data; /** diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceControlType.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceControlType.java index dd2eb778..1b2a2184 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceControlType.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceControlType.java @@ -7,7 +7,6 @@ import org.apache.commons.lang3.StringUtils; import org.springframework.util.ObjectUtils; -import io.github.lunasaw.sip.common.entity.control.*; import lombok.SneakyThrows; @Getter diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipSender.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipSender.java index b67abb94..d44b7ee1 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipSender.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipSender.java @@ -1,5 +1,17 @@ package io.github.lunasaw.sip.common.transmit; +import java.util.Objects; + +import javax.sip.ServerTransaction; +import javax.sip.SipException; +import javax.sip.address.SipURI; +import javax.sip.header.CallIdHeader; +import javax.sip.header.UserAgentHeader; +import javax.sip.header.ViaHeader; +import javax.sip.message.Message; +import javax.sip.message.Request; +import javax.sip.message.Response; + import gov.nist.javax.sip.SipProviderImpl; import gov.nist.javax.sip.SipStackImpl; import gov.nist.javax.sip.message.SIPRequest; @@ -8,7 +20,6 @@ import io.github.lunasaw.sip.common.constant.Constant; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; -import io.github.lunasaw.sip.common.entity.xml.XmlBean; import io.github.lunasaw.sip.common.layer.SipLayer; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.event.Event; @@ -18,17 +29,6 @@ import lombok.Data; import lombok.extern.slf4j.Slf4j; -import javax.sip.ServerTransaction; -import javax.sip.SipException; -import javax.sip.address.SipURI; -import javax.sip.header.CallIdHeader; -import javax.sip.header.UserAgentHeader; -import javax.sip.header.ViaHeader; -import javax.sip.message.Message; -import javax.sip.message.Request; -import javax.sip.message.Response; -import java.util.Objects; - /** * 发送SIP消息 * @@ -38,17 +38,17 @@ @Data public class SipSender { - public static String doSubscribeRequest(FromDevice fromDevice, ToDevice toDevice, XmlBean xmlBean, SubscribeInfo subscribeInfo) { + public static String doSubscribeRequest(FromDevice fromDevice, ToDevice toDevice, String content, SubscribeInfo subscribeInfo) { - return doSubscribeRequest(fromDevice, toDevice, xmlBean, subscribeInfo, null, null); + return doSubscribeRequest(fromDevice, toDevice, content, subscribeInfo, null, null); } - public static String doMessageRequest(FromDevice fromDevice, ToDevice toDevice, XmlBean xmlBean) { - return doMessageRequest(fromDevice, toDevice, xmlBean, null, null); + public static String doMessageRequest(FromDevice fromDevice, ToDevice toDevice, String contend) { + return doMessageRequest(fromDevice, toDevice, contend, null, null); } - public static String doNotifyRequest(FromDevice fromDevice, ToDevice toDevice, XmlBean xmlBean, SubscribeInfo subscribeInfo) { - return doNotifyRequest(fromDevice, toDevice, xmlBean, subscribeInfo, null, null); + public static String doNotifyRequest(FromDevice fromDevice, ToDevice toDevice, String content, SubscribeInfo subscribeInfo) { + return doNotifyRequest(fromDevice, toDevice, content, subscribeInfo, null, null); } public static String doInviteRequest(FromDevice fromDevice, ToDevice toDevice, String contend, String subject) { @@ -75,26 +75,26 @@ public static String doRegisterRequest(FromDevice fromDevice, ToDevice toDevice, return callId; } - public static String doSubscribeRequest(FromDevice fromDevice, ToDevice toDevice, XmlBean xmlBean, SubscribeInfo subscribeInfo, Event errorEvent, + public static String doSubscribeRequest(FromDevice fromDevice, ToDevice toDevice, String contend, SubscribeInfo subscribeInfo, Event errorEvent, Event okEvent) { String callId = SipRequestUtils.getNewCallId(); - Request messageRequest = SipRequestProvider.createSubscribeRequest(fromDevice, toDevice, xmlBean.toString(), subscribeInfo, callId); + Request messageRequest = SipRequestProvider.createSubscribeRequest(fromDevice, toDevice, contend, subscribeInfo, callId); SipSender.transmitRequest(fromDevice.getIp(), messageRequest, errorEvent, okEvent); return callId; } - public static String doNotifyRequest(FromDevice fromDevice, ToDevice toDevice, XmlBean xmlBean, SubscribeInfo subscribeInfo, Event errorEvent, + public static String doNotifyRequest(FromDevice fromDevice, ToDevice toDevice, String contend, SubscribeInfo subscribeInfo, Event errorEvent, Event okEvent) { String callId = SipRequestUtils.getNewCallId(); - Request messageRequest = SipRequestProvider.createNotifyRequest(fromDevice, toDevice, xmlBean.toString(), subscribeInfo, callId); + Request messageRequest = SipRequestProvider.createNotifyRequest(fromDevice, toDevice, contend, subscribeInfo, callId); SipSender.transmitRequest(fromDevice.getIp(), messageRequest, errorEvent, okEvent); return callId; } - public static String doMessageRequest(FromDevice fromDevice, ToDevice toDevice, XmlBean xmlBean, Event errorEvent, Event okEvent) { + public static String doMessageRequest(FromDevice fromDevice, ToDevice toDevice, String contend, Event errorEvent, Event okEvent) { String callId = SipRequestUtils.getNewCallId(); - Request messageRequest = SipRequestProvider.createMessageRequest(fromDevice, toDevice, xmlBean.toString(), callId); + Request messageRequest = SipRequestProvider.createMessageRequest(fromDevice, toDevice, contend, callId); SipSender.transmitRequest(fromDevice.getIp(), messageRequest, errorEvent, okEvent); return callId; } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandlerAbstract.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandlerAbstract.java index e446fe75..32d81c04 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandlerAbstract.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/event/message/MessageHandlerAbstract.java @@ -5,13 +5,13 @@ import javax.sip.RequestEvent; import javax.sip.message.Response; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; import org.apache.commons.lang3.StringUtils; import com.luna.common.text.StringTools; import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.sip.common.constant.Constant; -import io.github.lunasaw.sip.common.entity.base.DeviceSession; import io.github.lunasaw.sip.common.transmit.ResponseCmd; import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.Getter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/request/SipRequestProvider.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/request/SipRequestProvider.java index 997413f4..616466d5 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/request/SipRequestProvider.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/request/SipRequestProvider.java @@ -1,30 +1,29 @@ package io.github.lunasaw.sip.common.transmit.request; +import java.text.ParseException; +import java.util.List; +import java.util.Optional; +import java.util.UUID; + +import javax.sip.address.SipURI; +import javax.sip.address.URI; +import javax.sip.header.*; +import javax.sip.message.Request; + +import org.apache.commons.lang3.StringUtils; +import org.assertj.core.util.Lists; +import org.springframework.util.DigestUtils; + import com.luna.common.check.Assert; + import gov.nist.javax.sip.message.SIPRequest; import gov.nist.javax.sip.message.SIPResponse; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.sip.common.entity.SdpSessionDescription; import io.github.lunasaw.sip.common.entity.SipMessage; import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.sip.common.enums.ContentTypeEnum; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.utils.SipRequestUtils; -import io.github.lunasaw.sip.common.utils.SipUtils; -import org.apache.commons.lang3.StringUtils; -import org.assertj.core.util.Lists; -import org.springframework.util.DigestUtils; - -import javax.sdp.SessionDescription; -import javax.sip.SipFactory; -import javax.sip.address.SipURI; -import javax.sip.address.URI; -import javax.sip.header.*; -import javax.sip.message.Request; -import java.text.ParseException; -import java.util.List; -import java.util.Optional; -import java.util.UUID; /** * Sip命令request创造器 diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/response/SipResponseProvider.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/response/SipResponseProvider.java index b9578ed4..0d5c9663 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/response/SipResponseProvider.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/response/SipResponseProvider.java @@ -7,7 +7,6 @@ import org.assertj.core.util.Lists; import javax.sip.header.*; -import javax.sip.message.Request; import javax.sip.message.Response; import java.util.List; diff --git a/sip-common/src/test/java/io/github/lunasaw/sip/common/test/ApplicationTest.java b/sip-common/src/test/java/io/github/lunasaw/sip/common/test/ApplicationTest.java index f43bba85..ba6b32ac 100644 --- a/sip-common/src/test/java/io/github/lunasaw/sip/common/test/ApplicationTest.java +++ b/sip-common/src/test/java/io/github/lunasaw/sip/common/test/ApplicationTest.java @@ -10,7 +10,6 @@ import org.springframework.boot.test.context.SpringBootTest; import com.luna.common.os.SystemInfoUtil; -import com.luna.common.text.RandomStrUtil; import lombok.SneakyThrows; From f77a0d534559426073bcd80d1dfc023d48ded35b Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Wed, 13 Dec 2023 16:56:07 +0800 Subject: [PATCH 12/17] :memo: code reformat --- .../client/entity/InviteResponseEntity.java | 2 +- .../client/transmit/cmd/ClientSendCmd.java | 2 +- .../request/invite/InviteProcessorClient.java | 2 +- .../control/DeviceControlMessageHandler.java | 2 +- .../catalog/CatalogQueryMessageHandler.java | 2 +- .../entity/control/DeviceControlDragIn.java | 33 +++---------------- .../common/entity}/enums/CmdTypeEnum.java | 2 +- .../entity}/enums/DeviceControlType.java | 3 +- .../common/entity}/enums/DeviceGbType.java | 2 +- .../entity}/enums/InviteSessionNameEnum.java | 2 +- .../common/entity/response/DeviceItem.java | 2 +- .../common/entity/utils}/PtzCmdEnum.java | 2 +- .../common/entity}/utils/PtzUtils.java | 3 +- .../gbproxy/server/entity/InviteEntity.java | 2 +- .../server/transimit/cmd/ServerSendCmd.java | 6 ++-- .../ServerRegisterRequestProcessor.java | 2 +- .../client/DefaultInviteProcessorClient.java | 2 +- .../DefaultSubscribeProcessorClient.java | 2 +- .../test/subscribe/SubscribeServerTest.java | 2 +- .../lunasaw/sip}/common/entity/GbSipDate.java | 2 +- 20 files changed, 26 insertions(+), 51 deletions(-) rename {sip-common/src/main/java/io/github/lunasaw/sip/common => gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity}/enums/CmdTypeEnum.java (95%) rename {sip-common/src/main/java/io/github/lunasaw/sip/common => gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity}/enums/DeviceControlType.java (95%) rename {sip-common/src/main/java/io/github/lunasaw/sip/common => gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity}/enums/DeviceGbType.java (94%) rename {sip-common/src/main/java/io/github/lunasaw/sip/common => gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity}/enums/InviteSessionNameEnum.java (91%) rename {sip-common/src/main/java/io/github/lunasaw/sip/common/enums => gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/utils}/PtzCmdEnum.java (96%) rename {sip-common/src/main/java/io/github/lunasaw/sip/common => gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity}/utils/PtzUtils.java (93%) rename {gb28181-common/src/main/java/io/github/lunasaw/gb28181 => sip-common/src/main/java/io/github/lunasaw/sip}/common/entity/GbSipDate.java (98%) diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/entity/InviteResponseEntity.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/entity/InviteResponseEntity.java index d7b2ffdb..607b541b 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/entity/InviteResponseEntity.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/entity/InviteResponseEntity.java @@ -1,6 +1,6 @@ package io.github.lunasaw.gbproxy.client.entity; -import io.github.lunasaw.sip.common.enums.InviteSessionNameEnum; +import io.github.lunasaw.gb28181.common.entity.enums.InviteSessionNameEnum; import lombok.Getter; import lombok.Setter; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java index 8485b713..83585b77 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java @@ -10,7 +10,7 @@ import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.gb28181.common.entity.notify.*; import io.github.lunasaw.gb28181.common.entity.response.*; -import io.github.lunasaw.sip.common.enums.CmdTypeEnum; +import io.github.lunasaw.gb28181.common.entity.enums.CmdTypeEnum; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.SipSender; import io.github.lunasaw.sip.common.transmit.event.Event; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/invite/InviteProcessorClient.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/invite/InviteProcessorClient.java index 5c8bc439..d34d8eb5 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/invite/InviteProcessorClient.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/invite/InviteProcessorClient.java @@ -5,7 +5,7 @@ import io.github.lunasaw.gbproxy.client.entity.InviteResponseEntity; import io.github.lunasaw.sip.common.entity.GbSessionDescription; import io.github.lunasaw.sip.common.entity.SdpSessionDescription; -import io.github.lunasaw.sip.common.enums.InviteSessionNameEnum; +import io.github.lunasaw.gb28181.common.entity.enums.InviteSessionNameEnum; import io.github.lunasaw.sip.common.service.SipUserGenerate; import lombok.SneakyThrows; import org.apache.commons.collections4.CollectionUtils; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/control/DeviceControlMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/control/DeviceControlMessageHandler.java index b875599f..4eafb5ca 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/control/DeviceControlMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/handler/control/DeviceControlMessageHandler.java @@ -2,7 +2,7 @@ import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageClientHandlerAbstract; import io.github.lunasaw.gbproxy.client.transmit.request.message.MessageProcessorClient; -import io.github.lunasaw.sip.common.enums.DeviceControlType; +import io.github.lunasaw.gb28181.common.entity.enums.DeviceControlType; import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java index a44d0f8c..2952d585 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/catalog/CatalogQueryMessageHandler.java @@ -17,7 +17,7 @@ import io.github.lunasaw.gbproxy.client.transmit.request.subscribe.SubscribeProcessorClient; import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; import io.github.lunasaw.gb28181.common.entity.query.DeviceQuery; -import io.github.lunasaw.sip.common.enums.CmdTypeEnum; +import io.github.lunasaw.gb28181.common.entity.enums.CmdTypeEnum; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.event.message.MessageHandler; import lombok.Getter; diff --git a/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragIn.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragIn.java index 92510e64..45d2faec 100644 --- a/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragIn.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/control/DeviceControlDragIn.java @@ -1,8 +1,10 @@ package io.github.lunasaw.gb28181.common.entity.control; -import javax.xml.bind.annotation.*; +import javax.xml.bind.annotation.XmlAccessType; +import javax.xml.bind.annotation.XmlAccessorType; +import javax.xml.bind.annotation.XmlElement; +import javax.xml.bind.annotation.XmlRootElement; -import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.AllArgsConstructor; import lombok.Getter; import lombok.NoArgsConstructor; @@ -46,32 +48,5 @@ public DeviceControlDragIn(String cmdType, String sn, String deviceId) { this.setControlType("DragZoomIn"); } - public static void main(String[] args) { - DeviceControlDragIn deviceControlDrag = new DeviceControlDragIn(); - - deviceControlDrag.setDragZoomIn(new DragZoom("1", "2", "3", "4", "5", "6")); - - System.out.println(deviceControlDrag); - - String data = "\n" + - "\n" + - " DeviceControl\n" + - " 797466\n" + - " 41010500002000000001\n" + - " DragZoomIn\n" + - " \n" + - " 1\n" + - " 1\n" + - " 1\n" + - " 1\n" + - " 1\n" + - " 1\n" + - " \n" + - "\n"; - - DeviceControlDragIn o = (DeviceControlDragIn) XmlUtils.parseObj(data, DeviceControlDragIn.class); - System.out.println(o); - } - } diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/CmdTypeEnum.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/CmdTypeEnum.java similarity index 95% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/enums/CmdTypeEnum.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/CmdTypeEnum.java index ed0ab1f8..09557185 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/CmdTypeEnum.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/CmdTypeEnum.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.enums; +package io.github.lunasaw.gb28181.common.entity.enums; /** * @author luna diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceControlType.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/DeviceControlType.java similarity index 95% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceControlType.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/DeviceControlType.java index 1b2a2184..a1fab029 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceControlType.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/DeviceControlType.java @@ -1,8 +1,9 @@ -package io.github.lunasaw.sip.common.enums; +package io.github.lunasaw.gb28181.common.entity.enums; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; +import io.github.lunasaw.gb28181.common.entity.control.*; import lombok.Getter; import org.apache.commons.lang3.StringUtils; import org.springframework.util.ObjectUtils; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceGbType.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/DeviceGbType.java similarity index 94% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceGbType.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/DeviceGbType.java index 1c89d6f5..1b64f599 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/DeviceGbType.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/DeviceGbType.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.enums; +package io.github.lunasaw.gb28181.common.entity.enums; import java.util.HashMap; import java.util.Map; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/InviteSessionNameEnum.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/InviteSessionNameEnum.java similarity index 91% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/enums/InviteSessionNameEnum.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/InviteSessionNameEnum.java index bc591fda..749bc12f 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/InviteSessionNameEnum.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/enums/InviteSessionNameEnum.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.enums; +package io.github.lunasaw.gb28181.common.entity.enums; /** * @author luna diff --git a/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceItem.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceItem.java index 3f7e153c..ef54b3f7 100644 --- a/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceItem.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/response/DeviceItem.java @@ -2,13 +2,13 @@ import javax.xml.bind.annotation.*; +import io.github.lunasaw.gb28181.common.entity.enums.DeviceGbType; import org.apache.commons.lang3.StringUtils; import com.luna.common.check.Assert; import com.luna.common.date.DateUtils; import com.luna.common.os.SystemInfoUtil; -import io.github.lunasaw.sip.common.enums.DeviceGbType; import lombok.Getter; import lombok.Setter; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/PtzCmdEnum.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/utils/PtzCmdEnum.java similarity index 96% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/enums/PtzCmdEnum.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/utils/PtzCmdEnum.java index 0c227112..f0a8ee44 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/enums/PtzCmdEnum.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/utils/PtzCmdEnum.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.sip.common.enums; +package io.github.lunasaw.gb28181.common.entity.utils; import java.util.HashMap; import java.util.Map; diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/utils/PtzUtils.java b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/utils/PtzUtils.java similarity index 93% rename from sip-common/src/main/java/io/github/lunasaw/sip/common/utils/PtzUtils.java rename to gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/utils/PtzUtils.java index d970ce9c..77268544 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/utils/PtzUtils.java +++ b/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/utils/PtzUtils.java @@ -1,6 +1,5 @@ -package io.github.lunasaw.sip.common.utils; +package io.github.lunasaw.gb28181.common.entity.utils; -import io.github.lunasaw.sip.common.enums.PtzCmdEnum; public class PtzUtils { diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/entity/InviteEntity.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/entity/InviteEntity.java index b31f440b..a110c8cc 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/entity/InviteEntity.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/entity/InviteEntity.java @@ -1,6 +1,6 @@ package io.github.lunasaw.gbproxy.server.entity; -import io.github.lunasaw.sip.common.enums.InviteSessionNameEnum; +import io.github.lunasaw.gb28181.common.entity.enums.InviteSessionNameEnum; import io.github.lunasaw.sip.common.enums.ManufacturerEnum; import io.github.lunasaw.sip.common.enums.StreamModeEnum; import org.apache.commons.lang3.StringUtils; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java index 4170efe0..4e47a7c6 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/cmd/ServerSendCmd.java @@ -18,11 +18,11 @@ import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.gb28181.common.entity.notify.DeviceBroadcastNotify; -import io.github.lunasaw.sip.common.enums.CmdTypeEnum; -import io.github.lunasaw.sip.common.enums.PtzCmdEnum; +import io.github.lunasaw.gb28181.common.entity.enums.CmdTypeEnum; +import io.github.lunasaw.gb28181.common.entity.utils.PtzCmdEnum; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; import io.github.lunasaw.sip.common.transmit.SipSender; -import io.github.lunasaw.sip.common.utils.PtzUtils; +import io.github.lunasaw.gb28181.common.entity.utils.PtzUtils; /** * @author luna diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/register/ServerRegisterRequestProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/register/ServerRegisterRequestProcessor.java index 0cb81bea..e3597106 100755 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/register/ServerRegisterRequestProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/register/ServerRegisterRequestProcessor.java @@ -20,7 +20,7 @@ import gov.nist.javax.sip.header.SIPDateHeader; import gov.nist.javax.sip.message.SIPRequest; import io.github.lunasaw.sip.common.entity.FromDevice; -import io.github.lunasaw.gb28181.common.entity.GbSipDate; +import io.github.lunasaw.sip.common.entity.GbSipDate; import io.github.lunasaw.sip.common.entity.RemoteAddressInfo; import io.github.lunasaw.sip.common.entity.SipTransaction; import io.github.lunasaw.sip.common.transmit.ResponseCmd; diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultInviteProcessorClient.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultInviteProcessorClient.java index 55983e2b..1652ec7d 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultInviteProcessorClient.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultInviteProcessorClient.java @@ -6,7 +6,7 @@ import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.GbSessionDescription; import io.github.lunasaw.sip.common.entity.SdpSessionDescription; -import io.github.lunasaw.sip.common.enums.InviteSessionNameEnum; +import io.github.lunasaw.gb28181.common.entity.enums.InviteSessionNameEnum; import io.github.lunasaw.sip.common.transmit.event.SipSubscribe; import lombok.SneakyThrows; import lombok.extern.slf4j.Slf4j; diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java index 28e1f411..2dcf2dad 100644 --- a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/client/DefaultSubscribeProcessorClient.java @@ -9,7 +9,7 @@ import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.gb28181.common.entity.query.DeviceQuery; import io.github.lunasaw.gb28181.common.entity.response.DeviceSubscribe; -import io.github.lunasaw.sip.common.enums.CmdTypeEnum; +import io.github.lunasaw.gb28181.common.entity.enums.CmdTypeEnum; import io.github.lunasaw.sip.common.subscribe.SubscribeHolder; import io.github.lunasaw.sip.common.subscribe.SubscribeInfo; diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java index 7606854d..8d87450c 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeServerTest.java @@ -1,6 +1,6 @@ package io.github.lunasaw.gbproxy.test.subscribe; -import io.github.lunasaw.sip.common.enums.CmdTypeEnum; +import io.github.lunasaw.gb28181.common.entity.enums.CmdTypeEnum; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; diff --git a/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/GbSipDate.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/GbSipDate.java similarity index 98% rename from gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/GbSipDate.java rename to sip-common/src/main/java/io/github/lunasaw/sip/common/entity/GbSipDate.java index 9ef44c2e..55c4989d 100644 --- a/gb28181-common/src/main/java/io/github/lunasaw/gb28181/common/entity/GbSipDate.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/entity/GbSipDate.java @@ -1,4 +1,4 @@ -package io.github.lunasaw.gb28181.common.entity; +package io.github.lunasaw.sip.common.entity; import java.util.*; From 132bafceddd1b11d1744ae3aaf9b0a01bb8841a1 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Wed, 13 Dec 2023 17:09:42 +0800 Subject: [PATCH 13/17] :memo: 1.1.4 code reformat --- gb28181-client/pom.xml | 2 +- .../request/message/MessageClientHandlerAbstract.java | 3 ++- .../subscribe/ClientSubscribeRequestProcessor.java | 9 +++++++-- gb28181-common/pom.xml | 2 +- gb28181-server/pom.xml | 2 +- gb28181-test/pom.xml | 2 +- pom.xml | 6 +++--- sip-common/pom.xml | 4 ++-- 8 files changed, 18 insertions(+), 12 deletions(-) diff --git a/gb28181-client/pom.xml b/gb28181-client/pom.xml index ab4b1d85..718413ae 100644 --- a/gb28181-client/pom.xml +++ b/gb28181-client/pom.xml @@ -6,7 +6,7 @@ io.github.lunasaw sip-proxy - 1.1.3 + 1.1.4 ${gb28181-proxy.version} diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageClientHandlerAbstract.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageClientHandlerAbstract.java index 3db3b46c..737ff129 100755 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageClientHandlerAbstract.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/message/MessageClientHandlerAbstract.java @@ -5,6 +5,7 @@ import io.github.lunasaw.sip.common.transmit.event.message.MessageHandlerAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; import lombok.Data; +import org.springframework.context.annotation.Lazy; import org.springframework.stereotype.Component; import javax.annotation.Resource; @@ -20,7 +21,7 @@ public abstract class MessageClientHandlerAbstract extends MessageHandlerAbstrac @Resource public MessageProcessorClient messageProcessorClient; - public MessageClientHandlerAbstract(MessageProcessorClient messageProcessorClient) { + public MessageClientHandlerAbstract(@Lazy MessageProcessorClient messageProcessorClient) { this.messageProcessorClient = messageProcessorClient; } diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java index 661a600c..5ded13ef 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/request/subscribe/ClientSubscribeRequestProcessor.java @@ -1,8 +1,9 @@ package io.github.lunasaw.gbproxy.client.transmit.request.subscribe; +import javax.annotation.Resource; import javax.sip.RequestEvent; -import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.annotation.Lazy; import org.springframework.stereotype.Component; import gov.nist.javax.sip.message.SIPRequest; @@ -28,9 +29,13 @@ public class ClientSubscribeRequestProcessor extends SipMessageRequestProcessorA private String method = METHOD; - @Autowired + @Resource private SubscribeProcessorClient subscribeProcessorClient; + public ClientSubscribeRequestProcessor(@Lazy SubscribeProcessorClient subscribeProcessorClient) { + this.subscribeProcessorClient = subscribeProcessorClient; + } + /** * 收到SUBSCRIBE请求 处理 * diff --git a/gb28181-common/pom.xml b/gb28181-common/pom.xml index b2f07439..4ae02a74 100644 --- a/gb28181-common/pom.xml +++ b/gb28181-common/pom.xml @@ -6,7 +6,7 @@ io.github.lunasaw sip-proxy - 1.1.3 + 1.1.4 ${gb28181-proxy.version} diff --git a/gb28181-server/pom.xml b/gb28181-server/pom.xml index 108b5e64..64d7b57d 100644 --- a/gb28181-server/pom.xml +++ b/gb28181-server/pom.xml @@ -6,7 +6,7 @@ io.github.lunasaw sip-proxy - 1.1.3 + 1.1.4 ${gb28181-proxy.version} diff --git a/gb28181-test/pom.xml b/gb28181-test/pom.xml index ebbc2361..62dd923f 100644 --- a/gb28181-test/pom.xml +++ b/gb28181-test/pom.xml @@ -6,7 +6,7 @@ io.github.lunasaw sip-proxy - 1.1.3 + 1.1.4 ${gb28181-proxy.version} diff --git a/pom.xml b/pom.xml index 0bb3b894..35956510 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ io.github.lunasaw sip-proxy - 1.1.3 + 1.1.4 pom sip-common @@ -28,8 +28,8 @@ ${project.name} 1.3.0-91 2.1.4 - 1.1.3 - 1.1.3 + 1.1.4 + 1.1.4 diff --git a/sip-common/pom.xml b/sip-common/pom.xml index 5824dd51..d7143762 100644 --- a/sip-common/pom.xml +++ b/sip-common/pom.xml @@ -6,11 +6,11 @@ io.github.lunasaw sip-proxy - 1.1.3 + 1.1.4 jar - 1.1.3 + 1.1.4 sip-common sip-common 轻量级SIP框架封装 From fbb6bc81f446809eb285a6655b1073a0b85bf545 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Wed, 13 Dec 2023 19:52:37 +0800 Subject: [PATCH 14/17] :memo: 1.1.4 code reformat --- .../sip/common/conf/DefaultProperties.java | 40 +++------- .../sip/common/conf/StackLoggerImpl.java | 56 ++++++++++--- .../src/main/resources/config.properties | 18 +++++ sip-common/src/main/resources/sip.config | 78 +++++++++++++++++++ 4 files changed, 152 insertions(+), 40 deletions(-) create mode 100644 sip-common/src/main/resources/config.properties create mode 100644 sip-common/src/main/resources/sip.config diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/DefaultProperties.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/DefaultProperties.java index f47b8a52..d5b5c45d 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/DefaultProperties.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/DefaultProperties.java @@ -1,7 +1,11 @@ package io.github.lunasaw.sip.common.conf; +import java.io.File; +import java.nio.file.Files; import java.util.Properties; +import org.springframework.util.ResourceUtils; + import lombok.extern.slf4j.Slf4j; /** @@ -16,40 +20,18 @@ public static Properties getProperties(String name, String ip, boolean sipLog) { Properties properties = new Properties(); properties.setProperty("javax.sip.STACK_NAME", name); properties.setProperty("javax.sip.IP_ADDRESS", ip); - // 关闭自动会话 - // properties.setProperty("javax.sip.AUTOMATIC_DIALOG_SUPPORT", "true"); - /** - * 完整配置参考 gov.nist.javax.sip.SipStackImpl,需要下载源码 - * gov/nist/javax/sip/SipStackImpl.class - * sip消息的解析在 gov.nist.javax.sip.stack.UDPMessageChannel的processIncomingDataPacket 方法 - */ - // * gov/nist/javax/sip/SipStackImpl.class - // 接收所有notify请求,即使没有订阅 - properties.setProperty("gov.nist.javax.sip.DELIVER_UNSOLICITED_NOTIFY", "true"); - properties.setProperty("gov.nist.javax.sip.AUTOMATIC_DIALOG_ERROR_HANDLING", "false"); - properties.setProperty("gov.nist.javax.sip.CANCEL_CLIENT_TRANSACTION_CHECKED", "true"); - // 为_NULL _对话框传递_终止的_事件 - properties.setProperty("gov.nist.javax.sip.DELIVER_TERMINATED_EVENT_FOR_NULL_DIALOG", "true"); - // 是否自动计算content length的实际长度,默认不计算 - properties.setProperty("gov.nist.javax.sip.COMPUTE_CONTENT_LENGTH_FROM_MESSAGE_BODY", "true"); - // 会话清理策略 - properties.setProperty("gov.nist.javax.sip.RELEASE_REFERENCES_STRATEGY", "Normal"); - // 处理由该服务器处理的基于底层TCP的保持生存超时 - properties.setProperty("gov.nist.javax.sip.RELIABLE_CONNECTION_KEEP_ALIVE_TIMEOUT", "60"); - // 获取实际内容长度,不使用header中的长度信息 - properties.setProperty("gov.nist.javax.sip.COMPUTE_CONTENT_LENGTH_FROM_MESSAGE_BODY", "true"); - // 线程可重入 - properties.setProperty("gov.nist.javax.sip.REENTRANT_LISTENER", "true"); - // 定义应用程序打算多久审计一次 SIP 堆栈,了解其内部线程的健康状况(该属性指定连续审计之间的时间(以毫秒为单位)) - properties.setProperty("gov.nist.javax.sip.THREAD_AUDIT_INTERVAL_IN_MILLISECS", "30000"); - - // properties.setProperty("gov.nist.javax.sip.MESSAGE_PROCESSOR_FACTORY", - // "gov.nist.javax.sip.stack.NioMessageProcessorFactory"); /** * sip_server_log.log 和 sip_debug_log.log ERROR, INFO, WARNING, OFF, DEBUG, TRACE */ + try { + File configFile = ResourceUtils.getFile("classpath:config.properties").getAbsoluteFile(); + properties.load(Files.newInputStream(configFile.toPath())); + } catch (Exception e) { + throw new RuntimeException(e); + } + if (sipLog) { properties.setProperty("gov.nist.javax.sip.STACK_LOGGER", "io.github.lunasaw.sip.common.conf.StackLoggerImpl"); properties.setProperty("gov.nist.javax.sip.SERVER_LOGGER", "io.github.lunasaw.sip.common.conf.ServerLoggerImpl"); diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/StackLoggerImpl.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/StackLoggerImpl.java index 7077e2cc..d4c7fb05 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/StackLoggerImpl.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/StackLoggerImpl.java @@ -2,8 +2,8 @@ import java.util.Properties; -import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import org.slf4j.spi.LocationAwareLogger; import org.springframework.stereotype.Component; import gov.nist.core.StackLogger; @@ -11,7 +11,41 @@ @Component public class StackLoggerImpl implements StackLogger { - private final static Logger logger = LoggerFactory.getLogger(StackLoggerImpl.class); + /** + * 完全限定类名(Fully Qualified Class Name),用于定位日志位置 + */ + private static final String FQCN = StackLoggerImpl.class.getName(); + + /** + * 获取栈中类信息(以便底层日志记录系统能够提取正确的位置信息(方法名、行号)) + * + * @return LocationAwareLogger + */ + private static LocationAwareLogger getLocationAwareLogger() { + return (LocationAwareLogger)LoggerFactory.getLogger(new Throwable().getStackTrace()[4].getClassName()); + } + + /** + * 封装打印日志的位置信息 + * + * @param level 日志级别 + * @param message 日志事件的消息 + */ + private static void log(int level, String message) { + LocationAwareLogger locationAwareLogger = getLocationAwareLogger(); + locationAwareLogger.log(null, FQCN, level, message, null, null); + } + + /** + * 封装打印日志的位置信息 + * + * @param level 日志级别 + * @param message 日志事件的消息 + */ + private static void log(int level, String message, Throwable throwable) { + LocationAwareLogger locationAwareLogger = getLocationAwareLogger(); + locationAwareLogger.log(null, FQCN, level, message, null, throwable); + } @Override public void logStackTrace() { @@ -35,27 +69,27 @@ public void logException(Throwable ex) { @Override public void logDebug(String message) { -// logger.debug(message); + log(LocationAwareLogger.INFO_INT, message); } @Override public void logDebug(String message, Exception ex) { -// logger.debug(message); + log(LocationAwareLogger.INFO_INT, message, ex); } @Override public void logTrace(String message) { - logger.trace(message); + log(LocationAwareLogger.INFO_INT, message); } @Override public void logFatalError(String message) { -// logger.error(message); + log(LocationAwareLogger.INFO_INT, message); } @Override public void logError(String message) { -// logger.error(message); + log(LocationAwareLogger.INFO_INT, message); } @Override @@ -70,17 +104,17 @@ public boolean isLoggingEnabled(int logLevel) { @Override public void logError(String message, Exception ex) { -// logger.error(message); + log(LocationAwareLogger.INFO_INT, message, ex); } @Override public void logWarning(String message) { - logger.warn(message); + log(LocationAwareLogger.INFO_INT, message); } @Override public void logInfo(String message) { - logger.info(message); + log(LocationAwareLogger.INFO_INT, message); } @Override @@ -107,4 +141,4 @@ public void setStackProperties(Properties stackProperties) { public String getLoggerName() { return null; } -} +} \ No newline at end of file diff --git a/sip-common/src/main/resources/config.properties b/sip-common/src/main/resources/config.properties new file mode 100644 index 00000000..6df7dbc5 --- /dev/null +++ b/sip-common/src/main/resources/config.properties @@ -0,0 +1,18 @@ +#SIP Stack Configuration +#Wed Dec 13 19:34:16 CST 2023 +# ????notify????????? +gov.nist.javax.sip.DELIVER_UNSOLICITED_NOTIFY=true +gov.nist.javax.sip.AUTOMATIC_DIALOG_ERROR_HANDLING=false +gov.nist.javax.sip.CANCEL_CLIENT_TRANSACTION_CHECKED=true +# ?_NULL _?????_???_?? +gov.nist.javax.sip.DELIVER_TERMINATED_EVENT_FOR_NULL_DIALOG=true +# ??????content length??????????? +gov.nist.javax.sip.COMPUTE_CONTENT_LENGTH_FROM_MESSAGE_BODY=true +# ?????? +gov.nist.javax.sip.RELEASE_REFERENCES_STRATEGY=Normal +# ??????????????TCP??????? +gov.nist.javax.sip.RELIABLE_CONNECTION_KEEP_ALIVE_TIMEOUT=60 +# ????? +gov.nist.javax.sip.REENTRANT_LISTENER=true +# ?????????????? SIP ??????????????????????????????????????? +gov.nist.javax.sip.THREAD_AUDIT_INTERVAL_IN_MILLISECS=30000 diff --git a/sip-common/src/main/resources/sip.config b/sip-common/src/main/resources/sip.config new file mode 100644 index 00000000..c22fe364 --- /dev/null +++ b/sip-common/src/main/resources/sip.config @@ -0,0 +1,78 @@ +SipStack的实现。JAIN-SIP堆栈由一组属性初始化(有关这些属性 SipStack 的说明,请参阅 JAIN SIP 文档)。对于 NIST SIP 堆栈,所有属性也可以作为 JVM 系统属性作为 -D 参数从命令行传递。除此之外,以下是 NIST SIP 堆栈的有意义的属性(在创建 JAIN-SIP statck 时在属性数组中指定这些属性): +gov.nist.javax.sip.TRACE_LEVEL = 整数 仍支持使用此属性,但已弃用。请使用 gov.nist.javax.sip.STACK_LOGGER 和 gov.nist.javax.sip.SERVER_LOGGER 与日志记录框架集成以及自定义日志记录格式。 此属性由内置的基于 log4j 的记录器使用。您可以在此处使用标准的 log4j 级别名称(即 ERROR、INFO、WARNING、OFF、DEBUG、TRACE) 如果将其设置为 INFO 或更高版本,则传入的有效消息将记录在SERVER_LOG。如果将此值设置为 32 并指定DEBUG_LOG,则大量跟踪信息将转储到指定的DEBUG_LOG。服务器日志会累积信令跟踪。 这可以使用跟踪查看器工具进行查看。 报告不明显的问题时,请将服务器日志和调试日志发送给我们。还可以将字符串 DEBUG 或 INFO 分别用于级别 32 和 16。如果此属性的值设置为 LOG4J,则根据 log4j 设置文件(例如 log4j.properties)确定有效日志级别。堆栈的记录器名称是使用 gov.nist.javax.sip.LOG4J_LOGGER_NAME 属性指定的。默认情况下,堆栈的 log4j 记录器名称与堆栈名称相同。例如, properties.setProperty("gov.nist.javax.sip.TRACE_LEVEL", "LOG4J"); properties.setProperty("gov.nist.javax.sip.LOG4J_LOGGER_NAME", "SIPStackLogger"); 现在允许您完全使用 log4j 工具控制堆栈中的日志记录。 +gov.nist.javax.sip.LOG_FACTORY = 类路径 仍支持使用此属性,但已弃用。请使用 gov.nist.javax.sip.STACK_LOGGER 和 gov.nist.javax.sip.SERVER_LOGGER 与日志记录框架集成以及自定义日志记录格式。 MessageLogFactory 实现的完全限定类路径。堆栈调用 MessageLogFactory 函数来格式化接收或发送的消息的日志。此功能允许您将与应用程序或环境条件相关的辅助信息记录到日志流中。日志工厂必须具有默认构造函数。 +gov.nist.javax.sip.SERVER_LOG = 文件名 仍支持使用此属性,但已弃用。请使用 gov.nist.javax.sip.STACK_LOGGER 和 gov.nist.javax.sip.SERVER_LOGGER 与日志记录框架集成以及自定义日志记录格式。 在此处记录有效的传入消息。如果此值为 null 且 TRACE_LEVEL高于 INFO(或 TRACE),则消息将打印到 stdout。否则,将以以后可以使用位于 tools/tracesviewer 目录中的跟踪查看器应用程序查看的格式记录消息。 将此邮件连同错误报告一起邮寄给我们。 +gov.nist.javax.sip.DEBUG_LOG = fileName 仍支持使用此属性,但已弃用。请使用 gov.nist.javax.sip.STACK_LOGGER 和 gov.nist.javax.sip.SERVER_LOGGER 与日志记录框架集成以及自定义日志记录格式。 调试日志的位置。 将此邮件连同错误报告一起邮寄给我们。 +gov.nist.javax.sip.LOG_MESSAGE_CONTENT = true|false 如果要将内容捕获到日志中,请设置为 true。默认值为 false。如果您使用 SIP 通过 TCP 推送大量字节,则记录内容是一个坏主意。 +gov.nist.javax.sip.LOG_STACK_TRACE_ON_MESSAGE_SEND = true|false 如果要在 INFO 级别记录每个消息发送的堆栈跟踪,请设置为 true。这对于调试来说非常方便。 +gov.nist.javax.sip.STACK_LOGGER = 实现 gov.nist.core.StackLogger 接口的类的完整路径名 如果定义了此属性,则 sip 堆栈将尝试通过 no arg 构造函数实例化它。这允许使用与默认提供的日志记录实现不同的日志记录实现来记录处理 SIP 消息时堆栈中发生的情况。如果未定义此属性,则默认的 sip 堆栈 LogWriter 将用于日志记录 +gov.nist.javax.sip.SERVER_LOGGER = 实现 gov.nist.core.ServerLogger 接口的类的完整路径名 如果定义了此属性,则 sip 堆栈将尝试通过 no arg 构造函数实例化它。这允许使用与默认提供的日志记录实现不同的日志记录实现来记录 sip 堆栈发送/接收的消息。如果未定义此属性,则默认的 sip 堆栈 ServerLog 将用于日志记录 +gov.nist.javax.sip.AUTOMATIC_DIALOG_ERROR_HANDLING = [true|false] 默认值为 真 。这也可以根据每个提供商进行设置。默认情况下,此标志设置为 true。当设置为 假 启用以下行为: +关闭合并请求循环检测: 以下行为已关闭:如果请求的“收件人”标头字段中没有标记,则 UAS 核心必须根据正在进行的事务检查请求。如果 From 标记、Call-ID 和 CSeq 与正在进行的事务关联的标记完全匹配,但请求与该事务不匹配(根据第 17.2.3 节中的匹配规则),则 UAS 核心应生成 482(检测到循环)响应并将其传递给服务器事务。 +gov.nist.javax.sip.IS_BACK_TO_BACK_USER_AGENT = [true|false] 默认值为 假 此属性控制堆栈管理的 Dialog 对象的设置。纯 B2BUA 应用程序应将此标志设置为 真 。也可以基于每个对话框设置此属性。将此设置为 真 对 re-INVITE 实施序列化,并使 re-INVITE 的发送异步。re-INVITE 的发送控制如下:如果上一个 in-DIALOG 请求是邀请 ClientTransaction,那么使用该对话框的下一个 re-INVITE 将等到发送 ACK 后再接受新的 re-INVITE。如果上一个 DIALOG 内事务是 INVITE ServerTransaction,则 Dialog 将等待 ACK,然后才允许发送 re-INVITE。如果在 32 秒内未确认对话框,则该对话框将被拆除,并向对等方发送 BYE。 +gov.nist.javax.sip.MAX_MESSAGE_SIZE = 整数 TCP 连接可以读取的最大内容大小。必须至少为 4K。默认值为“无穷大”——即。没有限制。这是为了防止通过写入 TCP 连接在服务器阻塞之前发起的 DOS 攻击。 +gov.nist.javax.sip.DELIVER_TERMINATED_EVENT_FOR_NULL_DIALOG = [true|false] 如果设置为 false(默认值),则当处于 NULL 状态的对话框终止时,应用程序不会收到通知。( 处于 NULL 状态的对话框不与实际的 SIP 对话框关联。它们是一种编程便利。在形成 Transaction 的 Dialog 的第一个响应之前,Dialog 处于 NULL 状态。如果设置为 true,则当处于 NULL 状态的 Dialog 终止时,SipListener 将获取 DialogTerminatedEvent。 +gov.nist.javax.sip.CACHE_SERVER_CONNECTIONS = [true|false] 默认值为 true。如果将此项设置为 false,则堆栈会在服务器事务进入 TERMINATED 状态后关闭服务器套接字。这允许服务器防止客户端发起的基于 TCP 的拒绝服务攻击(即启动数百个客户端事务)。如果为 true(默认操作),堆栈将保持套接字打开状态,以便以牺牲线程和内存资源为代价来最大限度地提高性能 - 使自身容易受到 DOS 攻击。 +gov.nist.javax.sip.CACHE_CLIENT_CONNECTIONS = [true|false] 默认值为 true。如果将此项设置为 false,则堆栈会在客户端事务进入 TERMINATED 状态后关闭服务器套接字。这允许客户端在事务终止后释放与客户端事务关联的任何缓冲区、线程和套接字连接,但会牺牲性能。 +gov.nist.javax.sip.THREAD_POOL_SIZE = 整数 并发控制并发活动线程数。如果未指定,则默认值为“无穷大”。如果您尝试构建容器,此功能非常有用。 + +如果未指定此项,并且侦听器 是可重入的,则传递给侦听器的每个事件都将在新线程的上下文中运行。 +如果指定了此选项,并且侦听器是可重入的,则堆栈将使用线程池中的线程运行侦听器。这允许您将并发级别管理到固定的最大值。实例化堆栈时会预先分配线程。 +如果指定了此选项,并且侦听器不是可重入的,则堆栈将使用此池中的线程池线程来解析和管理状态机,但会在自己的线程中运行侦听器。 +gov.nist.javax.sip.REENTRANT_LISTENER = true|false 默认值为 false。如果侦听器是可重入的,则设置为 true。如果侦听器是可重入的,则堆栈将管理一个线程池,并从读取消息的同一线程同步调用侦听器。多个事务可以同时接收消息,这将导致多个线程同时在侦听器中处于活动状态。听众必须牢记这一点。 如果希望在多线程计算机上获得良好的性能,请将侦听器编写为可重入,并将此属性设置为 true +gov.nist.javax.sip.MAX_CONNECTIONS = 整数 堆栈同时处理的最大 TCP 连接数。 +gov.nist.javax.sip.MAX_SERVER_TRANSACTIONS = 整数 服务器事务表的最大大小。低水位线是高水位线的 80%。在低水位线到高水位线范围内有选择地丢弃请求。如果表小于低水位线,则无条件接受请求。默认高水位线为 5000 +gov.nist.javax.sip.MAX_CLIENT_TRANSACTIONS = 整数 在调用方阻止并等待该数字降至阈值以下之前,活动客户端事务的最大数量。默认值是无限制的,即调用方从不阻塞并等待客户端事务变得可用(即它在应用程序中执行自己的资源管理)。 +gov.nist.javax.sip.PASS_INVITE_NON_2XX_ACK_TO_LISTENER = true|false 如果为 true,则侦听器将看到服务器事务的非 2xx 响应的 ACK。这不是 RFC 3261(INVITE 服务器事务状态机)的标准行为,但这是测试的有用标志。例如,TCK 使用此标志。 +gov.nist.javax.sip.MAX_LISTENER_RESPONSE_TIME = 整数 等待用于序列化消息传递的事务锁的最长时间(秒)。默认时间是“无穷大”——即,如果侦听器从未响应,堆栈将挂起对事务的引用,并导致无法使用的线程卡住等待锁的释放。此属性的良好值是事务的生存期或侦听器中的预期阻塞延迟。 +gov.nist.javax.sip.MAX_TX_LIFETIME_INVITE = 整数 默认值 -1 : infinite。典型值可能取决于早期对话超时,例如,3 分钟可能是一个很好的默认值:INVITE 事务应该在堆栈中存在的最大时间(秒)。这是为了避免在事务可能处于的任何状态下发生任何泄漏,即使应用程序行为不端 当达到最大时间时,将向应用程序侦听器触发超时事件,以便应用程序可以执行操作,然后在堆栈中典型的 8 秒后从堆栈中删除 +gov.nist.javax.sip.MAX_TX_LIFETIME_NON_INVITE = 整数 默认值 -1 : infinite。典型依赖于 T1,例如 2 * T1 可能是一个很好的默认值 非 INVITE 事务应该存在于堆栈中的最大时间(秒)。这是为了避免在事务可能处于的任何状态下发生任何泄漏,即使应用程序行为不端 当达到最大时间时,将向应用程序侦听器触发超时事件,以便应用程序可以采取行动,然后在堆栈中典型的 8 秒后从堆栈中删除。有一个特定的属性,因为与 INVITE 相比,非 INVITE 属性的生存期很短,因此可以急切地收集以节省内存使用量 +gov.nist.javax.sip.DELIVER_TERMINATED_EVENT_FOR_ACK = [true|false] 默认值为 假 。ACK Server Transaction 是 Pseuedo 事务。如果您希望在 ACK 事务上发出终止通知(以便在清理期间可以在用户代码中统一处理所有服务器事务),请将此标志设置为 真 。 +gov.nist.javax.sip.READ_TIMEOUT = 整数 这与传入的 TCP 连接有关,以防止服务器匮乏。这定义了堆栈读取 SIP 消息的第一个字节后连续读取之间的超时(以毫秒为单位)。所有 sip 标头都必须在此时间间隔内传送,并且每个连续缓冲区必须是在此时间间隔内传送的内容。默认值为 -1(即堆栈对饥饿攻击完全开放),客户端可以随心所欲地慢。 +gov.nist.javax.sip.CONNECTION_TIMEOUT = 整数 这与传出 TCP 连接有关,以防止长线程块。这定义了堆栈在放弃之前等待打开 TCP 连接的超时(以毫秒为单位)。默认值为 10000 +* +gov.nist.javax.sip.NETWORK_LAYER = 类路径 这是一个 EXPERIMENTAL 属性(仍在积极开发中)。定义一个网络层,该层允许客户端控制套接字分配和监视套接字活动。网络层应实现 gov.nist.core.net.NetworkLayer。默认实现仅充当标准 java.net 套接字层的包装器。此功能仍在积极开发中(可能会扩展以支持安全性和其他功能)。 +gov.nist.javax.sip.ADDRESS_RESOLVER = 类路径 AddressResolver 接口实现的完全限定类路径。AddressResolver 允许您使用 getHostByName 支持无法直接解析为 IP 地址的地址的查找方案。通过指定自己的地址解析器,您可以自定义地址查找。默认地址解析器是直通地址解析器(即仅返回输入字符串而不执行解析)。请参阅 gov.nist.javax.sip.DefaultAddressResolver。 +gov.nist.javax.sip.AUTO_GENERATE_TIMESTAMP= [true| false] (默认值为 false)如果原始请求包含时间戳,则为重新传输的请求自动生成 getTimeOfDay 时间戳。这对于分析很有用。 +gov.nist.javax.sip.THREAD_AUDIT_INTERVAL_IN_MILLISECS = 长整型 定义应用程序打算审核 SIP 堆栈有关其内部线程运行状况的频率(该属性指定连续审核之间的时间(以毫秒为单位)。审核允许应用程序检测灾难性故障,例如内部线程因异常而终止或陷入死锁状态。此类事件将使堆栈无法运行,因此需要应用层立即采取行动(例如,警报、陷阱、重启、故障转移等)。默认情况下,线程审核处于禁用状态。如果未指定此属性,则审核将保持禁用状态。有关如何使用此属性的示例,请参见 src/examples/threadaudit。 +gov.nist.javax.sip.NIO_MAX_SOCKET_IDLE_TIME = 长整型 定义 NIO TCP 套接字在对该套接字执行最后一次 IO 操作后将保持活动状态的毫秒数。这允许在挂断或保持空闲的新呼叫的初始高初始负载后进行清理。请注意,断开套接字连接不会结束 SIP 呼叫。当 SIP RFC 规范需要任何现有呼叫时,将建立新的套接字。 +gov.nist.javax.sip.NIO_BLOCKING_MODE = 字符串 定义 NioMessageFactory 的阻塞模式。默认情况下,它将设置为“BLOCKING”。设置为“NONBLOCKING”以实现非阻塞连接行为 +* +gov.nist.javax.sip.stack.USE_DIRECT_BUFFERS = [true|false] 默认值为 真 如果设置为 假 时,NIO 堆栈不会使用直接缓冲区。由于直接缓冲区位于堆内存之外,因此它们可能会导致不可预见的内存不足异常,如 http://java.net/jira/browse/JSIP-430 所示。此标志允许使用非直接缓冲区来更好地监视和管理内存。 +gov.nist.javax.sip.COMPUTE_CONTENT_LENGTH_FROM_MESSAGE_BODY = [true|false] 默认值为 假 如果设置为 真 ,当您从 字符串 ,MessageFactory 将根据消息内容计算内容长度,并忽略 Message 中提供的内容长度参数。否则,它将使用提供的内容长度,并在内容被截断时生成分析异常。 +gov.nist.javax.sip.CANCEL_CLIENT_TRANSACTION_CHECKED = [true|false] 默认值为 真 。添加此标志是为了支持负载平衡器或故障转移管理器,在这些管理器中,您可能希望从与原始堆栈不同的堆栈中取消正在进行的事务。如果设置为 假 则在发送 CANCEL 请求时,不会检查 CANCEL 客户端事务是否存在 INVITE 或 INVITE 状态。因此,您可以从与 INVITE 不同的堆栈中取消 INVITE。您还可以在延迟创建 CANCEL 客户端事务,并在 INVITE 服务器事务终止后将其发送出去。显然,这将导致协议错误。将标志设置为 true ( default ) 可以避免常见的协议错误。 +gov.nist.javax.sip.IS_BACK_TO_BACK_USER_AGENT = [true|false] 默认值为 假 此属性控制堆栈管理的 Dialog 对象的设置。纯 B2BUA 应用程序应将此标志设置为 真 。也可以基于每个对话框设置此属性。将此设置为 真 对 re-INVITE 实施序列化,并使 re-INVITE 的发送异步。re-INVITE 的发送控制如下:如果上一个 in-DIALOG 请求是邀请 ClientTransaction,那么使用该对话框的下一个 re-INVITE 将等到发送 ACK 后再接受新的 re-INVITE。如果上一个 DIALOG 内事务是 INVITE ServerTransaction,则 Dialog 将等待 ACK,然后才允许发送 re-INVITE。如果在 32 秒内未确认对话框,则该对话框将被拆除,并向对等方发送 BYE。 +gov.nist.javax.sip.RECEIVE_UDP_BUFFER_SIZE = int 默认值为 8*1024 。此属性控制用于 SIP 消息的 UDP 缓冲区的大小。在负载下,如果缓冲区容量溢出,消息将被丢弃,从而导致重新传输,从而进一步增加负载并导致更多的重新传输。对于服务器来说,此属性的良好值是一个大数字,约为 8*8*1024。 +gov.nist.javax.sip.SEND_UDP_BUFFER_SIZE = int 默认值为 8*1024 。此属性控制用于 SIP 消息的 UDP 缓冲区的大小。在负载下,如果缓冲区容量溢出,消息将被丢弃,从而导致重新传输,从而进一步增加负载并导致更多的重新传输。对于服务器来说,此属性的良好值是一个大数字,大约为 8*8*1024 或更高。 +gov.nist.javax.sip.CONGESTION_CONTROL_TIMEOUT = int 由于堆栈太慢而无法响应,消息在被丢弃之前允许在队列中等待多长时间。默认值为 8000 毫秒。该值以毫秒为单位 +gov.nist.javax.sip.TCP_POST_PARSING_THREAD_POOL_SIZE = 整数 使用 0 或不设置此选项可禁用它。使用 TCP 时,您的电话/客户端通常独立连接,创建自己的 TCP 套接字。但是,有时允许 SIP 设备通过单个套接字对多个呼叫进行隧道传输。这也可以通过运行“sipp -t t1”来模拟 SIPP。在堆栈中,每个 TCP 套接字都有自己的线程。当所有调用都使用相同的套接字时,它们都使用单个线程,这会导致严重的性能损失,尤其是在多核计算机上。此选项指示 SIP 堆栈使用线程池,并在多个线程之间拆分 CPU 负载。线程数在此参数中指定。在解析消息后,将立即拆分处理。在解析之前无法拆分它,因为在 TCP 中,SIP 消息大小位于消息的 Content-Length 标头中,并且必须同步对 TCP 网络流的访问。此外,在 TCP 中,消息大小可能更大。这会导致所有调用的大部分分析发生在单个线程中,这可能会影响使用单个套接字进行所有调用的普通应用程序的性能。在大多数应用程序中,它不会影响性能。如果电话/客户端对每个调用使用单独的 TCP 套接字,则此选项不会产生太大影响,但线程池导致的内存占用量略有增加。在这种情况下,建议通过将此选项设置为 0 或根本不设置来禁用此选项。您可以使用“sipp -t t0”模拟多插槽模式。使用此选项,我们还可以避免在出现故障时关闭 TCP 套接字,因为我们必须继续为其他调用处理其他消息。注意:此选项依赖于SIP消息中准确的Content-Length标头。一旦处理了格式错误的消息,它就无法恢复,因为流迭代器将不再对齐。最终,连接将关闭。 +gov.nist.javax.sip.DELIVER_UNSOLICITED_NOTIFY = [true|false] 默认值为 假 。添加此标志是为了允许 Sip 侦听器接收所有 NOTIFY 请求,包括那些不属于有效对话框的请求。 +gov.nist.javax.sip.REJECT_STRAY_RESPONSES = [true|false] 默认值为 假 一个标志,用于检查响应以测试响应是否与我们之前生成的 via 标头相对应。请注意,设置此标志意味着堆栈将控制通过堆栈发送的 Sip 请求的 VIA 标头的设置。堆栈会将后缀附加到 VIA 标头分支,并检查到达堆栈的任何响应,以查看该响应后缀是否存在。如果它不存在,则堆栈将静默删除响应。 +gov.nist.javax.sip.MAX_FORK_TIME_SECONDS = 整数 跟踪接收分叉响应的原始事务的最长时间。此属性仅与 Dialog Stateful 应用程序(用户代理或 B2BUA)相关。当在发送原始 INVITE 客户端事务的此时间间隔内收到分叉响应时,堆栈会将原始 INVITE 客户端事务放在 ResponseEventExt 中,并将其传送到应用程序。事件处理程序可以从此事件中获取原始事务。 +gov.nist.javax.sip.EARLY_DIALOG_TIMEOUT_SECONDS=整数 对话可以保持早期状态的最长时间。默认值为 3 分钟(180 秒)。 +gov.nist.javax.sip.THREAD_PRIORITY=integer 控制堆栈启动的线程的优先级。 +gov.nist.javax.sip.MESSAGE_PARSER_FACTORY = 实现 gov.nist.javax.sip.parser.MessageParserFactory 的类的名称 此工厂允许 MessageParser 的可插入实现,这些实现将负责分析传入消息。举个例子,可以通过这个工厂插入一个惰性解析器。 +gov.nist.javax.sip.MESSAGE_PROCESSOR_FACTORY = 实现 gov.nist.javax.sip.parser.MessageProcessorFactory 的类的名称 此工厂允许 MessageProcessor 的可插入实现,这些实现将处理传入消息。举个例子,可以通过这个工厂插入一个蔚来处理器。 +gov.nist.javax.sip.TIMER_CLASS_NAME = 实现 gov.nist.javax.sip.stack.timers.SipTimer 接口的类的名称 这允许 Timer 的可插入实现,这些实现将负责调度各种 SIP Timer。举个例子,可以插入一个常规计时器,一个预定的线程池执行器。 +gov.nist.javax.sip.DELIVER_RETRANSMITTED_ACK_TO_LISTENER=布尔值 一个测试属性,允许应用程序查看重新传输的 200 个 OK 请求的 ACK。 请注意,这仅用于测试目的 +gov.nist.javax.sip.AGGRESSIVE_CLEANUP=boolean Deprecated - 请改用RELEASE_REFERENCES_STRATEGY 该属性将大量清理 Dialog 和 Transaction 结构,以提高 memroy 的使用率和性能(高达 50% 的收益)。但是,在代码中需要小心它如何以及何时访问事务和对话数据,因为当事务将状态更改为 COMPLETED 或 TERMINATED 时,它会积极清理,而 Dialog 会在收到/发送 ACK 后进行清理 +gov.nist.javax.sip.RELEASE_REFERENCES_STRATEGY=字符串 一个属性,指定用于清理 Dialog 和 Transaction 结构中的引用的策略。可以使用以下选项 +无:这是默认设置。它将对请求和响应的引用保留为事务和对话的一部分。这会消耗最多的内存使用量 +正常:它删除了事务和对话框中对请求和响应的引用,以清理它们,但保留请求或响应的字节数组,以便在应用程序需要它们时能够重新解析它们。与“无”相比,这提供了 2 倍的内存改进 +主动:它删除了事务和对话框中对请求和响应的引用,并清理它们,并且不允许重新修复。需要仔细的应用程序设计。与普通策略相比,这进一步改进了内存,并改进了 CPU。 +gov.nist.javax.sip.PATCH_SIP_WEBSOCKETS_HEADERS=布尔值 指定是否使用 .invalid 地址修补 websocket 客户端的属性 +gov.nist.javax.sip.ALWAYS_ADD_RPORT=布尔值 一个属性,指定在对等数据包源端口与 via 标头端口不同时是否放置 rport +gov.nist.javax.sip.LINGER_TIMER=int 一个属性,用于指定 Dialog 和 Transaction 结构在堆栈释放它们之前将在内存中保留多少秒 +gov.nist.javax.sip.MIN_KEEPALIVE_TIME_SECONDS = 整数 来自客户端的保持活动 ping (CRLF、CRLF) 之间的最短时间。如果 ping 到达的频率低于此频率,则将使用 CRLF CRLF 回复,如果大于此频率,则将拒绝。默认值为 -1(即不响应 CRLF CRLF)。 +gov.nist.javax.sip.DIALOG_TIMEOUT_FACTOR= 整数 默认值为 64。未收到 ACK 的对话框收到超时通知之前的时钟周期数。请注意,仅当注册的 SipListener 类型为 SipListenerExt 时,这才相关 +gov.nist.javax.sip.SIP_MESSAGE_VALVE= 字符串 默认值为 null。自定义阀门组件的类名集合。这些类用逗号分隔,稍后调用回调时将遵循该顺序。在分配任何长期存在的 SIP 堆栈资源(无事务、无对话框)之前,将创建这些类的所有实例,并为每条消息调用 SIPMessageValve.processRequest/Response() 方法。在 processRequest 回调实现中,您可以删除消息、无状态发送响应或以其他方式转换/预处理消息,然后再将其发送到管道的后续步骤。类似地,在 processResponse() 中,您可以操作响应或静默删除它,但不建议删除响应,因为在发送响应请求时,事务已经存在。 +gov.nist.javax.sip.SIP_EVENT_INTERCEPTOR 默认值为 null。自定义侦听器对象的类名。此对象的实例将在堆栈初始化时创建。您必须实现接口 gov.nist.javax.sip.stack.SIPEventInterceptor 并处理生命周期回调。此接口是 https://jain-sip.dev.java.net/issues/show_bug.cgi?id=337 的解决方案。它允许包装 JSIP 管道,并在 SIP 消息通过管道检查点时执行自定义分析逻辑。此拦截器的一个示例实现是 gov.nist.javax.sip.stack.CallAnalysisInterceptor,它将定期检查停滞在 JAIN SIP 线程中的请求,如果某些请求花费的时间过长,它将记录所有线程的堆栈跟踪。日志记录只能发生在某些事件上,因此它不会使 CPU 不堪重负。在负载下在生产中使用此类的总体性能损失在普通笔记本电脑上仅为 2% 的峰值。内部的锁定极少。此功能的一个已知限制是,您必须使用 gov.nist.javax.sip.REENTRANT_LISTENER=true 来确保请求将在原始线程中完全针对 UDP 进行处理。 +gov.nist.javax.sip.TLS_CLIENT_PROTOCOLS = 字符串 创建传出 TLS 连接时要使用的协议的逗号分隔列表。默认值为“TLSv1.2、TLSv1.1、TLSv1”。建议不要使用SSL协议,因为 http://googleonlinesecurity.blogspot.fr/2014/10/this-poodle-bites-exploiting-ssl-30.html +gov.nist.javax.sip.gov.nist.javax.sip.ENABLED_CIPHER_SUITES = 字符串 创建传出 TLS 连接时要使用的套件的逗号分隔列表。默认值为“TLS_RSA_WITH_AES_128_CBC_SHA、SSL_RSA_WITH_3DES_EDE_CBC_SHA、TLS_DH_anon_WITH_AES_128_CBC_SHA、SSL_DH_anon_WITH_3DES_EDE_CBC_SHA”。 +gov.nist.javax.sip.TLS_SECURITY_POLICY = 字符串 TLS 安全策略实现的完全限定路径名,在对外滩 TLS 连接进行证书验证时会参考该路径名。 +gov.nist.javax.sip.TLS_CLIENT_AUTH_TYPE = 字符串 有效值为 Default(向后兼容以前的版本)、Enabled、Want、Disabled 或 DisabledAll。如果您希望 SSL 堆栈在接受连接之前要求客户端提供有效的证书链,请设置为“已启用”。如果希望 SSL 堆栈请求客户端证书,请设置为“想要”,但如果未提供客户端证书,则不会失败。Disabled 值不需要服务器连接的证书链。DisabledAll 不需要服务器和客户端连接的证书链。 +gov.nist.javax.sip.RELIABLE_CONNECTION_KEEP_ALIVE_TIMEOUT 以秒为单位的值,用作默认的 keepalive 超时(另请参见 http://tools.ietf.org/html/rfc5626#section-4.4.1)。默认为“infiinity”秒(即未传递超时事件)。 +gov.nist.javax.sip.SSL_HANDSHAKE_TIMEOUT 以秒为单位的值,用作执行 SSL 握手的默认超时 这可以防止不良客户端在不发送任何数据来阻止服务器的情况下进行连接 +gov.nist.javax.sip.SSL_RENEGOTIATION_ENABLED = [true|false]默认值为 true。允许或禁止 SSL 重新协商以解决潜在的 DoS 问题 - 引用和其他引用 。 安全的选择是禁用它。 +javax.net.ssl.keyStore = 文件名 默认值为 零 。如果未定义,则 keyStore 和 trustStore 将保留给 java 运行时默认值。如果已定义,则创建的任何 TLS 套接字(客户端和服务器)都将使用 fileName 中提供的密钥存储。信任存储将默认为同一存储文件。必须提供密码才能使用以下属性访问 keyStore: properties.setProperty("javax.net.ssl.keyStorePassword", ""); properties.setProperty("javax.net.ssl.trustStorePassword", ""); 如果未提供 trustStorePassword,则 keyStorePassword 将用于两者。可以使用以下设置将信任存储更改为单独的文件: properties.setProperty("javax.net.ssl.trustStore", ""); 如果提供了信任库属性,那么信任库上的密码必须与密钥库相同。 +请注意,堆栈支持 SipStackExt 中定义的扩展。这些将在下一个版本的 JAIN-SIP 中得到支持。应仅使用此类中定义的扩展。 \ No newline at end of file From f844624b93c89a397a2bd2b135724e30f90adec5 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Wed, 13 Dec 2023 20:31:12 +0800 Subject: [PATCH 15/17] =?UTF-8?q?:memo:=201.1.4=20=E8=AE=BE=E5=A4=87?= =?UTF-8?q?=E8=AE=A2=E9=98=85=E6=8E=A8=E9=80=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...ler.java => RecordInfoMessageHandler.java} | 4 +- ...ava => ResponseCatalogMessageHandler.java} | 6 +- .../request/notify/NotifyProcessorServer.java | 9 +++ .../notify/NotifyServerHandlerAbstract.java | 45 ++++++++++++++ .../notify/ServerNotifyRequestProcessor.java | 29 +++++++++- .../notify/catalog/CatalogNotifyHandler.java | 58 +++++++++++++++++++ 6 files changed, 144 insertions(+), 7 deletions(-) rename gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/{RecordInfoMessageServerHandler.java => RecordInfoMessageHandler.java} (89%) rename gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/{ResponseCatalogMessageServerHandler.java => ResponseCatalogMessageHandler.java} (83%) create mode 100644 gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/NotifyProcessorServer.java create mode 100755 gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/NotifyServerHandlerAbstract.java create mode 100644 gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/catalog/CatalogNotifyHandler.java diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageServerHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageHandler.java similarity index 89% rename from gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageServerHandler.java rename to gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageHandler.java index 7bcff709..24cb85f0 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageServerHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/RecordInfoMessageHandler.java @@ -21,13 +21,13 @@ @Slf4j @Getter @Setter -public class RecordInfoMessageServerHandler extends MessageServerHandlerAbstract { +public class RecordInfoMessageHandler extends MessageServerHandlerAbstract { public static final String CMD_TYPE = "RecordInfo"; private String cmdType = CMD_TYPE; - public RecordInfoMessageServerHandler(MessageProcessorServer messageProcessorServer) { + public RecordInfoMessageHandler(MessageProcessorServer messageProcessorServer) { super(messageProcessorServer); } diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageServerHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageHandler.java similarity index 83% rename from gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageServerHandler.java rename to gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageHandler.java index 964e0142..a9cd492a 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageServerHandler.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/message/response/ResponseCatalogMessageHandler.java @@ -21,11 +21,11 @@ @Slf4j @Getter @Setter -public class ResponseCatalogMessageServerHandler extends MessageServerHandlerAbstract { +public class ResponseCatalogMessageHandler extends MessageServerHandlerAbstract { public static final String CMD_TYPE = "Catalog"; - public ResponseCatalogMessageServerHandler(MessageProcessorServer messageProcessorServer) { + public ResponseCatalogMessageHandler(MessageProcessorServer messageProcessorServer) { super(messageProcessorServer); } @@ -34,7 +34,7 @@ public void handForEvt(RequestEvent event) { DeviceSession deviceSession = getDeviceSession(event); String userId = deviceSession.getUserId(); - ToDevice toDevice = (ToDevice) messageProcessorServer.getToDevice(userId); + ToDevice toDevice = (ToDevice)messageProcessorServer.getToDevice(userId); if (toDevice == null) { // 未注册的设备不做处理 return; diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/NotifyProcessorServer.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/NotifyProcessorServer.java new file mode 100644 index 00000000..5767a4b1 --- /dev/null +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/NotifyProcessorServer.java @@ -0,0 +1,9 @@ +package io.github.lunasaw.gbproxy.server.transimit.request.notify; + +import io.github.lunasaw.gb28181.common.entity.notify.DeviceOtherUpdateNotify; +import io.github.lunasaw.sip.common.service.SipUserGenerate; + +public interface NotifyProcessorServer extends SipUserGenerate { + + void deviceNotifyUpdate(String userId, DeviceOtherUpdateNotify deviceOtherUpdateNotify); +} \ No newline at end of file diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/NotifyServerHandlerAbstract.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/NotifyServerHandlerAbstract.java new file mode 100755 index 00000000..1da95790 --- /dev/null +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/NotifyServerHandlerAbstract.java @@ -0,0 +1,45 @@ +package io.github.lunasaw.gbproxy.server.transimit.request.notify; + +import javax.annotation.Resource; +import javax.sip.RequestEvent; + +import org.springframework.stereotype.Component; + +import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.sip.common.transmit.event.message.MessageHandlerAbstract; +import io.github.lunasaw.sip.common.utils.SipUtils; +import lombok.Data; + +/** + * @author luna + */ +@Data +@Component +public abstract class NotifyServerHandlerAbstract extends MessageHandlerAbstract { + + @Resource + public NotifyProcessorServer notifyProcessorServer; + + public NotifyServerHandlerAbstract(NotifyProcessorServer notifyProcessorServer) { + this.notifyProcessorServer = notifyProcessorServer; + } + + @Override + public String getRootType() { + return "Root"; + } + + public DeviceSession getDeviceSession(RequestEvent event) { + SIPRequest sipRequest = (SIPRequest)event.getRequest(); + + // 客户端发送的userId + String userId = SipUtils.getUserIdFromFromHeader(sipRequest); + // 服务端接收的userId + // 服务端收到消息,fromHeader是服务端的userId + String sipId = SipUtils.getUserIdFromToHeader(sipRequest); + + return new DeviceSession(userId, sipId); + } + +} diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java index 02bc1211..903535a4 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java @@ -1,10 +1,21 @@ package io.github.lunasaw.gbproxy.server.transimit.request.notify; +import java.nio.charset.Charset; +import java.util.Optional; + +import javax.annotation.Resource; import javax.sip.RequestEvent; import org.springframework.stereotype.Component; -import io.github.lunasaw.sip.common.transmit.event.request.SipRequestProcessorAbstract; +import com.luna.common.text.StringTools; + +import gov.nist.javax.sip.message.SIPRequest; +import io.github.lunasaw.sip.common.constant.Constant; +import io.github.lunasaw.sip.common.entity.FromDevice; +import io.github.lunasaw.sip.common.transmit.event.message.SipMessageRequestProcessorAbstract; +import io.github.lunasaw.sip.common.utils.SipUtils; +import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.Getter; import lombok.Setter; @@ -16,12 +27,15 @@ @Component @Getter @Setter -public class ServerNotifyRequestProcessor extends SipRequestProcessorAbstract { +public class ServerNotifyRequestProcessor extends SipMessageRequestProcessorAbstract { public static final String METHOD = "NOTIFY"; private String method = METHOD; + @Resource + public NotifyProcessorServer notifyProcessorServer; + /** * 收到Notify请求 处理 * @@ -29,7 +43,18 @@ public class ServerNotifyRequestProcessor extends SipRequestProcessorAbstract { */ @Override public void process(RequestEvent evt) { + SIPRequest request = (SIPRequest)evt.getRequest(); + + // 在服务端看来 收到请求的时候fromHeader还是客户端的 toHeader才是自己的,这里是要查询自己的信息 + String userId = SipUtils.getUserIdFromToHeader(request); + + // 获取设备 + FromDevice fromDevice = (FromDevice)notifyProcessorServer.getFromDevice(); + if (!userId.equals(fromDevice.getUserId())) { + return; + } + doMessageHandForEvt(evt, fromDevice); } } diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/catalog/CatalogNotifyHandler.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/catalog/CatalogNotifyHandler.java new file mode 100644 index 00000000..4bb6dbc8 --- /dev/null +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/catalog/CatalogNotifyHandler.java @@ -0,0 +1,58 @@ +package io.github.lunasaw.gbproxy.server.transimit.request.notify.catalog; + +import javax.sip.RequestEvent; + +import io.github.lunasaw.gbproxy.server.transimit.request.notify.NotifyProcessorServer; +import org.springframework.stereotype.Component; + +import io.github.lunasaw.gb28181.common.entity.base.DeviceSession; +import io.github.lunasaw.gb28181.common.entity.notify.DeviceOtherUpdateNotify; +import io.github.lunasaw.gbproxy.server.transimit.request.message.MessageProcessorServer; +import io.github.lunasaw.gbproxy.server.transimit.request.notify.NotifyServerHandlerAbstract; +import io.github.lunasaw.sip.common.entity.ToDevice; +import lombok.Getter; +import lombok.Setter; +import lombok.extern.slf4j.Slf4j; + +/** + * @author luna + * @date 2023/10/19 + */ +@Component +@Slf4j +@Getter +@Setter +public class CatalogNotifyHandler extends NotifyServerHandlerAbstract { + + public static final String CMD_TYPE = "Catalog"; + + public CatalogNotifyHandler(NotifyProcessorServer notifyProcessorServer) { + super(notifyProcessorServer); + } + + @Override + public void handForEvt(RequestEvent event) { + DeviceSession deviceSession = getDeviceSession(event); + + String userId = deviceSession.getUserId(); + ToDevice toDevice = (ToDevice)notifyProcessorServer.getToDevice(userId); + if (toDevice == null) { + // 未注册的设备不做处理 + return; + } + + DeviceOtherUpdateNotify deviceOtherUpdateNotify = parseXml(DeviceOtherUpdateNotify.class); + + notifyProcessorServer.deviceNotifyUpdate(userId, deviceOtherUpdateNotify); + } + + @Override + public String getCmdType() { + return CMD_TYPE; + } + + @Override + public String getRootType() { + return RESPONSE; + } +} From 8437ddd0430b898ef44e2bdd29a172e0407d12a8 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Thu, 14 Dec 2023 10:54:33 +0800 Subject: [PATCH 16/17] :memo: log debug remove --- .../client/transmit/cmd/ClientSendCmd.java | 4 ++ .../notify/ServerNotifyRequestProcessor.java | 7 ---- .../server/DefaultNotifyProcessorServer.java | 42 +++++++++++++++++++ .../src/main/resources/log/logback.xml | 4 +- .../test/subscribe/SubscribeClientTest.java | 15 +++---- pom.xml | 2 +- .../sip/common/conf/DefaultProperties.java | 9 ++-- .../sip/common/conf/StackLoggerImpl.java | 4 +- .../sip/common/transmit/SipSender.java | 22 ++++++---- .../resources/{ => sip}/config.properties | 10 +---- .../src/main/resources/{ => sip}/sip.config | 6 +-- 11 files changed, 81 insertions(+), 44 deletions(-) create mode 100644 gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultNotifyProcessorServer.java rename sip-common/src/main/resources/{ => sip}/config.properties (59%) rename sip-common/src/main/resources/{ => sip}/sip.config (98%) diff --git a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java index 83585b77..fab2b092 100644 --- a/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java +++ b/gb28181-client/src/main/java/io/github/lunasaw/gbproxy/client/transmit/cmd/ClientSendCmd.java @@ -307,6 +307,10 @@ public static String deviceRegister(FromDevice fromDevice, ToDevice toDevice, In return SipSender.doRegisterRequest(fromDevice, toDevice, expires); } + public static String deviceRegister(FromDevice fromDevice, ToDevice toDevice, Integer expires, Event event) { + return SipSender.doRegisterRequest(fromDevice, toDevice, expires, event); + } + /** * 设备注销 * diff --git a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java index 903535a4..d4d1d64f 100644 --- a/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java +++ b/gb28181-server/src/main/java/io/github/lunasaw/gbproxy/server/transimit/request/notify/ServerNotifyRequestProcessor.java @@ -1,21 +1,14 @@ package io.github.lunasaw.gbproxy.server.transimit.request.notify; -import java.nio.charset.Charset; -import java.util.Optional; - import javax.annotation.Resource; import javax.sip.RequestEvent; import org.springframework.stereotype.Component; -import com.luna.common.text.StringTools; - import gov.nist.javax.sip.message.SIPRequest; -import io.github.lunasaw.sip.common.constant.Constant; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.transmit.event.message.SipMessageRequestProcessorAbstract; import io.github.lunasaw.sip.common.utils.SipUtils; -import io.github.lunasaw.sip.common.utils.XmlUtils; import lombok.Getter; import lombok.Setter; diff --git a/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultNotifyProcessorServer.java b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultNotifyProcessorServer.java new file mode 100644 index 00000000..0ab11bed --- /dev/null +++ b/gb28181-test/src/main/java/io/github/lunasaw/gbproxy/test/user/server/DefaultNotifyProcessorServer.java @@ -0,0 +1,42 @@ +package io.github.lunasaw.gbproxy.test.user.server; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Qualifier; + +import io.github.lunasaw.gb28181.common.entity.notify.DeviceOtherUpdateNotify; +import io.github.lunasaw.gbproxy.server.transimit.request.notify.NotifyProcessorServer; +import io.github.lunasaw.gbproxy.test.config.DeviceConfig; +import io.github.lunasaw.sip.common.entity.Device; +import org.springframework.stereotype.Component; + +/** + * @author weidian + * @version 1.0 + * @date 2023/12/14 + * @description: + */ +@Component +public class DefaultNotifyProcessorServer implements NotifyProcessorServer { + @Autowired + @Qualifier("serverFrom") + private Device fromDevice; + + @Autowired + @Qualifier("serverTo") + private Device toDevice; + + @Override + public Device getToDevice(String userId) { + return DeviceConfig.DEVICE_SERVER_VIEW_MAP.get(userId); + } + + @Override + public Device getFromDevice() { + return fromDevice; + } + + @Override + public void deviceNotifyUpdate(String userId, DeviceOtherUpdateNotify deviceOtherUpdateNotify) { + + } +} diff --git a/gb28181-test/src/main/resources/log/logback.xml b/gb28181-test/src/main/resources/log/logback.xml index 81ac9907..6b24a982 100644 --- a/gb28181-test/src/main/resources/log/logback.xml +++ b/gb28181-test/src/main/resources/log/logback.xml @@ -33,7 +33,7 @@ - ${LOG_HOME}/info.log + ${LOG_HOME}/sip-proxy.log @@ -58,7 +58,7 @@ - ${LOG_HOME}/error.log + ${LOG_HOME}/sip-proxy-error.log ${LOG_HOME}/sip-proxy-error.log.%d{yyyy-MM-dd}.%i diff --git a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java index 13a1331a..b0f846bc 100644 --- a/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java +++ b/gb28181-test/src/test/java/io/github/lunasaw/gbproxy/test/subscribe/SubscribeClientTest.java @@ -1,7 +1,5 @@ package io.github.lunasaw.gbproxy.test.subscribe; -import javax.sip.message.Request; - import org.junit.jupiter.api.AfterAll; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; @@ -9,15 +7,13 @@ import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.test.context.SpringBootTest; +import io.github.lunasaw.gbproxy.client.transmit.cmd.ClientSendCmd; import io.github.lunasaw.gbproxy.test.Gb28181ApplicationTest; import io.github.lunasaw.gbproxy.test.config.DeviceConfig; import io.github.lunasaw.sip.common.entity.Device; import io.github.lunasaw.sip.common.entity.FromDevice; import io.github.lunasaw.sip.common.entity.ToDevice; import io.github.lunasaw.sip.common.layer.SipLayer; -import io.github.lunasaw.sip.common.transmit.SipSender; -import io.github.lunasaw.sip.common.transmit.request.SipRequestProvider; -import io.github.lunasaw.sip.common.utils.SipRequestUtils; import lombok.extern.slf4j.Slf4j; /** @@ -54,10 +50,9 @@ public void before() { } @Test - public void atest() { - String callId = SipRequestUtils.getNewCallId(); - Request registerRequest = SipRequestProvider.createRegisterRequest((FromDevice)fromDevice, (ToDevice)toDevice, 300, callId); - - SipSender.transmitRequest(fromDevice.getIp(), registerRequest); + public void test_register() { + ClientSendCmd.deviceRegister((FromDevice)fromDevice, (ToDevice)toDevice, 300, (eventResult) -> { + test_register(); + }); } } diff --git a/pom.xml b/pom.xml index 35956510..e52c1b14 100644 --- a/pom.xml +++ b/pom.xml @@ -22,7 +22,7 @@ 8 8 - 2.7.10 + 2.7.18 2.5.2 lunasaw ${project.name} diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/DefaultProperties.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/DefaultProperties.java index d5b5c45d..3dc5916f 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/DefaultProperties.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/DefaultProperties.java @@ -10,8 +10,11 @@ /** * 获取sip默认配置 - * - * @author lin + * 完整配置参考 gov.nist.javax.sip.SipStackImpl,需要下载源码 + * gov/nist/javax/sip/SipStackImpl.class + * sip消息的解析在 gov.nist.javax.sip.stack.UDPMessageChannel的processIncomingDataPacket 方法 + * + * @author luna */ @Slf4j public class DefaultProperties { @@ -26,7 +29,7 @@ public static Properties getProperties(String name, String ip, boolean sipLog) { * sip_server_log.log 和 sip_debug_log.log ERROR, INFO, WARNING, OFF, DEBUG, TRACE */ try { - File configFile = ResourceUtils.getFile("classpath:config.properties").getAbsoluteFile(); + File configFile = ResourceUtils.getFile("classpath:sip/config.properties").getAbsoluteFile(); properties.load(Files.newInputStream(configFile.toPath())); } catch (Exception e) { throw new RuntimeException(e); diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/StackLoggerImpl.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/StackLoggerImpl.java index d4c7fb05..3f7bcfca 100755 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/StackLoggerImpl.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/conf/StackLoggerImpl.java @@ -69,12 +69,12 @@ public void logException(Throwable ex) { @Override public void logDebug(String message) { - log(LocationAwareLogger.INFO_INT, message); + // log(LocationAwareLogger.INFO_INT, message); } @Override public void logDebug(String message, Exception ex) { - log(LocationAwareLogger.INFO_INT, message, ex); + // log(LocationAwareLogger.INFO_INT, message, ex); } @Override diff --git a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipSender.java b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipSender.java index d44b7ee1..d74bfbf2 100644 --- a/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipSender.java +++ b/sip-common/src/main/java/io/github/lunasaw/sip/common/transmit/SipSender.java @@ -68,13 +68,6 @@ public static String doInviteRequest(FromDevice fromDevice, ToDevice toDevice, S return callId; } - public static String doRegisterRequest(FromDevice fromDevice, ToDevice toDevice, Integer expire) { - String callId = SipRequestUtils.getNewCallId(); - Request messageRequest = SipRequestProvider.createRegisterRequest(fromDevice, toDevice, expire, callId); - SipSender.transmitRequest(fromDevice.getIp(), messageRequest); - return callId; - } - public static String doSubscribeRequest(FromDevice fromDevice, ToDevice toDevice, String contend, SubscribeInfo subscribeInfo, Event errorEvent, Event okEvent) { String callId = SipRequestUtils.getNewCallId(); @@ -117,6 +110,21 @@ public static String doAckRequest(FromDevice fromDevice, ToDevice toDevice, Stri return callId; } + public static String doRegisterRequest(FromDevice fromDevice, ToDevice toDevice, Integer expires) { + return doRegisterRequest(fromDevice, toDevice, expires, SipRequestUtils.getNewCallId(), null, null); + } + + public static String doRegisterRequest(FromDevice fromDevice, ToDevice toDevice, Integer expires, Event event) { + return doRegisterRequest(fromDevice, toDevice, expires, SipRequestUtils.getNewCallId(), event, null); + } + + public static String doRegisterRequest(FromDevice fromDevice, ToDevice toDevice, Integer expires, String callId, Event errorEvent, + Event okEvent) { + Request registerRequest = SipRequestProvider.createRegisterRequest(fromDevice, toDevice, expires, callId); + SipSender.transmitRequest(fromDevice.getIp(), registerRequest, errorEvent, okEvent); + return callId; + } + public static String doInfoRequest(FromDevice fromDevice, ToDevice toDevice, String content, String callId) { return doInfoRequest(fromDevice, toDevice, content, callId, null, null); } diff --git a/sip-common/src/main/resources/config.properties b/sip-common/src/main/resources/sip/config.properties similarity index 59% rename from sip-common/src/main/resources/config.properties rename to sip-common/src/main/resources/sip/config.properties index 6df7dbc5..5db811d6 100644 --- a/sip-common/src/main/resources/config.properties +++ b/sip-common/src/main/resources/sip/config.properties @@ -1,18 +1,10 @@ #SIP Stack Configuration #Wed Dec 13 19:34:16 CST 2023 -# ????notify????????? gov.nist.javax.sip.DELIVER_UNSOLICITED_NOTIFY=true gov.nist.javax.sip.AUTOMATIC_DIALOG_ERROR_HANDLING=false -gov.nist.javax.sip.CANCEL_CLIENT_TRANSACTION_CHECKED=true -# ?_NULL _?????_???_?? gov.nist.javax.sip.DELIVER_TERMINATED_EVENT_FOR_NULL_DIALOG=true -# ??????content length??????????? gov.nist.javax.sip.COMPUTE_CONTENT_LENGTH_FROM_MESSAGE_BODY=true -# ?????? gov.nist.javax.sip.RELEASE_REFERENCES_STRATEGY=Normal -# ??????????????TCP??????? -gov.nist.javax.sip.RELIABLE_CONNECTION_KEEP_ALIVE_TIMEOUT=60 -# ????? +gov.nist.javax.sip.RELIABLE_CONNECTION_KEEP_ALIVE_TIMEOUT=15 gov.nist.javax.sip.REENTRANT_LISTENER=true -# ?????????????? SIP ??????????????????????????????????????? gov.nist.javax.sip.THREAD_AUDIT_INTERVAL_IN_MILLISECS=30000 diff --git a/sip-common/src/main/resources/sip.config b/sip-common/src/main/resources/sip/sip.config similarity index 98% rename from sip-common/src/main/resources/sip.config rename to sip-common/src/main/resources/sip/sip.config index c22fe364..12529ea6 100644 --- a/sip-common/src/main/resources/sip.config +++ b/sip-common/src/main/resources/sip/sip.config @@ -57,9 +57,9 @@ gov.nist.javax.sip.TIMER_CLASS_NAME = 实现 gov.nist.javax.sip.stack.timers.Sip gov.nist.javax.sip.DELIVER_RETRANSMITTED_ACK_TO_LISTENER=布尔值 一个测试属性,允许应用程序查看重新传输的 200 个 OK 请求的 ACK。 请注意,这仅用于测试目的 gov.nist.javax.sip.AGGRESSIVE_CLEANUP=boolean Deprecated - 请改用RELEASE_REFERENCES_STRATEGY 该属性将大量清理 Dialog 和 Transaction 结构,以提高 memroy 的使用率和性能(高达 50% 的收益)。但是,在代码中需要小心它如何以及何时访问事务和对话数据,因为当事务将状态更改为 COMPLETED 或 TERMINATED 时,它会积极清理,而 Dialog 会在收到/发送 ACK 后进行清理 gov.nist.javax.sip.RELEASE_REFERENCES_STRATEGY=字符串 一个属性,指定用于清理 Dialog 和 Transaction 结构中的引用的策略。可以使用以下选项 -无:这是默认设置。它将对请求和响应的引用保留为事务和对话的一部分。这会消耗最多的内存使用量 -正常:它删除了事务和对话框中对请求和响应的引用,以清理它们,但保留请求或响应的字节数组,以便在应用程序需要它们时能够重新解析它们。与“无”相比,这提供了 2 倍的内存改进 -主动:它删除了事务和对话框中对请求和响应的引用,并清理它们,并且不允许重新修复。需要仔细的应用程序设计。与普通策略相比,这进一步改进了内存,并改进了 CPU。 +None:这是默认设置。它将对请求和响应的引用保留为事务和对话的一部分。这会消耗最多的内存使用量 +Normal:它删除了事务和对话框中对请求和响应的引用,以清理它们,但保留请求或响应的字节数组,以便在应用程序需要它们时能够重新解析它们。与“无”相比,这提供了 2 倍的内存改进 +Aggressive:它删除了事务和对话框中对请求和响应的引用,并清理它们,并且不允许重新修复。需要仔细的应用程序设计。与普通策略相比,这进一步改进了内存,并改进了 CPU。 gov.nist.javax.sip.PATCH_SIP_WEBSOCKETS_HEADERS=布尔值 指定是否使用 .invalid 地址修补 websocket 客户端的属性 gov.nist.javax.sip.ALWAYS_ADD_RPORT=布尔值 一个属性,指定在对等数据包源端口与 via 标头端口不同时是否放置 rport gov.nist.javax.sip.LINGER_TIMER=int 一个属性,用于指定 Dialog 和 Transaction 结构在堆栈释放它们之前将在内存中保留多少秒 From 02cada733c6f8678ae3cb65c1e68aa8501e50765 Mon Sep 17 00:00:00 2001 From: chenzhangyue Date: Thu, 14 Dec 2023 10:59:31 +0800 Subject: [PATCH 17/17] :memo: log debug remove --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index e52c1b14..7b697786 100644 --- a/pom.xml +++ b/pom.xml @@ -23,7 +23,7 @@ 8 8 2.7.18 - 2.5.2 + 2.5.3 lunasaw ${project.name} 1.3.0-91