performance.uas.diff.txt Maven / Gradle / Ivy
diff --git a/src/gov/nist/javax/sip/message/SIPMessage.java b/src/gov/nist/javax/sip/message/SIPMessage.java
index 3ab19f1..6ed47ee 100755
--- a/src/gov/nist/javax/sip/message/SIPMessage.java
+++ b/src/gov/nist/javax/sip/message/SIPMessage.java
@@ -138,7 +138,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
/**
* unparsed headers
*/
- private LinkedList unrecognizedHeaders;
+ protected LinkedList unrecognizedHeaders;
/**
* List of parsed headers (in the order they were added)
@@ -171,7 +171,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
protected Object messageContentObject;
// Table of headers indexed by name.
- private Map nameTable;
+ protected Map headerTable;
/**
* The application data pointer. This is un-interpreted by the stack. This is provided as a
@@ -179,7 +179,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
*/
protected Object applicationData;
- private String forkId;
+ protected String forkId;
/**
* Return true if the header belongs only in a Request.
@@ -476,7 +476,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
*/
public Object clone() {
SIPMessage retval = (SIPMessage) super.clone();
- retval.nameTable = new ConcurrentHashMap();
+ retval.headerTable = new ConcurrentHashMap();
retval.fromHeader = null;
retval.toHeader = null;
retval.cSeqHeader = null;
@@ -546,7 +546,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
*/
public SIPMessage() {
this.headers = new ConcurrentLinkedQueue();
- nameTable = new ConcurrentHashMap();
+ headerTable = new ConcurrentHashMap();
try {
this.attachHeader(new ContentLength(0), false);
} catch (Exception ex) {
@@ -658,8 +658,8 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
String headerNameLowerCase = SIPHeaderNamesCache.toLowerCase(h.getName());
if (replaceFlag) {
- nameTable.remove(headerNameLowerCase);
- } else if (nameTable.containsKey(headerNameLowerCase) && !(h instanceof SIPHeaderList)) {
+ headerTable.remove(headerNameLowerCase);
+ } else if (headerTable.containsKey(headerNameLowerCase) && !(h instanceof SIPHeaderList)) {
if (h instanceof ContentLength) {
try {
ContentLength cl = (ContentLength) h;
@@ -684,19 +684,19 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
}
}
- if (!nameTable.containsKey(headerNameLowerCase)) {
- nameTable.put(headerNameLowerCase, h);
+ if (!headerTable.containsKey(headerNameLowerCase)) {
+ headerTable.put(headerNameLowerCase, h);
headers.add(h);
} else {
if (h instanceof SIPHeaderList) {
- SIPHeaderList< ? > hdrlist = (SIPHeaderList< ? >) nameTable
+ SIPHeaderList< ? > hdrlist = (SIPHeaderList< ? >) headerTable
.get(headerNameLowerCase);
if (hdrlist != null)
hdrlist.concatenate((SIPHeaderList) h, top);
else
- nameTable.put(headerNameLowerCase, h);
+ headerTable.put(headerNameLowerCase, h);
} else {
- nameTable.put(headerNameLowerCase, h);
+ headerTable.put(headerNameLowerCase, h);
}
}
@@ -727,7 +727,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
public void removeHeader(String headerName, boolean top) {
String headerNameLowerCase = SIPHeaderNamesCache.toLowerCase(headerName);
- SIPHeader toRemove = (SIPHeader) nameTable.get(headerNameLowerCase);
+ SIPHeader toRemove = (SIPHeader) headerTable.get(headerNameLowerCase);
// nothing to do then we are done.
if (toRemove == null)
return;
@@ -748,10 +748,10 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
// JvB: also remove it from the nameTable! Else NPE in
// DefaultRouter
- nameTable.remove(headerNameLowerCase);
+ headerTable.remove(headerNameLowerCase);
}
} else {
- this.nameTable.remove(headerNameLowerCase);
+ this.headerTable.remove(headerNameLowerCase);
if (toRemove instanceof From) {
this.fromHeader = null;
} else if (toRemove instanceof To) {
@@ -785,7 +785,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
if (headerName == null)
throw new NullPointerException("null arg");
String headerNameLowerCase = SIPHeaderNamesCache.toLowerCase(headerName);
- SIPHeader removed = (SIPHeader) nameTable.remove(headerNameLowerCase);
+ SIPHeader removed = (SIPHeader) headerTable.remove(headerNameLowerCase);
// nothing to do then we are done.
if (removed == null)
return;
@@ -929,7 +929,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
private Header getHeaderLowerCase(String lowerCaseHeaderName) {
if (lowerCaseHeaderName == null)
throw new NullPointerException("bad name");
- SIPHeader sipHeader = (SIPHeader) nameTable.get(lowerCaseHeaderName);
+ SIPHeader sipHeader = (SIPHeader) headerTable.get(lowerCaseHeaderName);
if (sipHeader instanceof SIPHeaderList)
return (Header) ((SIPHeaderList) sipHeader).getFirst();
else
@@ -1399,7 +1399,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
public ListIterator getHeaders(String headerName) {
if (headerName == null)
throw new NullPointerException("null headerName");
- SIPHeader sipHeader = (SIPHeader) nameTable.get(SIPHeaderNamesCache
+ SIPHeader sipHeader = (SIPHeader) headerTable.get(SIPHeaderNamesCache
.toLowerCase(headerName));
// empty iterator
if (sipHeader == null)
@@ -1420,15 +1420,15 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
*/
public String getHeaderAsFormattedString(String name) {
String lowerCaseName = name.toLowerCase();
- if (this.nameTable.containsKey(lowerCaseName)) {
- return this.nameTable.get(lowerCaseName).toString();
+ if (this.headerTable.containsKey(lowerCaseName)) {
+ return this.headerTable.get(lowerCaseName).toString();
} else {
return this.getHeader(name).toString();
}
}
protected SIPHeader getSIPHeaderListLowerCase(String lowerCaseHeaderName) {
- return nameTable.get(lowerCaseHeaderName);
+ return headerTable.get(lowerCaseHeaderName);
}
/**
@@ -1439,7 +1439,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
*/
@SuppressWarnings("unchecked")
private List getHeaderList(String headerName) {
- SIPHeader sipHeader = (SIPHeader) nameTable.get(SIPHeaderNamesCache
+ SIPHeader sipHeader = (SIPHeader) headerTable.get(SIPHeaderNamesCache
.toLowerCase(headerName));
if (sipHeader == null)
return null;
@@ -1459,7 +1459,7 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
* @return true if the header is present in the message
*/
public boolean hasHeader(String headerName) {
- return nameTable.containsKey(SIPHeaderNamesCache.toLowerCase(headerName));
+ return headerTable.containsKey(SIPHeaderNamesCache.toLowerCase(headerName));
}
/**
@@ -1613,15 +1613,15 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
return false;
}
SIPMessage otherMessage = (SIPMessage) other;
- Collection values = this.nameTable.values();
+ Collection values = this.headerTable.values();
Iterator it = values.iterator();
- if (nameTable.size() != otherMessage.nameTable.size()) {
+ if (headerTable.size() != otherMessage.headerTable.size()) {
return false;
}
while (it.hasNext()) {
SIPHeader mine = (SIPHeader) it.next();
- SIPHeader his = (SIPHeader) (otherMessage.nameTable.get(SIPHeaderNamesCache
+ SIPHeader his = (SIPHeader) (otherMessage.headerTable.get(SIPHeaderNamesCache
.toLowerCase(mine.getName())));
if (his == null) {
return false;
@@ -1918,32 +1918,32 @@ public abstract class SIPMessage extends MessageObject implements javax.sip.mess
public abstract String toString();
public void cleanUp() {
- applicationData = null;
- callIdHeader = null;
- contentEncodingCharset = null;
- contentLengthHeader = null;
- cSeqHeader = null;
- forkId = null;
- fromHeader = null;
- if(headers != null) {
- headers.clear();
- headers = null;
- }
- matchExpression = null;
- maxForwardsHeader = null;
- messageContent = null;
- messageContentBytes = null;
- messageContentObject = null;
- if(nameTable != null) {
- nameTable.clear();
- nameTable = null;
- }
- stringRepresentation = null;
- toHeader = null;
- if(unrecognizedHeaders != null) {
- unrecognizedHeaders.clear();
- unrecognizedHeaders = null;
- }
+// applicationData = null;
+// callIdHeader = null;
+// contentEncodingCharset = null;
+// contentLengthHeader = null;
+// cSeqHeader = null;
+// forkId = null;
+// fromHeader = null;
+// if(headers != null) {
+// headers.clear();
+// headers = null;
+// }
+// matchExpression = null;
+// maxForwardsHeader = null;
+// messageContent = null;
+// messageContentBytes = null;
+// messageContentObject = null;
+// if(nameTable != null) {
+// nameTable.clear();
+// nameTable = null;
+// }
+// stringRepresentation = null;
+// toHeader = null;
+// if(unrecognizedHeaders != null) {
+// unrecognizedHeaders.clear();
+// unrecognizedHeaders = null;
+// }
}
/**
diff --git a/src/gov/nist/javax/sip/message/SIPRequest.java b/src/gov/nist/javax/sip/message/SIPRequest.java
index 9f2f092..300e96c 100755
--- a/src/gov/nist/javax/sip/message/SIPRequest.java
+++ b/src/gov/nist/javax/sip/message/SIPRequest.java
@@ -1231,4 +1231,9 @@ public class SIPRequest extends SIPMessage implements javax.sip.message.Request,
public Object getInviteTransaction() {
return inviteTransaction;
}
+
+ @Override
+ public void cleanUp() {
+ super.cleanUp();
+ }
}
diff --git a/src/gov/nist/javax/sip/message/SIPResponse.java b/src/gov/nist/javax/sip/message/SIPResponse.java
index 7100459..bc47c02 100755
--- a/src/gov/nist/javax/sip/message/SIPResponse.java
+++ b/src/gov/nist/javax/sip/message/SIPResponse.java
@@ -646,7 +646,7 @@ public class SIPResponse
@Override
public void cleanUp() {
- statusLine = null;
+// statusLine = null;
super.cleanUp();
}
}
diff --git a/src/gov/nist/javax/sip/parser/StringMsgParser.java b/src/gov/nist/javax/sip/parser/StringMsgParser.java
index 3f00e3f..c15abfd 100755
--- a/src/gov/nist/javax/sip/parser/StringMsgParser.java
+++ b/src/gov/nist/javax/sip/parser/StringMsgParser.java
@@ -75,7 +75,7 @@ public class StringMsgParser implements MessageParser {
protected boolean readBody;
protected ParseExceptionListener parseExceptionListener;
protected String rawStringMessage;
- private boolean strict;
+ protected boolean strict;
protected static boolean computeContentLengthFromMessage = false;
diff --git a/src/gov/nist/javax/sip/stack/SIPClientTransaction.java b/src/gov/nist/javax/sip/stack/SIPClientTransaction.java
index 5d12325..ca7a2c3 100755
--- a/src/gov/nist/javax/sip/stack/SIPClientTransaction.java
+++ b/src/gov/nist/javax/sip/stack/SIPClientTransaction.java
@@ -1587,7 +1587,7 @@ public class SIPClientTransaction extends SIPTransaction implements ServerRespon
// we release the ref to the dialog asap and just keep the id of the dialog to look it up in the dialog table
if(defaultDialog != null) {
String dialogId = defaultDialog.getDialogId();
- // we nullify the ref only if it can be find in the dialog table (not always true, check challenge unittest of the testsuite)
+ // we nullify the ref only if it can be find in the dialog table (not always true if the dialog is in null state, check challenge unittest of the testsuite)
if(dialogId != null && sipStack.getDialog(dialogId) != null) {
defaultDialogId = dialogId;
defaultDialog = null;
diff --git a/src/gov/nist/javax/sip/stack/SIPDialog.java b/src/gov/nist/javax/sip/stack/SIPDialog.java
index 3057675..0f7ec92 100755
--- a/src/gov/nist/javax/sip/stack/SIPDialog.java
+++ b/src/gov/nist/javax/sip/stack/SIPDialog.java
@@ -45,6 +45,7 @@ import gov.nist.javax.sip.header.ContactList;
import gov.nist.javax.sip.header.ContentLength;
import gov.nist.javax.sip.header.ContentType;
import gov.nist.javax.sip.header.From;
+import gov.nist.javax.sip.header.HeaderFactoryImpl;
import gov.nist.javax.sip.header.MaxForwards;
import gov.nist.javax.sip.header.RAck;
import gov.nist.javax.sip.header.RSeq;
@@ -67,6 +68,12 @@ import gov.nist.javax.sip.message.SIPDuplicateHeaderException;
import gov.nist.javax.sip.message.SIPMessage;
import gov.nist.javax.sip.message.SIPRequest;
import gov.nist.javax.sip.message.SIPResponse;
+import gov.nist.javax.sip.parser.AddressParser;
+import gov.nist.javax.sip.parser.CallIDParser;
+import gov.nist.javax.sip.parser.ContactParser;
+import gov.nist.javax.sip.parser.HeaderParser;
+import gov.nist.javax.sip.parser.ParserFactory;
+import gov.nist.javax.sip.parser.RecordRouteParser;
import java.io.IOException;
import java.io.PrintWriter;
@@ -157,11 +164,12 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
private transient Object applicationData; // Opaque pointer to application data.
private transient SIPRequest originalRequest;
+ private transient String originalRequestRecordRouteHeadersString;
private transient RecordRouteList originalRequestRecordRouteHeaders;
// Last response (JvB: either sent or received).
// private SIPResponse lastResponse;
- protected Collection lastResponseHeaders;
+ protected Collection lastResponseHeaders;
protected String lastResponseDialogId;
protected Via lastResponseTopMostVia;
protected Integer lastResponseStatusCode;
@@ -213,10 +221,13 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
// Dialog.
protected javax.sip.address.Address localParty;
+ protected String localPartyStringified;
protected javax.sip.address.Address remoteParty;
+ private String remotePartyStringified;
protected CallIdHeader callIdHeader;
+ protected String callIdHeaderString;
public final static int NULL_STATE = -1;
@@ -241,6 +252,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
// requests
private Address remoteTarget;
+ private String remoteTargetStringified;
private EventHeader eventHeader; // for Subscribe notify
@@ -284,7 +296,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
protected String firstTransactionMergeId;
protected int firstTransactionPort = 5060;
protected Contact contactHeader;
-
+ protected String contactHeaderStringified;
// //////////////////////////////////////////////////////
// Inner classes
@@ -570,7 +582,46 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
eventListeners = new CopyOnWriteArraySet();
}
- public void cleanUp() {
+ protected void cleanUpOnAck() {
+ if(originalRequest != null) {
+// originalRequestRecordRouteHeaders = originalRequest.getRecordRouteHeaders();
+ if(originalRequestRecordRouteHeaders != null) {
+ originalRequestRecordRouteHeadersString = originalRequestRecordRouteHeaders.toString();
+ }
+ originalRequestRecordRouteHeaders = null;
+ originalRequest = null;
+ }
+ if(firstTransaction != null) {
+ firstTransaction.getOriginalRequest().cleanUp();
+ firstTransaction = null;
+ }
+ if(lastTransaction != null) {
+ lastTransaction.getOriginalRequest().cleanUp();
+ lastTransaction = null;
+ }
+ if(callIdHeader != null) {
+ callIdHeaderString = callIdHeader.toString();
+ callIdHeader = null;
+ }
+ if(contactHeader != null) {
+ contactHeaderStringified = contactHeader.toString();
+ contactHeader = null;
+ }
+ if(remoteTarget != null) {
+ remoteTargetStringified = remoteTarget.toString();
+ remoteTarget = null;
+ }
+ if(remoteParty != null) {
+ remotePartyStringified = remoteParty.toString();
+ remoteParty = null;
+ }
+ if(localParty != null) {
+ localPartyStringified = localParty.toString();
+ localParty = null;
+ }
+ }
+
+ protected void cleanUp() {
if(eventListeners != null) {
eventListeners.clear();
}
@@ -602,6 +653,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
if(originalRequestRecordRouteHeaders != null) {
originalRequestRecordRouteHeaders.clear();
originalRequestRecordRouteHeaders = null;
+ originalRequestRecordRouteHeadersString = null;
}
remoteTarget = null;
if(routeList != null) {
@@ -610,6 +662,18 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
}
}
+ protected RecordRouteList getOriginalRequestRecordRouteHeaders() {
+ if(originalRequestRecordRouteHeaders == null && originalRequestRecordRouteHeadersString != null) {
+ try {
+ originalRequestRecordRouteHeaders = (RecordRouteList) new RecordRouteParser(originalRequestRecordRouteHeadersString).parse();
+ } catch (ParseException e) {
+ sipStack.getStackLogger().logError("error reparsing the originalRequest RecordRoute Headers", e);
+ }
+ originalRequestRecordRouteHeadersString = null;
+ }
+ return originalRequestRecordRouteHeaders;
+ }
+
private void recordStackTrace() {
StringWriter stringWriter = new StringWriter();
PrintWriter writer = new PrintWriter(stringWriter);
@@ -980,10 +1044,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
*/
private void sendAck(Request request, boolean throwIOExceptionAsSipException)
throws SipException {
- if(originalRequest != null) {
- originalRequestRecordRouteHeaders = originalRequest.getRecordRouteHeaders();
- originalRequest = null;
- }
+
SIPRequest ackRequest = (SIPRequest) request;
if (sipStack.isLoggingEnabled())
sipStack.getStackLogger().logDebug("sendAck" + this);
@@ -1046,9 +1107,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
this.setLastAckSent(ackRequest);
messageChannel.sendMessage(ackRequest);
- // Sent atleast one ACK.
- firstTransaction = null;
- lastTransaction = null;
+ cleanUpOnAck();
this.isAcknowledged = true;
this.highestSequenceNumberAcknowledged = Math.max(this.highestSequenceNumberAcknowledged,
((SIPRequest)ackRequest).getCSeq().getSeqNumber());
@@ -1117,10 +1176,6 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
* Mark that the dialog has seen an ACK.
*/
void ackReceived(long cseqNumber) {
- if(originalRequest != null) {
- originalRequestRecordRouteHeaders = originalRequest.getRecordRouteHeaders();
- originalRequest = null;
- }
// Suppress retransmission of the final response
if (this.isAckSeen()) {
sipStack.getStackLogger().logDebug("Ack already seen for response -- dropping");
@@ -1157,8 +1212,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
} else {
sipStack.getStackLogger().logDebug("tr is null -- not updating the ack state" );
}
- firstTransaction = null;
- lastTransaction = null;
+ cleanUpOnAck();
}
/**
@@ -1890,6 +1944,14 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
* @see javax.sip.Dialog#getCallId()
*/
public CallIdHeader getCallId() {
+ if(callIdHeader == null && callIdHeaderString != null) {
+ try {
+ this.callIdHeader = (CallIdHeader) new CallIDParser(callIdHeaderString).parse();
+ } catch (ParseException e) {
+ sipStack.getStackLogger().logError("error reparsing the call id header", e);
+ }
+ callIdHeaderString = null;
+ }
return this.callIdHeader;
}
@@ -1907,6 +1969,14 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
*/
public javax.sip.address.Address getLocalParty() {
+ if(localParty == null && localPartyStringified != null) {
+ try {
+ this.localParty = (Address) new AddressParser(localPartyStringified).address(true);
+ } catch (ParseException e) {
+ sipStack.getStackLogger().logError("error reparsing the localParty", e);
+ }
+ localPartyStringified = null;
+ }
return this.localParty;
}
@@ -1929,6 +1999,14 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
*/
public javax.sip.address.Address getRemoteParty() {
+ if(remoteParty == null && remotePartyStringified != null) {
+ try {
+ this.remoteParty = (Address) new AddressParser(remotePartyStringified).address(true);
+ } catch (ParseException e) {
+ sipStack.getStackLogger().logError("error reparsing the remoteParty", e);
+ }
+ remotePartyStringified = null;
+ }
if (sipStack.isLoggingEnabled()) {
sipStack.getStackLogger().logDebug("gettingRemoteParty " + this.remoteParty);
}
@@ -1942,7 +2020,14 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
* @see javax.sip.Dialog#getRemoteTarget()
*/
public javax.sip.address.Address getRemoteTarget() {
-
+ if(remoteTarget == null && remoteTargetStringified != null) {
+ try {
+ this.remoteTarget = (Address) new AddressParser(remoteTargetStringified).address(true);
+ } catch (ParseException e) {
+ sipStack.getStackLogger().logError("error reparsing the remoteTarget", e);
+ }
+ remoteTargetStringified = null;
+ }
return this.remoteTarget;
}
@@ -2152,9 +2237,17 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
newRequest.setHeader(cseq);
newRequest.setHeader(from);
newRequest.setHeader(to);
- Iterator headerIterator = lastResponseHeaders.iterator();
+ Iterator headerIterator = lastResponseHeaders.iterator();
while (headerIterator.hasNext()) {
- SIPHeader nextHeader = (SIPHeader) headerIterator.next();
+ String nextHeaderString = (String) headerIterator.next();
+ SIPHeader nextHeader = null;
+ try {
+ HeaderParser headerParser = ParserFactory.createParser(nextHeaderString + "\n");
+ nextHeader = headerParser.parse();
+ } catch (ParseException ex) {
+ throw new IllegalArgumentException("error reparsing the call id header", ex);
+ }
+
// // Some headers do not belong in a Request ....
// if (SIPMessage.isResponseHeader(nextHeader)
// || nextHeader instanceof ViaList
@@ -2794,7 +2887,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
if(lastResponseHeaders != null) {
lastResponseHeaders.clear();
}
- this.lastResponseHeaders = new CopyOnWriteArrayList();
+ this.lastResponseHeaders = new CopyOnWriteArrayList();
Iterator headerIterator = sipResponse.getHeaders();
while (headerIterator.hasNext()) {
SIPHeader nextHeader = headerIterator.next();
@@ -2816,7 +2909,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
|| nextHeader instanceof To) {
continue;
}
- lastResponseHeaders.add(nextHeader);
+ lastResponseHeaders.add(nextHeader.toString());
}
this.setAssigned();
// Adjust state of the Dialog state machine.
@@ -2931,9 +3024,9 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
* execute.
*/
if ( this.getState() != DialogState.CONFIRMED && this.getState() != DialogState.TERMINATED ) {
- if (originalRequestRecordRouteHeaders != null) {
- if (originalRequestRecordRouteHeaders != null) {
- ListIterator it = originalRequestRecordRouteHeaders.listIterator(originalRequestRecordRouteHeaders.size());
+ if (getOriginalRequestRecordRouteHeaders() != null) {
+// if (originalRequestRecordRouteHeaders != null) {
+ ListIterator it = getOriginalRequestRecordRouteHeaders().listIterator(getOriginalRequestRecordRouteHeaders().size());
while (it.hasPrevious()) {
RecordRoute rr = (RecordRoute) it.previous();
Route route = (Route) routeList.getFirst();
@@ -2942,7 +3035,7 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
} else
break;
}
- }
+// }
}
}
@@ -3362,6 +3455,14 @@ public class SIPDialog implements javax.sip.Dialog, DialogExt {
* @return contact header belonging to the dialog.
*/
public Contact getMyContactHeader() {
+ if(contactHeader == null && contactHeaderStringified != null) {
+ try {
+ this.contactHeader = (Contact) new ContactParser(contactHeaderStringified).parse();
+ } catch (ParseException e) {
+ sipStack.getStackLogger().logError("error reparsing the contact header", e);
+ }
+ contactHeaderStringified = null;
+ }
return contactHeader;
}
diff --git a/src/gov/nist/javax/sip/stack/SIPServerTransaction.java b/src/gov/nist/javax/sip/stack/SIPServerTransaction.java
index c971b08..b345d0a 100755
--- a/src/gov/nist/javax/sip/stack/SIPServerTransaction.java
+++ b/src/gov/nist/javax/sip/stack/SIPServerTransaction.java
@@ -1840,8 +1840,8 @@ public class SIPServerTransaction extends SIPTransaction implements ServerReques
cleanUpOnTimer();
// it should be available in the processTxTerminatedEvent, so we can nullify it only here
if(originalRequest != null) {
- originalRequestSentBy = originalRequest.getTopmostVia().getSentBy();
- originalRequestFromTag = originalRequest.getFromTag();
+// originalRequestSentBy = originalRequest.getTopmostVia().getSentBy();
+// originalRequestFromTag = originalRequest.getFromTag();
originalRequest = null;
}
if(inviteTransaction != null) {
@@ -1881,9 +1881,18 @@ public class SIPServerTransaction extends SIPTransaction implements ServerReques
inviteTransaction.releaseSem();
inviteTransaction = null;
}
- if(originalRequest !=null) {
+ if(originalRequest != null) {
originalRequest.setTransaction(null);
originalRequest.setInviteTransaction(null);
+ if(!originalRequest.getMethod().equalsIgnoreCase(Request.INVITE)) {
+ if(originalRequestSentBy == null) {
+ originalRequestSentBy = originalRequest.getTopmostVia().getSentBy();
+ }
+ if(originalRequestFromTag == null) {
+ originalRequestFromTag = originalRequest.getFromTag();
+ }
+ originalRequest.cleanUp();
+ }
}
if(lastResponse != null) {
lastResponseAsBytes = lastResponse.encodeAsBytes(this.getTransport());
diff --git a/src/performance/uas/Shootme.java b/src/performance/uas/Shootme.java
index b899593..cbe8de6 100644
--- a/src/performance/uas/Shootme.java
+++ b/src/performance/uas/Shootme.java
@@ -1,6 +1,7 @@
package performance.uas;
import gov.nist.javax.sip.message.RequestExt;
+import gov.nist.javax.sip.parser.selective.SelectiveParserFactory;
import java.util.Properties;
import java.util.Timer;
@@ -170,7 +171,6 @@ public class Shootme implements SipListener {
serverTransactionId = ((SipProvider)requestEvent.getSource()).getNewServerTransaction(request);
}
serverTransactionId.sendResponse(response);
-
} catch (Exception ex) {
ex.printStackTrace();
//System.exit(0);
@@ -207,7 +207,7 @@ public class Shootme implements SipListener {
properties.setProperty("gov.nist.javax.sip.RECEIVE_UDP_BUFFER_SIZE", "65536");
properties.setProperty("gov.nist.javax.sip.SEND_UDP_BUFFER_SIZE", "65536");
properties.setProperty("gov.nist.javax.sip.CONGESTION_CONTROL_ENABLED", "false");
-// properties.setProperty("gov.nist.javax.sip.MESSAGE_PARSER_FACTORY", LazyMessageParserFactory.class.getName());
+ properties.setProperty("gov.nist.javax.sip.MESSAGE_PARSER_FACTORY", SelectiveParserFactory.class.getName());
try {
// Create SipStack object
sipStack = sipFactory.createSipStack(properties);
@@ -251,7 +251,8 @@ public class Shootme implements SipListener {
public void processTransactionTerminated(
TransactionTerminatedEvent transactionTerminatedEvent) {
-
+ Request request = transactionTerminatedEvent.getServerTransaction().getRequest();
+// System.out.println(request);
}
public void processDialogTerminated(
© 2015 - 2025 Weber Informatics LLC | Privacy Policy