Open Interfaces CCT SDK
Open Interfaces CCT SDK
Open Interfaces CCT SDK
Nortel
-1-
Nortel
SOAP is an industry-accepted W3C specification used to describe messages (XML documents and their attachments) so that they can be sent across a network.
A SOA is a collection of services. A service is a function that is well-defined, self-contained, and does not depend on the context or state of other services. These services communicate with each other. 3[3] A Web service is an application that accepts XML-formatted requests from other systems across a network (Internet or intranet) using lightweight, vendor-neutral communications protocols. 4[4] WSDL is the Web Services Description Language. WSDL provides a grammar for describing services as a set of endpoints that exchange messages. A WSDL document serves as a language and platform-agnostic (XML) description of one or more services. It describes the services, how to access them, and what type of response (if any) to expect. A WSDL document can be either privately exchanged or posted to a UDDI registry (either public or private) to allow broader access.
2[2]
1[1]
-2-
Nortel
This documentation is for the CCT Open Interfaces which are related to the following version of the contact centre. Version Build 7.0 7.0.1.142 The specific version of each service can be found by going to the splash an locating the service, the version is detailed in the header of the table Service Method List i.e. for the AddressService the table can be found @ http://47.166.94.66:9090/Services.jsp?servicename=AddressService Please refer to the Developer Program web site for the latest version of all documentation.
Advantages of SOA
SOA is an architectural style whose goal is to achieve a loose coupling among interacting software agents. This means that applications existing on different Operating Systems written in different Operating Systems written in different programming languages can communicate and exchange data with each other. The Open Interfaces provides a number of basic features that make it easier to deploy a variety of applications. These features include: zero deployment SOA has a loose coupling of services with operating systems, programming languages and other technologies and hence does not place additional requirements on the client to download Nortel libaries technology agnostic SOA is not associated with a specific OS, programming language or technology and hence leaves the clients free to develop in their language(s) of choice. Common integration point SOA is becoming a common integration technology between different technologies and applications .
-3-
Nortel
SDK contents
The SDK contains the following elements:
application programming interface documentation installed reference client source code for reference client implementations Tutorial for creating a client using flex technology.
Reference Client
The CCT Open Interfaces contains a reference client that can be used to test the web services. This reference client is similar in design to the .Net CCT reference client and allows users to exercise the majority of the call control functionality available through the web services. The reference client can be found at \Open Interfaces CCT SDK\reference client\OI_RefClient This reference client can be launched using the RefClient.bat. Once launched the reference client can be configured to point to the CCT server, by accessing the Preferences file menu and entering the CCT server name the configured port name and whether this service has been configured to use TLS. Once the OI reference client has been configured to point to the CCT server hosting the Open Interfaces the user will need to log in using the correct CCT login in credentials Parameter Description Username A windows user that has been imported into CCT Password Domain Password associated with the windows user The name of the server or domain on which the user has been registered.
SDK support
Support for the SDK APIs is supplied by the Developer Partner Program. For more information about contacting support personnel, see Contacting support.
-4-
Nortel
Related Documents
The following table lists documents that contain more information about the Open Interfaces: The following table lists documents that contain more information about the Communication Control Toolkit: For information about Security considerations Planning and engineering requirements See Nortel Contact Center Security (NN44400-612) Nortel Contact Center Planning and Engineering (NN44400-210) Nortel Contact Center Engineering Requirements (NN44400-211) Nortel Contact Center Installation (NN44400-311) Nortel Contact Center Commissioning (NN44400-312) Nortel Contact Center Upgrade and Patches (NN44400-410) Nortel Contact Center Troubleshooting (NN44400-712)
Installing, upgrading, and maintaining the Communication Control Toolkit server software
Troubleshooting problems
-5-
Nortel
Contacting Support
If you are a Developer Partner, contact the Developer Support personnel through the following e-mail address: nt4cti@nortel.com. For details about creating new Developer Partner memberships or renewing existing memberships, contact the Developer Support personnel through the following e-mail address:devprog@nortel.com. For details about the Developer Partner Program, see http://www.nortel.com/prd/dpp/.
-6-
Nortel
high functionality client application using the Full API simple client application using the Lite API
Each of the above APIs has its own client reference implementation. These API client reference implementations include source code, enabling you to write your own Communication Control Toolkit SDK API Clients.
complete feature set suitable for both complex client or complex CCT server based solutions
The following is a list of services that comprise of the Full API: Service Name
SOAOICCT_AddressService SOAOICCT_AgentService SOAOICCT_AgentTerminalConnectionService SOAOICCT_AgentTerminalService SOAOICCT_ConnectionService SOAOICCT_ContactService SOAOICCT_MetricsService SOAOICCT_RoutePointAddressService SOAOICCT_RoutePointConnectionService SOAOICCT_TerminalConnectionService SOAOICCT_TerminalService SOAOICCT_UserService SOAOICCT_NotificationProducer SOAOICCT_NotificationConsumer
-7-
Nortel
rapid client or simple server based solutions easy to use, ideal for form or non-form based integrations reduced feature set of Full API
The following is a list of services that comprise of the Full API: Service Name
SOAOICCT_SessionService SOAOICCT_NotificationProducer SOAOICCT_NotificationConsumer
-8-
Nortel
Prerequisites
The following assumptions are made. 1. That the CCT and the CCT Open Interfaces are configured an running. Please refer to the Nortel Contact Center Commissioning guide on how to configure the web services. 2. That the developers are both familiar with their choice of technology and how that technology integrates with web services.
CCT Login
Before the service can be used the developer must first receive a Single Sign On (SSO) token that will be used for all subsequent calls to the service. To receive this token the developer must supply the required authentication details; Username The user will need to have imported either a windows or domain user into the CCT system Password a password associated with the supplied windows username. Domain the domain of the windows user that was imported. (or server name if user is created locally on CCT server)
-9-
Nortel
When the user logs in successfully they receive an sso token that associates a session with the user. This session is used to validate subsequent method calls with a specific session and associate any registered notifications with a specific session. Each session has a time out associated with it. The default for a Session timeout is 2 hours but can be configured using the OI configuration screen. Each time the service is accessed this timeout is reset.
Method Call
Third party applications wishing to access the call control functionality of the CCT Open Interfaces will issue SOAP messages directly or through a proxy layer to the services.
Asynchronous Events
Historically with web-services in a client server environment where a client wants to be kept up to date with status on the server, this was realized through polling. i.e. the client would periodically poll the server for its current status. For example, if a soft phone application wants to know when there was a change in state of the phone conversation, the following steps would occur for a polling approach; The client asks server if any changes in call The server responds indicating no changes. The client asks server if any changes in call The server responds indicating no changes. This continues until at some point after the call changes state, the server responds indicating a change in state and the client can then act on this change.
This approach isnt very efficient. If the time between polls is small then CPU usage and network traffic increases. If there are more than one client/consumer, the server/producer can get saturated process client requests.
The solution to this problem is web services notifications. Instead of periodically asking the producer if there are any changes, we make an initial call asking the producer to notify the consumer whenever a certain event occurs. The CCT Open Interfaces relies on the WS-Notification standard to deliver asynchronous notifications to registered clients. There are two principle parts to this solution the Notification Producer and the Notification Consumer. Basically, notification producers have to expose a subscribe operation that notification consumers can use to request a subscription. Consumers, in turn, have to expose a notify operation that producers can use to deliver the notification.
Notification Producer
A Notification Producer is capable of producing a set of Notification messages. A NotificationProducer accepts incoming Subscribe requests. Each Subscribe request contains a reference to a NotificationConsumer and identifies the subset of the Notifications the NotificationProducer should produce. This subset can be described
- 10 -
Nortel
by identifying one or more boolean filters, including filtering by Topic, as discussed in [WS-Topics]. Topics are used to represent the set of items of interest for subscription. The NotificationProducer agrees to produce Notification Messages as requested in the Subscribe request, or returns a fault if the subscription cannot be handled. The user as the choice of registering for all events or a specific list of events, for performance reasons it is recommended that the user registers only for events they are interested in.
Notification Consumer
A Notification Consumer represents the endpoint to which the Notification Producer sends events. The client application implements the Notification Consumer web service based on the Notification Consumer WSDL. The client application then subscribes for events i.e. contact state changes, with the Notification Producer. When an event occurs the producer creates the appropriate notification message and determines what consumers have registered interest in that event from its list of subscriptions. Finally, the producer invokes the notify operation of the consumer passing the notification message as parameter. Please note that the Notification service requires ports being established between the Server and the Client machines, this may require firewall configuration changes.
The project can be obtained from the following directory Tutorial Location
OI Reference Client /Open Interfaces CCT SDK/reference client/project
- 11 -
Nortel
The SSO object Address objects Terminal objects Contact objects Connection objects TerminalConnection objects
Note: The objects described here are from the Communication Control Toolkit Full API. Similar objects, with slightly different names, exist in the Lite API.
The SSO object is required for all subsequent calls to the Open Interfaces. The SSO is used to verify that the user has been authenticated and to associate the user with their current session.
- 12 -
Open Interfaces CCT SDK If there is no activity related to this SSO token for 2 hours (see configuration) the session will timeout and subsequent calls using this session will fail. If the user has registered for events then a SessionTermination imminent event will notify that the session is about to expire and must be refreshed. If the Open Interfaces service is interrupted (planned or unplanned) the session will be invalidated and an exception will be thrown the next time this session is used.
Nortel
object properties that are queried and/or set by the application (for example, the "do not disturb" status of the address) methods that are invoked by the client to perform some function (for example, originate a call from this address) events for which the application can register handlers to be notified of changes related to the address or other objects related to it (for example, a change in value of one of the address properties, or a change in state of one of the connections to this address)
Like many of the object interfaces defined by the Open Interfaces, the Address object contains a special GetCapabilities method. This method returns an object that is used to determine what properties and/or methods the object currently supports. For example, in the case of an AddressService, the Capabilities object is defined by the AddressCapabilities complex type. The Capabilities object contains a set of Boolean flags that map to specific properties and/or methods found on the parent object. These flags indicate whether the
- 13 -
Nortel
corresponding property or method is used by the application. Some of the flags defined by the Capabilities object are static in nature (for example, the address never supports Do Not Disturb functionality), or they are dynamically updated by the Communication Control Toolkit server in response to changes in the state of the object. The Capabilities object is used by the application to adjust the user interface to match the set of capabilities provided by the Address object. The Address object defines a rich set of events so that the client application can listen for changes in the Communication Control Toolkit server that are related to the address. The following events are available on the Address object:
Address property changed event Indicates a change in one of the properties of the address object. Connection state changed and remote connection state changed events Separate events are provided for local and remote connections. Local connections are those connections that are directly related to the address, whereas remote connections are those that are related to the address through an existing contact and thereby represent the remote leg of a call. More discussion regarding connection objects will follow in a later section. Connection property changed event This event signals a change in a property of one of the local connections currently associated with the address. Contact property changed event This event signals a change in a property of a contact object associated with the address.
Based on the client application, not all of the events need to have event handlers registered against them; however, Nortel recommends that you register a connection state changed event handler. Nortel also recommends that you register an address state changed event handler on the session service. This enables addresses to be taken out of service or entirely removed from the configuration. For more information, see AddressService, SessionService
Like Address objects, Terminal objects are remote objects that reside on the Communication Control Toolkit server. The objects can be accessed through the TermnialService. This base TerminalService defines a terminal that models a common business set (also known as a Knowledge Worker set).
- 14 -
Open Interfaces CCT SDK The capabilities supported by a particular terminal are obtained through the TerminalCapabilities complex type, returned by calling the terminal service GetCapabilities method.
Nortel
The Communication Control Toolkit Open Interface also defines a specialization of the Terminal object used to model a contact center agent set. The AgentTerminal service derives from the base Terminal service to provide the expanded functionality of the contact center agent set. Since the AgentTerminal service expands the set of properties and methods available to the client, the Capabilities property for an agent terminal returns an AgentTerminalCapabilities complex type, rather than the TerminalCapabilities complex type that is returned for a normal terminal. Regardless of the particular type of terminal being modeled, all terminals require an address to be associated with them to be useful. The Terminal object provides a RelatedAddresses property that returns the set of addresses defined to be related to the terminal. This information is used by the client application to provide an intelligent interface. This intelligent interface allows you to select the primary terminal and address combination used to initiate outbound contacts. Like the Address object, the Terminal object also defines a set of events on which the client application registers event handlers, although the set is somewhat smaller. The following events are available on the Terminal object:
Terminal property changed event Indicates a change in one of the properties of the Terminal object. Terminal connection state changed event Indicates a change in the state of one of the terminal connections associated with the terminal. To find out more about Terminal Connection objects, see TerminalConnectionState.
Traditional voice Terminal objects (i.e. those that represent a physical phone set) are statically configured on the Communication Control Toolkit server and are assigned to the CCT user via the administration console. Other Terminal objects that represent multimedia terminals or SIP-based telephony clients are dynamically created when a Contact Center agent logs in (refer to the Agent service for more information). Thus, in this environment it is required that a Open Interfaces client application register for Terminal state change event in order to become aware of these dynamically created Terminal objects. Similarly, the Address objects assigned to these Terminals are also dynamically created and require an event handler installed on the ISession.AddressStateChanged event. Note: Because of their dependence on the Nortel Contact Center functionality, these multimedia Terminal objects will never be available in a Knowledge Worker (non Contact Center) environment. For more information, see TerminalService
- 15 -
Nortel
Client applications become aware of the existence of a contact through various methods:
a notification received by a registered endpoint on the "contact entering scope" event of the applications Session object a notification received by a registered endpoint on the "connection state changed" event of one of the applications Address objects a notification received by a registered endpoint on the "terminal connection state changed" event of one of the applications Terminal objects the return value of a method called on one of the remote objects associated with the session (for example, the Originate method on an Address object)
A Contact object is a remote object residing on the server, which is accessible through the ContactService. The Contact object implements a GetCapabilities method, which returns a ContactCapabilities complex type. The Capabilities complex type allows the client application to determine what functions the Contact object supports. Unlike the Address and Terminal objects, Contact objects do not directly provide any events to the client. Instead, changes to the properties of a Contact object are received by the application through a "contact property changed" event handler registered on one of the clients Address objects. This approach allows the client to install the event handler prior to actually receiving the contact, thereby eliminating the possibility of missing contact-related events in the time period between when the client first learns of the existence of the contact and when it has an event handler registered on it. The most notable property of the Contact object is the ability to associate arbitrary data with the contact. This data can be accessed through the Data property on the Contact service as an array of key/value pairs. or optionally as Strings or Binary data,, and it remains associated with the contact for the life of the contact. The contact data can be accessed and/or modified by any client that has access to the contact. If a contact is transferred from one address to another, the contact-related data moves with the contact. Client applications can use this contact data to record such things as caller account information with the contact so that when it is moved from department to department, the caller does not need to repeat or reenter it. For more information, see ContactService.
- 16 -
Nortel
IAddress object A IAddress object B IContact object C, representing the call IConnection object CA, representing the relationship between address A and contact C IConnection object CB, representing the relationship between address B and contact C
The Connection object is a remote object residing on the Communication Control Toolkit server that can be accessed through the Connection service. The Connection object, coupled with the TerminalConnection Service, provides the majority of the state information and control capabilities found in the Communication Control Toolkit Open Interfaces. The client application learns about new connections through the event handlers that the client has registered on the connection state changed events of the sessions Address objects. If the client receives a state change event for a connection it has never seen before, it can assume that the connection represents a new contact on the associated Address object. No one connection state can be expected to signal a new connection on an address. The client application can also query the address object directly for an array of current connections on that address. This is useful following
- 17 -
Nortel
connection to the Communication Control Toolkit server for determining the current state of affairs for the addresses assigned to the clients session. As events occur in the Communication Control Toolkit server affecting the state of the connection, state change events are relayed to the client. The client, upon receiving these events, can perform whatever processing is necessary, such as updating a display, enabling buttons, and so on. One important state change that the client must watch for is a transition to the Disconnected state. This state transition signals the client that the associated connection object is no longer valid and all references to it should be discarded. If the client application is monitoring remote connection objects associated with its addresses, it is important to note that the client is not guaranteed to receive a Disconnected event for any remote connections, since local connections from the contact to the address may be torn down before the remote connection. In this case, the removal of the local connection should cause the client to discard any references to associated remote Connection objects. The capabilities associated with the Connection object, defined by the ConnectionCapabilities complex type, are highly state dependent. Capabilities that are enabled while the connection is in one state may become disabled in another state, and vice versa. Due to this state dependence, the client application should use the connection capabilities object provided with each state change event to determine what capabilities are currently enabled. For more information, see Connection Service
ITerminal object T1 ITerminal object T2 ITerminalConnection object TCCA-T1, representing the relationship between Connection object CA and Terminal object T1 ITerminalConnection object TCCB-T2, representing the relationship between Connection object CB and Terminal object T2
- 18 -
Nortel
The TerminalConnection is modeled in the Communication Control Toolit Open Interface as a remote object that implements the TerminalConnection interface. Like most Communication Control Toolkit objects, it has a GetCapabilities method that returns an object that implements the TerminalConnectionCapabilities complex type. This object allows the application to determine what operations the terminal connection may be able to perform at the current instant in time. Unlike connections, terminal connections for remote legs of a contact are not visible to the client session. Thus, a client session having access to address A and terminal T1 has a view of the Communication Control Toolkit objects that is a subset of those shown in the above diagram. The following diagram depicts the Session View of Communication Control Toolkit objects: ??
Remote terminal connections are not modeled in the Communication Control Toolkit. This is because real-world systems typically do not have visibility all the way back to the physical set used for the far end of the call. In the case where a client session is granted access to both terminals and addresses involved in a contact, the session is able to see both ends of the call, but it has this visibility due to its access to both terminals involved in the call only. State change event handling for TerminalConnection objects is very similar to that for Connection objects with the exception that there are no event notifications for remote terminal connections. To receive terminal connection state changed events, the client application must register an event handler on the terminals terminal connection state changed event. Changes in the state of a terminal connection usually cause a change in the enabled capabilities for the terminal connection. For this reason, the client application should use the terminal connection capabilities provided with each state transition event to update itself with the current set of capabilities for the terminal
- 19 -
Nortel
connection. A transition to the Dropped state is the signal to the client application to discard all references to the terminal connection. For more information, see TerminalConnection Service.
Object specializations
The Communication Control Toolkit SDK interfaces object generally model the most common or basic form of the object. There are some specializations of the base interfaces defined in the Communication Control Toolkit SDK API for terminals and addresses that extend or modify the base functionality.
Agent Terminals
The base Terminal service models a standard physical terminal. An extension of this service is defined specifically for modeling a terminal used by an agent in a contact center. The AgentTerminal service extends the Terminal service to provide the additional functionality available on a contact center agent terminal. In support of the AgentTerminal service, additional service extensions include
AgentTerminalCapabilities Extends TerminalCapabilities to include additional capabilities properties to cover the additional functionality found in the AgentTerminal service. AgentTerminalConnection Extends TerminalConnection to model the association between a Connection object and an agent terminal. The AgentTerminalConnection interface provides additional functionality for controlling terminal connections to an agent terminal.
RoutePointConnection Extends Connection to model the association between a Contact object and a route point address. The
- 20 -
Nortel
RoutePointConnection service provides additional functionality for controlling connections to a route point address. To determine what type of object it is dealing with, a client application uses standard run-time type checking of the received object.
Refer to the ConnectionState enumeration for descriptions of the various Connection states.
- 21 -
Nortel
Refer to the TerminalConnectionState enumeration for descriptions of the various TerminalConnection states.
- 22 -
Nortel
Reference Information
FAQs
For a complete and up to date list of Frequently Asked Questions please visit the developer partner site.
Intrinsics Limitations
It is not recommended that intrinsics should be used to store large quantities of data as it may impact overall performance in the Contact Centre. If these intrinsics are to be accessed using the scripting engine contained in Contact Centre then there are additional limitations to the size and amount of intrinsics that can be associated with a contact, please refer to the scripting documentation for further details.
Security
There are two levels of security for the CCT Open Interfaces. Firstly the web services authenticate whether the user is know and configured and secondly all communication between client and server can be optionally encrypted. User Validation & Authentication: Before the service can be used the developer must first receive a Single Sign On (SSO) token that will be used for all subsequent calls to the service. To receive this token the developer must supply the server details (IP address/CCT server name and port) & the required authentication details; Username Upon registration with the Developer Partner Program (DPP) a developer will receive a user name to allow access to the service. Password a password associated with the supplied username. Domain the domain on which the web service is hosted. When the user submits their username and password to the service it is validated to determine if it is a valid windows user. Depending on the initial configuration of the service this user can be a local windows user on the CCT Server or a windows user on the domain. Once the service has verified that the user is a valid windows user it then checks to see if the user is configured in the CCT console. Once both of these criteria are met the user receives an SSO token representing their current session.
5
This value can vary from Service Provider Implementation i.e. CS1K, CS2k and SIP OCS, please refer to manual for specific limit.
- 23 -
Nortel
Each session has a time out associated with it. The default for a Session timeout is 2 hours but can be configured using the OI configuration screen. Each time the service is accessed this timeout is reset. For further information on how to configure the user store and CCT users please consult the section Nortel Contact Center Commissioning.
Encryption:
The client communicates with the server through the use of SOAP messages. These SOAP messages are essentially XML data made up of header and a body. The Open Interfaces CCT can be configured to encrypt these SOAP messages at the transport layer using TLS configuration. To configure TLS an administrator will need to generate a certificate signing request (CSR). The administrator will need to present this CSR to their chosen Certificate Authority (CA) to receive a corresponding certificate. For further information on how to configure TLS please consult the document Nortel Contact Center Commissioning .
- 24 -
Nortel
Location
http:// <CCT HostName>:9080/SOAOICC T/services/AddressService?ws dl http:// <CCT HostName>:9080/SOAOICC T/services/AgentService?wsdl http:// <CCT HostName>:9080/SOAOICC T/services/AgentTerminalCon nectionService?wsdl http:// <CCT HostName>:9080/SOAOICC T/services/AgentTerminalServ ice?wsdl http:// <CCT HostName>:9080/SOAOICC T/services/ConnectionService ?wsdl http:// <CCT HostName>:9080/SOAOICC T/services/ContactService?ws dl http:// <CCT HostName>:9080/SOAOICC T/services/MetricsService?ws dl http:// <CCT HostName>:9080/SOAOICC T/services/RoutePointAddress Service?wsdl http:// <CCT HostName>:9080/SOAOICC T/services/RoutePointConnect ionService?wsdl http:// <CCT HostName>:9080/SOAOICC
JavaDoc Location
/Open Interfaces CCT SDK/docs/javadoc/index.html
SOAOICCT_AgentService
SOAOICCT_AgentTerminalConnection Service
SOAOICCT_AgentTerminalService
SOAOICCT_ConnectionService
SOAOICCT_ContactService
SOAOICCT_MetricsService
SOAOICCT_RoutePointAddressService
SOAOICCT_RoutePointConnectionServ ice
SOAOICCT_SessionService
- 25 -
Nortel
SOAOICCT_TerminalService
SOAOICCT_UserService
SOAOICCT_NotificationProducer
SOAOICCT_NotificationConsumer
- 26 -