Tom Miller February 2009 June 2009 Publications & Future Plans New CSTA Standards Enhancements Ecma/TC32-TG11/2009/011
Contents New Editions of: CSTA Standards: ECMA-269, ECMA-323, ECMA-348 CSTA Technical Report TR/82 Status & Publication Schedule Major Enhancements in new editions: Conferencing Location Services Call Control etc. Other Ecma CSTA standardization activities (future) UML-based CSTA Object Model Eventing mechanism for CSTA Web Services etc.
New Editions of the CSTA Standards & Technical Reports ECMA th edition CSTA Services description ECMA th edition CSTA XML schema for the services in ECMA-269 ECMA th edition Web Services (WSDL) schema for services in ECMA-269 & ECMA-323 ECMA TR/82 2 nd edition CSTA Scenarios including new advanced conferencing features
Publication Status Status of drafts of new editions: Drafts of new editions of ECMA-269 & ECMA-323 created and reviewed by TG11 Drafts of new editions of ECMA-348 & TR/82 being prepared Technical content of new editions frozen by CSTA TG11 (February 2009) The new editions incorporate enhancements agreed to by TG11 since the last editions were published in December 2006 Final drafts of new editions expected to be available in early April for voting in the Ecma General Assembly in June 2009 After publication by Ecma – the new editions of ECMA- 269 & ECMA-323 & TR/82 forwarded to ISO/IEC for voting
Highlights of enhancements in the new editions New features that enable the establishment and control of advanced types of conferencing Meet me conferencing Conference reservation, etc. Set of dedicated location-based features that enable location- aware applications Tracking of location changes of users and devices Call Control enhancements: enable applications to deflect calls to multiple destinations provide location information with CSTA call events (independent of location- based dedicated services) Enhanced deviceID formats indicate when a number and/ or a name associated with in a deviceID in a CSTA message should be treated as private (e.g. restrict presentation) New features that allow applications to synchronize with a CSTA implementation Query for active monitors & registrations after system events
Conferencing Enhancements Specifies a Conferencing model for the life cycle of a conference A new Make Connection service – to reserve conference resources for future use Detailed scenarios (TR/82) that illustrate: Creating a conference Reserving a conference (scheduled conferences) Enabling a conference Inviting one or a set of participants to a conference Populating a conference conference participant added to conference after calling into a conference (meet me) conference participant is added to conference after being called by conference (outbound) Mixed use of inbound (meet me) and outbound for same conference Automatically added after answer or after participant validation Removing participants from a conference Suspending a conference for future use Releasing a conference Etc. Improves the existing conference after consultation and single step conferencing model
Conference Life Cycle Creating a Conference A conference involving a Conferencing Device may be created via the Make Connection service. The Make Connection service creates a conference call with one connection at the Conferencing Device. A conference can be created that is either reserved or enabled. A reserved conference refers to a call involving a Conferencing Device that allocates resources at a Conferencing Device for future use. A reserved conference is modeled with a Conference Device connection in an initiated connection state. An enabled conference refers to a call involving a Conferencing Device that is ready to process media between participants that will be added to the call or are already part of the call. The Answer Call service may be used to enable a reserved conference by transiting the Conference Device connection state from initiated to connected (e.g. when a reserved conference is ready to start). Once the conference is enabled participants may be added to the call via services like Conference Call and Single Step Conference Call. The participants may be authenticated (via speech, DTMF, etc.) prior to being added to the conference. Removing participants Participants may be removed from the call via the Clear Connection service. Suspending a Conference A conference may be suspended (e.g. no media exchanged between participants in the call) via the Park Call service to place the connection at the Conferencing Device in the queued connection state. When a conference is suspended, resources at the Conferencing Device may be reused for other purposes. Releasing a conference A conference is released when all resources involving the conference are stopped. This is modeled with a Conference Device connection state of null. This may happen as a result of the Clear Connection service.
Implicit conferencing features Changes in the conference may also occur implicitly (i.e. without being invoked by a CSTA service). For example: a conference may be implicitly created and enabled whenever a conference participant becomes part of a call involving a Conferencing Device. a participant may be implicitly added to the conference when: a participant calls a Conferencing Device and the participant is added to the conference (no participant authentication is required). the participant answers a call that was initiated on behalf of the Conferencing Device. Once the participant answers the participant is added to the conference. a conference may be implicitly suspended when the last participant leaves the conference and the conference is maintained for future use. a conference may be implicitly released when the last participant leaves the conference (and there is no need to maintain the conference) or after an amount of time when no participants are involved with the conference.
Conference Model
New Location-based Features new services to allow applications to obtain and manage location information for users and devices such as: Setting location information – used by application when it wants to specify a location of a user and/or a device (e.g, client solicits mobile user for location information at application start up) Polling location information – used to obtain the latest location information associated with a user and/or a device Starting a location tracking session to be notified when location information changes via Location Information Reports Suspending and Resuming a location tracking session Services to get the capabilities location tracking capabilities etc.
Location Tracking Session Used for the continuous reporting of changes in user and/or device location information Started with a Start Location Tracking Session service that passes back a session identifier that is used with all services for the session. Specifies criteria for collecting location information, including filtering. In order to control the rate in which location information is collected, the application specifies a set of collection criteria on how the location information should be collected. For example the Start Location Tracking Session service may specify that location information should be collected every minute. The criteria for the reporting location information. In order to reduce the frequency of CSTA Location Information Report(s), an application specifies a set of reporting criteria that specifies how to buffer collected location information before sending it to the application. For example the Start Location Tracking Session service may specify that collected location information should be sent every 5 minutes.
Location Tracking Session
Format of Location Information in CSTA - based upon IETF Standards The CSTA LocationInfo parameter type contains a PIDF-LO element: Presence Information Data Format - Location Object for carrying location information as defined in IETF RFC-4119 as updated by IETF RFC Location information in a PIDF-LO element is contained in a GEOPRIV element. The GEOPRIV element consists of elements including: location-info - consisting of one or more chunks - each chunk can be either in Geospacial format or civic address format as discussed. Note that when two chunks are provided in a location-info element that corresponds to the same place, this is referred to as a compound location. A GEOPRIV element can be associated with a person or a device (or a generic tuple) element using the data model in RFC There can be multiple GEOPRIV elements in a single PIDF-LO. For example: For a CSTA user with 2 devices, location information in a single PIFDF-LO may be in three GEOPRIV elements: one contained in a person element, one contained in a device element (for a cell phone), and one contained in another device element (for an office phone). For a CSTA device such as an office phone, location information may be in a single GEOPRIV element contained in device element. The GEOPRIV location-info element contains two chunks of location information - one that specifies a location using Geospatial format and one that contains an office number as a civic address type that augments the Geospatial information. For a CSTA group-device consisting of 3 member devices, location information may be in three GEOPRIV elements each contained in separate device elements. The construction and interpretation of the location information in a PIDF- LO is based upon the latest draft of the IETF PIDF-LO Profile.
Call Control Enhancements Option to deflect a call to multiple destinations Application specifies (e.g. based upon rules) a set of device that all alert at the same time Caller connected to first one that answers, other alerting devices are cleared Parameters/features added to existing call control services: callCharacteristics added to Deflect and Single Step Transfer so an application can change the characteristics when it moves a call. Parameters added to existing call control events: locationInfo on all call control events so that location information can be presented with other information about the calling party on call arrival. calledDevice on Service Initiated event so that application knows who will be called when a prompt is answered Enhanced deviceID formats indicate when a number and/ or a name associated with in a deviceID in a CSTA message should be treated as private (e.g. restrict presentation)
Synchronization Enhancements Services that an application can use to synchronize with a switch: Get Monitors service to obtain the list of active monitors Get Registrations service to obtain the list of registrations Get Location Tracking services to obtain the list of location tracking services Typically used after system events like switchovers when there is a possibility of lost CSTA messages.
Ecma/CSTA Standardization Activities – work in progress Eventing Mechanism for next edition of Web Services for CSTA (ECMA-348) Standardize an event mechanism based upon latest WS- standards WS-Eventing – based upon current activities in W3C WS-RA working group WS-Base Notification Status: Working Draft version exists – under review Standard planned for December 2009 GA Voting UML-based Object Model Standard for CSTA (new Standard) Set of UML for all features in ECMA-269/ECMA-323 Java and C# libraries published with the Standard Enables easy access to CSTA features by CSTA developers Status: technical approach agreed major features such as call control specified, other categories need to be specified & incorporated into Working Draft Goal: New Standard planned for December 2009 GA Voting
Other Possible work items Presence information over CSTA Setting and observing presence for CSTA users and devices Call Control feature enhancements for mobile users One Number Service FMC, dual mode handsets, etc. Conferencing enhancements Whisper, sidebar, conference split, conference merge, etc. CSTA in Service Oriented Architecture (SOA) Beyond CSTA Web Services (ECMA-348) CSTA in a Unified Communications Environment Use of CSTA for UC apps Scenarios for multi-modal calls (IM, video, voice, etc.) Representational State Transfer (REST) API for CSTA Simplified access to CSTA services uaCSTA Enhancements - Improving SIP & CSTA synergy
Summary New editions of CSTA editions (expected June 2009) add powerful new features to CSTA Conferencing Location Services Call control routing enhancements Work in progress (CSTA Object Model Interface & Web Service with Eventing Standards expected December 2009) will facilitate use of CSTA features for: Java and C# developers Web Services developers CSTA Object Model Standard enhance use of CSTA as an application interface Future work items will keep CSTA aligned with latest technologies to enable state of the art applications Enterprise applications Unified communications REST SIP
Background Slides
List of ECMA-269 Changes in the 8 th edition : Conference Device Category - added conference modeling (2009/003 & 2008/067 Clause 12) : Location Features - added location services modeling clause (2008/041 & 2008/052 Clause 13) : Typo - changed explicit association to implicit association (2008/067 Clause 9.2) : DeviceID Tags - added deviceID tags privateNumber and a privateName (2008/044 & 2008/ 052 Clause 15) : ErrorCode parameter type - added error codes for Make Connection parameters (2008/ 043 & /067 Clause 12) & : LocationInfo & LocationInfoList parameter types: Added parameter type (2008/041 & 2008/052 Clause 13) added PIDF Profile Options (2008/065-Rev1 & 2008/067 Clause 14) : Get Switching Function Capabilities: added maximum number of maxDestinationDevicesForDeflect parameter for Deflect Call service (2007/022 & 2007/026 Clause 13) added privateNumber and privateName DeviceID Tags to deviceIDFormat parameter (2008/044 & 2008/052 Clause 15) : Get Registrations service & : RegistrationInfo service - new services (2007/026 Clause 14) : Get Monitors service & MonitorInfo service - new services (2007/023 & 2007/026 Clause 14) : Snapshot Call service - added optional locationInfo parameter to endpoint information in positive response (2008/020 Clause 3 & 2008/067) : Snapshot Call Data service- added optional locationInfo parameter to endpoint information in service request (2008/020 Clause 3 & 2008/067) : Answer Call service - added new Make Connection cause to Event Sequence tables (2008/ 058 & 2008/067 Clause 12).
List of ECMA-269 Changes in the 8 th edition (continued) : Conference Call service - clarified text allow two connected or two held calls to be conferenced (2008/058 & 2008/067 Clause 12) : Deflect Call service - added Deflect to Multiple Destinations feature (2007/022 & 2007/026 Clause 13) : Deflect Call service - added callCharacteristics parameter (2008/063 & 2008/057 Clause 16) : Make Connection service - new service (2008/058, 2008/043, & 2008/067 Clause 12) : Single Step Transfer Call service - added callCharacteristics parameter (2008/063 & 2008/ 057 Clause 16) : all call control events - added optional LocationInfoList to call control events (2008/020 Clause 3 & 2008/035) : Service Initiated event: 1.added calledDevice parameter (2007/021 & 2007/026 Clause 12) 2.added Make Connection to causes (2008/058 & 2008/067 Clause 12) : Connection Cleared event - added Multiple Alerting cause code (2007/021 & 2007/026 Clause 12) : Originated event - added Make Connection to causes (2008/058 & 2008/067 Clause 12) : Typo - Media Attachment Device changed to Media Access Device (2007/040 Clause 4) : Location Services - added service descriptions for location services (2008/041 & 2008/052 Clause 13) : Start Location Tracking Service 1.added location collection filters (2008/064 and 2008/067 Clause 14) 2.added PIDF Profile Options in response (2008/065-Rev1 & 2008/067 Clause 14)
List of ECMA-269 Changes in the 8 th edition (continued) 25.C.4.1: Capabilities for Snapshot Call service - added optional locationInfoList (2008/020 Clause 3 & 2008/067) 26.C.4.3: Capabilities for SnapshotCallData service - added optional locationInfoList (2008/020 Clause 3 & 2008/067) 27.C.5.11: Capabilities for Deflect Call service: 1.added multiple destination option (2007/022 & 2007/026 Clause 13) 2.added callCharacteristics parameter option (2008/063 & 2008/057) 28.C.5.19: Capabilities for Make Connection service (2008/058, 2008/043, & 2008/067 Clause 12) 29.C.5.26: Capabilities for Single Step Transfer Call service - added callCharacteristics parameter option (2008/063 & 2008/057) 30.C.6: Capabilities for Call Control Events - added locationInfoList as optional parameter for all call control events (2008/020 Clause 3 & 2008/035) 31.C.6.17: Capabilities for Service Initiated event - added calledDevice parameter option (2007/021 & 2007/026 Clause 12) : Device Identifier Tags - added deviceID tags to indicate when a deviceID number is private number and when a deviceID name is private (2008/044 & 2008/052 Clause 15)