From 00e61d9a80b5b013a75d1ce567dc997694577a45 Mon Sep 17 00:00:00 2001
From: panlinlin <648540858@qq.com>
Date: 星期一, 28 十二月 2020 11:45:40 +0800
Subject: [PATCH] 增加对 需要扩展SDP的设备的单独设置

---
 src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java |   50 ++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 40 insertions(+), 10 deletions(-)

diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java b/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java
index 4204ce7..93f533f 100644
--- a/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java
+++ b/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java
@@ -1,37 +1,67 @@
 package com.genersoft.iot.vmp.gb28181.transmit.response.impl;
 
+import java.text.ParseException;
+
 import javax.sip.Dialog;
 import javax.sip.InvalidArgumentException;
 import javax.sip.ResponseEvent;
 import javax.sip.SipException;
+import javax.sip.address.SipURI;
+import javax.sip.header.CSeqHeader;
+import javax.sip.header.ViaHeader;
 import javax.sip.message.Request;
+import javax.sip.message.Response;
 
+import gov.nist.javax.sip.header.CSeq;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 import org.springframework.stereotype.Component;
 
 import com.genersoft.iot.vmp.conf.SipConfig;
 import com.genersoft.iot.vmp.gb28181.SipLayer;
+import com.genersoft.iot.vmp.gb28181.transmit.SIPProcessorFactory;
 import com.genersoft.iot.vmp.gb28181.transmit.response.ISIPResponseProcessor;
 
-/**    
+
+/**
  * @Description:澶勭悊INVITE鍝嶅簲
- * @author: songww
- * @date:   2020骞�5鏈�3鏃� 涓嬪崍4:43:52     
+ * @author: swwheihei
+ * @date: 2020骞�5鏈�3鏃� 涓嬪崍4:43:52
  */
 @Component
 public class InviteResponseProcessor implements ISIPResponseProcessor {
 
+	private final static Logger logger = LoggerFactory.getLogger(InviteResponseProcessor.class);
+
 	/**
 	 * 澶勭悊invite鍝嶅簲
 	 * 
-	 * @param request
-	 *            鍝嶅簲娑堟伅
-	 */ 
+	 * @param evt 鍝嶅簲娑堟伅
+	 * @throws ParseException
+	 */
 	@Override
-	public void process(ResponseEvent evt, SipLayer layer, SipConfig config) {
+	public void process(ResponseEvent evt, SipLayer layer, SipConfig config) throws ParseException {
 		try {
-			Dialog dialog = evt.getDialog();
-			Request reqAck =dialog.createAck(1L);
-			dialog.sendAck(reqAck);
+			Response response = evt.getResponse();
+			int statusCode = response.getStatusCode();
+			// trying涓嶄細鍥炲
+			if (statusCode == Response.TRYING) {
+			}
+			// 鎴愬姛鍝嶅簲
+			// 涓嬪彂ack
+			if (statusCode == Response.OK) {
+				Dialog dialog = evt.getDialog();
+				CSeqHeader cseq = (CSeqHeader) response.getHeader(CSeqHeader.NAME);
+				Request reqAck = dialog.createAck(cseq.getSeqNumber());
+
+				SipURI requestURI = (SipURI) reqAck.getRequestURI();
+				ViaHeader viaHeader = (ViaHeader) response.getHeader(ViaHeader.NAME);
+				requestURI.setHost(viaHeader.getHost());
+				requestURI.setPort(viaHeader.getPort());
+				reqAck.setRequestURI(requestURI);
+
+				dialog.sendAck(reqAck);
+			}
 		} catch (InvalidArgumentException | SipException e) {
 			e.printStackTrace();
 		}

--
Gitblit v1.8.0