Internet Engineering Task Force (IETF) R. Jesske Request for Comments: 8606 Deutsche Telekom Updates: 3326 June 2019 Category: Standards Track ISSN: 2070-1721 ISDN User Part (ISUP) Cause Location Parameter for the SIP Reason Header Field Abstract The SIP Reason header field is defined to carry ISUP (ISDN User Part) cause values as well as SIP response codes. Some services in SIP networks may need to know the ISUP location where the call was released in the PSTN (Public Switched Telephone Network) to correctly interpret the reason of release. This document updates RFC 3326 by adding a location parameter for this purpose. Status of This Memo This is an Internet Standards Track document. This document is a product of the Internet Engineering Task Force (IETF). It represents the consensus of the IETF community. It has received public review and has been approved for publication by the Internet Engineering Steering Group (IESG). Further information on Internet Standards is available in Section 2 of RFC 7841. Information about the current status of this document, any errata, and how to provide feedback on it may be obtained at https://www.rfc-editor.org/info/rfc8606. Copyright Notice Copyright (c) 2019 IETF Trust and the persons identified as the document authors. All rights reserved. This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Simplified BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Simplified BSD License. Jesske Standards Track [Page 1] RFC 8606 ISUP Release Location Parameter June 2019 Table of Contents 1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . 2 2. Terminology . . . . . . . . . . . . . . . . . . . . . . . . . 3 3. Rationale . . . . . . . . . . . . . . . . . . . . . . . . . . 3 4. Mechanism . . . . . . . . . . . . . . . . . . . . . . . . . . 3 5. Example . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 6. Privacy Considerations . . . . . . . . . . . . . . . . . . . 5 7. Security Considerations . . . . . . . . . . . . . . . . . . . 5 8. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 6 8.1. Registration of the Location Parameter for the Reason Header Field . . . . . . . . . . . . . . . . . . . . . . 6 9. Normative References . . . . . . . . . . . . . . . . . . . . 6 Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . . 7 Author's Address . . . . . . . . . . . . . . . . . . . . . . . . 7 1. Introduction Section 3.4 of [RFC3326] describes a SIP message flow for canceling an INVITE request when a REL (release) message is received from the ISUP side. That document specifies the SIP Reason header field [RFC3326] that is used to indicate the reason of release. The reason of release indicates why a SIP Dialog or a PSTN call, in cases where the call was interworked to the PSTN, was terminated. The termination may be normal, based on a failure within an entity (e.g. temporary failure) or caused by other factors (e.g., congestion). The reason may be a SIP response or an ISUP release cause as specified within [Q.850]. [RFC6432] specifies that an ISUP [Q.850] cause code can be carried within a SIP response, but not the Q.850 location information. The [Q.850] location information identifies the part of the ISUP network where the call was released. This document adds a location value parameter to the reason-extension parameter defined in [RFC3326] so that the [Q.850] location value can be interworked from the PSTN. The interworking from the PSTN needs only to include the location received by the interworking gateway. [Q.850] describes the definitions of the cause code values and the locations used in ISDN and DSS1 (Digital Subscriber Signalling System No. 1) environments. The cause code is used for identifying the reason of release of a call, and the location identifies where the call was released. Jesske Standards Track [Page 2] RFC 8606 ISUP Release Location Parameter June 2019 2. Terminology The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here. 3. Rationale The primary intent of the parameter defined in this specification is for use in IMS (IP Multimedia Subsystem) networks defined by 3GPP, but it is also open to be used by any other networks that include ISUP interworking gateways and use Q.850 reason codes. The purpose of this parameter is to hold the location of the call release so that it can be transported from the originating PSTN entity to the SIP entity via a response or BYE message. The ISDN location is defined in [Q.850]. 4. Mechanism As defined by [RFC6432], any SIP Response message, with the exception of 100 (Trying), MAY contain a Reason header field with a Q.850 [Q.850] cause code. This specification adds a parameter with the ISUP location value defined in [Q.850] to the Reason header field that identifies the location of the call release in ISUP. The location is a 4-bit value that reflects the possible locations where an ISUP call is released. Some values are spare or reserved for national use. The Augmented BNF (ABNF) [RFC5234] for this parameter is shown in Figure 1. Jesske Standards Track [Page 3] RFC 8606 ISUP Release Location Parameter June 2019 reason-extension =/ isup-cause-location isup-cause-location = "location" EQUAL isup-location-value isup-location-value = "U" / ; for 0 0 0 0 user "LPN" / ; for 0 0 0 1 private network serving the local user "LN" / ; for 0 0 1 0 public network serving the local user "TN" / ; for 0 0 1 1 transit network "RLN" / ; for 0 1 0 0 public network serving the remote user "RPN" / ; for 0 1 0 1 private network serving the remote user "LOC-6" / ; for 0 1 1 0 spare "INTL" / ; for 0 1 1 1 international network "LOC-8" / ; for 1 0 0 0 spare "LOC-9" / ; for 1 0 0 1 spare "BI" / ; for 1 0 1 0 network beyond interworking point "LOC-11" / ; for 1 0 1 1 spare "LOC-12" / ; for 1 1 0 0 reserved for national use "LOC-13" / ; for 1 1 0 1 reserved for national use "LOC-14" / ; for 1 1 1 0 reserved for national use "LOC-15" ; for 1 1 1 1 reserved for national use Figure 1: ABNF for isup-cause-location Note: These are the location values defined within [Q.850]. The 'LOC-*' names are the wire codepoints for the values currently left as 'spare' or 'reserved' in [Q.850]; these will continue to be the wire codepoints in the case of future allocation or national usage of the such values. The UAC or UAS SHALL include the location parameter in a request or response when setting up the Reason header field with a [Q.850] cause when the ISUP [Q.850] location is available. The use of the location parameter is restricted to Q.850 cause values. Other values MUST be ignored if present. 5. Example The following example shows a SIP 404 response message containing a Reason header field with a [Q.850] cause value and an isup-cause- location value. The 404 Response will be sent when a gateway receives an ISUP release with a [Q.850] cause set to 1, meaning Unallocated (unassigned) number, i.e., the number is not known in the PSTN. Jesske Standards Track [Page 4] RFC 8606 ISUP Release Location Parameter June 2019 SIP/2.0 404 Not Found Via: SIP/2.0/TCP proxy.example.com:5060;branch=z9hG4bKx5st Via: SIP/2.0/TCP 192.0.2.3:5060;branch=z9hG4bK4321 From: Alice <sips:alice@atlanta.example.com>;tag=1234567 To: Bob <sips:bob@biloxi.example.com>;tag=765432 Call-ID: 12345600@atlanta.example.com CSeq: 1 INVITE Reason: Q.850;cause=1;text="Unallocated (unassigned) number"; location=LN Content-Length: 0 Figure 2: Example of a Location in the Reason Header Field 6. Privacy Considerations While the addition of the location parameter provides an indicator of the entity that added the location in the signaling path, it provides little more exposure than the [Q.850] cause itself. The ISUP location value itself will not reveal the identity of the originating or terminating party of the call. It shows only the ISUP network location of the device that released the call. The ISUP location does not show the physical location of the caller or callee. 7. Security Considerations This document doesn't change any of the security considerations described in [RFC3326]. The addition of the location parameter provides an indicator of the [Q.850] location where the call was released within the PSTN. This information may be used for specific location-driven services but does not create any additional security constraints. Because the [Q.850] location is very imprecise, the [Q.850] location value itself will not add any major security constraints. The use of this parameter is not restricted to a specific architecture. [RFC3398] describes detailed security considerations due to interworking between ISUP and SIP. Beyond these considerations, the addition of the location does not introduce new security concerns. The location shows the network part where the call was released. Knowing this does not increase the possibilities of extended fraud scenarios. Jesske Standards Track [Page 5] RFC 8606 ISUP Release Location Parameter June 2019 8. IANA Considerations 8.1. Registration of the Location Parameter for the Reason Header Field IANA has registered a new SIP header parameter in the "Header Field Parameters and Parameter Values" subregistry of the "Session Initiation Protocol (SIP) Parameters" registry <https://www.iana.org/assignments/sip-parameters>, per the guidelines in [RFC3968]: Header Field: Reason Parameter Name: location Predefined Values: Yes Reference: RFC 8606 9. Normative References [Q.850] ITU-T, "Usage of cause and location in the Digital Subscriber Signalling System No. 1 and the Signalling System No. 7 ISDN user part", Recommendation ITU-T Q.850, October 2018, <https://www.itu.int/rec/T-REC-Q.850>. [RFC2119] Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10.17487/RFC2119, March 1997, <https://www.rfc-editor.org/info/rfc2119>. [RFC3326] Schulzrinne, H., Oran, D., and G. Camarillo, "The Reason Header Field for the Session Initiation Protocol (SIP)", RFC 3326, DOI 10.17487/RFC3326, December 2002, <https://www.rfc-editor.org/info/rfc3326>. [RFC3398] Camarillo, G., Roach, A., Peterson, J., and L. Ong, "Integrated Services Digital Network (ISDN) User Part (ISUP) to Session Initiation Protocol (SIP) Mapping", RFC 3398, DOI 10.17487/RFC3398, December 2002, <https://www.rfc-editor.org/info/rfc3398>. [RFC3968] Camarillo, G., "The Internet Assigned Number Authority (IANA) Header Field Parameter Registry for the Session Initiation Protocol (SIP)", BCP 98, RFC 3968, DOI 10.17487/RFC3968, December 2004, <https://www.rfc-editor.org/info/rfc3968>. Jesske Standards Track [Page 6] RFC 8606 ISUP Release Location Parameter June 2019 [RFC5234] Crocker, D., Ed. and P. Overell, "Augmented BNF for Syntax Specifications: ABNF", STD 68, RFC 5234, DOI 10.17487/RFC5234, January 2008, <https://www.rfc-editor.org/info/rfc5234>. [RFC6432] Jesske, R. and L. Liess, "Carrying Q.850 Codes in Reason Header Fields in SIP (Session Initiation Protocol) Responses", RFC 6432, DOI 10.17487/RFC6432, November 2011, <https://www.rfc-editor.org/info/rfc6432>. [RFC8174] Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, May 2017, <https://www.rfc-editor.org/info/rfc8174>. Acknowledgments Thanks to Michael Kreipl, Thomas Belling, Marianne Mohali, Peter Daws, Paul Kyzivat, Dale Worley, Yehoshua Gev, and Keith Drage for the comments and review. Author's Address Roland Jesske Deutsche Telekom Heinrich-Hertz Str, 3-7 Darmstadt 64295 Germany Email: r.jesske@telekom.de URI: www.telekom.de Jesske Standards Track [Page 7]