| ECRIT | B.R. Rosen |
| Internet-Draft | NeuStar |
| Intended status: Standards Track | H. Tschofenig |
| Expires: January 16, 2013 | Nokia Siemens Networks |
| R. Marshall | |
| TeleCommunication Systems, Inc. | |
| July 17, 2012 |
Additional Data related to an Emergency Call
draft-ietf-ecrit-additional-data-03.txt
When an emergency call is sent to a Public Safety Answering Point (PSAP), the device that sends it, as well as any service provider in the path of the call, or access network may have information about the call which the PSAP may be able to use. This document describes an XML data structure that contains this kind of information in a standardized form. A Uniform Resource Identifier (URI) that points to the structure can be included in the SIP signaling with the call, or the data may be included in the body of a SIP message.
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.
Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet- Drafts is at http:/⁠/⁠datatracker.ietf.org/⁠drafts/⁠current/⁠.
Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."
This Internet-Draft will expire on January 16, 2013.
Copyright (c) 2012 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 (http:/⁠/⁠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.
As communications devices increasingly utilize the Internet to interconnect and communicate, users will expect to use such devices to request help. The Internet Protocol suite provides many advantages but also requires re-thinking of the traditional emergency calling architecture. The IETF emergency services architecture, as described in [RFC6443] and [I-D.ietf-ecrit-phonebcp], offers a much richer communication exchange and thereby better situational awareness for call takers. The richness comes in various forms, including the multi-media communication capabilities (via voice, video, instant messaging, and real-time text), but also via more extensive flow of information. Sharing information between various actors will enable more intelligent decision making and therefore better response in case of an emergency. A pre-requisite is to offer the technical capabilities to let call takers to gain access to this information stored elsewhere (granted that they are authorized to access it).
In general, there are four types of data exchanged:
When an emergency call is sent to a PSAP, while there is a rich set of data in the SIP message used for the call setup, the device, as well as any other service provider in the path may have even more information useful for a PSAP. This information may include the identity and contact information of the service provider, subscriber identity and contact information, the type of service the provider offers, what kind of device is being used, etc. Some data is device or service dependent data. For example, a car telematics system or service may have crash information. A medical monitoring device may have sensor data. While the details of the information may vary by device or service, there needs to be a common way to send such data to a PSAP.
This document focuses only on the data that can be obtained about a call and a mechanism for transporting it in an existing SIP header field, the Call-Info header, which is specified in Section 20.9 of [RFC3261]. For this purpose a new token, namely 'emergencyCallData' is defined to be carried in the "purpose" parameter. If the "purpose" parameter is set to 'emergencyCallData' then the Call-Info header contains a HTTPS URL that points to a service and data structure with information about the call or is a CID that allows the data structure itself to be placed in the body of the message. Section 8 shows a SIP INVITE example containing such a Call-Info header using the purpose parameter.
Besides a service provider in the path of a call, the access network (which in the IETF emergency call architecture provides location in the form of a PIDF-LO [RFC4119]) also has similar information that would be valuable to the PSAP. This information is not specific to the location itsef, but rather would provide descriptive information having to do with the immediate circumstances about the provision of the location (who the access network is, how to contact that entity, what kind of service the access network provides, possibly subscriber data, etc.). This data is similar in nearly every respect with the data known by services providers in the path of the call. For this reason, this document describes a "provided-by" namespace per [RFC4119] for passing information known to the access network.
The data is defined as a series of "blocks" that represent a class of information. Each of the blocks is a MIME type, and an extensible set of these types constitute the data structure. A registry is defined to list the block types that may be included.
The data structure contains an element which itself is a URI that has device or service dependent data. Thus the common Additional Data about a Call defined by this document contains a 'hook', in the form of a URI, for a device or service dependent data structure.
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119 [RFC2119].
The Additional Data about a Call is information specific to a call known by the device that sends it or a service provider in the path of a call or in the access network the call originates in. The Additional Data about a Call is a set of information blocks. Each block is a MIME type, and any set of blocks may be included in the set.
Two mechanisms are provided to transport the data set, namely
More than one Call-Info header with an emergencyCallData purpose can be expected, but at least one MUST be provided. The device MUST provide one if no service provider is in the path of the call. The device MAY insert one if it uses a service provider, and any intermediary service provider SHOULD insert its own. When there are multiple intermediaries, each intermediary SHOULD each insert one. For example, a device may provide one, a telematics service provider may provide one and the mobile carrier handling the call may provide one. There may be circumstances where there is a service provider who is unaware that the call is an emergency call and cannot reasonably be expected to determine that it is an emergency call. In that case, that service provider is not expected to provide emergencyCallData.
Note: The access network MAY supply additional data as well. For this purpose, this document defines a namespace and adds the namespace to the "provided-by" registry defined by PIDF-LO [RFC4119].
In regions where callers can elect to suppress certain personally identifying information, the network or PSAP functionality can inspect privacy flags within the SIP headers to determine what information may be passed, stored, or displayed to comply with local policy or law.
Additional data about a call is defined as a series of MIME objects, each with an XML data structure contained inside. MIME-multipart is used to enclose the XML documents and the sections below define them. When additional data is passed by value, the CID URL points to one of the blocks, and a link is provided in each of the other blocks to link to the next block. When additional data is provided by reference, the data is retrieved with an HTTP Get operation, which returns a multi-part MIME header and a set of MIME blocks threaded with the links. A registry of allowed types is created by this document. Every block MUST be one of the types in the registry.
This block is intended to be provided by any service provider in the path of the call or the access network provider. It includes identification and contact information. This block SHOULD be provided for every service provider in the path of the call, and the access network provider. Devices also use this block to provide identifying information. The MIME type is "addDataProviderInfo+xml".
<?xml version="1.0"?>
<xs:schema
targetNamespace="urn:ietf:params:xml:ns:addDataProviderInfo"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:ad="urn:ietf:params:xml:ns:addDataProviderInfo"
xmlns:xml="http://www.w3.org/XML/1998/namespace"
xmlns:vc="urn:ietf:params:xml:ns:vcard-4.0"
elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:import namespace="http://www.w3.org/XML/1998/namespace"
schemaLocation="http://www.w3.org/2001/xml.xsd"/>
<xs:simpleType name="iso3166a2">
<xs:restriction base="xs:token">
<xs:pattern value="[A-Z]{2}"/>
</xs:restriction>
</xs:simpleType>
<xs:element name="addDataProviderInfo">
<xs:complexType>
<xs:sequence>
<xs:element name="DataProviderString"
type="xs:string" minOccurs="1" maxOccurs="1"/>
<xs:element name="ProviderID"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="TypeOfProvider"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="ContactURI" type="xs:anyURI"
minOccurs="1" maxOccurs="1"/>
<xs:element name="Language" type="ad:iso3166a2"
minOccurs="0" maxOccurs="unbounded" />
<xs:element name="DataProviderContact"
type="vc:vcards" minOccurs="0" maxOccurs="1">
<xs:element name="Link"
type="xs:string" minOccurs="0" maxOccurs="1">
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
Figure 1: addDataProviderInfo XML Schema
This block describes the service that the service provider provides to the caller. It SHOULD be included by all SPs in the path of the call. The mime type is "addCallSvcInfo+xml".
There can be more than one value returned. For example, a VoIP prison telephone service is a reasonable combination.
<?xml version="1.0"?>
<xs:schema
targetNamespace="urn:ietf:params:xml:ns:addCallSvcInfo"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:svc="urn:ietf:params:xml:ns:addCallSvcInfo"
xmlns:xml="http://www.w3.org/XML/1998/namespace"
elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:import namespace="http://www.w3.org/XML/1998/namespace"
schemaLocation="http://www.w3.org/2001/xml.xsd"/>
<xs:element name="addCallSvcInfo">
<xs:complexType>
<xs:sequence>
<xs:element name="SvcEnvironment"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="SvcDelByProvider"
type="xs:string" minOccurs="0" maxOccurs="unbounded"/>
<xs:element name="SvcMobility"
type="xs:string" minOccurs="0" maxOccurs="unbounded"/>
<xs:element name="Link"
type="xs:string" minOccurs="0" maxOccurs="1">
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
Figure 2: addCallSvcInfo XML Schema
This block provides information about the device used to place the call. It should be provided by any service provider that knows what device is being used, and by the device itself. The mime type is "addDataDevInfo+xml".
<?xml version="1.0"?>
<xs:schema
targetNamespace="urn:ietf:params:xml:ns:addDataDevInfo"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:svc="urn:ietf:params:xml:ns:addDataDevInfo"
xmlns:xml="http://www.w3.org/XML/1998/namespace"
elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:import namespace="http://www.w3.org/XML/1998/namespace"
schemaLocation="http://www.w3.org/2001/xml.xsd"/>
<xs:element name="addDataDevInfo">
<xs:complexType>
<xs:sequence>
<xs:element name="DeviceClassification"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="DeviceMfgr"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="DeviceModelNr"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="UniqueDeviceID"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xs:element name="TypeOfDeviceID"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xsd:element name="devicespecificType"
type="xs:string" minOccurs="0" maxOccurs="1"/>
<xsd:element name="devicespecificSchema"
type="xsd:anyURI" minOccurs="0" maxOccurs="1"/>
<xs:element name="Link"
type="xs:string" minOccurs="0" maxOccurs="1">
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
Figure 3: addDataDevInfo XML Schema
This block describes the owner of the device (if provided by the device) or the subscriber information, if provided by a service provider. The contact location is not necessarily the location of the caller or incident, but is rather the nominal contact address. The mime type is "addCallSub+xml".
<?xml version="1.0"?>
<xs:schema
targetNamespace="urn:ietf:params:xml:ns:addCallSub"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:sub="urn:ietf:params:xml:ns:addCallSub"
xmlns:xml="http://www.w3.org/XML/1998/namespace"
xmlns:vc="urn:ietf:params:xml:ns:vcard-4.0"
elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:import namespace="http://www.w3.org/XML/1998/namespace"
schemaLocation="http://www.w3.org/2001/xml.xsd"/>
<xs:element name="addCallSub">
<xs:complexType>
<xs:sequence>
<xs:element name="SubscriberData"
type="vc:vcards" minOccurs="0" maxOccurs="1">
<xs:element name="Link"
type="xs:string" minOccurs="0" maxOccurs="1">
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
Figure 4: addCallSub XML Schema
INVITE sips:bob@biloxi.example.com SIP/2.0
Via: SIPS/2.0/TLS pc33.atlanta.example.com;branch=z9hG4bK74bf9
Max-Forwards: 70
To: Bob <sips:bob@biloxi.example.com>
From: Alice <sips:alice@atlanta.example.com>;tag=9fxced76sl
Call-ID: 3848276298220188511@atlanta.example.com
Call-Info: <http://wwww.example.com/alice/photo.jpg> ;purpose=icon,
<http://www.example.com/alice/> ;purpose=info,
<cid:1234567890@atlanta.example.com> ;purpose=emergencyCallData
Geolocation: <cid:target123@atlanta.example.com>
Geolocation-Routing: no
Accept: application/sdp, application/pidf+xml,
application/addDataProviderinfo+xml
CSeq: 31862 INVITE
Contact: <sips:alice@atlanta.example.com>
Content-Type: multipart/mixed; boundary=boundary1
Content-Length: ...
--boundary1
Content-Type: application/sdp
...SDP goes here
--boundary1
Content-Type: application/pidf+xml
Content-ID: <target123@atlanta.example.com>
…PIDF-LO goes here
--boundary1--
Content-Type: application/addDataProviderinfo+xml
Content-ID: <1234567890@atlanta.example.com>
…Additional Data goes here
--boundary1--
In a vCard, used extensively in this document, there is no way to specify a "Main" telephone number. These numbers are useful to emergency responders who are called to a large enterprise. This document adds a new Property Value to the "tel" property of the TYPE parameter called "main". It can be used in any vCard in additional data.
The information in this data structure will usually be considered private. HTTPS is specified to require the provider of the information to validate the credentials of the requester. While the creation of a PKI that has global scope may be difficult, the alternatives to creating devices and services that can provide critical information securely are more daunting.
The Call-info header with purpose='emergencyCallData' MUST only be sent on an emergency call, which can be ascertained by the presence of an emergency service urn in a Route header of a SIP message.
<how recipient validates credentials of sender>
<how sender validates credentials of recipient>
<how sender validates credentials of anyone requesting device dependent data>
[Editor's Note: The privacy considerations outlined in [I-D.iab-privacy-considerations] need to be addressed here in a future version of this document.
There is much private data in this information. Local regulations may govern what data must be provided in emergency calls, but in general, the emergency call system is often aided by the kinds of information described in this document. There is a tradeoff between the privacy considerations and the utility of the data. Certainly, if the data cannot be protected, due to failure of the TLS mechanisms described here, data not required by regulation SHOULD not be sent.
This document creates a new registry called ’Additional Call Data Blocks’. As defined in [RFC5226], this registry operates under "Expert Review" and "Specification Required" rules.
The content of this registry includes:
Name: Element Name of enclosing block.
Reference: The document that describes the block
The values defined are:
+---------------------+-----------+ | Name | Reference | +---------------------+-----------+ | addDataProviderInfo | RFCXXXX | | addCallSvcInfo | RFCXXXX | | addCallSvcInfo | RFCXXXX | | addCallSub | RFCXXXX | +---------------------+-----------+ RFC Editor Note: replace XXXX in the table above with this documents RFC number
This document creates a new registry called ’Additional Call Data Service Delivered’. As defined in [RFC5226], this registry operates under "Expert Review" rules.
The content of this registry includes:
Name: enumeration token of the service.
Description: Short description identifying the service.
The values defined are:
+--------+----------------------------------------+ | Name | description | +--------+-------+--------------------------------+ | Wrless | Wireless Telephone Service: Includes | | | Satellite, CDMA, GSM, Wi-Fi, WiMAX, | | | LTE (Long Term Evolution) | | Coin | Fixed Public Pay/Coin telephones: Any | | | coin or credit card operated device | | 1way | One way outbound service | | Prison | Inmate call/service | | Temp | Soft dialtone/quick service/warm | | | disconnect/suspended | | MLTS | Multi-line telephone system: Includes | | | all PBX, Centrex, key systems, | | | Shared Tenant Service | | SenseU | Sensor, unattended: Includes devices | | | that generate DATA ONLY. This is | | | one-way information exchange and | | | there will be no other form of | | | communication | | SenseA | Sensor, attended: Includes devices | | | that are supported by a monitoring | | | service provider or automatically | | | open a two-way communication path | | POTS | Wireline: Plain Old Telephone Service | | VOIP | VoIP Telephone Service: A type of | | | service that offers communication | | | over internet protocol, such as Fixed| | | Nomadic, Mobile, ... | +--------+-------+--------------------------------+
This document creates a new registry called ’Additional Call Data Device Classification’. As defined in [RFC5226], this registry operates under "Expert Review" rules.
The content of this registry includes:
Name: enumeration token of the device classification.
Description: Short description identifying the device type.
The values defined are:
+--------+----------------------------------------+ | Name | description | +--------+-------+--------------------------------+ |Cordless| Cordless handset | | Fixed | Fixed phone | | Mobile | Mobile handset | | ATA | analog terminal adapter | |Satphone| Satellite phone | | FSense | Stationary computing device (alarm | | | system, data sensor) | | Guard | Guardian devices | | Desktop| Desktop PC | | Laptop | Laptop computing device | | Tablet | Tablet computing device | | Alarm | Alarm system | | MSense | Mobile Data sensor | | Beacon | Personal beacons (spot) | | Auto | Auto telematics | | Truck | Truck telematics | | Farm | Farm equipment telematics | | Marine | Marine telematics | | PDA | Personal digital assistant | | PND | Personal navigation device) | | SmrtPhn| Smart phone | | Itab | Internet tablet | | Game | Gaming console | | Video | Video phone | | Text | Other text device | | NA | Not Available | +--------+----------------------------------------+
This document creates a new registry called ’Additional Call Data Device ID Type’. As defined in [RFC5226], this registry operates under "Expert Review" rules.
The content of this registry includes:
Name: enumeration token of the device id type.
Description: Short description identifying the type of device id.
The values defined are:
+--------+----------------------------------------+ | Name | description | +--------+-------+--------------------------------+ | MEID | Mobile Equipment Identifier (CDMA) | | ESN | Electronic Serial Number(GSM) | | MAC | Media Access Control Address (IEEE) | | WiMAX | device certificate unique id | | IMEI | International Mobile Equipment ID (GSM)| | UDI | Unique Device Identifier (medical) | | RFID | Radio Frequency Identification | | Sense | Sensors (types to be identified ) | | SN | Manufacturer Serial Number | | Other | Other | +--------+----------------------------------------+
This document defines the 'emergencyCallData' value for the "purpose" parameter of the Call-Info header field. The Call-Info header and the corresponding registry for the 'purpose' parameter was established with RFC 3261 [RFC3261].
Header Parameter New
Field Name Value Reference
---------- --------- ----------------- ---------
Call-Info purpose emergencyCallData [This RFC]
This section registers the namespace specified in ??? in the provided-by registry established by RFC 4119.
This specification requests the registration of a new MIME type according to the procedures of RFC 4288 [RFC4288] and guidelines in RFC 3023 [RFC3023].
This specification requests the registration of a new MIME type according to the procedures of RFC 4288 [RFC4288] and guidelines in RFC 3023 [RFC3023].
This specification requests the registration of a new MIME type according to the procedures of RFC 4288 [RFC4288] and guidelines in RFC 3023 [RFC3023].
This specification requests the registration of a new MIME type according to the procedures of RFC 4288 [RFC4288] and guidelines in RFC 3023 [RFC3023].
This section registers a new XML namespace, as per the guidelines in RFC 3688 [RFC3688].
BEGIN
<?xml version="1.0"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.0//EN"
"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type"
content="text/html;charset=iso-8859-1"/>
<title>Namespace for Additional Emergency Call Data:
Data Provider Information</title>
</head>
<body>
<h1>Namespace for Additional Data related to an Emergency Call</h1>
<h2>Data Provider Information</h2>
<p>See [TBD: This document].</p>
</body>
</html>
END
This section registers a new XML namespace, as per the guidelines in RFC 3688 [RFC3688].
BEGIN
<?xml version="1.0"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.0//EN"
"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type"
content="text/html;charset=iso-8859-1"/>
<title>Namespace for Additional Emergency Call Data:
Service Information</title>
</head>
<body>
<h1>Namespace for Additional Data related to an Emergency Call</h1>
<h2>Service Information</h2>
<p>See [TBD: This document].</p>
</body>
</html>
END
This section registers a new XML namespace, as per the guidelines in RFC 3688 [RFC3688].
BEGIN
<?xml version="1.0"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.0//EN"
"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type"
content="text/html;charset=iso-8859-1"/>
<title>Namespace for Additional Emergency Call Data:
Device Information</title>
</head>
<body>
<h1>Namespace for Additional Data related to an Emergency Call</h1>
<h2>Device Information</h2>
<p>See [TBD: This document].</p>
</body>
</html>
END
This section registers a new XML namespace, as per the guidelines in RFC 3688 [RFC3688].
BEGIN
<?xml version="1.0"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.0//EN"
"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type"
content="text/html;charset=iso-8859-1"/>
<title>Namespace for Additional Emergency Call Data:
Owner/Subscriber Information</title>
</head>
<body>
<h1>Namespace for Additional Data related to an Emergency Call</h1>
<h2> Owner/Subscriber Information</h2>
<p>See [TBD: This document].</p>
</body>
</html>
END
This specification registers four schemas, as per the guidelines in RFC 3688 [RFC3688].
This document registers a new value in the vCARD Parameter Values registry as defined by [RFC6350] with the following template:
This work was originally started in NENA and has benefitted from a large number of participants in NENA standardization efforts, originally in the Long Term Definition Working Group, the Data Technical Committee and most recently the Additional Data working group. The authors are grateful for the initial work and extended comments provided by the many NENA participants.
| [RFC6443] | Rosen, B., Schulzrinne, H., Polk, J. and A. Newton, "Framework for Emergency Calling Using Internet Multimedia", RFC 6443, December 2011. |
| [I-D.ietf-ecrit-phonebcp] | Rosen, B and J Polk, "Best Current Practice for Communications Services in support of Emergency Calling", Internet-Draft draft-ietf-ecrit-phonebcp-20, September 2011. |
| [I-D.iab-privacy-considerations] | Cooper, A, Tschofenig, H, Aboba, B, Peterson, J and J Morris, "Privacy Considerations for Internet Protocols", Internet-Draft draft-iab-privacy-considerations-01, October 2011. |