2.1.0 - 2024-08-30
Release versions now have three components, not four. This release requires Rhino 3.1 or later. |
Dependencies
-
All open source libraries have been updated to the latest available release.
Fixes
-
Handle early cancel: ensure that CANCELs that arrive before their respective INVITEs have finished processing are delivered to the right place. (#380144)
-
Fixed a race between SipSession invalidation and incoming mid-dialog requests that could sometimes cause server transactions to leak without a final response. (#1290178)
-
Ensure that headers added to an outgoing CANCEL are retained. (#1991104)
-
Removed unnecessary "no servlet found" alarm, which could be raised in some edge cases with no way to automatically clear it. (#340625)
2.0.0.0 - 2022-02-24
-
This release is built on and requires JDK 11. It requires Rhino 3.0 or later releases.
-
Network transport is now based on the Netty framework. (SIP-342)
-
Fixed an issue where the SIP stack would prematurely terminate an INVITE transaction if the TCP connection to the UAS was closed after receiving a 1xx response. (SIP-586)
-
Add support for SIP URIs using "transport=tls". (SIP-592)
-
When a "transport=tls" SIP URI is used for routing a request, the stack will select the TLS transport, and, if DNS SRV procedures are used, lookup the matching "_sips._tcp" SRV records.
-
-
Updated transaction statistics so they can be grouped by method. (SIS-1500)
-
Tracing improvements when servers are blocked and fail over handling. (SIP-566)
-
Improve block list behaviour on transaction timeout (Timer F) for non-INVITE transactions. (SIP-531)
-
Only block a server on non-INVITE transaction timeout if no 1xx has been received.
-
-
The target address is no longer blocked when the
RFC3263:failover_timer
fires for a transaction. (SIP-563) -
When doing last-resort attempts during RFC3263 failover, choose the highest priority node as the one to try, rather than the lowest priority (SIP-559)
-
Fixed a race condition that could lead to empty or incorrect header values being encoded. (SIP-556)
-
Fixed an issue when checking if a SIP URI matched a local address. URIs containing a valid SRV or NAPTR name may not have matched in some cases. (SIP-557)
-
Updated DNS resolver to use
timeout
andattempts
options configured in the host’s/etc/resolv.conf
file, or theRES_OPTIONS
environment variable, if it exists. (SIP-553) -
Fixed TLS client authentication behaviour; "NEED" mode was not being applied. (SIP-567)
-
Fixed skewed SRV balancing when using low weighted values (SIP-501).
-
Enabled EDNS0 support (SIP-526)
-
Fixed an incorrect loop that could lead to a stuck thread when storing replicated dialog state. (SIP-538)
-
Peers will no longer be blacklisted on 503 responses. Also, retries to alternate peers will be limited to a max of 2 or 10% of all SRV records. If all retries are unsuccessful, a 504 will be returned. (VOLTE-7087)
-
Fixed handling of truncated UDP datagrams. These were not detected and rejected properly, causing decoding of subsequent UDP messages to fail. (SIP-428/SIP-434)
1.1.0.39 - 2022-03-08
-
Fixed deadlock that could occur when invalidating a Proxy’s SipSession while the Proxy is processing an error response. (SIPSERV-353)
1.1.0.38 - 2021-07-26
-
Ensure that CANCELs are cloned when passing to the next application instance, so that headers and attributes are not changed inadvertently. (SIPSERV-352)
1.1.0.37 - 2021-06-08
-
Fixed handling of CANCEL between application instances, where the CANCEL could potentially be dropped due to looking up the wrong state for the corresponding INVITE. (SIPSERV-350)
1.1.0.36 - 2021-04-01
-
Fixed parsing error when handling semicolons in URI user parts. (SIPSERV-348)
This fix removes the previous behaviour of escaping special characters in a URI string before parsing the whole URI. This was specified in SIP Servlet javadoc (e.g. SipFactory.createURI()), but this violates RFC2396 which states that URIs are always in their escaped form. This may cause URI strings in application configuration or source code to be rejected if they contain unescaped special characters. Such URI strings are invalid and must be correctly escaped.
1.1.0.35 - 2020-12-16
-
Updated javassist version to handle application libraries packaged as multi-release jars. (SIPSERV-345)
1.1.0.33 - 2020-10-29
-
Fixed check when sending INVITE/2xx responses while a SipSession has unacknowledged reliable responses containing SDP. SipSession was incorrectly rejecting non-INVITE 2xx responses when in this state. (SIPSERV-342)
1.1.0.32 - 2020-10-14
-
Ensure that outgoing CANCEL requests use the same transport and target address as the INVITE request being cancelled. (SIPSERV-340)
1.1.0.31 - 2020-05-13
-
Fixed servlet application classloader so that classes from
WEB-INF/classes
andWEB-INF/lib
take priority. (SIPSERV-338) -
Ensure that any remaining transaction and cancel handling state is cleaned up when a SipSession becomes invalidated. (SIPSERV-339)
1.1.0.30 - 2019-12-04
-
Correctly handle responses for dialog-terminating NOTIFY and BYE requests that overlap. Ensure the SipSession activity does not end until all responses have been sent/received. (SIPSERV-337)
1.1.0.29 - 2019-07-15
-
Fixed a tracing issue where values received from the network could inadvertently be used inside format strings, causing runtime formatting exceptions when tracing enabled. (SIPSERV-336)
1.1.0.28 - 2019-06-19
-
Fixed session leak due to terminating NOTIFY requests not being detected correctly in some cases. (SIPSERV-335)
1.1.0.27 - 2019-05-21
-
Fixed
B2buaHelper.getLinkedSession()
to not throw an exception when the parent session’s linked session no longer exists. Returnnull
instead. (SIPSERV-332) -
Don’t log unnecessary warnings for late events. (SIPSERV-333)
-
If a late 2xx response to INVITE arrives while a session is ending, re-send the ACK. (SIPSERV-334)
1.1.0.26 - 2019-03-29
-
Fixed incorrect invalidate-when-ready behaviour which allowed sessions to be considered "ready to invalidate" while transactions were still in progress. (SIPSERV-326)
-
Fixed NullPointerException that could occur when trying to access pending messages in some cases. (SIPSERV-327)
-
Ensure all sessions, including derived sessions, receive the
sessionReadyToInvalidate
event. (SIPSERV-329) -
Fixed DNS NAPTR record service matching to be case-insensitive. (SIP-525)
-
Relaxed address parsing to permit no whitespace between an unquoted display-name and the URI, as per RFC 3261 errata https://www.rfc-editor.org/errata/eid5598. (SIP-521)
-
Fix parsing of multi-valued headers so that commas in valid positions within a header value are not treated as header delimiters. (SIP-496)
-
Fix address parsing so that an asterisk occurring in the display name does not cause the address to be mistakenly treated as a wildcard address. (SIP-497)
1.1.0.25 - 2018-08-02
-
Fixed session state leak when a forked session was ended in the first 30s after answer. (SIPSERV-325)
1.1.0.24 - 2018-04-05
-
Fixed deadlock that could occur when forwarding a response on a derived session. (SIPSERV-324)
1.1.0.23 - 2018-03-09
-
Automatically switch to TCP if trying to send large (> 1300 bytes) requests over UDP. Threshold may be adjusted with UDPMaxRequestSize config property. (SIPSERV-321/SIP-26)
-
Reject incoming messages if their session is invalidated in another thread before message is passed to the servlet. Requests are rejected with 481, responses are ignored. (SIPSERV-323)
1.1.0.22 - 2017-10-02
-
Fixed an IllegalStateException when accessing an attribute of a session that has ended. (SIPSERV-320)
1.1.0.21 - 2017-06-07
-
Fixed bug in handling addresses from P-Asserted-Identity and P-Preferred-Identity headers. (SIPSERV-316)
-
Fixed a SipSession leak that could occur when using forked responses. (SIPSERV-315)
-
Fixed bug where Proxy was incorrectly processing reliable responses, causing them to be dropped. (SIPSERV-317)
-
Fixed bug in tel URL parsing where '#' characters in valid positions were being rejected. (SIPSERV-318)
1.1.0.20 - 2017-04-28
-
Fixed handling of RA link names when multiple SIP Servlet RA entities are deployed. (SIPSERV-314)
1.1.0.18 - 2017-03-14
-
Improved handling of CANCELs when cancel state has been concurrently removed in another thread. (SIPSERV-306)
-
Send 503 response when rejecting initial requests due to overload. (SIPSERV-308)
-
Fixed NullPointerException when forwarding late 2xx responses. (SIPSERV-310)
-
Fixed issue where retransmits of late 2xx responses could create new derived sessions, rather than being associated with existing sessions. (SIPSERV-311)
-
Allow SipServletRequest.createCancel() to create CANCELs for re-INVITEs. (SIPSERV-312)
-
Don’t log late 2xx responses at Warning level. (SIPSERV-309)
1.1.0.17 - 2016-12-21
-
Fixed a race condition between incoming CANCEL and outgoing final responses when a UAS session was in proceeding or early states. (SIPSERV-301)
-
Fixed an issue where the B2buaHelper would return the wrong linked request when creating requests in the reverse direction to the initial INVITE. (SIPSERV-304)
-
Removed unnecessary exception thrown when an invalidated session receives a response. (SIPSERV-305)
1.1.0.16 - 2016-11-21
-
Update Contact header in all target refresh messages that are forwarded as a B2BUA. (SIPSERV-303)
1.1.0.14 - 2016-11-03
-
Ignore CANCELs arriving after a SipSession has been invalidated. (SIPSERV-299)
-
Added getPackage() support to SarClassLoader. (SIPSERV-294)
1.1.0.13 - 2016-09-16
-
Fixed a potential deadlock creating a servlet timer on a different SipApplicationSession than the one associated with the event currently being handled. (SIPSERV-290)
-
Fixed problems with BYE crossover scenarios. When receiving a BYE just after one was sent, the container generates a 200 OK response. When sending a BYE just after one was was received, the request will be sent without causing an exception. (SIPSERV-291)
-
Fixed bug where calling SipApplicationSession.invalidate() had no effect for converged applications. (SIPSERV-293)
1.1.0.12 - 2016-08-05
-
Ignore CANCELs arriving after a SipSession has already been terminated. (SIPSERV-284)
-
Fixed handling of INVITEs sent by an application to its own local SIP address via the loopback interface. (SIPSERV-285)
1.1.0.10 - 2016-06-03
-
The SIP Servlet container service is deactivated when a servlet fails to initialize. If initialization fails, the servlet’s destroy() method is invoked. (SIPSERV-272)
-
A follow-up to fix for SIPSERV-276. The SIP Servlet SBB now only handles timer events fired on SipApplicationSession activities. Timer events fired on other activities are ignored. (SIPSERV-286)
1.1.0.9 - 2016-05-26
-
Fixed potential deadlock that could occur when responding to an INVITE at the same time as processing an incoming CANCEL for the same INVITE. (SIPSERV-282)
-
Amend a previous fix to release locks when exceptions occur during SIP Servlet container startup or the SipServletListener.servletInitialized() method. (SIPSERV-277)
1.1.0.8 - 2016-05-19
-
ServletInitialized is now triggered after the container is considered operational and all the applications have been deployed. (SIPSERV-277)
-
Messages sent on new SipApplicationSessions created by SipFactory are now correctly delivered to the servlet. (SIPSERV-276)
1.1.0.7 - 2016-04-12
-
Preserve changes to the From and To headers in the SIP session. (SIPSERV-260)
-
Container now allows empty values for environment entries of type java.lang.String. For primitive types with empty values, the binding is skipped and a warning is displayed. (SIPSERV-221)
-
VirtualAddresses config property now supports host:port syntax. (SIPSERV-264)
1.1.0.5 - 2016-03-01
-
Fixed deployment of SARs containing indirect references to libraries (SIPSERV-252).
-
Add support for host:port syntax in VirtualAddresses (SIPSERV-264).
1.1.0.4 - 2016-02-05
-
Add RFC3263 DNS failover support, disabled by default to match existing behaviour (SIPSERV-240).
-
Fixed IllegalStateException that could occur when forwarding response upstream between two proxy applications (SIPSERV-249).
-
Fixed route set in derived SipSessions (SIPSERV-250).
-
Fixed UnknownFormatConversionException that could occur with Finest tracing enabled (SIPSERV-237).
-
Fixed creation of upstream derived SipSessions in B2buaHelper.getLinkedSession(), and generation of local tags in B2buaHelper.createResponseToOriginalRequest() (SIPSERV-253).
-
Fixed response creation so that Contact header is available for modification by application (SIPSERV-254).
-
Fixed initial local sequence numbers in derived SipSessions (SIPSERV-255).
-
Fixed copying of parent session attributes to derived sessions (SIPSERV-259).
1.1.0.2 - 2016-01-26
-
Updated RA security permissions to support Java 8 (SIPSERV-233).
-
Fixed deadlock that could occur when viewing SipSession activities in rhino-console (SIPSERV-226).
1.1.0.1 - 2014-09-20
-
Provide SIP Servlet applications with full access to SLEE Resource Adaptors (SIPSERV-208)
-
Provide annotations for servlet applications to declare RA Type bindings (SIPSERV-209)
-
Support @Resource injection of JNDI bindings by name (SIPSERV-210)
-
Provide API for attaching activities to SipApplicationSessions (SIPSERV-211)
-
Provide annotations for servlet application listeners to declare event handler methods (SIPSERV-212)
-
Provide API for non-SIP initial events to select a known servlet application instance (SIPSERV-213)
-
Documentation for Servlet - SLEE RA integration (SIPSERV-217)
-
-
Handling servlet not set when request forwarded in different thread (SIPSERV-204)
-
ClassCastException when installing custom application router (SIPSERV-205)
-
SIP TCP connections don’t handle extra CRLFs (SIPSERV-206)
-
Servlet temp dir is broken when using multiple hosts (SIPSERV-219)
-
Support multi-valued headers passed to SipServletMessage.{set,add}Header (SIPSERV-203)
-
Review use of security permissions in container and servlet apps (SIPSERV-215)
-
Fixed ready-to-invalidate behaviour in hybrid services (SIPSERV-220)
1.0.0.4 - 2013-07-15
-
SarClassLoader was using wrong resource path (SIPSERV-190)
-
IllegalStateException trying to respond to invalid ACK (SIPSERV-191)
-
Linking already linked sessions should be silently ignored (SIPSERV-192)
-
Contact header missing in subsequent provisional responses (SIPSERV-193)
-
SipServletMessage.setContent() should accept null (SIPSERV-194)
-
Improve SarClassLoader performance (SIPSERV-201)
1.0.0.2 - 2012-08-20
-
Released to comply with SIP Servlet Specification 1.1 (JSR 289) (SIPSERV-1)
-
Included example SIP applications; registrar-servlet, proxy-servlet, presence-servlet and b2b-proxy-servlet (SIPSERV-64)
-
The optional security mechanisms described in SIP Servlet Section 17 are not currently implemented, these will be implemented in future releases (SIPSERV-62):
-
Server authentication module (SIPSERV-122)
-
Digest authentication support (SIPSERV-123)
-
Implement P-Asserted-identity based authentication (SIPSERV-124)
-
Identity and Identity-info headers based authentication (SIPSERV-125)
-
TLS/SSL client cert based authentication (SIPSERV-126)
-
Declarative security support (SIPSERV-127)
-
Programmatic security support (SIPSERV-128)
-