CTI OS Developers Guide 8.0
CTI OS Developers Guide 8.0
CTI OS Developers Guide 8.0
Release 8.0(1)
August 2010
Americas Headquarters Cisco Systems, Inc. 170 West Tasman Drive San Jose, CA 95134-1706 USA http://www.cisco.com Tel: 408 526-4000 800 553-NETS (6387) Fax: 408 527-0883
THE SPECIFICATIONS AND INFORMATION REGARDING THE PRODUCTS IN THIS MANUAL ARE SUBJECT TO CHANGE WITHOUT NOTICE. ALL STATEMENTS, INFORMATION, AND RECOMMENDATIONS IN THIS MANUAL ARE BELIEVED TO BE ACCURATE BUT ARE PRESENTED WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED. USERS MUST TAKE FULL RESPONSIBILITY FOR THEIR APPLICATION OF ANY PRODUCTS. THE SOFTWARE LICENSE AND LIMITED WARRANTY FOR THE ACCOMPANYING PRODUCT ARE SET FORTH IN THE INFORMATION PACKET THAT SHIPPED WITH THE PRODUCT AND ARE INCORPORATED HEREIN BY THIS REFERENCE. IF YOU ARE UNABLE TO LOCATE THE SOFTWARE LICENSE OR LIMITED WARRANTY, CONTACT YOUR CISCO REPRESENTATIVE FOR A COPY. The Cisco implementation of TCP header compression is an adaptation of a program developed by the University of California, Berkeley (UCB) as part of UCBs public domain version of the UNIX operating system. All rights reserved. Copyright 1981, Regents of the University of California. NOTWITHSTANDING ANY OTHER WARRANTY HEREIN, ALL DOCUMENT FILES AND SOFTWARE OF THESE SUPPLIERS ARE PROVIDED AS IS WITH ALL FAULTS. CISCO AND THE ABOVE-NAMED SUPPLIERS DISCLAIM ALL WARRANTIES, EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, THOSE OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OR ARISING FROM A COURSE OF DEALING, USAGE, OR TRADE PRACTICE. IN NO EVENT SHALL CISCO OR ITS SUPPLIERS BE LIABLE FOR ANY INDIRECT, SPECIAL, CONSEQUENTIAL, OR INCIDENTAL DAMAGES, INCLUDING, WITHOUT LIMITATION, LOST PROFITS OR LOSS OR DAMAGE TO DATA ARISING OUT OF THE USE OR INABILITY TO USE THIS MANUAL, EVEN IF CISCO OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. CCDE, CCENT, CCSI, Cisco Eos, Cisco HealthPresence, Cisco IronPort, the Cisco logo, Cisco Nurse Connect, Cisco Pulse, Cisco SensorBase, Cisco StackPower, Cisco StadiumVision, Cisco TelePresence, Cisco Unified Computing System, Cisco WebEx, DCE, Flip Channels, Flip for Good, Flip Mino, Flipshare (Design), Flip Ultra, Flip Video, Flip Video (Design), Instant Broadband, and Welcome to the Human Network are trademarks; Changing the Way We Work, Live, Play, and Learn, Cisco Capital, Cisco Capital (Design), Cisco:Financed (Stylized), Cisco Store, Flip Gift Card, and One Million Acts of Green are service marks; and Access Registrar, Aironet, AllTouch, AsyncOS, Bringing the Meeting To You, Catalyst, CCDA, CCDP, CCIE, CCIP, CCNA, CCNP, CCSP, CCVP, Cisco, the Cisco Certified Internetwork Expert logo, Cisco IOS, Cisco Lumin, Cisco Nexus, Cisco Press, Cisco Systems, Cisco Systems Capital, the Cisco Systems logo, Cisco Unity, Collaboration Without Limitation, Continuum, EtherFast, EtherSwitch, Event Center, Explorer, Follow Me Browsing, GainMaker, iLYNX, IOS, iPhone, IronPort, the IronPort logo, Laser Link, LightStream, Linksys, MeetingPlace, MeetingPlace Chime Sound, MGX, Networkers, Networking Academy, PCNow, PIX, PowerKEY, PowerPanels, PowerTV, PowerTV (Design), PowerVu, Prisma, ProConnect, ROSA, SenderBase, SMARTnet, Spectrum Expert, StackWise, WebEx, and the WebEx logo are registered trademarks of Cisco Systems, Inc. and/or its affiliates in the United States and certain other countries. All other trademarks mentioned in this document or website are the property of their respective owners. The use of the word partner does not imply a partnership relationship between Cisco and any other company. (1002) CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Copyright 2010, Cisco Systems, Inc. All rights reserved.
CONTENTS
About This Guide Purpose Audience
xix xix xix 1-xx xix
Organization Conventions
Related Documentation
xxi
1-xxi
1-xxi
Introduction
Introduction to CTI
What is a CTI-Enabled Application? Screen Pop 1-1 Agent State Control 1-2 Third-Party Call Control 1-2
Leveraging CTI Application Event Flow Asynchronous Events 1-2 Request-Response Paradigm 1-3
1-2
Overview of CTI OS 1-4 Advantages of CTI OS as a CTI Development Interface 1-5 Key Benefits of CTI OS for CTI Application Developers 1-6 Illustrative Code Fragments 1-6
CHAPTER
2-1
Client Interface Library Architecture Connection Layer 2-2 Service Layer 2-2 Object Interface Layer 2-3 Custom Application 2-3 CIL Object Model 2-3 Session Object 2-3 Agent Object 2-4
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
iii
Contents
Call Object 2-4 SkillGroup Object 2-4 Object Creation and Lifetime Reference Counting 2-5 Where To Go From Here
CHAPTER
2-5
2-11
CIL Coding Conventions CTI OS CIL Data Types CIL Error Codes COM Error Codes
3-3 3-7
Generic Interfaces 3-7 Arguments 3-8 Accessing Properties and Parameters with GetValue 3-8 Setting Object Properties and Request Parameters with SetValue UniqueObjectID
3-9 3-11
3-9
3-11
4-1
Setting Up Your Environment for .NET 4-1 Integrating with Microsoft Visual Studio .NET 2005 Integrating your Application with CTI OS via the CIL Planning and Designing Your Integration 4-4 What Language and Interface to Use 4-5 Testing CTI Applications 4-5 Developing a Test Plan 4-6 Test Environment 4-6 Using the Samples
4-6
4-2 4-4
Using The CTI OS ActiveX Controls 4-8 Building a Simple Softphone with ActiveX Controls Adding a Hook for Screenpops 4-9 Using the COM CIL in Visual C++ 8.0(1) 4-11 COM Client Interface Library (COM CIL.) 4-11 Adding COM Support to your Application 4-12 Using the CIL Dynamic Link Libraries 4-12 Creating an Instance of a COM Object 4-13 Subscribing and Unsubscribing to COM Events in C++
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-8
4-13
iv
Release 8.0(1)
Contents
Next Steps
4-14
Using the C++ CIL and Static Libraries 4-14 Header Files and Libraries 4-14 Project Settings for Compiling and Linking Subscribing for Events in C++ 4-17 STLPort 4-18 Next Steps 4-18 Using the Java CIL Libraries Next Steps 4-19 Using the .NET CIL Libraries Next Steps 4-19
4-18
4-15
4-19
Connecting to the CTI OS Server 4-20 How to Create the Session Instance 4-20 How to Set the Event Listener and Subscribe to Events 4-21 How to Set Connection Parameters for the Session 4-21 How to Connect the Session to the CTI OS Server 4-21 Dealing with Connection Failures 4-22 How to Set the Connection Mode 4-23 Settings Download 4-28 Disconnecting from CTI OS Server 4-29 Logging In and Logging Out an Agent 4-30 How to Log In an Agent 4-30 How to Handle Duplicate Log In Attempts How to Log Out an Agent 4-35
4-31
Working with Calls 4-37 Handling Multiple Calls 4-37 What is the Current Call? 4-38 How to Get a Call Object 4-38 How to Set the Current Call for the Session 4-38 Call Wrapup 4-39 Logout and NotReady Reason Codes 4-39 When Does the Application Receive the OnButtonEnablementChange() Event? Making Requests 4-42 Preventing Multiple Duplicate Requests
4-42
4-40
Working with Events 4-43 Handling Events in Order 4-43 Coding Considerations for CIL Event Handling Monitoring the OnCallEnd() Event 4-43 Working with Agent Statistics
4-44
4-43
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
Contents
Overview 4-44 How to Set Up an Agent Application to Receive Agent Statistics 4-44 How to Set Up a Monitor-Mode Application to Receive Agent Statistics Accessing Agent Statistics 4-48 Changing Which Agent Statistics are Sent 4-49 Agent Statistics Computed by the Sample CTI OS Desktop 4-49
4-45
Working with Skill Group Statistics 4-49 Overview 4-49 How to Set Up a Monitor-Mode Application to Receive Skill Group Statistics Accessing Skill Group Statistics 4-51 Changing Which Skill Group Statistics are Sent 4-52 Skill Group Statistics Computed by the Sample CTI OS Desktop 4-52 Enabling Silent Monitor in Your Application 4-53 Enabling CTI OS Based Silent Monitoring in Your Application 4-53 Enabling Unified CM Based Silent Monitoring in your Application 4-57 Deployment of Custom CTI OS Applications 4-61 Deploying Applications Using the ActiveX Controls 4-61 Deploying Applications Using COM (But Not ActiveX Controls) Deploying Applications using C++ CIL 4-67 Deploying Applications using .NET CIL 4-68 Custom Application and CTI OS Security 4-68 Building Supervisor Applications 4-68 General Flow 4-69 Monitored and Unmonitored Events 4-69 Requesting and Monitoring the Supervisors Teams Monitoring Agents 4-75 Monitoring Calls 4-79 Sample Code in the CTI OS Toolkit .NET Samples 4-82 Java CIL Samples 4-84 Win32 Samples 4-84
CHAPTER
4-50
4-67
4-69
4-82
5-1
Button Controls and Grid Controls Button Controls 5-8 Grid Controls 5-8 Supervisor Status Bar 5-8
5-3
5-8
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
vi
Release 8.0(1)
Contents
AgentStateCtl 5-8 AgentSelectCtl 5-14 AgentStatisticsCtl 5-19 AlternateCtl 5-23 AnswerCtl 5-23 BadLineCtl 5-24 CallAppearanceCtl 5-24 ChatCtl 5-29 ConferenceCtl 5-32 EmergencyAssistCtl 5-34 HoldCtl 5-34 MakeCallCtl 5-35 ReconnectCtl 5-36 SkillgroupStatisticsCtl 5-36 StatusBarCtl 5-40 SupervisorOnlyCtl 5-41 RecordCtl 5-42 TransferCtl 5-43 The Silent Monitor StandAlone ActiveX Control Connect 5-44 Disconnect 5-45 StartMonitoring 5-45 StopMonitoring 5-45 SilentMonitor Com Object Events 5-45 Deployment 5-46 Sample Usage in Visual Basic 6.0 5-46
CHAPTER
5-44
6-1 6-1
ISessionEvents Interface 6-2 OnConnection 6-2 OnConnectionClosed 6-2 OnConnectionFailure 6-3 OnConnectionRejected 6-3 OnCTIOSFailure 6-3 OnCurrentAgentReset 6-5 OnCurrentCallChanged 6-5 OnFailure Event 6-6 OnGlobalSettingsDownloadConf
6-6
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
vii
Contents
OnHeartbeat 6-15 OnMissingHeartbeat 6-16 OnMonitorModeEstablished 6-17 OnSnapshotDeviceConf 6-17 OnSnapshotSkillGroupList 6-18 OnTranslationRoute 6-18 ICallEvents Interface 6-20 OnAgentPrecallEvent 6-20 OnAgentPrecallAbortEvent 6-22 OnAlternateCallConf 6-22 Parameters 6-23 OnAnswerCallConf 6-23 OnCallBegin 6-23 OnCallCleared 6-25 OnCallConnectionCleared 6-26 OnCallConferenced 6-27 OnCallDataUpdate 6-29 OnCallDelivered 6-31 OnCallDequeuedEvent 6-32 OnCallDiverted 6-33
6-34
OnCallEnd 6-34 OnCallEstablished 6-35 OnCallFailed 6-36 OnCallHeld 6-37 OnCallOriginated 6-38 OnCallQueuedEvent 6-39 OnCallReachedNetworkEvent 6-40 OnCallRetrieved 6-41 OnCallServiceInitiatedEvent 6-41 OnCallStartRecordingConf 6-42 OnCallStopRecordingConf 6-43 OnCallTransferred 6-43 OnClearCallConf 6-45 OnClearConnectionConf 6-45 OnConferenceCallConf 6-46 OnConsultationCallConf 6-46 OnControlFailureConf 6-47 OnHoldCallConf 6-47 OnMakePredictiveCallConf 6-48
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
viii
Release 8.0(1)
Contents
OnReconnectCallConf 6-48 OnReleaseCallConf 6-48 OnRetrieveCallConf 6-49 OnSendDTMFConf 6-49 OnSetCallDataConf 6-49 OnSnapshotCallConf 6-50
6-53
OnTransferCallConf
6-53
IAgentEvents Interface 6-53 OnAgentDeskSettingsConf 6-53 OnAgentInfoEvent 6-55 OnAgentStateChange 6-56 OnAgentStatistics 6-58 OnChatMessage 6-59 OnControlFailureConf 6-60 OnEmergencyCall 6-65 OnLogoutFailed 6-66 OnMakeCallConf 6-66 OnNewAgentTeamMember 6-67 OnPostLogout 6-69 OnPreLogout 6-70 OnQueryAgentStateConf 6-71 OnSetAgentModeEvent 6-73 OnSetAgentStateConf 6-74 OnStartMonitoringAgent 6-74 OnStopMonitoringAgent 6-75 OnUserMessageConf 6-76 ISkillGroupEvents Interface 6-76 OnSkillGroupStatisticsUpdated OnSkillInfoEvent 6-77
6-76
IButtonEnablementEvents 6-77 OnButtonEnablementChange 6-77 OnSupervisorButtonChange 6-80 IMonitoredAgentEvents Interface IMonitoredCallEvents Interface ISilentMonitorEvents 6-82 OnCallRTPStarted 6-82 OnCallRTPStopped 6-83 OnStartSilentMonitorConf
6-80 6-81
6-84
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
ix
Contents
OnSilentMonitorStartedEvent 6-85 OnSilentMonitorStartRequestedEvent 6-87 OnSilentMonitorSessionDisconnected 6-88 OnSilentMonitorStopRequestedEvent 6-88 OnSilentMonitorStatusReportEvent 6-90 OnStopSilentMonitorConf 6-92 OnRTPStreamTimedoutEvent 6-93 IGenericEvents Interface OnEvent 6-93
6-93
Java Adapter Classes 6-94 IAllInOne 6-94 IAgentEvents 6-94 IButtonEnablementEvents ICallEvents 6-94 ISkillGroupEvents 6-94 Events in Java CIL Events in .NET CIL
6-95 6-95
6-94
Getting All Event Parameters 6-96 How to Get All Parameters from an Event
CHAPTER
6-96
Session Object
8-1 8-1
Methods 8-3 AddEventListener (Java and .NET only) 8-4 AddListener Methods (C++ only) 8-5 Connect 8-5 CreateSilentMonitorManager 8-7 CreateWaitObject (C++, Java, and .NET) 8-8 DestroySilentMonitorManager 8-9 DestroyWaitObject (C++ , Java, and .NET) 8-9 DisableSkillGroupStatistics (C++ , Java, and .NET) 8-10 Disconnect 8-10 DumpProperties 8-11 EnableSkillGroupStatistics (C++, Java, and .NET) 8-11 GetAllAgents 8-12 GetAllCalls 8-14 GetAllProperties 8-17 GetAllSkillGroups 8-17 GetCurrentAgent 8-18
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
Release 8.0(1)
Contents
GetCurrentCall 8-19 GetCurrentSilentMonitor 8-19 GetElement 8-20 GetNumProperties 8-20 GetObjectFromObjectID 8-20 GetPropertyName 8-21 GetPropertyType 8-21 GetSystemStatus (Java, .NET, and C++ only) 8-21 GetValue Methods 8-21 IsAgent 8-21 IsCCMSilentMonitor 8-22 IsSupervisor 8-22 IsValid 8-23 RemoveEventListener (Java and .NET) 8-23 RemoveListener Methods (C++ only) 8-23 RequestDesktopSettings 8-24 SetAgent 8-25 SetCurrentCall 8-26 SetCurrentSilentMonitor 8-27 SetMessageFilter 8-28 SetSupervisorMonitorMode 8-28 Notes On Message Filters 8-29 Message Filter Syntax 8-29 A Simple Example 8-30 General Form of Filter Syntax 8-30 Combining Filters 8-30 Filtering for Specific Events 8-31 Filtering Skillgroup Statistics 8-32 Filtering CCM Based Silent Monitor Calls
CHAPTER
8-33
CtiOs Object
7-1
Methods 7-1 DumpProperties 7-2 GetAllProperties 7-2 GetElement 7-3 GetLastError (Java and .NET only) Remarks 7-4 GetNumProperties 7-5 GetPropertyName 7-5
7-4
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
xi
Contents
GetPropertyType 7-6 GetValue 7-7 GetValueArray 7-7 GetValueBoolObj (Java and .NET only) 7-8 GetValueInt 7-8 GetValueIntObj (Java only) 7-9 GetValueShortObj (Java only) 7-10 GetValueString 7-10 GetValueUIntObj (Java only) 7-11 GetValueUShortObj (Java only) 7-12 IsValid 7-12 ReportError (Java and .NET only) 7-13 SetValue (Java and .NET) 7-13 SetValue (C++, COM, and VB) 7-14
CHAPTER
Agent Object
9-1 9-1
Methods 9-9 Arguments Parameters 9-11 DisableAgentStatistics 9-11 DisableSkillGroupStatistics 9-12 EnableAgentStatistics 9-13 EnableSkillGroupStatistics 9-13 GetAgentState 9-14 GetAllProperties 9-15 GetElement 9-15 GetMonitoredAgent 9-15 GetMonitoredCall 9-15 GetNumProperties 9-16 GetPropertyName 9-16 GetPropertyType 9-16 GetSkillGroups 9-16 GetValue Methods 9-18 IsAgent 9-19 IsSupervisor 9-19 Login 9-20 Logout 9-22 MakeCall 9-23
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
xii
Release 8.0(1)
Contents
MakeEmergencyCall 9-28 QueryAgentState 9-29 ReportBadCallLine 9-29 RequestAgentTeamList 9-30 RequestSupervisorAssist 9-31 SendChatMessage 9-32 SetAgentState 9-33 StartMonitoringAgent 9-34 StartMonitoringAgentTeam 9-35 StartMonitoringAllAgentTeams 9-36 StartMonitoringCall 9-37 StopMonitoringAgent 9-37 StopMonitoringAgentTeam 9-38 StopMonitoringAllAgentTeams 9-39 SuperviseCall 9-39
CHAPTER
10
Call Object
Considerations for Passing Call Variables Retrieving ECC Variable Values Adding ECC Values Properties
10-4 10-3 10-2
Methods 10-6 Arguments Parameters 10-8 Alternate 10-8 Answer 10-9 Clear 10-10 ClearConnection 10-11 Conference 10-12 GetCallContext 10-13 GetCallData 10-14 Hold 10-15 MakeConsultCall 10-16 Reconnect 10-20 Retrieve 10-21 SendDTMFSignal 10-22 SetCallData 10-23 SingleStepConference 10-24
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
xiii
Contents
10-26
11
11-1
Methods 11-16 DisableSkillGroupStatistics 11-16 DumpProperties 11-17 EnableSkillGroupStatistics 11-17 GetElement 11-18 GetValue Methods 11-18 IsValid 11-18 SetValue 11-18
CHAPTER
12
Helper Classes
12-1
Arg Class 12-2 AddRef 12-2 Clone 12-3 CreateInstance 12-3 DumpArg 12-4 GetArgType (.NET only) GetType 12-5 GetValue Methods 12-6 Release 12-7 SetValue 12-8
12-4
Arguments Class 12-9 Usage Notes 12-10 AddItem (C++, COM, VB only) 12-11 AddRef (C++ and COM only) 12-12 Clear 12-13 Clone 12-13 CreateInstance (C++ and COM only) 12-14 DumpArgs 12-14 GetElement Methods 12-15 Parameters 12-16
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
xiv
Release 8.0(1)
Contents
GetValue Methods 12-16 IsValid 12-19 NumElements 12-19 Release (C++ and COM only) 12-20 RemoveItem 12-20 SetElement (C++, COM, and VB only) SetValue 12-22 CILRefArg Class (C++, Java, and .NET only) GetType 12-24 GetUniqueObjectID (Java and .NET only) GetValue 12-25 SetValue 12-25
12-21
12-24 12-24
CCtiOsException Class (C++, Java, and .NET only) CCtiosException Constructor 12-26 GetCode 12-27 GetStatus 12-27 GetString 12-27 What 12-28 CWaitObject Class 12-28 Methods 12-29 CreateWaitObject 12-29 DestroyWaitObject 12-29 DumpEventMask 12-29 GetMask 12-30 GetTriggerEvent 12-30 InMask 12-31 SetMask 12-31 WaitOnMultipleEvents 12-31 Logger Class (.NET and Java Only) Methods 12-32 Logger() Constructor 12-33 GetTraceMask 12-33 SetTraceMask 12-34 AddLogListener 12-34 RemoveLogListener 12-34 Trace 12-35
12-32
12-26
LogWrapper Class (.NET and Java Only) Methods 12-36 LogWrapper() Constructor 12-37
12-35
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
xv
Contents
Return Values 12-37 LogWrapper(String filename) Constructor 12-37 Return Values 12-37 LogWrapper(string, int, int, int) Constructor 12-37 Dispose (.NET Only) 12-38 GetMaxDaysBeforeExpire (.NET Only) 12-39 SetMaxNumberFiles 12-39 GetMaxNumberFiles (.NET Only) 12-39 SetMaxDaysBeforeExpire 12-40 ProcessConfigFile 12-40
CHAPTER
13
13-1
Methods 13-3 Argument Parameter Rules 13-4 AcceptSilentMonitoring 13-4 GetIPPhoneInfo 13-5 GetSessionInfo 13-6 GetSMSessionList 13-7 IsMonitoredTarget 13-8 SetIPPhoneInfo 13-8 StartSilentMonitorRequest 13-10 StartSMMonitoredMode 13-11 StartSMMonitoringMode 13-12 StopSilentMonitorMode 13-13 StopSilentMonitorRequest 13-14
APPENDIX
CTI OS Keywords and Enumerated Types Keywords A-1 Java CIL Keywords A-2 .NET CIL Keywords A-2 Enumerated Types Java Interfaces
A-2 A-3
A-1
APPENDIX
CTI OS Logging
B-1
Creating CTI OS Client Logs (COM and C++) B-1 How to Install the Tracing Mechanism (COM and C++) Setting Trace Levels (COM and C++) Configuring Tracing (COM and C++)
B-2 B-2
B-1
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
xvi
Release 8.0(1)
Contents
Java CIL Logging Utilities B-3 ILogEvents B-3 LogEvent B-3 Logger B-4 LogEventsAdapter B-4 Logging and Tracing (Java)
B-5
Logging and Tracing (.NET) B-5 Using the Default Logging Mechanism B-6 Creating a Custom Logging Mechanism B-8 Configuring Tracing (Java and .NET) B-8
APPENDIX
C-1
Migrating a COM CIL Application C-2 Migrating a C++ Application that uses COM CIL Migrate to Visual Basic .NET and use .COM CIL
C-2 C-2
Migrating a Visual Basic 6.0 to Use COM CIL C-3 Migrate to Visual Basic .NET and use CTI OS ActiveX Controls
I NDEX
C-3
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
xvii
Contents
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
xviii
Release 8.0(1)
Audience
This manual is for system integrators and programmers who want to use CTI OS to integrate CTI applications with the Cisco Contact Center software.
Organization
The manual is divided into the following chapters. Chapter Chapter 1, Introduction Chapter 2, CTI OS Client Interface Library Architecture Chapter 3, CIL Coding Conventions Chapter 4, Building Your Application Chapter 5, CTI OS ActiveX Controls Chapter 6, Event Interfaces and Events Description Provides an overview of CTI and the CTI OS Client Interface. Discusses CTI OS architecture.
Explains how to build an application using the CTI OS libraries. Discusses how to build your custom CTI application to use the CTI OS Client Interface Library Describes the CTI OS softphone controls and explains how to use them in a VB or COM container. Describes the CTI OS event interfaces.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
xix
Chapter Chapter 7, CtiOs Object Chapter 8, Session Object Chapter 9, Agent Object Chapter 10, Call Object Chapter 11, SkillGroup Object
Description Discusses features common to all CTI OS objects derived from CtiOsObject. Describes the methods associated with the CTI OS Session object. Describes the methods associated with the CTI OS Agent object. Describes the methods associated with the CTI OS Call object. Describes the methods associated with the CTI OS SkillGroup object.
Chapter 12, Helper Classes Describes the methods associated with the CTI OS Arguments classes. Chapter 13, SilentMonitorManager Object Appendix A, CTI OS Keywords and Enumerated Types Appendix B, CTI OS Logging Appendix C, Migrating From CTI OS 7.1(x) or 7.2(x) Describes the methods associated with the CTI OS Silent Monitor Manager object. Discusses CTI OS keywords and enumerated types. Discusses a few issues related to CTI OS logging. Describes the migration steps and the new parameters required to build the application.
Related Documentation
Documentation for Cisco Unified ICM/Unified Contact Center Enterprise & Hosted (Unifed ICM/CCE/CCH), as well as related documentation, is accessible from Cisco.com at http://www.cisco.com/cisco/web/psa/default.html?mode=prod.
Related documentation includes the documentation sets for Cisco CTI Object Server (CTI OS), Cisco Agent Desktop (CAD), Cisco Agent Desktop - Browser Edition (CAD-BE), Cisco Unified Contact Center Management Portal, Cisco Unified Customer Voice Portal (Unified CVP), Cisco Unified IP IVR, Cisco Support Tools, and Cisco Remote Monitoring Suite (RMS). For documentation for these Cisco Unified Contact Center Products, go to http://www.cisco.com/cisco/web/psa/default.html?mode=prod click on Voice and Unified Communications, then click on Cisco Unified Contact Center Products or Cisco Unified Voice Self-Service Products, then click on the product/option you are interested in. For troubleshooting tips for these Cisco Unified Contact Center Products, go to http://docwiki.cisco.com/wiki/category:Troubleshooting, then click the product/option you are interested in. Also related is the documentation for Cisco Unified Communications Manager, which can also be accessed fromhttp://www.cisco.com/cisco/web/psa/default.html?mode=prod
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
xx
Release 8.0(1)
Technical Support documentation and tools can be accessed from http://www.cisco.com/en/US/support/index.html The Product Alert tool can be accessed through (login required) http://www.cisco.com/cgi-bin/Support/FieldNoticeTool/field-notice
Conventions
This manual uses the following conventions. Format Boldface type is used for user entries, keys, buttons, and folder and submenu names. Italic type indicates one of the following:
Example Choose Edit > Find from the ICM Configure menu bar.
A skill group is a collection of agents who share similar skills. Do not use the numerical naming convention that is used in the predefined templates (for example, persvc01). IF (condition, true-value, false-value) For more information, see the Database Schema Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted.
A newly introduced term For emphasis A generic syntax item that you must replace with a specific value A title of a publication
The Save command from the File menu is referenced as File > Save.
Documentation Feedback
You can provide comments about this document by sending email to the following address: mailto:[email protected] We appreciate your comments.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
xxi
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
xxii
Release 8.0(1)
CHAPTER
Introduction
This chapter provides an introduction to Computer Telephony Integration (CTI) and describes how CTI can enhance the value of contact center applications. This chapter also introduces the Computer Telephony Integration Object Server (CTI OS) product and discusses the advantages of using CTI OS to develop custom CTI enabled applications.
Introduction to CTI
The workflow of a modern contact center is based on two main areas: the media for communicating with the customer and the platform for servicing customer requests. CTI is the integration of the communications media (i.e. phone, email, or web) with the customer service platform (i.e. customer databases, transaction processing systems, or CRM (customer relationship management) software packages). Integrating communications media with the customer service platform helps agents to service customers better and faster in two ways. First, it enables the agent to leverage the information and events provided by the media to direct his workflow. Second, it increases the depth and breadth of customer information presented to the agent when the customers contact arrives at the workstation.
Screen Pop
The most common CTI application is a screen pop. In a screen pop, the customer service platform is provided with customer information at the arrival of a phone call and begins processing the customers transaction at the same time as the communication begins between the customer and the agent. This transfer of customer information is called the call context information: a rich set of customer-specific data that travels with the call throughout the enterprise.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
1-1
Introduction
For example, a screen pop application for a cellular telephone company might be triggered based on the arrival of a phone call. It uses the customer ANI (automated number identification, or calling line ID) to do a database look up to retrieve the customers account information and displays this customer record for the agent. By the time the agent can say Thank you for calling ABC Telephony Company, the account record is on his screen and he is ready to service the customers request.
Asynchronous Events
The CTI environment is one of diverse servers and applications communicating over a network. This naturally leads to asynchronous, or unsolicited events events that arrive based on some stimulus external to the users application. The main source of events in the CTI environment is the communications media. Figure 1-1 depicts the stages of a typical inbound telephone call and its associated events:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
1-2
Release 8.01)
Chapter 1
Figure 1-1
CALL SETUP
RINGING
TALKING
WRAP UP
The following events are generated, based on the state of the call:
OnCallBegin: Indicates that the call has entered the setup phase. OnCallDelivered: Generated when the call starts ringing. OnCallEstablished: Generated when the call is answered. OnCallCleared: Generated when the voice connection is terminated (e.g. call hung up). OnCallEnd: Generated when the logical call appearance (including call data) is complete.
In addition to the events and states shown in Figure 1-1, the following are typical call events used for CTI applications:
OnCallHeld: Generated when the call transitions from the active to held state. OnCallRetrieved: Generated when the call is removed from hold. OnCallTransferred: Indicates that the call has been transferred to another party. OnCallConferenced: Indicates that a new party has been added to the call.
The foregoing is only a brief sample of the events available via CTI OS. The complete set of events available for CTI developers is detailed in later chapters in this guide.
Request-Response Paradigm
In addition to being able to respond to asynchronous events, a CTI enabled application can make programmatic requests for services via the CTI interface. Specifically, the CTI application uses the request-response mechanism to perform agent state and third-party call control, and to set call context data. The typical request-response flow for CTI uses the model shown in Figure 1-2:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
1-3
Introduction
Figure 1-2
CLIENT
SERVER
REQUEST
CONF
EVENT
A request generated by the CTI-enabled application (CLIENT) is sent to the CTI service (SERVER), and a response message (CONF) is generated to indicate that the request has been received. In most cases if the request is successful, a follow-on event will be received indicating that the desired behavior has occurred. Detailed descriptions of this kind of request-response-event message flow are detailed in later chapters in this guide.
Overview of CTI OS
The Computer Telephony Integration Object Server (CTI OS) is Ciscos next generation customer contact integration platform. CTI OS combines a powerful, feature-rich server and an object-oriented software development toolkit to enable rapid development and deployment of complex CTI applications. Together with the Cisco CTI Server Interface, CTI OS and Client Interface Library (CIL) creates a high performance, scalable, fault-tolerant three-tiered CTI architecture, as illustrated in Figure 1-3.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
1-4
Release 8.01)
Chapter 1
Figure 1-3
Ethernet Cisco Peripheral Gateway Cisco CTI Server Site Telephone Network
82970
PBX/ACD
The CIL is the first tier, providing an application-level interface to developers. The CTI OS Server is the second tier, providing the bulk of the event and request processing and enabling the object services of the CTI OS system. The Cisco CTI Server is the third tier, providing the event source and the back-end handling of telephony requests.
Rapid integration. Developing CTI applications with CTI OS is significantly easier and faster than any previously available Cisco CTI integration platform. The same object oriented interface is used across programming languages, enabling rapid integrations in .NET, and C++, Visual Basic, or any Microsoft COM compliant container environment. CTI OS enables developers to create a screen pop application in as little as five minutes. The only custom-development effort required is within the homegrown application to which CTI is being added. Complex solutions made simple. CTI OS enables complex server-to-server integrations and multiple agent monitoring-type applications. The CIL provides a single object-oriented interface that can be used in two modes: agent mode and monitor mode. See Chapter 2, CTI OS Client Interface Library Architecture for an explanation of these two modes. Fault tolerant. CTI OS is built upon the Unified ICM NodeManager fault-tolerance platform, which automatically detects process failure and restarts the process, enabling work to continue. Upon recovery from a failure, CTI OS initiates a complete, system-wide snapshot of all agents, calls, and supervisors and propagates updates to all client-side objects.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
1-5
Introduction
Object-oriented interactions. CTI OS provides an object-oriented CTI interface by defining objects for all call center interactions. Programmers interface directly with Session, Agent, SkillGroup, and Call objects to perform all functions. CIL objects are thin proxies for the server-side objects, where all the heavy-lifting is done. The Session object manages all objects within the CIL. A UniqueObjectID identifies each object. Programmers can access an object by its UniqueObjectID or by iterating through the object collections. Connection and session management. The CTI OS CIL provides out-of-the-box connection and session management with the CTI OS Server, hiding all of the details of the TCP/IP sockets connection. The CIL also provides an out-of-the-box failover recovery: upon recovery from a failure, the CIL will automatically reconnect to another CTI OS (or reconnect to the same CTI OS after restart), re-establish the session, and recover all objects for that session. All parameters are key-value pairs. The CTI OS CIL provides helper classes to treat all event and request parameters as simply a set of key-value pairs. All properties on the CTI OS objects are accessible by name via a simple Value = GetValue(key) mechanism. Client programmers can add values of any type to the CTI OS Arguments structure, using the enumerated CTI OS keywords, or their own string keywords (for example, AddItem(DialedNumber, 1234)). This provides for future enhancement of the interface without requiring any changes to the method signatures. Simple event subscription model. The CTI OS CIL implements a publisher-subscriber design pattern to enable easy subscription to event interfaces. Programmers can subscribe to the appropriate event interface that suits their needs, or use the IAllInOne interface to subscribe for all events. C++ and COM contain subclassable event adapter classes. These classes enable programmers to subscribe to event interfaces; they only add minimal custom code for the events they use and no code at all for events they do not use.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
1-6
Release 8.01)
CHAPTER
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
2-1
Figure 2-2
Connection Layer
The Connection layer provides basic communication and connection recovery facilities to the CIL. It creates the foundation, or bottom tier of the CILs layered architecture, and decouples the higher-level event and message architecture from the low-level communication link (TCP/IP sockets). The Connection layer sends and receives socket messages to the CTI OS Server, where it connects to a server-side connection layer. In addition to basic communication facilities, the connection layer provides fault tolerance to the CIL by automatically detecting and recovering from a variety of network failures. The Connection layer uses a heartbeat-by-exception mechanism, sending heartbeats only when the connection has been silent for some period of time to detect network-level failures.
Service Layer
The Service layer sits between the connection layer and the Object Interface layer. Its main purpose is to translate the low-level network packets sent and received by the connection layer and the high-level command and event messages used in the Object Interface layer. The Service layer implements a generic message serialization protocol which translates key-value pairs into a byte stream for network transmission and deserializes the messages back to key-value pairs on the receiving side. This generic serialization mechanism ensures forward-compatibility, since future enhancements to the message set will not require any changes at the Connection or Service layers. A secondary purpose of the Service layer is to isolate the client from the network, such that network issues do not block the client and vice versa. This is done via a multi-threading model which allows user-program execution to continue without having to block on network message sending or receiving. This prevents client applications from getting stuck when a message is not immediately dispatched across the network, and allows messages to be received from the network even if the client application is temporarily blocked.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
2-2
Release 8.01)
Chapter 2
Custom Application
The custom application is the business application that is developed to integrate with the CTI OS Client Interface Library. The custom application makes use of the CIL in two ways. One, the CIL provides the object-based interface for interacting with CTI OS, to send requests for agent and call control. Two, the CIL provides an events subscription service, which the custom application will take advantage of to receive events from CTI OS. For example, a custom application would use the Agent object to send a MakeCallRequest, and then receive a OnCallBeginEvent (and others) from the CILs events interfaces.
Session Object
The Session object is the main object in the CIL. It controls the logical session between the client application and the CTI OS server. The Session object provides the interface to the lower layers of the CIL architecture (the Service and Connection layers), and also encapsulates the functions required to dispatch messages to all of the other objects in the CIL.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
2-3
The Session object provides object management (creation, collection management, and deletion), and is the publisher for all CIL events. In addition, the Session object provides automatic fault tolerance and failover recovery.
Session Modes
A Session object can be set to work in one of two modes: Agent Mode or Monitor Mode. The Session object maintains the state of the Session mode, and recovers the session mode during failover. The client application must set the session mode after it connects to the CTI OS Server; the Session mode remains active until the connection to the CTI OS Server is closed.
Agent Mode
A client connects to CTI OS Server in Agent Mode when it wants to receive events for a specific agent or supervisor. Once agent mode has been set, the CIL receives the events for the specified agent, as well as all call events for that agents calls. If the agent is also configured as a Supervisor in Unified ICM, the CIL receives events for all agents in the Supervisors team.
Monitor Mode
A client connects to the CTI OS Server in Monitor Mode when it wants to receive a programmer-specified set of events, such as all agent state events. For details of setting up a monitor mode connection, refer to the section in Chapter 4, How to Select Monitor Mode. For the complete interface specification of the Session object, see Chapter 8, Session Object.
Agent Object
The Agent object provides an interface to Agent functionality, including changing agent states and making calls. The agent object also provides access to many properties, including agent statistics. Depending on the Session Mode, a CIL application can have zero to many agent objects. For the complete interface specification of the Agent object, see Chapter 9, Agent Object.
Call Object
The Call object provides an interface to Call functionality, including call control and accessing call data properties. Depending on the Session Mode, a CIL application can have any number of call objects. For the complete interface specification of the Call object, see Chapter 10, Call Object.
SkillGroup Object
The SkillGroup object provides an interface to SkillGroup properties, specifically skill group statistics. Depending on the Session Mode, a CIL application can have zero to many SkillGroup objects. For the complete interface specification of the SkillGroup object, see Chapter 11, SkillGroup Object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
2-4
Release 8.01)
Chapter 2
Reference Counting
Object lifetime is controlled using reference counting. Reference counts determine if an object is still in use; that is, if a pointer or reference to it still exists in some collection or member variable. When all references to the object have been released, the object is deleted. An application or object that will hold a reference to a CIL object must add to its reference count using the AddRef method. When the reference is no longer required, the application or object holding that reference must decrement the reference count using the Release() method. Reference counting is discussed further in Chapter 7, CtiOs Object.
Note
Reference counting must be done explicitly in C++ applications (COM or non-COM). Visual Basic, Java, and the .NET frameworkwill perform automatic reference counting.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
2-5
Note
In C++, the object must be created on the heap memory store so that it can exist beyond the scope of the method creating it. For clients using other CILs, this is handled automatically. The Session will hold a reference to the Agent object as long as it is in use, but the client programmer must release the last reference to the object to prevent a memory leak. In Monitor Mode, objects are created at the CIL when the CIL receive an event for that agent for first time (e.g in an OnAgentStateChange event). When the Session receives an event for an unrecognized Agent, that new Agent is added to the Sessions collection of agents. During application clean-up, the Session object will release its references to all agents in the Agent collection. To ensure proper memory clean-up, the programmer must release all reference to Agent objects.
Explanation The client application must call Release() on the returned object when the object is no longer needed. The client application must call Release() on the returned object when the object is no longer needed. These methods increment the reference count on the passed in object. When the CilRefArg is deleted the reference count of the enclosed object will be decremented.
CILRefArg
CreateInstance(), GetValue()
CILRefArg
SetValue(), operator=
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
2-6
Release 8.01)
Chapter 2
Table 2-1
SessionLib (C++)
Explanation This method increments the reference count on the passed in object. The previous "current" call's reference count is decremented. If an end call event is received for the current call, its reference count is decremented one extra time. This method call decrements the reference count on the passed in object. The client application must call DestroyWaitObject() on the returned object when the object is no longer needed. This method decrements the reference count of the passed in object. The client application must call DestroySilentMonitorManager () on the returned object when it is no longer needed. This method increments the reference count on the passed in object. The previous "current" silent monitor's reference count is decremented. The client application must call Release() on the returned object when it is no longer needed.
CCtiOsSession
DestroyWaitObject()
CCtiOsSession
CreateWaitObject()
CCtiOsSession
CCtiOsSession
CCtiOsSession
SetCurrentSilent Monitor()
CCtiOsSession
GetCurrentCall(), GetCurrentSilent MonitorManager(), GetAllCalls(), GetAllSkillGroups(), GetAllAgents(), GetCurrentAgent(), GetValue(), GetObjectFromObject ID()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
2-7
Table 2-1
SessionLib (C++)
Explanation This method increments the reference count on the passed in object. If the passed in object is NULL, then this method decrements the current agent object's reference count. The client application must call Release() on the returned object when it is no longer needed.
CSilentMonitor Manager
Table 2-2
CtiosClient.dll (COM)
Explanation This method increments the reference count for every SkillGroup object, adds them to a safe array and then returns the safe array. The client application must call Release() on the returned object when it is no longer needed. The client application must call Release() on the returned object (second argument) when it is no longer needed. The client application must call Release() on the returned object (first argument) when it is no longer needed. The client application must call Release() on the returned object (second argument) when it is no longer needed. The client application must call Release() on the returned object (first argument) when it is no longer needed. The client application must call Release() on the returned object when it is no longer needed.
IAgent
GetMonitoredAgent(), GetMonitoredCall()
IAgent
IAgent
GetAllProperties()
ISkillGroup
ISkillGroup
GetAllProperties()
ICall
GetCallContext(), GetCallData()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
2-8
Release 8.01)
Chapter 2
Table 2-2
CtiosClient.dll (COM)
Explanation The client application must call Release() on the returned object (second argument) when it is no longer needed. The client application must call Release() on the returned object (first argument) when it is no longer needed. This method increments the reference count of the passed in object and decrements the reference count of the previous monitor. The client application must call Release() on the returned object when it is no longer needed. The client application must call Release() on the returned object (second argument) when it is no longer needed.
ICall
GetAllProperties()
ISilent GetMonitor() MonitorManager ISilent GetSessionInfo(), MonitorManager GetIPPhoneInfo(), GetSMSessionList(), GetValue(), GetValueArray(), GetElement() ISilentMonitorM GetAllProperties() anager
The client application must call Release() on the returned object (first argument) when it is no longer needed. This method increments the reference count on the passed in object. If the passed in object is NULL, then this method decrements the current agent object's reference count. The client application must call Release() on the returned object when it is no longer needed. This method increments the reference count for every Call object, adds them to a safe array and then returns the safe array. This method increments the reference count for every Agent object, adds them to a safe array and then returns the safe array.
ISession
SetAgent()
ISession
GetCurrentAgent(), GetCurrentCall()
ISession
GetAllCalls()
ISession
GetAllAgents()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
2-9
Table 2-2
CtiosClient.dll (COM)
Explanation This method increments the reference count for every SkillGroup object, adds them to a safe array and then returns the safe array. The client application must call Release() on the returned object (second argument) when it is no longer needed. The client application must call Release() on the returned object (first argument) when it is no longer needed.
ISession
ISession
GetAllProperties()
ISession
GetObjectFromObject The client application must call Release() on the returned object ID() (second argument) when it is no longer needed. CreateSilentMonitor Manager() The client application must call DestroySilentMonitorManager() on the returned object when it is no longer needed. This method call decrements the reference count on the passed in object. The client application must call Release() on the returned object when it is no longer needed.
ISession
ISession
ISession
Table 2-3
CtiosComArguments.dll (COM)
Explanation The client application must call Release() on the returned object when it is no longer needed. The client application must call Release() on the returned object when it is no longer needed. If ARG_TYPE = ARG_ARRAY, the client application must call Release() on the returned object when it is no longer needed.
IArg
GetValueArray()
IArg
GetValue()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
2-10
Release 8.01)
Chapter 2
Table 2-3
CtiosComArguments.dll (COM)
Explanation The client application must call Release() on the returned object (second argument) when it is no longer needed. The client application must call Release() on the returned object when it is no longer needed.
IArguments
Clone()
Table 2-4
ArgumentsLib (C++)
Explanation The client application must call Release() on the returned object when it is no longer needed. The client application must call Release() on the returned object when it is no longer needed.
Arguments
Arguments
SetValue()
If the returned object is of type Arg or of type Arguments, the client application must call Release() on the returned object when it is no longer needed. If the returned object is of type Arg or of type Arguments, the client application must call Release() on the returned object when it is no longer needed.
Arguments
SetElement()
For information about CIL coding conventions, see Chapter 3, CIL Coding Conventions. For information about building an application using the CIL, see Chapter 4, Building Your Application. For a description and syntax of the CIL programming interfaces, see Chapters 8 through 13.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.01)
2-11
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
2-12
Release 8.01)
CHAPTER
Data types Asynchronous execution (error codes versus events) Generic interfaces with the Arguments structure Optional and reserved parameters Accessing properties and parameters with GetValue Adding parameters to requests with AddItem Setting properties with SetValue UniqueObjectIDs: how to identify objects Obtaining an object from its UniqueObjectID Using Button Enablement Masks Methods that call AddRef()
STRING: A variable-length string variable. If a maximum length exists, it is listed with the parameter description. INT: A 32-bit wide integer. UNSIGNED INT: A 32-bit wide unsigned integer.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
3-1
SHORT: A 16-bit wide short integer. UNSIGNED SHORT: A 16-bit wide unsigned short integer. BOOL: A logical true or false variable. Different implementations will use variables of different sizes to represent this type. In COM, the VARIANT_BOOL is used. Tests of variables of this data type must be against VARIANT_TRUE and VARIANT_FALSE and not simply against 0 or 1. ARGUMENTS: A custom data structure used by CTI OS, which holds a variable-length set of key-value pairs. ARG: An individual element (value), which can be stored in an ARGUMENTS structure.
Table 3-1 describes the appropriate language specific types to which the documented type are associated.
Table 3-1 CTI OS CIL Data Type
SHORT short
BOOL bool
ARGUMEN TS Arguments
ARG Arg
Integer short
Boolean
Arguments
Arg IArg*
long System.Int64
short System.Int16
Arg Arg
3-2
Release 8.0(1)
Chapter 3
To determine the success or failure of the underlying telephony operation requested, the CTI programmer must wait for an event confirming the success or failure of the request. To generalize the message flow model, most requests made at the CTI OS CIL will be answered with a confirmation message and/or an event message. See the object interface reference in Chapters 8-12 for details on each particular request. This type of response is called asynchronous it can arrive at any time after the request is made, but typically requests are services in sub-second timeframes. For each method request in the programmers interface sections of this document, the expected event sequence is described, so that programmers know which events to expect. In the event of a request failure, an eControlFailureConf message will be send to the client; the eControlFailureConf message will have a parameter called MessageType indicating which request failed, and a parameter called ErrorMessage, with a description of the failure cause. For example: when sending a MakeCall request, the method will typically return CIL_OK, which means that the method call was successful. If the underlying make call request is successful, the CIL will receive several follow-on events, such as eBeginCallEvent and eServiceInitiatedEvent. If the request fails, the CIL will receive the eControlFailureConf message. A common mistake: developers who have not previously programmed with asynchronous events might mistake the error code returned from a method call for the actual result of the request. The correct semantics are to interpret the error code as being indicative of the result of the method call, and to interpret the follow-on events to determine the actual result of the requested operation.
The numeric values listed in Table 3-2 are subject to change. It is recommended that you use the error code enumerations to check a given error code, rather than rely on a specific numeric value.
Table 3-2
CIL Error Code CIL_OK CIL_FAIL E_CTIOS_METHOD_NO_ IMPLEMENTED E_CTIOS_INVALID_ PROPERTY E_CTIOS_MODE_CONFLICT E_CTIOS_INVALID_ EVENTID E_CTIOS_INVALID_ ARGUMENT
Description The method succeeded. The request to silent monitor the call was successfully initiated. The method failed. There is no implementation available for this method. One or more properties are invalid. A conflict when setting session mode. The Event ID is not valid. The Argument is not valid.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
3-3
CIL Error Code E_CTIOS_INVALID_ SESSION E_CTIOS_UNEXPECTED E_CTIOS_OBJ_ALLOCATION_ FAILED E_CTIOS_ARRAYREF_ ALLOCATION_FAILED E_CTIOS_ARGUMENT_ ALLOCATION_FAILED E_CTIOS_TARGET_ OBJECT_ NOT_FOUND E_CTIOS_PROP_ ATTRIBUTES_ACCESS_ FAILED E_CTIOS_INVALID_ OBJECT_TYPE E_CTIOS_INVALID_AGENT E_CTIOS_INVALID_CALL E_CTIOS_IN_FAILOVER E_CTIOS_INVALID_ DESKTOP_TYPE E_CTIOS_MISSING_ ARGUMENT E_CTIOS_CALL_NOT_ON_ HOLD E_CTIOS_CALL_ALREADY_ ON_HOLD E_CTIOS_CALL_NOT_ ALERTING E_CTIOS_AGENT_NOT_ LOGIN E_CTIOS_INVALID_ METHOD_PARAMETER E_CTIOS_UNKNOWN E_CTIOS_OUT_OF_ MEMORY E_CTIOS_PORT_ UNAVAILABLE E_CTIOS_SM_SESSION_ TERMINATED_ ABNORMALLY E_CTIOS_SM_REJECTED_ ALREADY_IN_SESSION
Numeric Value -104 -105 -106 -107 -108 -109 -110 The Session is not valid.
Description An unexpected error has occurred. There is not enough memory available and the creation of CCtiOsObject failed. There is not enough memory available and an creation of an array of references to objects of type CCtiOsObject failed. There is not enough memory available and the creation of an object of type Arguments failed. There are no CTI OS Objects capable of processing an incoming event. An error occurred while accessing a property's attributes, System may be running out of memory. The object type is not one of the following predefined types CAgent, CCall, CSkillGroups, or CWaitObject. No valid agent. No valid call. The session is recovering from a connection failure and had started the Fail Over procedure. Indicates that the desktop type specified in the request for DeskSettings download is neither Agent or Supervisor. Missing a required argument. Call is not on hold. Call is already on hold. Call is not in alert state, it can not be answered. Agent is not logged in. The input parameter is invalid. The cause of this error is unknown. Failed to allocate new memory. The specified port is not available for use. The Silent Monitor session was terminated abnormally.
-111 -112 -113 -114 -115 -116 -117 -118 -119 -120 -121 -122 -123 -124 -125
-126
The request was rejected because there is an active silent monitor session in progress.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
3-4
Release 8.0(1)
Chapter 3
CIL Error Code E_CTIOS_SM_PACKET_ SNIFFER_NOT_INSTALLED E_CTIOS_PACKET_ SNIFFER_FAILED E_CTIOS_SOCKET_CALL_ FAILED E_CTIOS_MEDIA_ TERMINATION_NOT_ INSTALLED E_CTIOS_MT_UNKNOWN_ CODEC E_CTIOS_MEDIA_ TERMINATION_FAILED E_CTIOS_SNIFFER_NO_ PACKETS_RECEIVED E_CTIOS_SNIFFER_ FAILED_TO_OPEN_DEVICE E_CTIOS_SNIFFER_ FAILED_TO_SET_FILTER E_CTIOS_ERROR_IN_ PACKET_FILTER E_CTIOS_INVALID_ MONITORED_IP_ADDRESS E_CTIOS_INVALID_ SNIFFER_OBJECT E_CTIOS_INVALID_ DECODER_OBJECT E_CTIOS_NO_SM_ SESSION_IN_PROGRESS E_CTIOS_INVALID_ SILENT_MONITOR_ SESSION E_CTIOS_FAILED_ REMOVING_SILENT_ MONITOR_SESSION E_CTIOS_IP_PHONE_ INFORMATION_NOT_ AVAILABLE E_CTIOS_PEER_NOT_ ENABLED_FOR_SILENT_ MONITOR E_CTIOS_NOT_ENABLED_ FOR_SILENT_MONITOR
Description The packet sniffer is not present in the system; verify installation. An error occurred in the packet sniffer. A CTI OS socket call failed. EVVBU Media Termination component in the system, verify installation.
-131 -132 -133 -134 -135 -136 -137 -138 -139 -140 -141 -142
Specified CODEC is not supported. An error occurred in the Media Termination Packet Decoder. The Sniffer has not received any IP packets. The Sniffer failed to open the networking device. The Sniffer failed when setting the packet filter. The packet filter expression is incorrect. The IP Address specified for the monitored device (IP Phone) is not valid. Invalid Sniffer object. Invalid Decoder object. There are no Silent Monitor Sessions in progress. The specified Silent Monitor session does not exist. Silent Monitor Session was not removed from the collection.
-143
-144
-145
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
3-5
CIL Error Code E_CTIOS_NO_PENDING_REQ UEST E_CTIOS_ALREADY_IN_SESS ION E_CTIOS_MODE_SET_ALREA DY E_CTIOS_MODE_NOT_SET E_CTIOS_INVALID_OBJECT_S TATE E_CTIOS_INVALID_SILENT_M ONITOR_MODE
Description There are no pending requests to be processed. There is already an established session. The session mode has already been set. The session mode is not set yet. Indicates that the object is not in the correct state. This error occurs when a request to initiate CTI OS silent monitor is made and CTI OS is configured to use CCM silent monitor. This error also occurs when a request to initiate CCM silent monitor is made and CTI OS is configured to use CTI OS silent monitor. CoCreateInstance failed to create a COM object wrapper for a CIL Object (Session, Agent, Call, Skill, etc.). A COM component failed to access data from the registry. The Dial Pad common dialog was not created and CoCreateInstance failed. Failed converting COM pointer to C++ pointer.
E_CTIOS_COM_OBJ_ ALLOCATION_FAILED E_CTIOS_COM_ CORRUPTED_REGISTRY E_CTIOS_COM_DIALPAD_ FAIL_TO_LOAD E_CTIOS_COM_CONV_ COMPTR_TO_CPPPTR_ FAILED E_CTIOS_COM_NOT_ INITIALIZED E_CTIOS_SESSION_ DISCONNECT_PENDING E_CTIOS_SESSION_NOT_ CONNECTED E_CTIOS_SESSION_NOT_DISC ONNECTED E_CTIOS_AGENT_ ALREADY_IN_SESSION E_CTIOS_SET_AGENT_ SESSION_DISCONNECT_ REQUIRED E_CTIOS_SERVICE_SEND_ME SSAGE_FAILED E_CTIOS_CALL_ALREADY_C URRENT_IN_SESSION E_CTIOS_LOGIN_ INCONSISTENT_ ARGUMENTS
The MS COM library is not initialized. Invoke CoInitialize(...). A disconnect is already pending. The session is not connected. The call to Connect failed because the session is not in a disconnected state. The session may be connected or a previous call to Disconnect may not yet have completed. An object for this agent already exists in the session. Session must be disconnected before operation.
-900 -901
Could not send message. Session may not be connected. An object for this call is already set as current in the session. The AgentID and/or PeripheralID provided to a Login call do not match the properties set on the Agent object when SetAgent() was called.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
3-6
Release 8.0(1)
Chapter 3
Note
If a method that is supposed to trigger an event returns an error code, you need to check this return value before continuing to wait for events. Depending on the error code, the event you were waiting for may not be triggered.
In Visual Basic, HRESULT values are hidden under the covers. When an error occurs, a Visual Basic exception is thrown, which can be caught using the On Error: construct. The CIL error code is returned as the result of the method call:
VB example: On Error GoTo Error_handler Dim errorCode as Long ErrorCode = pCall.Answer If ErrorCode = CIL_FAILED Debug.print An error has occurred.
The complete set of HRESULT values is defined by Microsoft in the header file winerror.h. The most common HRESULT values that might be seen by CTI OS developers are listed in Table 3-3:
Table 3-3 COM Error Codes
Numeric Value Description 0x00000000 0x00000001 0x80000008 0x80040143 The method succeeded. The method succeeded, but something unusual happened. The method failed. The class was not found in the registry. You will need to run regsvr32.exe on the DLL file to register it.
Generic Interfaces
One of the main design goals of CTI OS was to enable future enhancements to the CTI OS feature set without breaking existing interfaces. To accomplish this, a parameter for almost every method and event will be an Arguments array containing the actual parameters needed. Therefore, parameters may be added or deleted in future versions without affecting the signature of the method or event. This provides the benefit to developers that code developed to work with one version of the CTI OS developers toolkit
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
3-7
will work with future versions without requiring any code changes on the clients side (except to take advantage of new features). For example, CTI OS will automatically send a new parameter in the Arguments array for an event, without requiring an interface or library code change. The dilemma of creating a generic interface is solved by using generic mechanisms to send parameters with events and request, and to access properties.
Arguments
The CTI OS developers toolkit makes extensive use of a new data structure (class) called Arguments. Arguments is a structure of key-value pairs that supports a variable number of parameters and accepts any user-defined parameter names. For any given event, the arguments structure allows the CTI OS Server to send the CIL any new parameters without requiring client side changes. Similarly, for any request, the programmer can send any new parameters, without any changes to the underlying layers. Example of using Arguments in a Visual Basic MakeCall request:
Dim args As New Arguments args.AddItem "DialedNumber", dialthis.Text If Not 0 = Len(callvar1.Text) Then ' set callvar1 args.AddItem "CallVariable1", callvar1.Text End If ' send makecall request m_Agent.MakeCall args, errorcode
Java example:
Arguments args = new Arguments(); args.SetValue(CtiOs_IkeywordIDs.CTIOS_DIALEDNUMBER, 12345); args.SetValue(CtiOs_IkeywordIDs.CTIOS_CALLVARIABLE1, MyData); int iRet = m_Agent.MakeCall(args);
The Arguments structure can store and retrieve all native C/C++, Visual Basic, and .NET and Java types, as well as nested Arguments structures.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
3-8
Release 8.0(1)
Chapter 3
String sID = args.GetValueString(CtiOs_IkeywordIDs.CTIOS_AGENTID); Integer IPeriph = args.GetValueIntObj(CtiOs_IkeywordIDs.CTIOS_PERIPHERALID); if (IPeriph == null) // Error accessing Peripheral ID! Handle Error here else iPeriph = IPeriph.intValue();
CTI OS defines a set of well-known keywords for event parameters and properties. The well-known keywords are of type string and are listed throughout this document with the methods and events for which they are valid. The complete set of valid keywords are listed in the C++ header file, ctioskeywords.h, and are provided in the COM (Visual Basic) type library as well. Java CIL keywords are listed in the Javadoc in the description of the CtiOs_IKeywordIDs interface.
The complete syntax and usage of the GetValue, AddItem, and SetValue methods is detailed in Chapter 7, CtiOs Object. The Arguments structure is detailed in Chapter 12, Helper Classes.
UniqueObjectID
The CTI OS Server creates and manages the CTI OS objects, representing all interactions for the contact center. The CTI OS Server and CIL use the UniqueObjectID field to match up a CTI OS object on the CIL with the corresponding object on the Server. The UniqueObjectID is a variable-length string which can uniquely identify the object within the current context of the CTI OS Server and the Unified ICME and CTI Interlink Advanced. The UniqueObjectID is composed of an object type (e.g. call, agent, skillgroup, etc.), and two or more additional identifying fields. Table 3-4 explains the composition of the UniqueObjectID.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
3-9
Chapter 3 UniqueObjectID
Table 3-4
UniqueObjectID Components
Explanation The call object is uniquely identified by its PeripheralID (5000, generated by Unified ICM), ConnectionCallID (202, generated by the PBX/ACD), and its ConnectionDeviceID (23901, generated by the PBX/ACD). The agent object is uniquely identified by its PeripheralID (5000, generated by Unified ICM), and its agent ID. The device object is uniquely identified by its PeripheralID (5000, generated by Unified ICM), and its instrument number (configured by the PBX/ACD). The skill group object is uniquely identified by its PeripheralID (5000, generated by Unified ICM), and its SkillGroupNumber (configured by the PBX/ACD). The team object is uniquely identified by its PeripheralID (5000, generated by Unified ICM), and its TeamID (5001, also generated by Unified ICM).
Agent Object
agent.5000.22866
SkillGroup Object
skillgroup.5000.77
Note
The CTI OS UniqueObjectID is not the same as the Unified ICM globally unique 64 bit key used in the Unified ICME historical databases (herein called the ICMEnterpriseUniqueID), which exists only for calls. The ICMEnterpriseUniqueID stays with the call even when the call is transferred between call center sites, whereas the UniqueObjectID for a call is specific to its site (by PeripheralID, ConnectionCallID, and ConnectionDeviceID). The ICMEnterpriseUniqueID in CTI OS takes the form of a variable-length string with the form
icm.routercallkeyday.routercallkeycallid
where routercallkeyday is the field Day in the Unified ICM Route_Call_Detail and Termination_Call_Detail tables, and routercallkeycallid is the field RouterCallKey in the Unified ICM Route_Call_Detail and Termination_Call_Detail tables. The CTI OS server enables certain types of monitor mode applications that track the pre-call notification event (eTranslationRouteEvent or eAgentPrecallEvent) and seek to match the call data with the arrival of an eCallBeginEvent. To do so, the application will receive the pre-call notification (for calls routed by Unified ICM (either pre-route, post-route, or translation route), and create a record (object) using the ICMEnterpriseUniqueID field as the with a unique key. Later, when the call arrives at the ACD, and is
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
3-10
Release 8.0(1)
Chapter 3
queued or targeted (by the ACD) for a specific agent, the application can match the saved record (object) with the incoming call by the ICMEnterpriseUniqueID field. The following events will contain the ICMEnterpriseUniqueID that can be used to associate a call with the saved call information:
The GetObjectFromObjectID method will perform an AddRef() on the pointer before it is returned to the programmer. C++ example:
string sUniqueObjectID = call.5000.101.23901; Ccall * pCall = NULL; m_pSession->GetObjectFromObjectID(sUniqueObjectID, (CCtiOsObject**)&pCall); pCall->Clear(); pCall->Release(); // release our reference to this object pCall = NULL;
Java example:
String sUID = call.5000.101.23901; Call rCall = (Call) m_Session.GetObjectFromObjectID(sUID);
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
3-11
unsigned int unBitMask = 0; if (args.IsValid(EnablementMask)) { args.GetValueInt(EnablementMask, & unBitMask) //do bitwise comparison If(unBitMask & ENABLE_ANSWER) m_AnswerButton.Enable(); } }
The advantage of using this approach is that all of the peripheral-specific details of enabling and disabling buttons is determined in a central location at the CTI OS Server. This allows future new features to be enabled, and software bugs to be corrected in a central location, which is a great benefit for deploying future releases.
Warning
The button enablement feature is intended to be used in agent mode applications and not for monitor mode applications.
For any given event, the CTI OS Server calculates the appropriate button enablement bitmask, and sends it to the CIL with the event parameters. The button enablement bit masks are discussed in detail in Chapter 6, Event Interfaces and Events. You can use these masks to write a custom softphone-type application without writing custom code to enable and disable buttons. This approach is also used internally for the CTI OS ActiveX softphone controls.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
3-12
Release 8.0(1)
Chapter 3
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
3-13
CHAPTER
ActiveX Controls. This section covers using the CTI OS ActiveX controls in a COM container such as Visual Basic. COM CIL in C++. This section covers the steps required to use the CILs COM components in a Microsoft Visual C++ application. C++ CIL using static libraries. This section covers the steps required to reference the CILs C++ classes in your application, and how to link the C++ static library files into a Microsoft Visual C++ application. Java CIL libraries. This section covers considerations for installing and using the Java CIL libraries. .NET CIL Class libraries. This section covers the steps required to reference the .NET CIL components in a C# and Visual Basic .NET project files.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-1
The Production Ready Contact Center Desktop applications are the CTI OS Toolkit Agent Desktop, CTI OS Toolkit IPCC Supervisor Desktop and the CTI OS Toolkit Outbound Option Desktop, the default client desktops for Cisco CTI OS used by call center agents and supervisors. These desktop applications are built using the COM CIL and the CTI OS ActiveX controls. These applications are implemented using Visual Basic .NET (VB.NET) and Visual Studio.NET 2005 (VS.2005).
Windows Vista , native application development The CTI OS Toolkit 8.0(1) focuses on satisfying Vista's fundamentals technical pillar as follows:
C++/COM/.NET CIL, CTI OS ActiveX Controls, build targets (DLLs, EXEs) include built-in
manifest information.
C++/COM/.NET CIL, CTI OS ActiveX Controls, build targets (DLLs, EXEs) include Cisco's
- Detection of .NET Framework 2.0 CLR and installation on demand (if required). - Secure installation of production ready CTI OS desktops and auto configuration. - Set appropriate run-time and access rights to configuration areas used by production ready CTI OS desktops such that only authorized users can launch an application based on its logon authorization level. - Silent installation/uninstallation supporting unattended software setup. - Use Vista's Side-by-Side (SxS) paradigm to install system library dependencies .
Implement a new MR/ES installation mechanism using the Native Patch Manager Framework. NET CIL is registered at the target computer's .NET Framework 2.0 Global Assembly Cache
(GAC).
Note
Sample Code needs to built with Visual Studio 2005 in Administrative mode.
Microsoft .NET Framework 2.0 & 3.0 application development. New processor support (for example, Core Duo) for code generation and profiling. Additional support for project file based Web applications. Secure C++ application development.
In order to access the .NET CIL and the RCWs directly from Visual Studio. NET 2005 you need to add the following configuration to your environment.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-2
Release 8.0(1)
Chapter 4
Adding CTI OS Toolkit 8.0(1) Components to the Add Reference Dialog Box
In Visual Studio.NET 2005, you have the ability to select class libraries and assemblies from the .NET tab of the Add Reference Dialog. This facilitates the development process and always allows you to use the correct version of the components. In order to enable the .NET CIL class libraries to appear on the Add References dialog, follow the steps described in: http://msdn.microsoft.com/library/default.asp?url=/library/en-us/vbcon/html/vbtskaddingremovingrefe rences.asp Set a registry key that specifies the location of assemblies to display. To do this, add one of the following registry keys, where <AssemblyLocation> is the directory of the assemblies that you want to appear in the Add Reference dialog box:
[HKEY_CURRENT_USER\SOFTWARE\Microsoft\.NETFramework\<version>\AssemblyFoldersEx\MyAsse mblies]@="<AssemblyLocation>" [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\.NETFramework\<version>\AssemblyFoldersEx\MyAss emblies]@="<AssemblyLocation>"
Creating the registry key under the HKEY_LOCAL_MACHINE node allows all users to see the assemblies in the specified location in the Add Reference dialog box. Creating the registry key under the HKEY_CURRENT_USER node affects only the setting for the current user. For example, if you want to add:
From Visual Studios View menu, make sure to select the Add/Remove Toolbox Items command.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-3
2.
From the Customize Toolbox dialog box, select the .NET Framework Components tab.
Warning
Never select the COM Components tab from the Customize Toolbox dialog box and never select the CTI OS ActiveX controls. Doing this will cause Microsoft Visual Studio .NET 2005 to automatically generate a set of private RCWs that are not optimized nor approved by Cisco, and may lead your application for unexpected behavior that could result in application failure.
3. 4.
From the list, select the CTI OS RCW that corresponds to the CTI OS ActiveX Control you want to add to the toolbox. For example, for the Agent State Control select the AxAgentStateCtl To add more CTI OS ActiveX controls, repeat steps 1 to 3.
Start with the call flow. What kind of call processing is done before calls are targeted for a specific skill? Determine how CTI data can be collected from the caller before the call arrives at an agent. Study the agents workflow. What are the points where CTI will be able to make the workflow easier and faster? Build a business case for the CTI integration. Evaluate what will CTI do for your application. A good approach is to make a list based on the priority (e.g. screen pop, then call control) and then design and implement features in that order. Design how CTI should work within your application. What are the interaction points? Get specifications as to which screen will interact, and which data values should be sent between your application and the CTI OS platform. Determine when the application should connect to the CTI OS Server. Some applications will be server-type integrations that will connect at startup, specify a monitor-mode event filter, and stay connected permanently. Agent-mode applications will connect up when a specific agent begins the work shift. Clean up when youre done. When and how does the application stop? Some applications will stay up and running permanently, while others will have a defined runtime, such as the agents workday or shift. For server-type applications without a specified stopping point, create an object lifetime model and procedure for recovering no-longer-used resources. For applications with a specific stopping point, determine the kind of clean up needs to be done when the application closes (e.g. disconnect from server, release resources).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-4
Release 8.0(1)
Chapter 4
ActiveX Controls. The CTI OS ActiveX controls are the appropriate choice for creating a rapid drag-and-drop integration of CTI and third-party call control with an existing desktop application. The CTI OS ActiveX controls are appropriate choice for developing a CTI integration with any fully ActiveX-compliant container, or any other container that fully supports ActiveX features (e.g. Powerbuilder, Delphi, and many third-party CRM packages). The ActiveX controls will be the easiest to implement in graphical environments, and will help achieve the fastest integrations by providing a complete user interface. All CTI OS ActiveX components are distributed via dynamic link library files (.dll), which only have to be registered once to work on any Microsoft Windows platform. These components are not appropriate for non-Windows environments. The CTI OS ActiveX controls can be used in Windows Forms .NET applications only if the Runtime Callable Wrappers (RCWs) provided with the CTI OS Toolkit are a part of the project. For more information, refer to Using The CTI OS ActiveX Controls on page 4-8. COM. The CTI OS Client Interface Library for COM (Microsofts Component Object Model) is the appropriate choice for developing a CTI integration with any COM-compliant container, or any other container that supports COM features, such as Microsoft Internet Explorer or Visual Basic for Applications scripting languages. The COM CIL will be the easiest to implement in scripting environments, and will help achieve the fastest integrations requiring a custom or non-graphical user interface. All CTI OS components are distributed via dynamic link library files (.dll), which only have to be registered once to work on any Microsoft Windows platform. These components are not appropriate for non-Windows environments. The COM CIL can be used in Windows Forms .NET applications only if the Runtime Callable Wrappers (RCWs) provided with the CTI OS Toolkit are a part of the project. For more information, refer to Adding a Hook for Screenpops on page 4-9. C++. The CTI OS Client Interface Library for C++ is the appropriate choice for building a high-performance application running on a Windows platform in a C++ development environment. The C++ CIL is distributed as a set of header files (.h) that specify the class interfaces to use and statically linked libraries (.lib) that contain the compiled implementation code. Java. The CTI OS Java Client Interface Library (Java CIL) is an appropriate choice for non-Microsoft (typically UNIX) operating systems, as well as for browser based applications. .NET Cil class libraries. This section covers the steps required to reference the .NET CIL components in a C# and Visual Basic .NET project files.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-5
Unit Testing. In a unit test, you ensure that the new code units can execute properly. Each component will operate correctly based on the input, and produce the correct output. An example of a unit test would be to stub-in or hardcode the expected screen-pop data, and ensure that all of the screens come up properly based on this data. Integration Testing. In an integration test, you ensure that the new components work together properly. The physical connections and data passing between the layers and servers involved in the system are tested. An example of an integration test would be testing your client application with the CTI OS server, to ensure that data can be passed correctly through the components. System Testing. In a system test, you ensure that the correct application behavior is exhibited. An example of a system test would be to make a phone call to a VRU, collect the appropriate caller information, transfer the call to an agent, and ensure that the screen pop arrives correctly. User Acceptance Testing. In a user acceptance test, you ensure that your application has met all business requirements set by your analysis and design process. An example of a user acceptance test would be to try your new application with real agents, and ensure that it satisfies their requirements.
Test Environment
The CTI OS Software Development Toolkit (SDK) CD media includes a CTIServerSimulator that can be used for application development and demo purposes. It has the capability to roughly simulate a Lucent PBX/ACD or a Cisco Unified Contact Center (Unified CC) environment. Documentation on how to configure and use the simulator can be found on the CTI OS CD in the directory Tools\Simulator.
Note
This simulator is appropriateonly for preliminary testing of client applications. Because it does not fully replicate the behavior of the actual switch environment, the simulator should not be used for any type of QA testing. To ensure proper design conformance and ensure the correctness of the application, the CTI application must be tested with the actual telephony environment in which it will run. This enables the event flow and third-party control components, which are driven by the switch- and implementation-specific call flow, to be properly and thoroughly tested.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-6
Release 8.0(1)
Chapter 4
and usage of the API. For many developers, these DSAs will form the foundation of your custom application. The samples are available for you to customize and distribute as a part of your finished product. For Unified ICM ACD types (such as Avaya, Nortel, Aspect, etc.), some DSAs can be deployed as Production Class Applications. Cisco certifies and supports the out-of-the-box CTI OS Agent Desktop application in a production environment when used in conjunction with a supported Unified ICM ACD. Refer to the ACD Supplement, Cisco ICM Software Supported Switches (ACDs), at http://www.cisco.com for the current list of supported ACD types. With Unified CC, these same DSAs are generally not intended for production use "as-is". They are neither certified nor supported by Cisco as working out-of-the-box applications. Table 4-1 lists the sample programs on the CTI OS Toolkit CD.
Table 4-1 CTI OS Toolkit Sample Programs
Program Name CTI Toolkit Outbound Desktop All Agents Sample .NET
Location CTIOS Toolkit\Win32 CIL\Samples\CTI Toolkit Outbound Desktop CTIOS Toolkit\dotNet CIL\Samples\All Agents Sample.NET CTIOS Toolkit\dotNet CIL\Samples\All Calls Sample.NET CTIOS Toolkit\dotNet CIL\Samples\CTI Toolkit Combo Desktop.NET
Description A softphone application that demonstrates Outbound Option (formerly Blended Agent) functionality. A Microsoft C# program demonstrating a monitor mode application. This program lists all agents in a grid along with current state updates. Similar to AllAgents but lists calls instead of agents. A Microsoft C# program that interfaces to CTI OS via the .NET CIL interface. The program demonstrates how to build a multi-functional contact center desktop that contains Agent, Unified CC Supervisor and Outbound Option features.
CTIOS Toolkit\dotNet CIL\Samples\CtiOs Microsoft C# program that implements a Tabular Grid used by the CTI Toolkit Combo Data Grid.NET Desktop.NET to show calls and statistics. CTTIOS Toolkit\Win32 CIL\Samples\CTI A Visual Basic .NET program using the CTI OS Toolkit AgentDesktop ActiveX controls. The application is the source code used by the out of the box CTI Toolkit Agent Desktop. CTTIOS Toolkit\Win32 CIL\Samples\CTI A Visual Basic .NET program using the CTI OS Toolkit IPCC SupervisorDesktop ActiveX controls. The application is the source code used by the out of the box CTI Toolkit Supervisor Desktop. CTIOS Toolkit\Win32 CIL\Samples\CTI Toolkit C++Phone A softphone written in C++ linking to the static C++ libraries. Sending requests and event handling as well as the use of the wait object is demonstrated. A Java counterpart to the Visual Basic all agents program.
C++Phone
AllAgents
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-7
Note: If the CTI OS ActiveX controls are not listed as shown in Figure 4-1, the files are either not copied on the target system or the controls were not properly registered.
Figure 4-1 Customize Toolbox in Visual Basic .Net Listing CTI OS ActiveX Controls Runtime Callable Wrappers
Once the CTI OS ActiveX controls have been selected in the .NET Framework Components Tab they should be visible in the Visual Basic .NET ToolBox. The CTI OS ActiveX RCWs components can now be dragged and dropped onto the Windows Form. For a softphone application, it is useful to start with the CallAppearanceCtl (see Figure 4-2).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-8
Release 8.0(1)
Chapter 4
Figure 4-2
Microsoft Visual Basic .NET Screen with the CTI OS ActiveX controls.
On the very left, the Toolbox is visible showing some of the CTI OS ActiveX RCWs icons. On the form, the AxCallGrid has been dragged and dropped. For a complete description of the ActiveX controls see Chapter 5, CTI OS ActiveX Controls. Figure 4-3 shows the CTI OS Toolkit Agent Desktop application, which is also included as a sample on the CTI OS CD.
Figure 4-3 CTI OS Toolkit Agent Desktop (see CD) Built with CTI OS ActiveX Controls
Once all ActiveX controls are placed on the phone, you can create an executable in Visual Basic .NET via Build->Build Solution or selecting <F7>.
CTI OS SessionResolver
A CTI OS Client application connects to CTI OS with a Session object (see Chapter 8, Session Object). Depending on the application, a client can use one or more Session objects. For most agent desktop applications, however, it is useful to employ only a single Session object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-9
If one chooses to write a program not using ActiveX controls, a Session object can be created and used directly (see CTI Toolkit AgentDesktop at the Win32 CIL samples). However, in the case of an application built with the ActiveX controls, all ActiveX controls must use the same session object. The ActiveX controls accomplish this by retrieving a pointer to the same session object via the SessionResolver. The program hosting the ActiveX can obtain the Same session object by using the SessionResolver.GetSession method to retrieve a session named .
' VB sample for a simple CTIOS phone ' needs references to Cisco.CTIOSCLIENTLib Cisco.CTIOSSESSIONRESOLVERLib and Cisco.CTIOSARGUMENTSLib ' ' dim CTIOS session interface ' the session interface handles connect, setagent and others Dim WithEvents m_session As Cisco.CTIOSCLIENTLib.Session ' the sessionresolver is needed to retrieve the session pointer
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-10
Release 8.0(1)
Chapter 4
Building Your Application Using the COM CIL in Visual C++ 8.0(1)
Dim m_sessionresolver As Cisco.CTIOSSESSIONRESOLVERLib.SessionResolver Private Sub Form_Initialize_Renamed() ' instantiate the sessionresolver Set m_sessionresolver = New Cisco.CTIOSSESSIONRESOLVERLib.SessionResolver ' CTI OS ActiveX controls use the session named "" - blank ' since the CTI OS ActiveX controls do the connection and login, ' all we do is listen for events Set m_session = m_sessionresolver.GetSession("") End Sub Private Sub Form_Terminate_Renamed() Call m_sessionresolver.RemoveSession("") End Sub Private Sub m_Session_OnCallEstablished(ByVal pIArguments As Cisco.CTIOSCLIENTLib.Arguments) ' Handles m_Session.OnCallEstablished GetCallVariable1 pIArguments End Sub Function GetCallVariable1(ByVal pIArguments As CTIOSCLIENTLib.IArguments) Dim m_uid As String m_uid = pIArguments.GetValueString("Uniqueobjectid") Dim m_call As Cisco.CTIOSCLIENTLib.Call Set m_call = m_session.GetObjectFromObjectID(m_uid) ' retrieve callvar1 Dim m_callvar1 As String m_callvar1 = m_call.GetValueString("Callvariable1") 'copy call variable1 to the clipboard Clipboard.SetText m_callvar1 End Function
Note
All C++ applications using COM CIL 8.0(1) must be built using Visual Studio .NET. Applications using COM CIL 8.0(1) built with Visual C++ 6.0 are not supported.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-11
Building a custom Win32 (Console or Windows) CTI application in Visual C++ 8.0(1) with COM requires knowledge of creating and using COM components in Microsoft Visual C++ 8.0(1). Client applications of this type tend to be more complex to build, and more powerful and faster in execution, than scripting clients (for example, Visual Basic). All the CIL components for COM are distributed as COM Dynamic Link Libraries (COM DLL). In order to be accessible to COM containers including Microsoft Visual C++ 8.0(1), COM components must be registered with Windows. The components required for programming in Microsoft Visual C++ 8.0(1) are:
CTI OS Client library (CTIOSClient.dll). This is the main CIL library for COM. The objects available in this library are described fully in Chapters 8 through 11. CTI OS Arguments Library (arguments.dll). The Arguments helper class is used extensively in CTI OS, and is described fully in Chapter 12, Helper Classes. CTI OS Session Resolver (ctiossessionresolver.dll). This object allows multiple applications or controls to use a single CTI OS Session object. It is required when building an application that will include the CTI OS ActiveX controls.
Microsoft Foundation Classes (MFC). The following header files are required for MFC applications to use COM: afxwin.h, afxext.h, afxdisp.h, and afxdtctl.h. If you build an application using the Microsoft Visual C++ 7.1(1) application wizard, these files are included for you automatically. Microsofts ActiveX Template Library (ATL). To use ATL, include the standard COM header file: atlbase.h.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-12
Release 8.0(1)
Chapter 4
Building Your Application Using the COM CIL in Visual C++ 8.0(1)
Note
You must register three DLLs, but you do not need to import the arguments.dll into your project since it is imported by the ctiosclient.dll type library.
Only the apartment threading model is supported. COM objects in C++ are created via the COM runtime library. To create a COM object at run time, your program will need to use the CreateInstance() method call.
// Create SessionResolver and Session object hRes = m_pSessionResolver.CreateInstance (OLESTR("CTIOSSessionResolver.SessionResolver")); if (m_pSessionResolver) { m_pSession = m_pSessionResolver->GetSession(_bstr_t("")); }
Once the Session object is created, you can use it to make requests, and subscribe for events.
This class must implement the method signatures for the events it expects to receive. When an event is fired from the event source, the corresponding method in your event sink class will be invoked, and you can perform your custom event handling code at that time. To subscribe for an event, the client must call the AtlAdvise() method, specifying a pointer to the interface of the event source.
// Add event sink as event listener for the _IallEvents interface
HRESULT hRes =
AtlAdvise(m_pSession, m_EventSink.GetIDispatch(FALSE), __uuidof(_IAllEvents), &m_dwEventSinkAdvise);
When the program run is complete, the client must unsubscribe from the event source, using the AtlUnadvise() method:
// Unsubscribe from the Session object for the _IAllEvents interface HRESULT hRes = AtlUnadvise( m_pSession, __uuidof(_IAllEvents), m_dwEventSinkAdvise );
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-13
Next Steps
For detailed information on the CTI OS client start up and shut down sequence, see section Disconnecting from CTI OS Server, page 4-29. For detailed information on the CTI OS Client Interface Library objects, see Chapters 8 through 12. The C++ Client Interface Library (C++ CIL.) application is a programming interface (API) used to build high performance CTI enabled desktop or server-to-server integration that use Cisco CTI OS. The API is deployed as a set of C++ static libraries and is use to build Win 32 or console based applications.
For a complete sample application that uses the CIL COM interface written in C++, see the Comphone sample application on the CTI OS CD.
All C++ applications using C++ CIL 8.0(1) must be built using Visual Studio .NET 2005. Applications using C++ CIL 8.0(1) built with Visual Studio .NET 2003 are not supported. The CTI OS Client Interface Library for C++ is the most powerful, object-oriented CTI interface for C++ developers. It provides the same interface methods and events as the COM interface for C++, but will be more straightforward for C++ developers who are not experienced COM programmers, and will provide faster code execution. The CIL interface for C++ is a set of C++ header files (.h), and static libraries compiled for the Win32 platform (Windows NT, Windows 2000). The header files required to access the class definitions are located on the CTI OS SDK media in the CTIOSToolkit\Include\ directory, and the static libraries are located in the CTI OS Toolkit\Win32 CIL\Libs directory.
To link your application code with the CIL for C++, you will require the following C++ static libraries:
ConnectionLibSpd.lib. This library contains the connection-layer services for CIL. ServiceLibSpd.lib. This library contains the service-layer services for CIL. SessionLib.lib. This library contains the object-interface services for CIL. UtilLibSpd.lib. This library contains helper classes for CIL. ArgumentsLibSpd.lib. This library contains the Arguments data structure for CIL. SilentMonitorLib.lib. This library contains all the services required to establish and control silent monitor sessions. SecuritySpd.Lib. This library contains the services required to establish secure connections with CTI OS Server. SilentMonitorClient.lib. This library is used by the CIL to communicate with the silent monitor service.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-14
Release 8.0(1)
Chapter 4
Building Your Application Using the C++ CIL and Static Libraries
SilentMonitorCommon.lib and ServiceEventHandler.lib. These libraries contain support classes for SilentMonitorClient.lib.
Note
The preceding are the Release versions of the libraries. The Debug equivalent libraries use the same library name with the appended d instead of Spd; e.g., for ArgumentsLibSpd, the Debug library is ArgumentsLibd.lib. In addition to the aforementioned CTI OS CIL libraries, your application will require:
the standard Microsoft sockets library, Wsock32.lib the standard multimedia library, winmm.lib the OpenSSL standard libraries:
libeay32d.lib ssleay32d.lib (Debug) and libeay32d.lib ssleay32r.lib (Release)
A console C++ application with C++ CIL needs to use the following in stdafx.h:
#pragma once #define WIN32_LEAN_AND_MEAN // Exclude rarely-used stuff from Windows headers #include <iostream> #include <tchar.h
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-15
Within the Project Settings dialog, select the C/C++ tab, select "General" and then select Additional include Directories. Provide either the absolute or relative path to find the header files (.h) required for your application. This path should point to the CTIOSToolkit\Win32 CIL\Include directory, where the CIL header files are installed. Within the Property Pages dialog, select the C/C++ folder. Select Code Generation. For a Debug Mode program, the setting for Runtime Library should be Multi-threaded Debug DLL (/MDd). For a Release Mode program, the setting should be Multi-threaded DLL (/MD). Next, under the Proprocessor, you will need to set the "Preprocessor Definitions". You need to provide the compiler with the following define constants _USE_NUMERIC_KEYWORDS=0;_WIN32_WINNT=0x0500; WIN32_LEAN_AND_MEAN in addition to the suggested by default. The following setings must be set for the C++ compiler:
Preprocessor Definitions
Add the following two macros:
_CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES=1 _CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES_COUNT=1
Language
Set the parameter "Treat wchar_t as Built-in Type" to No (/Zc:wchar_t-)
Precompile Headers
Set to Not Using Precompile Headers
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-16
Release 8.0(1)
Chapter 4
Building Your Application Using the C++ CIL and Static Libraries
Next, you need to set the link settings for your project, under the Link folder. You must list all the static libraries (in the section Header Files and Libraries on page 4-14) for your program to link with the settings described in Project Settings for Compiling and Linking. The libraries required for CIL (in addition to the default libraries) are described in the section Header Files and Libraries on page 4-14.
Finally, on the Link folder, select General to Input. You will need to set the Additional Library Directories: to the location of the CTIOSToolkit\Win32 CIL\Libs directory:
The foregoing are all the Project Settings required for CTI OS. Click OK, and save your project settings.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-17
To register for an event, you use the appropriate AddEventListener method on the Session object:
// Initialize the event sink m_pEventSink = new CEventSink(&m_ctiSession, &m_ctiAgent, this); // Add event sink as an event listener m_ctiSession.AddAllInOneEventListener((IAllInOne *) m_pEventSink);
To remove an event listener (upon program termination), use the appropriate RemoveEventListener on the Session object:
// Tell session object to remove our event sink m_ctiSession.RemoveSessionEventListener((IAllInOne *) m_pEventSink);
STLPort
Version 7.1(1)(0) of the Cisco CTI OS Toolkit no longer uses STLPort. Instead, it uses Microsofts version of STL, thereby removing any special configuration of the build environment.
Next Steps
For detailed information on the CTI OS client start up and shut down sequence, see the section Disconnecting from CTI OS Server, page 4-29. For detailed information on the CTI OS Client Interface Library objects, see Chapters 6 through 11. For a complete sample application that uses the CIL interface with C++ static libraries, see the C++phone sample application on the CTI OS CD.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-18
Release 8.0(1)
Chapter 4
The Java CIL ships with a GUI TestPhone application which provides most of the functionality found on the CTI OS Agent and Supervisor Desktops. The distribution also includes samples that are Java versions of some of the C++/COM/VB sample applications. For more informationSee section Using the Samples. The CTI OS Java Test Phone has been updated and compiled with CTI OS Java CIL 8.0(1) using the JDK/JRE 1.6_01 for Linux and has been functionally tested on Red Hat Linux Enterprise 5.0.
Next Steps
Refer to Event Interfaces and Events, page 6-1 and Keywords, page A-1 for differences between the C++ and Java event publishing. Refer to CtiOs Object, page 7-1 through 12 for differences in method calls and syntax for those classes between C++ and Java. Refer to Creating CTI OS Client Logs (COM and C++), page B-1 for differences between C++ and Java tracing.
Next Steps
Refer to Event Interfaces and Events, page 6-1 and Creating CTI OS Client Logs (COM and C++), page B-1 for differences between the C++, and .NET and Java event publishing. Refer to CtiOs Object, page 7-1 through 12 for differences in method calls and syntax for those classes between C++ and Java.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-19
Create a session instance, described below. Set the event listener and subscribe to events, described below. Set connection parameters, described below. Call the Connect() method, described on page 4-21. Set the connection mode, described on page 4-23.
This section also describes how to deal with connection failures, on page 4-22. If your system is a duplexed Unified CCE PG with CSA installed, and you do not have one side of the CTI OS server running, CSA does not respond to login requests on the CTI OS server port. This triggers a timeout (20 second delay) before you attempt to connect to the active CTIOS server, in the CTI OS client machine TCP stack. On start-up or log-in, the CTI OS client randomly chooses a CTI OS server side to connect and it may connect to the server side that is not running. To avoid this delay/timeout, you must:
Start the inactive CTI OS server side Disable CSA (temporarily) and reconfigure the CTI OS desktop for a simplex operation Upgrade the version of the CTI OS server to CTI OS 8.0 (The desktop does not appear frozen though the delay persists)
The client application should hold a reference to the Session object as long as it is in use, but the client programmer must release the last reference to the object to prevent a memory leak when the object is not longer needed. During application cleanup, the Session object must only be disposed by invoking the CCtiOsSession::Release() method. This will ensure proper memory cleanup. For example:
m_pSession->Release();
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-20
Release 8.0(1)
Chapter 4
In this example, the session is adding the containing class, the desktop application, as the listener, and using the eAllInOneList field in the CtiOs_Enums.SubscriberList class to subscribe to all events.
Create an instance of the Arguments class. Set values for the CTI OS servers, ports, and the heartbeat value. When setting values, use the String key fields in the CtiOs_IKeywordIDs interface, as shown in the example below. The following example demonstrates this task in Java:
/* 1. Create Arguments object.*/ Arguments rArgs = new Arguments(); /* 2. Set Connection values.*/ rArgs.SetValue(CTIOS_enums.CTIOS_CTIOSA, CTIOSServerA); rArgs.SetValue(CTIOS_enums.CTIOS_PORTA, 42408); rArgs.SetValue(CTIOS_enums.CTIOS_CTIOSB, CTIOSServerB); rArgs.SetValue(CTIOS_enums.CTIOS_PORTB, 42408); rArgs.SetValue(CTIOS_enums.CTIOS_HEARTBEAT, 100);
Note
Note
The Arguments.setValue() methods return a boolean value to indicate whether the method succeeded (true) or not (false).
For more information on the possible values and meanings of the int value returned by the Connect() method in the Java CIL, see page 4-22. When successful, the Connect() method generates the OnConnection() event. Code within the OnConnection() event should set the connection mode, as described in the next section.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-21
Connection Failure Events, page 4-22 Connection Attempt Error Codes in Java and .NET CIL, page 4-22 Configuring the Agent to Automatically Log In after Failover, page 4-23 Stopping the Failover Procedure, page 4-23
Also see How to Deal with Failover In Monitor Mode, page 4-27.
OnConnectionRejected() event indicates that an unsupported version mismatch has been found. OnCTIOSFailure() indicates that the CTI OS Server requested in the Connect() method is down. If an OnConnectionFailure() event is generated, the application is in Failover and the CIL continues to attempt to connect until the connection succeeds or until the application calls Disconnect(). The Arguments parameter for the event includes the following keywords:
FailureCode SystemEventID SystemEventArg1 ErrorMessage
For more information on the contents of the OnConnectionFailure() event, see the description in Chapter 6.
CIL_OK - The connection process has successfully begun. The CIL will either fire the OnConnection() event to indicate that the CIL successfully connected or will fire the OnConnectionFailure() event and go into failover mode. If the latter occurs, the CIL will continue to attempt to connect, alternating between hosts CTIOS_CTIOSA and CTIOS_CTIOSB, until the connection succeeds, at which point the CIL will fire the OnConnection() event. E_CTIOS_INVALID_ARGUMENT - A null Arguments parameter was passed to the Connect() method. The connection failed. No events are fired. E_CTIOS_MISSING_ARGUMENT - The Arguments parameter did not contain values for both CTIOS_CTIOSA and CTIOS_CTIOSB. At least one of these values must be provided. The connection failed. No events are fired. E_CTIOS_IN_FAILOVER - A previous connection attempt failed and the CIL is currently in failover and attempting to establish a connection. This continues until a connection is established, at which point the CIL will fire an OnConnection() event indicating that the previous Connect() method has succeeded. To attempt to connect again with different parameters, the application must first use the Disconnect() method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-22
Release 8.0(1)
Chapter 4
E_CTIOS_SESSION_NOT_DISCONNECTED - The Session is not disconnected (i.e. a previous Connect() method is in progress, or the Session is already connected). The application must call the Disconnect() method before attempting to establish another connection. The CIL may fire an OnConnection() event for the to previous call to the Connect() method if the connection was in progress, but will not fire one corresponding to this method call. E_CTIOS_UNEXPECTED - There was an unanticipated error. The connection failed. No events are fired.
Note
Once the application receives a Connect return code of CIL_OK, it should not call Connect again on that session until it receives an OnConnectionClosed event after a call to Disconnect.
The application should contain logic within the OnConnection() event handler to ensure it attempts to set the connection mode only during the initial connection, and not in an OnConnection() event due to failover.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-23
The properties required for the agent depend on the type of ACD you are using. The following example demonstrates the required properties for Unified CC users.
Step 2
Set the agent for the Session object to that Agent object.
Note
In the Java CIL only: If the SetAgent() method is called on a session in which the current agent is different than the agent parameter in the SetAgent() method, the Java CIL automatically calls the Disconnect() method on the current session instance, generating an OnCloseConnection() event, then attempts to reconnect, generating an OnConnection() event. Then the new agent is set as the current agent.
The following example, which assumes the Session object has been created and connected to the CTI OS Server, demonstrates this task in Java:
void OnConnection(Arguments rArgs) { /* 1. Create and agent and set the required properties. */ Agent agent = new Agent(); agent.SetValue(CtiOs_IKeywordIDs.CTIOS_AGENTID, "275"); agent.SetValue(CtiOs_IKeywordIDs.CTIOS_PERIPHERALID, "5002"); /* 2. Set the session's agent */ int returnValue = session.SetAgent(agent); }
OnQueryAgentStateConf() OnSetAgentModeConf() OnSnapshotDeviceConf(), if the agent is already logged in OnSnapshotCallConf(), if there is a call and the agent is already logged in OnCTIOSFailureEvent()
4-24
Release 8.0(1)
Chapter 4
Caution
Monitor mode, as the name implies, is intended for use in applications that passively listen to CTI OS server events. Monitor mode is not intended for use in applications that actively control the state of calls or agents. Such applications include but are not limited to the following: - Applications that log in agents and change their state - Applications that make or receive calls and change their state - Applications that silent monitor agents
Caution
When a Monitor mode session is initialized, the CTI OS Server performs a CPU intensive sequence of operations to provide the application with a snapshot of the state of the system. A large number of monitor-mode applications connecting to CTI OS server at the same time, such as in a fail-over scenario, may cause significant performance degradation on CTI OS Server. Therefore, minimize the number of Monitor mode applications connecting to CTI OS Server to two (2).
Warning
Note that the button enablement feature can only be used in agent mode sessions and are not intended for monitor mode applications.
Note
The filter String may also contain an asterisk (*), which is used as a wildcard to indicate any possible value. A prefix can be used in addition to * to narrow the results. For example, using 10* will match 1001, 1002, 10003.However, CTI OS ignores any characters that follow the asterisk. For example, using 10*1will match both 1001and 1002. The filter String must contain at least one key, and there must be at least one value for that key. However, a key may take multiple values, and the filter String may contain multiple keys. Multiple values for a single key must be separated by commas (,). Multiple keys must be separated by semicolons (;).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-25
Note
Multiple keys in a single filter combine using a logical AND. That is, the filter is instructing CTI OS to send to this connection only events that meet all the criteria included in the filter. For example, a filter String could be as follows:
S_MESSAGEID + "=" + CtiOs_Enums.EventID.eAgentStateEvent + ";" + S_AGENTID + "=5128";
The first key-value pair, S_MESSAGEID + "=" + CtiOs_Enums.EventID.eAgentStateEvent, serves to request events with a message ID equal to eAgentStateEvent; that is, it requests agent state events. The second key-value pair, S_AGENTID + "=5128", specifies that the request is for the agent with the ID 5128. The result of the filter then is that the connection will receive agent state events for agent 5128.
Filter Keys
Filter keys can be any known key value used by CTI OS. These keys have corresponding fields in the CtiOs_IKeywords interface.
Note
When constructing the filter String, use the fields that begin with S_, as these are the String values for the key. For example, in Java:
String sFilter = S_AGENTID + "=5128,5129,5130";
In this example, S_AGENTID is the String representation of the key indicating an Agent ID.
Create the filter Check events to verify that the CTIOS _MONITORED parameter is present and is TRUE Ignore events if the CTIOS_MONITORED parameter is missing or FALSE
Specify the filter String. See the previous section for filter details. Create an Arguments instance and add an item with CtiOs_IKeywordIDs.CTIOS_FILTER as the keyword and the filter String as the value. Use the CtiOsSession.SetMessageFilterArgs(args) method to select Monitor mode and to set the event filter.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-26
Release 8.0(1)
Chapter 4
Note
You should always include the OnCtiOsFailure() event in the message filter, so that the application can detect when a system component is online or offline.
Caution
A Monitor Mode application that monitors any Call-related events must also monitor the OnCallEnd() event, as described on page 4-43. The following example, which assumes the Session object has been created, demonstrates this task in Java:
/* 1. Constructing message filter string / String filter = "messageid=" + eAgentStateEvent + "," + eAgentInfoEvent + , + eCTIOSFailureEvent; /* 2. Create the Arguments object*/ Arguments rArgs = new Arguments(); /* 3. Add the filter to the Arguments instance.*/ rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_FILTER, filter); /* 3. Set the message filter.*/ int returnValue = session.SetMessageFilter(rArgs);
With Unified CC only, OnQueryAgentStateConf() for each team and each agent logged in OnSnapshotDeviceConf() for each device OnSnapshotCallConf() OnMonitorModeEstablished()
When the application detects a failover, for example, in a CTIOSFailure() event indicating a connection failure or an offline component, wait until the CIL has failed over and everything is back online and the CIL is connected to CTI OS. The Monitor mode application is responsible for determining when all required servers are online. You can do this by monitoring OnCtiosFailure() events and keeping track of system status changes as they occur.
Step 2 Step 3
Use the Disconnect() method to disconnect the session from CTI OS. Follow the steps starting at the beginning of the section Enabling Silent Monitor in Your Application to:
a. b.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-27
c. d. e.
Set connection parameters. Call the Connect() method. Set the connection mode in the OnConnection() event handler.
Settings Download
One of the many useful features of CTI OS is the ability to configure Agent Desktop settings for once on the server and have them be available to all agent desktops via the RequestDesktopSettings() method. Any changes can be made once on the server instead of changing each and every desktop. Settings download can be considered as part of the process of setting up a connection that the client application will use. Desktop settings are stored in the registries on the machines running CTI OS Server. Centralizing the desktop settings on the server streamlines the process of changing or updating the agent desktop. A settings download every time a client application connects ensures that all the desktops are based on the same settings. Downloading settings from CTI OS Server can be done after connecting and setting the mode via the RequestDesktopSettings() method on the Session object. The OnGlobalSettingsDownloadConf event indicates success and also returns the settings which are now available to the client application in the form of properties on the Session object. These properties can be accessed via the GetValue() methods. Refer to Chapter 9 for a list of all the properties of the Session object. The request for desktop settings can be made either in the OnConnection event or in the OnSetAgentModeEvent event (if Agent mode has been specified). Sample code:
Private Sub m_Session_OnConnection(ByVal pDispParam As Object) 'Issue a request to the server to send us all the Desktop 'Settings m_Session.RequestDesktopSettings eAgentDesktop End Sub
The OnGlobalSettingsDownloadConf event passes back the settings and they can be accessed via the Session object. For example, the following snippet checks for Sound Preferences and specifically to see if the Dial Tone is Mute or not:
Private Sub m_session_OnGlobalSettingsDownloadConf(ByVal pDispParam As Object) Dim SoundArgs As CTIOSARGUMENTSLib.Arguments ' check if "SoundPreferences is a valid property If m_session.IsValid("SoundPreferences ") = 1 Then Set SoundArgs = m_session.GetValue("SoundPreferences") Dim DialToneArgs As CTIOSARGUMENTSLib.Arguments If Not SoundArgs Is Nothing Then If SoundArgs.IsValid("DialTone") = 1 Then Set DialToneArgs = SoundArgs.GetValue("DialTone") End If End If Dim Mute As Integer If Not DialToneArgs Is Nothing Then If DialToneArgs.IsValid("Mute") = 1 Then Mute = DialToneArgs.GetValueInt("Mute") If Mute = 1 Then MsgBox "Dial Tone MUTE"//Your logic here Else MsgBox "Dial Tone NOT MUTE"//Your logic here
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-28
Release 8.0(1)
Chapter 4
Disconnect is a higher priority method than all others. Before calling Disconnect, ensure that all prior requests have completed lest the call to Disconnect may abort these requests. For example, calling Disconnect immediately after calling Logout may result in an agent not being logged out. Upon Disconnect(), each object maintained by the Session (Call, Skillgroup, Wait) is released and no further events are received. Cleaning up the Agent object is the developers responsibility since it was handed to the Session (via the SetAgent() method. Code sample: In the C++ and COM CIL only, to disconnect from CTI OS Server when the session mode has not yet been established by means of calling either CCtiOsSsession::SetAgent(...) or CCtiOsSsession::SetMessageFilter(...), disconnect must be called with an arguments array containing the CTIOS_FORCEDDISCONNECT set to True.
m_session.Disconnect // Perform disconnect if(m_ctiSession->GetValueInt(CTIOS_CONNECTIONMODE) == eSessionModeNotSet ) { // If the session mode has not yet been set by SetAgent or // SetSessionMode at the time of the disconnect. // we need to indicate the session that a disconnect needs to // be forced bool bAllocOk = true; Arguments * pDisconnectArgs = NULL; bAllocOk = Arguments::CreateInstance(&pDisconnectArgs); if ((false==bAllocOk) || (pDisconnectArgs == NULL)) { CDialog::OnClose(); argsWaitParams.Release(); return; } pDisconnectArgs->AddItem(CTIOS_FORCEDDISCONNECT,true); m_ctiSession->Disconnect(*pDisconnectArgs); pDisconnectArgs->Release(); } else { m_ctiSession->Disconnect(); }
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-29
Before attempting to log in an agent, you would typically request global configuration data, in order to correctly handle a duplicate log in attempt. For more information, see section How to Get Registry Configuration Values to Your Desktop Application. To log in the agent, in the SetAgentModeEvent() event:
Step 1 Step 2
Create an instance of the Arguments class. Set log in values for the agent in the Arguments instance. The properties required for the agent depend on the type of ACD you are using. The following example demonstrates the required properties for Unified CC. Log in the agent. The following example, which assumes the Agent object has been created, demonstrates this task in Java:
public void SetAgentMode(Arguments rArgs) { /* 1. Create Arguments object*/ Arguments rArgs = new Arguments(); / * 2. Set log in values.*/ rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_AGENTID, 275); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_PERIPHERALID, 5002); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_AGENTINSTRUMENT, 5002) rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_AGENTPASSWORD, ********); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_AUTOLOGIN, 1); /* 3. Log in the agent.*/ int returnValue = agent.Login(rArgs); }
Note
Step 3
Note
It is the client applications responsibility to keep track of whether the log in attempt is the first attempt, or during failover, and branch accordingly in the SetAgentMode() event to avoid calling the Login() method during failover. The Login() method generates the following events:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-30
Release 8.0(1)
Chapter 4
Note
The client application receiving the these events must check both the ENABLE_LOGOUT and ENABLE_LOGOUT_WITH_REASON bitmasks. For more information, see What to do in the OnButtonEnablementChange() Event, page 4-40. When not successful, the Login() method generates the eControlFailureConf() event.
Allow the Duplicate Log In with No Warning Allow the Duplicate Log In with a Warning Do not allow a duplicate log in By configuring how duplicate log in attempts are to be handled on a global basis by creating custom values in the CTI OS Server Registry. By using custom values in the CTI OS Server registry to control how duplicate log in attempts are handled, and downloading these settings to your desktop application as described on page 4-35, you can enable flexibility without having to modify your desktop application code. By implementing code in your desktop application to detect then to handle the duplicate log in attempt error according to the custom values in the CTI OS Server Registry. You can write code to handle duplicate log in attempts in each of the three ways listed above. Then when you must change how such attempts are handled, you would simply change the registry settings; you would then not need to change the desktop application code.
You control how duplicate log in attempts are handled in two ways:
How to Create Values in the CTI OS Server Registry to Control Duplicate Log In Attempts
You can create keys in the CTI OS Server Registry that will instruct desktop applications to handle duplicate log in attempts in a specific way.
Warning
Two keys exist by default in the registry that are used by the CTI OS CIL: WarnIfAlreadyLoggedIn and RejectIfAlreadyLoggedIn. You must not use these keys in your desktop application. You must instead create other keys as described in this section.
custom_WarnIfAgentLoggedIn custom_RejectIfAgentLoggedIn
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-31
The following table lists the settings to use to control how duplicate log in attempts are to be handled:
Table 4-2 :CTI OS Server Registry Settings (To control duplicate log in)
custom_WarnIf AgentLoggedIn Goal To warn the agent of the duplicate log in attempt, but to allow the agent to proceed To allow the agent to proceed with the duplicate log in attempt with no warning To not allow the agent to proceed with a duplicate log in attempt To create keys to control duplicate log in attempts:
Step 1
custom_RejectIfAg entLoggedIn 0
0 or 1
Open the registry and navigate to: HKEY_LOCAL_MACHINE\Software\Cisco Systems, Inc.\CTIOS\[CTI Instance Name]\CTIOS1\EnterpriseDesktopSettings\AllDesktops\Login\ConnectionProfiles\Name\[Profile Name]. Right click in the registry window and select New->DWord Value. The new value appears in the window. Change the value name to custom_WarnIfAgentLoggedIn. Double-click the value to open the Edit DWORD Value dialog box. Enter 1 in the Value data field to set the value to true, or 0 to set it to false. Repeat steps 2 through 5 for the value custom_RejectIfAgentLoggedIn.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-32
Release 8.0(1)
Chapter 4
Create an instance of the Arguments class. In the Arguments instance, set the value for the CTIOS_DESKTOPTYPE key to either:
CtiOs_Enums.DesktopType.eAgentDesktop CtiOs_Enums.DesktopType.eSupervisorDesktop Although the Arguments object must have one of these fields as a value for the CTIOS_DESKTOPTYPE key, this version of CTI OS does not utilize the desktop type parameter when sending global configuration data to a desktop application. Regardless of which field you use in defining the Arguments object, CTI OS returns all global configuration data with the OnGlobalSettingsDownloadConf() event. The desktop type indicators, through currently required, are reserved for future use.
Note
Step 3
Request desktop settings for the session using the RequestDesktopSettings() method. This results in a OnGlobalSettingsDownloadConf() event. The following example demonstrates steps 1 through 3 in Java:
/* 1. Create Arguments object*/ Arguments rArgs = new Arguments(); /* 2. Set the desktop type.*/ rArgs.SetValue(CTIOS_DESKTOPTYPE, CtiOs_Enums.DesktopType.eAgentDesktop); /* 3. Request desktop settings. This should cause CTI OS to send the OnGlobalSettingsDownloadConf event.*/ int returnValue = session.RequestDesktopSettings(rArgs);
Step 4
In the OnGlobalSettingsDownloadConf() event, get the Arguments instance for Login configuration from the event Arguments parameter. Use the S_LOGIN key from the CtiOs_IKeywordIDs interface.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-33
Step 5
Get the Arguments instance for the correct switch from the Login Arguments instance. The example below uses the IPCC/SoftACD login configuration information, the key for which is established by the CTI OS Server installation. Get the Integer instances for the custom values you established for the key in the CTI OS Server registry. For convenience, get the int values for those Integers to test with, as described in the section How to Handle Duplicate Log In Attempts, page 4-31. The following example demonstrates steps 4 through 7 in Java:
void OnGlobalSettingsDownloadConf(Arguments rArgs) { /* 4. Get the Arguments instance for the Login configuration information from the event Arguments parameter.*/ Arguments logInArgs = rArgs.getValueArray(CTIOS_LOGIN);
/* 5. Get the Arguments instance for the Connection Profile
Step 6 Step 7
from the Login Arguments instance. */ Arguments connectionProfilesArgs = logInArgs.GetValueArray(CTIOS_CONNECTIONPROFILES); /* 6. Get the Arguments instance for the specific switch from the Connection Profiles instance */ Arguments IPCCLogInArgs = connectionProfilesArgs.GetValueArray("IPCC/SoftACD") /* 7. Get the Integer instances for the custom values you entered in the CTI OS Server registry.*/ Integer warningIntObj = IPCCLogInArgs.GetValueIntObj(custom_WarnIfAgentLoggedIn); Integer rejectIntObj =IPCCLogInArgs.GetValueIntObj(custom_RejectIfAgentLoggedIn); /* 8. Get the int values for those object to test later.*/ custom_WarnIfAgentLoggedIn = warnIntObj.intValue(); custom_RejectIfAgentLoggedIn = rejectIntObj.intValue(); }
Get the agent state value from the Arguments instance passed to the event. Test the agent state value in the CtiOs_Enums.AgentState interface, as follows.
(state != eLogout) && (state != eUnknown)
Step 3
If the test is true, handle the duplicate log in attempt as described in the next section.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-34
Release 8.0(1)
Chapter 4
If your custom_WarnIfAgentLoggedIn = 1 and custom_RejectIfAgentLoggedIn = 0, notify the user that the agent is already logged in and proceed with Login() depending on the users response. If your custom_RejectIfAgentLoggedIn = 1, notify the user that the agent is already logged in and Disconnect.
Create an instance of the Arguments class. Set log out values for the agent in the Arguments instance.
Note
Unified CC requires a reason code to log out. Other switches may have different requirements.
Step 3
Log out the agent. The following example demonstrates this task in Java:
/* 1. Create Arguments object*/ Arguments rArgs = new Arguments(); /* 2. Set log out values.*/ rArgs.SetValue(CTIOS_EVENTREASONCODE, 1); /* 3. Log out the agent.*/ int returnValue = agent.Logout(rArgs);
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-35
Call Logout request on your current agent. You need to call Logout and not use SetAgentState(eLogout), because Logout provides additional logic to support pre-Logout notification, Logout failure notification, and resource cleanup. Heres the sample code for the same:
if(m_ctiAgent) { Arguments &rArgAgentLogout = Arguments::CreateInstance(); //add reason code if needed rArgAgentLogout.AddItem(CTIOS_EVENTREASONCODE, reasonCode); int nRetVal = m_ctiAgent->Logout(rArgAgentLogout); rArgAgentLogout.Release(); }
2.
Receive a response for the Logout request. You can expect the following events in response to a Logout request:
OnAgentStateChange (with Logout agent state)
OnPostLogout (you will additionally receive this event if the Logout request succeeds.
Note
You may disable statistics either prior to issuing the Logout request or upon receipt of the OnAgentStateChange to logout state. Use the OnPostLogout event to trigger session disconnect. This will guarantee that all event listeners can make CTI OS server requests in response to the logout OnAgentStateChange event.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-36
Release 8.0(1)
Chapter 4
{ m_ctiSession->Disconnect(); } } }
3. 4.
If you are not concerned with whether the agent is successfully logged out prior to disconnect, issue a session Disconnect request without a Logout request. Additionally, you must wait for OnConnectionClosed before destroying Agent and Session objects. This will guarantee that the CIL has completed cleanup of the Session object prior to your calling Release on these objects. Ensure that the agent object is set to NULL in the session before you Release the session object. For example, whenever your application is exiting and you are disconnecting the session object (e.g. when the user closes your application's window) you should do something similar to the code below:
if (m_ctiSession) { m_ctiSession->Disconnect(); // stop all events for this session int nRetVal = m_pctiSession->RemoveAllInOneEventListener((IAllInOne *) m_pmyEventSink);
5.
//The application is closing, remove current agent from session CAgent * pNullAgent = NULL; m_Session->SetAgent(*pNullAgent); m_Session->Release(); m_Session = NULL; } if(m_ctiAgent) { m_ctiAgent->Release(); m_ctiAgent = NULL; } if (m_pmyEventSink) { m_pmyEventSink->Release(); m_pmyEventSink = NULL; }
Apply incoming events to the correct call Select the correct call on which to make method calls (i.e. telephony requests)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-37
It is not necessary to maintain a set of Call Objects in order to do this. Instead, the application could store the string UniqueObjectID of each call (keyword CTIOS_UNIQUEOBJECTID). CTIOS_UNIQUEOBJECTID is always included in the args parameter for each call event. The actual Call Object can be obtained with the Session object's GetObjectFromObjectID() method to make a method call.
When there is only 1 call on a device, the CIL sets it to the Current Call. When there are multiple calls on a device and an application wants to act on a call that is not the Current Call, it sets a different call to the Current Call with the SetCurrentCall() method. When the call which is the Current Call ends, leaving multiple calls on the device, the application must set another call to be the Current Call. Whenever the Current Call is set to a different call, OnCurrentCallChanged() event is fired as well as an OnButtonEnablementChange() event.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-38
Release 8.0(1)
Chapter 4
Call Wrapup
The agent/supervisor desktop will need to behave differently at the end of a call depending on factors including:
the direction of the call (inbound or outbound) configuration of Unified CC or the ACD (whether wrapup data is required, optional, or not allowed) configuration of CTI OS server
The CTI Toolkit Combo Desktop .NET sample shows how to use this information to display a wrapup dialog that allows the agent to select from a set of pre-configured wrapup strings after an inbound call goes into wrapup state. (See ProcessOnAgentStateEvent in SoftphoneForm.cs) On an agent state change event, if the state changes to WorkReady or WorkNotready state, this indicates that the agent has transitioned to call wrapup state. The CTI OS server will provide the following key/value pairs in the event arguments to aid in determining whether wrapup data may be associated with the call and whether that data is required or optional. CTIOS_INCOMINGOROUTGOING indicates the direction of the call. The defined values are 0 = the direction of the call is unknown 1 = the call is an incoming call and the agent may enter wrapup data 2 = the call is an outgoing call and the agent may not enter wrapup data This value may be obtained using the GetValueInt method on the Agent object. CTIOS_WRAPUPOKENABLED indicates whether wrapup data is required for the recently ended call. A value of false indicates that wrapup data is not required. A value of true indicates that wrapup data is required. (In the Combo Desktop sample, this value is used as a boolean to determines whether the "Ok" button on the wrapup dialog is enabled when no wrapup information has been selected.) This value may be obtained using the GetValueBool method on the Agent object. The wrapup strings that are configured on CTI OS server are sent to the client during the login procedure and are stored under the keyword CTIOS_INCOMINGWRAPUPSTRINGS as an Arguments array within the Agent object. They can be obtained using the GetValueArray method on the Agent object. For information on how to configure wrapup strings on CTI OS server see Chapter 4 of the CTI OS System Manager's Guide.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-39
CTIOS_LOGOUTREASONCODES - This Arguments array provides a list of the logout reason codes configured on CTI OS server. They can be obtained using the GetValueArray method on the Agent object. CTIOS_NOTREADYREASONREQUIRED - This boolean value indicates whether a reason code is required when setting an agent to NotReady state. A value of true indicates that a reason code is required. A value of false indicates that a reason code is not required. This value can be obtained using the GetValueBool method on the Agent object. CTIOS_NOTREADYREASONCODES - This Arguments array provides a list of the not ready reason codes configured on CTI OS server. They can be obtained using the GetValueArray method on the Agent object.
When the Current Call is changed. When the call which is the Current Call receives an event which includes a CTIOS_ENABLEMENTMASK argument. Usually the included enablement mask is changed from what it was set to, but occasionally it is the same. This mask is used to indicate which functions are allowed for this Call in its current state. For example, when a Call receives an OnCallDelivered() event with a Connection State of LCS_ALERTING, its enablement mask is changed to set the Answer bit. When this Call is answered, and it receives the OnCallEstablished() event, the mask no longer sets the Answer bit, but instead enables the Hold, Release, TransferInit and ConferenceInit bits.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-40
Release 8.0(1)
Chapter 4
Caution
Failure to check both the ENABLE_NOTREADY and ENABLE_NOTREADY_WITH_REASON bitmasks may lead to problems properly displaying a NotReady control to the agent. The following example shows this in Java:
void OnButtonEnablementChange(Arguments rArguments) { m_appFrame.LogEvent("OnButtonEnablementChange", rArguments); // Get mask from message Long LMask = rArguments.GetValueUIntObj(CTIOS_ENABLEMENTMASK); if (null==LMask) return; final long bitMask = LMask.longValue(); /* Transfer modification of the GUI objects to the EventDispatchThread or we could have a thread sync issue. currently on the CtiOsSession's event thread.*/ SwingUtilities.invokeLater(new Runnable() { public void run() { /* Enable a button if it's bit is turned on. Disable it if not.*/ m_appFrame.m_btnAnswer.setEnabled (((bitMask & ENABLE_ANSWER) > 0)); m_appFrame.m_btnConference.setEnabled (((bitMask & ENABLE_CONFERENCE_COMPLETE) > 0)); m_appFrame.m_btnCCConference.setEnabled (((bitMask & ENABLE_CONFERENCE_INIT) > 0)); m_appFrame.m_btnHold.setEnabled (((bitMask & ENABLE_HOLD) > 0)); m_appFrame.m_btnLogin.setEnabled (((bitMask & ENABLE_LOGIN)> 0)); m_appFrame.m_btnLogout.setEnabled (((bitMask & (ENABLE_LOGOUT | CtiOs_Enums.ButtonEnablement.ENABLE_LOGOUT_WITH_REASON)) > 0)); m_appFrame.m_btnMakeCall.setEnabled (((bitMask & ENABLE_MAKECALL) > 0)); m_appFrame.m_btnNotReady.setEnabled(((bitMask & (ENABLE_NOTREADY | ENABLE_NOTREADY_WITH_REASON)) > 0)); m_appFrame.m_btnReady.setEnabled(((bitMask & ENABLE_READY) > 0)); m_appFrame.m_btnRelease.setEnabled(((bitMask & ENABLE_RELEASE)> 0)); m_appFrame.m_btnRetrieve.setEnabled (((bitMask & ENABLE_RETRIEVE) > 0)); m_appFrame.m_btnSSTransfer.setEnabled (((bitMask & ENABLE_SINGLE_STEP_TRANSFER)> 0)); m_appFrame.m_btnSSConference.setEnabled (((bitMask & ENABLE_SINGLE_STEP_CONFERENCE) > 0)); m_appFrame.m_btnTransfer.setEnabled (((bitMask & ENABLE_TRANSFER_COMPLETE)> 0)); m_appFrame.m_btnCCTransfer.setEnabled (((bitMask & ENABLE_TRANSFER_INIT) > 0)); } }); } // OnButtonEnablementChange We're
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-41
Making Requests
Telephony requests are made through either an Agent object or a Call object by calling the appropriate API methods listed in Chapters 9 and 10. It is important to ensure that a user not be able to make multiple duplicate requests before the first request has a chance to be sent down to the switch and the appropriate events be sent back to the application, since this will result in either multiple failures or unexpected results.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-42
Release 8.0(1)
Chapter 4
Because many events include agent state data and button enablement data indicating valid agent state transitions, if events are handled out of order agents may not be presented with valid options.
The order of arrival of CIL events is highly dependent upon the ACD that is in use at the customer site. Therefore CIL event order is not guaranteed. Do not write your event handling code in a manner that relies on a particular event order. If an application calls a COM CIL API method from a COM CIL event callback routine it must ensure that the method call is made on the same thread as the CIL event callback. This rule applies to the following methods:
CComSession::SetCurrentCall CComSession::SetAgent
This rule must be followed in order to guarantee that events are fired from the COM CIL to the application in the proper sequence. When handling events in the browser using JavaScript, event processing time should be kept to a minimum since all other JavaScript execution (e.g., handling of button clicks) may be blocked during handling of the event.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-43
Warning
The Call object in the CTI OS CIL is only deleted when the OnCallEnd() event is received. If the OnCallEnd() and OnCallDataUpdate() events are not monitored, Call objects will accumulate and cause a memory leak.
How to Set Up an Agent Application to Receive Agent Statistics on page 4-44 How to Set Up a Monitor-Mode Application to Receive Agent Statistics on page 4-45 Accessing Agent Statistics on page 4-48 Changing Which Agent Statistics are Sent on page 4-49 Agent Statistics Computed by the Sample CTI OS Desktop on page 4-49
Create an instance of the Session class, as described on page 4-20. Subscribe for events for the session, as described on page 4-21.
Note
You must register to receive agent and session events; therefore, in the AddEventListener() method you must use as parameters the field CtiOs_Enums.SubscriberList.eAgentList and CtiOs_Enums.SubscriberList.eSessionList. Or you can use the
CtiOs_Enums.SubscriberList.eAllInOneList.
Set connection parameters, as described on page 4-21. Connect the desktop application to the CTI OS Server, as described on page 4-21. In the OnConnection() event handler, set the Agent for the session, as described on page 4-24. Log in the agent, as described on page 4-30. Enable agents statistics using the EnableAgentStatistics() method.
Note
Though the EnableAgentStatistics() method requires an Arguments parameter, there are no parameters to set for agent statistics; you can therefore send an empty Arguments instance as a parameter.
Caution
The agent must be logged in before you can use the EnableAgentStatistics() method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-44
Release 8.0(1)
Chapter 4
Step 8
To disable agents statistics, use the DisableAgentStatistics() method. The following example demonstrates this task in Java:
/* 1. Create session.*/ CtiOsSession rSession = new CtiOsSession(); /* 2. Add event listener.*/ rSession.AddEventListener(this, CtiOs_Enums.SubscriberList.eAgentList); /* 3. Set Connection values.*/ Arguments rArgs = new Arguments(); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_CTIOSA, CTIOSServerA); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_PORTA, 42408); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_CTIOSB, CTIOSServerB); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_PORTB, 42408); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_HEARTBEAT, 100); /*4. Connect to server.*. returnCode = rSession.Connect(rArgs); public void OnConnection(Arguments rArgs) { /*5. Set agent for the session. */ returnCode = rSession.SetAgent(agent); /* 6. Log in the agent.*/ Arguments rArgs = new Arguments(); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_AGENTID, 275); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_PERIPHERALID, 5002); rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_AGENTINSTRUMENT, 5002) rArgs.SetValue(CtiOs_IKeywordIDs.CTIOS_AGENTPASSWORD, ********); returnCode = agent.Login(rArgs); /* 7. Enable Agent statistics. */ if (returnCode == CIL_OK) { agent.EnableAgentStatistics(new Arguments()); } }
The agent to monitor must be logged in Agent mode before a Monitor-mode application can receive statistics for that agent. CTI OS has a limitation in providing monitor-mode support to build agent desktop call-control applications, as well as in terms of having the ability to rely on button enablement messages. Create an instance of the Session class, as described on page 4-20. Subscribe for events for the session, as described on page 4-21.
Step 1 Step 2
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-45
Note
You must register to receive agent events; therefore, in the AddEventListener() method you must use as a parameter the field CtiOs_Enums.SubscriberList.eAgentList.
Set connection parameters, as described on page 4-21. Connect the desktop application to the CTI OS Server, as described on page 4-21. Set a String variable to store the ID of the agent for which you want statistics.
Note
The application must be aware of the Agent ID and the agents Peripheral ID for any agent to monitor; the application cannot dynamically get these values from CTI OS Server.
Step 6
Create String for the filter using the keyword CTIOS_MESSAGEID as the name, and *;agentID as the value.
Note
b. c. d. Step 7
Create an instance of the Arguments class. Set the value in the filter for the CTIOS_FILTER keyword to the String created in Step a. Use the SetMessageFilter() method in the Session class to set the filter for the session, using the Arguments instance you created in Step b as a parameter.
Wait for any event for the agent, to ensure that the Agent instance exists for the Session.
Caution
The application must wait for the first event for this agent before continuing, to ensure that the Agent instance is part of the current session.
Get the Agent instance from the Session using GetObjectFromObjectID() method. Enable agents statistics using the EnableAgentStatistics() method.
Note
Although the EnableAgentStatistics() method requires an Arguments parameter, there are no parameters to set for agent statistics; you can therefore you an empty Arguments instance as a parameter.
Caution Step 10
The agent must be logged in before you can use the EnableAgentStatistics() method. To disable agents statistics, use the DisableAgentStatistics() method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-46
Release 8.0(1)
Chapter 4
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-47
By implementing the eOnNewAgentStatisticsEvent() (in Java) or the OnAgentStatistics() event (in C++, COM, or VB 6.0) The name of the event to access agent statistics is different in Java when compared to other languages supported by CTI OS.
Caution
The rest of this section describes these methods for accessing agent statistics.
Get the Arguments instance containing statistics from the Agent instance using the GetValueArray() method. Parse the Arguments instance as needed to get specific statistics.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-48
Release 8.0(1)
Chapter 4
AvgTalkTimeToday = (AgentOutCallsTalkTimeToday + HandledCallsTalkTimeToday) / (AgentOutCallsToday + HandledCallsToday) CallsHandledToday = AgentOutCallsToday + HandledCallsToday TimeLoggedInToday = LoggedOnTimeToday TimeTalkingToday = AgentOutCallsTalkTimeToday + HandledCallsTalkTimeToday TimeHoldingToday = AgentOutCallsHeldTimeToday + IncomingCallsHeldTimeToday TimeReadyToday = AvailTimeToday TimeNotReadyToday = NotReadyTimeToday AvgHoldTimeToday = (AgentOutCallsHeldTimeToday + IncomingCallsHeldTimeToday) / (AgentOutCallsToday + HandledCallsToday) AvgHandleTimeToday = (AgentOutCallsTimeToday + HandledCallsTimeToday) / (AgentOutCallsToday + HandledCallsToday) AvgIdleTimeToday = NotReadyTimeToday / (AagentOutCallsToday + HandledCallsToday) PercentUtilitizationToday = (AgentOutCallsTimeToday + HandledCallsTimeToday) / (LoggedOnTimeToday + NotReadyTimeToday)
How to Set Up a Monitor-Mode Application to Receive Skill Group Statistics on page 4-50
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-49
Accessing Skill Group Statistics on page 4-51 Changing Which Skill Group Statistics are Sent on page 4-52 Skill Group Statistics Computed by the Sample CTI OS Desktop on page 4-52
Create an instance of the Session class, as described on page 4-20. Subscribe for events for the session, as described on page 4-21.
Note
You must register to receive session and skill group events; therefore, in the AddEventListener() method you must use as a parameter the field CtiOs_Enums.SubscriberList.eAllInOneList, or you must call the method twice using the fields CtiOs_Enums.SubscriberList.eSessionList and
CtiOs_Enums.SubscriberList.eSkillGroupList
Set connection parameters, as described on page 4-21. Connect the desktop application to the CTI OS Server, as described on page 4-21. Set the message filter as described on page 4-26.
a. b. c. d.
Create String for the filter using the keyword S_FILTERTARGET as the name and the event keyword (enum or number) eOnNewSkillGroupStatisticsEvent (numeric value 536871027) as the value. Create an instance of the Arguments class. Set the value in the filter for the CTIOS_FILTER keyword to the String created in Step a. Use the SetMessageFilter() method in the Session class to set the filter for the session, using the Arguments instance you created in Step b as a parameter. Create an instance of the Arguments class. Set values in the Arguments instance. You must provide the skill group number and the peripheral number for each skill group for which you want to receive statistics. Use the SetValue(keyword, int) method signature. For example: use SetValue(CTIOS_SKILLGROUPNUMBER, sgNumber) where sgNumber is an integer for the skill group for which you want to receive statistics, and SetValue(CTIOS_PERIPHERALID, peripheralNumber) where sgNumber is an integer for the skill group for which you want to receive statistics.
Step 6
Caution
The application must be aware of the Skill Group ID, and the skill groups Peripheral ID, for any skill group to monitor; the application cannot dynamically get these values from CTI OS Server.
c.
Use the Arguments instance as a parameter for the sessions EnableSkillGroupStatistics() method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-50
Release 8.0(1)
Chapter 4
d. Step 7
Repeat steps b and c for each skill group for which you want to receive events.
When the desktop application no longer requires the statistics for a certain skill group, the application can disable those statistics.
a. b.
Create an instance of the Arguments class. Set values in the Arguments instance. You must provide the skill group number and the peripheral number for each skill group for which you want to receive statistics. Use the SetValue(keyword, int) method signature. For example, use SetValue(CTIOS_SKILLGROUPNUMBER, sgNumber) where sgNumber is an integer for the skill group for which you want to receive statistics, and SetValue(CTIOS_PERIPHERALID, sgNumber) where sgNumber is an integer for the skill group for which you want to stop receiving statistics.
c.
Use the Arguments instance as a parameter for the sessions DisableSkillGroupStatistics() method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-51
In Java, eOnNewSkillGroupStatisticsEvent() In C++, COM, or VB, OnSkillGroupStatisticsUpdated() The name of the event through which to access skill group statistics is different in Java when compared to other languages supported by CTI OS.
Caution
AvgCallsQTimeNow = CallsQTimeNow/CallsQNow AvgAgentOutCallsTalkTimeToHalf = AgentOutCallsTalkTimeToHalf/AgentOutCallsToHalf AvgAgentOutCallsTimeToHalf = AgentOutCallsTimeToHalf/AgentOutCallsToHalf AvgAgentOutCallsHeldTimeToHalf = AgentOutCallsHeldTimeToHalf/AgentOutCallsHeldToHalf AvgHandledCallsTalkTimeToHalf = HandledCallsTalkTimeToHalf/HandledCallsToHalf AvgHandledCallsAfterCallTimeToHalf = HandledCallsAfterCallTimeToHalf/HandledCallsToHalf AvgHandledCallsTimeToHalf = HandledCallsTimeToHalf/HandledCallsToHalf AvgIncomingCallsHeldTimeToHalf = IncomingCallsHeldTimeToHalf/IncomingCallsHeldToHalf
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-52
Release 8.0(1)
Chapter 4
AvgInternalCallsRcvdTimeToHalf = InternalCallsRcvdTimeToHalf/InternalCallsRcvdToHalf AvgInternalCallsHeldTimeToHalf = InternalCallsHeldTimeToHalf/InternalCallsHeldToHalf AvgCallsQTimeHalf = CallsQTimeHalf/CallsQHalf AvgAgentOutCallsTalkTimeToday = AgentOutCallsTalkTimeToday/AgentOutCallsToday AvgAgentOutCallsTimeToday = AgentOutCallsTimeToday/AgentOutCallsToday AvgAgentOutCallsHeldTimeToday = AgentOutCallsHeldTimeToday/AgentOutCallsHeldToday AvgHandledCallsTalkTimeToday = HandledCallsTalkTimeToday/HandledCallsToday AvgHandledCallsAfterCallTimeToday = HandledCallsAfterCallTimeToday/HandledCallsToday AvgHandledCallsTimeToday = HandledCallsTimeToday/HandledCallsToday AvgIncomingCallsHeldTimeToday = IncomingCallsHeldTimeToday/IncomingCallsHeldToday AvgInternalCallsRcvdTimeToday = InternalCallsRcvdTimeToday/InternalCallsRcvdToday AvgInternalCallsHeldTimeToday = InternalCallsHeldTimeToday/InternalCallsHeldToday AvgCallsQTimeToday = CallsQTimeToday/CallsQToday
CTI OS based silent monitoring Cisco UnifiedCommunications Manager (Unified CM) based silent monitoring
Refer to the Silent Monitoring section of the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted for additional information on each. For information concerning how to enable silent monitor in your application, refer to Enabling CTI OS Based Silent Monitoring in Your Application, page 4-53 or Enabling Unified CM Based Silent Monitoring in your Application, page 4-57, as applicable.
CTI OS Silent Monitor functionality is only available in the C++ and COM CILs. The silent monitor manager object is responsible for establishing and maintaining the state of a silent monitor session. The first thing a client application should do is to create a silent monitor object instance. The application should then set this object instance as the current manager in the session object. The CIL provides the interface to this functionality. A client application can work in one of two possible modes:
Monitoring mode. The client receives audio from a remote monitored target (device/agent). Monitored mode. The client sends audio to a remote monitoring client.
Note
Silent Monitor will not work until you set the session mode using on of the following function calls: Session.SetAgent() for an Agent mode application Session.SetMessageFilters() for a Monitor mode application
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-53
Monitoring Mode
In this mode, the client receives audio confirmation and session status events for a specific silent monitor session. This mode is intended for use by client applications developed for Supervisor desktop functionality. The StartSMMonitoringMode method on the SilentMonitorManager object selects this mode. Following is a code sample for specifying the mode for the client application.
Dim m_Args As New Arguments Assemble arguments to set the work mode m_Args.AddItem("HeartbeatInterval", 5) m_Args.AddItem("HeartbeatTimeout", 15) 'Address or hostname of the silent monitor service m_Args.AddItem("SMSAddr", "localhost") 'Port on which silent monitor service is listening m_Args.AddItem("SMSListenPort", 42228) 'QoS setting when sending messages to the silent monitor service m_Args.AddItem("SMSTOS", 0) 'Milliseconds between heartbeats m_Args.AddItem("SMSHeartbeats", 5000) 'Number of missed heartbeats before the connection to the 'silent monitor service is considered disconnected m_Args.AddItem("SMSRetries", 3) Port number where audio will be listened for m_Args.AddItem("MediaTerminationPort", 4000) Set the working mode to monitoring m_SMManager.StartSMMonitoringMode(args)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-54
Release 8.0(1)
Chapter 4
Monitored Mode
In this mode, the client sends audio and status reports on silent monitor session and receives requests for start and stop silent monitor session. This mode is intended for client applications developed for Agent desktop functionality. The StartSMMonitoredMode method on the SilentMonitorManager object selects this mode. Following is a code sample for specifying the mode for the client application:
Dim m_Args As New Arguments Assemble arguments to set the work mode m_Args.AddItem("HeartbeatInterval", 5) m_Args.AddItem("HeartbeatTimeout", 15) 'Address or hostname of the silent monitor service m_Args.AddItem("SMSAddr", "localhost") 'Port on which silent monitor service is listening m_Args.AddItem("SMSListenPort", 42228) 'QoS setting when sending messages to the silent monitor service m_Args.AddItem("SMSTOS", 0) 'Milliseconds between heartbeats m_Args.AddItem("SMSHeartbeats", 5000) 'Number of missed heartbeats before the connection to the 'silent monitor service is considered disconnected m_Args.AddItem("SMSRetries", 3) Extension number of the IP Phone to monitor m_Args.AddItem("MonitoringDeviceID", 1234) Set the working mode to monitored m_silentMonitor.StartSMMonitoredMode(args)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-55
Request silent monitor session to start m_SMManager.StartSilentMonitorRequest(m_Args, m_nSMSessionKey) End Sub Private Sub m_session_OnSilentMonitorStatusReportEvent(By Val pIArguments As CTIOSCLIENTLib.IArguments) Dim strAgent As String Dim nMode As Integer nMode pIArguments.GetValueInt(StatusCode) If nMode = eSMStatusMonitorStarted Then strAgent = pIArguments.GetValueString(MonitoredUniqueObjectID) MsgBox Silent Monitor Status,, Started Monitoring Agent: & strAgent Else MsgBox Silent Monitor Status,, Request Failed with code = & nMode End If End Sub Private Sub tmrScreening_Timer() After listening the conversation for 30 sec, drop monitoring session Assemble arguments for stop request Agent to monitor m_Args.AddItem "SMSessionKey", m_nSMSessionKey Request silent monitor session to stop m_SMManager.StopSilentMonitorRequest(m_Args, m_nSMSessionKey) End Sub
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-56
Release 8.0(1)
Chapter 4
Following is a code sample for initiating and ending a silent monitor session:
Stop Silent Monitor ModeRequest m_SMManager.StopSilentMonitorMode Remove silent monitor manager object from session errorcode = m_session_SetCurrentSilentMonitor(Nothing) Destroy silent monitor manager object errorcode = m_session.DestroySilentMonitorManager()
Note
The SupervisoryAction parameter must be set to eSupervisorMonitor. The AgentReference parameter must be set to the unique object ID of the agent to be silent monitored.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-57
The AgentCallReference parameter must be set to the unique object ID of the call to be silent monitored.
When the request is successfully initiated and the silent monitor call is established, the supervisor and agent applications receive the OnSilentMonitorStartedEvent. This event can be used to trigger application specific logic. The Figure 4-5 illustrates the messaging that occurs between the CIL and CTI OS Server after an application initiates a CCM based silent monitor request using Agent.SuperviseCall().
Figure 4-5 CIL-to-CTI OS Server Messaging when CCM Based Silent Monitor Initiated Using Agent.SuperviseCall()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-58
Release 8.0(1)
Chapter 4
Arguments args = new Arguments() ; args.SetValue(Enum_CtiOs.CTIOS_AGENTREFERENCE, monAgentID) ; args.SetValue(Enum_CtiOs.CTIOS_AGENTCALLREFERENCE, monCallID) ; args.SetValue( Enum_CtiOs.CTIOS_SUPERVISORYACTION, SupervisoryAction.eSupervisorMonitor) ; CilError ret = curAgent.SuperviseCall(args) ;
Code Sample for Determining if the Current Agent is the Target of a Silent Monitor Call
Note
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-59
the call that resulted from the initiation of silent monitor (Agent.SuperviseCall(eSupervisorMonitor)). The application receives the SilentMonitorStopRequestedEvent event when the stop silent monitoring request is processed. Figure 4-6 illustrates the message flow.
Figure 4-6 Message Flow when Ending a CCM Based Silent Monitor Request
The silent monitor call can also be released using the Call.Clear() method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-60
Release 8.0(1)
Chapter 4
if ( m_ctiSession == null )
{ } }
return false ;
return m_ctiSession.IsCCMSilentMonitor() ;
DLL Agentselectctl agentstatectl.dll AlternateCtl.dll answerctl.dll arguments.dll badlinectl.dll buttoncontrol.dll ccnsmt.dll chatctl.dll conferencectl.dll cticommondlgs.dll CTIOSAgentStatistics.dll ctioscallappearance.dll ctiosclient.dll ctiossessionresolver.dll
Description AgentSelect ActiveX control Agentstate ActiveX control Alternate ActiveX control Answer/Release ActiveX control Arguments COM class Badline ActiveX control Basic Button ActiveX control Cisco EVVBU Media Termination ActiveX control Chat ActiveX control Conference ActiveX control Common Dialogs utility COM object AgentStatistics ActiveX control CallAppearance ActiveX control COM cil interfaces COM sessionresolver
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-61
Table 4-3
DLL CTIOSSkillGroupStatistics.dll ctiosstatusbar.dll EmergencyAssistCtl.dll gridcontrol.dll holdctl.dll IntlResourceLoader.dll makecallctl.dll ReconnectCtl.dll recordctl.dll SilentMonitorCtl.dll SubclassForm.dll SupervisorOnlyCtl.dll transferctl.dll
Description SkillgroupStatistics ActiveX control StatusBar ActiveX control EmergencyAssist ActiveX control GridControl ActiveX control Hold/Retrieve ActiveX control Internationalization COM object MakeCall ActiveX control Reconnect ActiveX control Record ActiveX control Standalone Silent Monitor ActiveX control COM utility control Supervisor ActiveX control Transfer ActiveX control
ActiveX controls need to be copied and registered using the regsvr32 Windows utility. Some ActiveX controls are dependent on others. For example, all Button type controls (e.g. AgentStatectl.dll) depend on (buttoncontrol.dll) and all Grid type controls (e.g. CtiosCallappearance.dll) depend on Gridcontrol.dll. The following table below means that for a dll listed in the left column to work properly, all dlls listed in the right column (dependencies) need to be available (copied and registered). Table 4-4 lists the dependencies of CTI OS ActiveX controls.
Table 4-4 Dependencies of CTI OS ActiveX Controls
Dependencies ATL80.dll, ctiosclient.dll, arguments.dll, buttoncontrol.dll, MSVCP80.dll, MSVCR80.dll When used in a.NET application must include: AxInterop.AgentSelectCtl.dll Interop.AgentSelectCtl.dll
agentstatectl.dll
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-62
Release 8.0(1)
Chapter 4
Table 4-4
answerctl.dll
When used in a.NET application must include: AxInterop.AnswerCtl.dll Interop.AnswerCtl.dll When used in a.NET application must include: Cisco.CTIOSARGUMENTSLib.dll
arguments.dll
badlinectl.dll
When used in a.NET application must include: AxInterop.BadLineCtl.dll Interop.BadLineCtl.dll When used in a.NET application must include: AxInterop.ButtonControl.dll Interop.ButtonControl.dll
buttoncontrol.dll
ccnsmt.dll chatctl.dll
conferencectl.dll
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-63
Table 4-4
CTIOSAgentStatistics.dll
ctioscallappearance.dll
ctiosclient.dll
If the client application will use silent monitoring in monitoring mode, ccnsmt.dll is also a dependency. If the client application will use silent monitoring in monitored mode, wpcap.dll is also a dependency. ctiossessionresolver.dll ATL80.dll, ctiosclient.dll, arguments.dll, MSVCP80.dll, MSVCR80.dll
Note
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-64
Release 8.0(1)
Chapter 4
Table 4-4
When used in a.NET application must include: AxInterop.CTIOSSkillGroup Statistics.dll Interop.CTIOSSkillGroup Statistics.dll
ctiosstatusbar.dll
EmergencyAssistCtl.dll
When used in a.NET application must include: AxInterop.EmergencyAssistCtl.dll Interop.EmergencyAssistCtl.dll When used in a.NET application must include: AxInterop.GridControl.dll Interop.GridControl.dll
gridcontrol.dll
holdctl.dll
When used in a.NET application must include: AxInterop.HoldCtl.dll Interop.HoldCtl.dll When used in a.NET application must include: Cisco.INTLRESOURCELOADER Lib.dll
IntlResourceLoader.dll
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-65
Table 4-4
ReconnectCtl.dll
recordctl.dll
SilentMonitorCtl.dll
When used in a.NET application must include: AxInterop.SilentMonitorCtl.dll Interop.SilentMonitorCtl.dll When used in a.NET application must include: AxInterop.SubclassForm.dll Interop.SubclassForm.dll
SubclassForm.dll
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-66
Release 8.0(1)
Chapter 4
Table 4-4
transferctl.dll
CTIOSClient.dll When used in a.NET application must include: Cisco.CTIOSCLIENTLib.dll Arguments.dll When used in a.NET application must include: Cisco.CTIOSARGUMENTSLib.dll CtiosSessionresolver.dll (only if used see previous discussion) When used in a.NET application must include: Cisco.CTIOSSESSIONRESOLVERLib.dll ATL80.dll (only if not already available on target system) If the client application will use silent monitoring in monitoring mode, ccnsmt.dll is needed. If the client application will use silent monitoring in monitored mode, wpcap.dll is also a dependency.
The Dll files need to be copied and registered on the target system. Registration is done by using the Windows utility regsvr32.exe providing the dll name (i.e., regsvr32 ctiosclient.dll). ATL80.dll is a Microsoft Dynamic Link Library implementing the Active Template Library used by CTI OS. It will usually be available on most Windows client systems in a windows system directory (e.g. \winnt\syste32 on Windows 2000). Since CTI OS depends on this DLL, it needs to be copied and registered if it is not already available at the target system.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-67
Description .NET CIL Class library, contains the CTI OS object classes .NET Util Class library, contains helper and utility classes used in conjuction with .NET CIL
Both assmebly libraries are strongly signed such that they can be installed in the Global Assembly Cache (GAC) at the application host computer. Or of prefered by the developer they can be at the working directory of the custom client application.
<Install Drive>\Program Files\Cisco Systems\CTIOS Client\CTIOS Toolkit\dotNet CIL\Samples\CTI Toolkit Combo Desktop.NET <Install Drive>\Program Files\Cisco Systems\CTIOS Client\CTIOS Toolkit\dotNet CIL\Samples\CtiOs Data Grid.NET
In the following section, string keys are used as keys to method calls. This is for the sake of readability. A developer writing an application can use either string or integer based keys.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-68
Release 8.0(1)
Chapter 4
General Flow
The general flow of a supervisor application is as follows.
1. 2. 3. 4.
Request the supervisors teams. Start monitoring the supervisors team. Select a team member and start monitoring the selected team members activity. Perform supervisory actions on the currently monitored call.
These steps illustrate the layers of a supervisor application. First, the application gets the team. Once the team is retrieved, the supervisor application can monitor agents. This generates more events/information allowing the supervisor application to monitor agent calls.
Note
Supervisor applications monitoring agent team members cannot receive agent statistics for each team member. To view agent statistics for all agents create a filter (monitor) mode application. Only two filter mode instances are allowed per CTI OS Server.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-69
Events Processed: OnNewAgentTeamMember OnMonitoredAgentStateChange OnMonitoredAgentInfo OnSkillInfo The following diagram illustrates the flow of messages between the application and CTI OS Server when the supervisor application requests its team and then requests to monitor the team. Since logging in a supervisor is the same as logging in an agent, this diagram picks up at the first AgentStateEvent after the agent has logged in.
Figure 4-8 Message Flow between the Application and the CTI OS Server
The requests leading up to and including Agent.StartMonitoringAgent() is in CTIObject.StartMonitoringAgent(). When writing a supervisor application, the developer should call Agent.RequestAgentTeamList() and Agent.StartMonitoringAllAgentTeams(). The developer should call these methods once the supervisor has logged in. In the CTI OS Toolkit Combo Desktop, this is done when processing the eAgentStateEvent in the SupervisorUIManager class ProcessAgentStateEvent() method. SupervisorUIManager checks to see that the current agent is a supervisor. If so and if CTIObject.StartMonitoringTeams() has not already been called, CTIObject.StartMonitoringTeams() is called. CTIObject.StartMonitoringTeams() then calls Agent.RequestAgentTeamList() and Agent.StartMonitoringAllAgentTeams(). If these requests are successful, the desktop will begin receiving OnNewAgentTeamMember, OnMonitoredAgentStateChange, and MonitoredAgentInfoEvent events. The next sections describe how to handle each of these events.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-70
Release 8.0(1)
Chapter 4
OnNewAgentTeamMember
OnNewAgentTeamMember events should be processed as follows. The OnNewAgentTeamMember event is received for two possible reasons. They are as follows.
1. 2.
After the application calls Agent.RequestAgentTeamList(), OnNewAgentTeamMember events are sent for each member of the supervisors team. An agent has been added or removed from the supervisors team.
To address point 2 above, the field ConfigOperation in the payload of the OnNewAgentTeamMember event must be examined. If this flag does not exist or exists and is set to TeamConfigFlag.CONFIG_OPERATION_ADDAGENT (1), the agent should be added to the grid. If the flag exists and is not set to TeamConfigFlag.CONFIG_OPERATION_ADDAGENT, the agent should be removed from the grid. In supervisor applications, use the value in the UniqueObjectID field of the event to uniquely reference/track each agent in the supervisors team. This ID uniquely identifies each agent cached on the CIL.
Since the supervisor is considered part of the team, an OnNewAgentTeamMember event is sent for the supervisor logged into the application. If the developer does not want to include the supervisor in the agent team grid, compare the current agent ID to the ID of the agent carried in the OnNewAgentTeamMember event. If the values are equal, do not add the supervisor to the grid. If the developer does not want to add primary supervisors to the grid, retrieve the Agent object stored in the CIL using the Session.GetObjectFromObjectID() method. When calling Session.GetObjectFromObjectID(), set the value in the UniqueObjectID (Enum_CtiOs.CTIOS_UNIQUEOBJECTID) field of the OnNewAgentTeamMember event as the key (first parameter to this method). This method will return an Agent object. Check the properties of the Agent object for the field AgentFlags (Enum_CtiOs.CTIOS_AGENTFLAGS). If the field exists with the TeamConfigFlag.AGENT_FLAG_PRIMARY_SUPERVISOR (0x01) bit set, the agent is a primary supervisor and should not be added to the grid. It is possible for an agent to be a teams supervisor while not being a member of the team. Some supervisor applications, including the combo desktop, may not want to add this type of supervisor to the agent select grid. This is tricky because supervisors that are not part of the team will generate OnMonitoredAgentStateChange events. The agent select grid normally updates when the OnMonitoredAgentStateChangeevent is received. In order to prevent this, supervisors who are not members of the team that they are supervising will need to be marked as such. This information can be used to avoid updates when an OnMonitoredAgentStateChange event is received for a supervisor that is not part of the team. In order to accomplish this, the application leverages the following.
1. 2.
OnNewAgentTeamMember events will not be received for supervisors that are not part of the team. The CIL keeps a cache of all the agents and supervisors that it knows about. Agents in this cache have properties that can be modified by applications built on top of the CIL.
Knowing this, the application will mark every agent that is included in a OnNewAgentTeamMember event as a member of this supervisor's team. When OnMonitoredAgentStateChange events are received, the agent select grid will only update when the agent that is represented by the event is marked as a
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-71
member of the team. In short, any agent that does not send a OnNewAgentTeamMember event to the CIL will not be displayed in the agent select grid. This is illustrated in the SupervisorUIManager.ProcessMonitoredAgentStateChange() method.
OnMonitoredAgentStateChange Events
OnMonitoredAgentStateChange events are sent when an agent in the supervisors team changes state. Supervisor applications, like the CTI OS Toolkit Combo Desktop use this event to update structures that store the supervisors team (the agent team grid). This event is processed similar to OnNewAgentTeamMember. However, there is one subtle difference. Instead of using the Arguments object carried with the event, the application should use the arguments associated with the agent object cached by the CIL. This is done to correctly handle skill group membership changes related to dynamic reskilling. The CIL contains logic that processes the OnMonitoredAgentStateChange and determines whether or not an agent has been added or removed from a skill group. The changes in the agents skill group membership are reflected in the agent objects properties.
OnMonitoredAgentInfo Event
This event can be used to populate the following agent information.
Time in State
If your application needs to track an agents time in state, it can be done as follows. The algorithm is contained in AgentSelectGridHelper.cs. The first part of the algorithm resides in the AgentData.UpdateData() method. This method decides if the agents state duration is known or unknown. An agents state duration is unknown if the agent has just been added to the grid or if the agents state has not changed since being added to the grid. If a state change is detected after the agent has been added to the grid, the time of the state change is marked. Second, there is a timer callback that the AgentSelectGridHelper class starts when the grid is initialized. The timer callback fires every ten seconds. When the callback fires, the method AgentSelectGridHelper.m_durationTimer_Tick() cycles through all of the rows in the grid. Each row whos Time in State column is not unknown, has its value set to the time the agent changed state minus the current time.
OnSkillInfo Event
OnSkillInfo events are sent to the CIL when skillgroup statistics are enabled using the Agent.EnableSkillGroupStatistics() method. These events are used to populate the fields in the Skill Name column of the team grid. OnSkillInfo events carry the ID of a skill group and its corresponding name. The AgentSelectGridHelper processes this event by storing a mapping of skill group IDs to skill group names. After the map is updated, each field in the Skill Name column is updated to reflect the new skill name.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-72
Release 8.0(1)
Chapter 4
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-73
Column Name
Agent State
OnNewAgentTeamMember OnMonitoredAgentStateChange
Enum_CtiOs.CTIOS_STATE
Time in State OnMonitoredAgentStateChange See the section Time in State, page 4-72. Skill Group Skill Name OnMonitoredAgentStateChange Enum_CtiOs.CTIOS_NUMSKILL GROUPS OnSkillInfoEvent See the section OnSkillInfo Event, page 4-72. Enum_CtiOs.CTIOS_AGENT AVAILABILITYSTATUS
Note
The Skill Group column lists the field from the Arguments object as CTIOS_NUMSKILLGROUPS. This field tells the developer how many skill groups the agent belongs to. To obtain information about each of the agents skill groups the developer should construct the following loop to get information about each of the agents skill groups (code taken from the sample source file CtiOsDataGrid\AgentSelectGridHelper.cs).
// Check to see if the event carries an array of skillgroups // (OnNewAgentTeamMember) // int numGroups ; if ( args.GetValueInt(Enum_CtiOs.CTIOS_NUMSKILLGROUPS, out numGroups) ) { CtiOsDataGrid.Trace( Logger.TRACE_MASK_METHOD_AVG_LOGIC, methodName, "Found skillgroup numbers") ; m_skillGroupNumbers.Clear() ; for ( int j = 1 ; j <= numGroups ; j++ ) { CtiOsDataGrid.Trace(
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-74
Release 8.0(1)
Chapter 4
Logger.TRACE_MASK_METHOD_AVG_LOGIC, methodName, string.Format("Looking for skillgroup at position {0}", j)) ; string unknownStr = string.Format( AgentSelectGridHelper.STRING_UNKNOWN_SG_FORMAT, j) ; // Keys for individual skillgroups are formatted as SkillGroup[{index}] // string sgKey = string.Format( AgentSelectGridHelper.STRING_SKILLGROUP_FORMAT, j) ; // Each element of the array is an argument containing // skillgroup information. // Arguments sgInfo ; if ( !args.GetValueArray(sgKey, out sgInfo) ) { CtiOsDataGrid.Trace( Logger.TRACE_MASK_WARNING, methodName, string.Format("No skillgroup info at position {0}", j)) ; m_skillGroupNumbers.Add(unknownStr) ; } else { string sgStr ; if ( sgInfo.GetValueString( Enum_CtiOs.CTIOS_SKILLGROUPNUMBER, out sgStr) ) { CtiOsDataGrid.Trace( Logger.TRACE_MASK_METHOD_AVG_LOGIC, methodName, string.Format( "Found skillgroup number {0} at poisition {1}", sgStr, j)) ; m_skillGroupNumbers.Add(sgStr) ; } else { CtiOsDataGrid.Trace( Logger.TRACE_MASK_WARNING, methodName, string.Format("No skillgroup number at poisition {0}", j)) ; m_skillGroupNumbers.Add(unknownStr) ; } } } }
Monitoring Agents
This section discusses step 3 in the flow of a supervisor application. The methods and events listed below are used to monitor an agent. Methods Called: Agent.StartMonitoringAgent(Arguments args)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-75
Events Processed: OnSupervisorButtonChange OnStopMonitoringAgent OnMonitoredAgentStateChange OnMonitoredCallBegin OnMonitoredCallCleared OnMonitoredCallConferenced OnMonitoredCallConnectionCleared OnMonitoredCallDataUpdate OnMonitoredCallDelivered OnMonitoredCallDequeued OnMonitoredCallDiverted OnMonitoredCallEstablished OnMonitoredCallFailed OnMonitoredCallHeld OnMonitoredCallOriginated OnMonitoredCallQueued OnMonitoredCallReachedNetwork OnMonitoredCallRetrieved OnMonitoredCallServiceInitiated OnMonitoredCallTransferred OnMonitoredCallTranslationRoute OnMonitoredCallEnd Once a supervisor application has been informed of an agent team member via the OnNewAgentTeamMember event, the supervisor can monitor the agent via the Agent.StartMonitoringAgent() method. The following sequence diagram illustrates the call to StartMonitoringAgent() and the events sent upon successful completion of the call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-76
Release 8.0(1)
Chapter 4
Figure 4-9
The requests leading up to and including Agent.StartMonitoringAgent() is in the CTIObject.StartMonitoringAgent() method. When calling the Agent.StopMonitoringAgent(), the agent object associated with the supervisor (the current agent) is the target of the method. The parameter is an Arguments object set as follows.
Table 4-6 Agent.StopMonitoring Agent Parameter
Key AgentReference
When calling Agent.StartMonitoringAgent(), the agent object associated with the supervisor (the current agent) is the target of the method. The parameter is an Arguments object set as follows.
Table 4-7 Agent.Start MonitoringAgent Parameter
Key AgentReference
OnSupervisorButtonChange
This event is delivered to define the operations that may be executed successfully by the supervisor. The operations included in this event are as follows.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-77
Logout an agent on the team Make an agent on the team ready Enable silent monitor Enable barge-in on agent Enable intercept call
The application uses the bitmask carried by this event, to enable or disable the functionality listed above. The ProcessSupervisorButtonChange() method in SupervisorUIManager illustrates how to process this event.
Key SupervisorID
Value The ID of the supervisor who is making the agent ready. This value is the value of the AgentID key associated with the current agent (the current agent is the agent passed into the call to Session.SetAgent() when first logging in the agent). The state to which to set the agent. In this case, the state is ready (integer with value 3).
AgentState
To logout an agent, the desktop calls the method Agent.SetAgentState(). When calling this method, the agent object representing the monitored agent is used as the target of the method. The parameter is an Arguments object populated with the following key/value pairs
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-78
Release 8.0(1)
Chapter 4
Table 4-9
Key SupervisorID
Value The ID of the supervisor who is making the agent ready. This value is the value of the AgentID key associated with the current agent (the current agent is the agent passed into the call to Session.SetAgent() when first logging in the agent). The state to which to set the agent. In this case, the state is ready (integer with value 3). The value associated with this key is 999. The value 999 indicates to the rest of Unified CC that the agent was logged out by their supervisor.
AgentState
EventReasonCode
An agent involved in a call will not be logged out until the agent is disconnected from the call. Both the out-of-the-box desktop and the combo desktop warn the supervisor of this behavior. This can be done by checking the state of the currently monitored agent. If the agents state is talking, hold, or reserved the monitored agent is involved in one or more calls and will not be logged out until the agent has been disconnected from all calls. This is illustrated in SupervisorUIManager.m_btnMonLogoutAgentClick(). Successfully calling Agent.SetAgentState() should be followed by one or more SupervisorButtonChange and MonitoredAgentEvents reflecting the change in the monitored agents state.
Monitoring Calls
This section discusses step 4 in the flow of a supervisor application. The methods and events listed below are used to monitor a call. Methods Called Agent.StartMonitoringCall() Agent.SuperviseCall() Events Processed Events Processed OnSupervisorButtonChange AgentStateEvents CallEvents MonitoredCallEvents
MonitoredCallEvents
As stated in the Monitoring Agents section, calling Agent.StartMonitoringAgent() will trigger MonitoredCallEvents for the agent specified in Agent.StartMonitoringAgent(). The MonitoredCallEvents received by the supervisor desktop, inform the desktop of the state of the monitored agents calls. The combo desktop uses these events to populate and update the monitored calls grid. Please see the SupervisorUIManager and CallAppearanceHelper classes for further details.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-79
To monitor a given call, the supervisor calls the Agent.StartMonitoringCall() method. The target of the call is the current agent (Agent object representing the supervisor). StartMonitoringCall() takes an Arguments object with the CallReference key set to the UniqueObjectID of the call to be monitored. This is illustrated in the CTIObject.StartMonitoringCall()method.
Once Agent.StartMonitoringCall() is called for a specific call, the application will begin receiving SupervisorButtonChange events. When a call is being monitored, the SupervisorButtonChange event may carry a bitmask indicating that the call can be barged into. To barge-in on a call, the application calls the Agent.SuperviseCall() method. The target of the SuperviseCall() method is the current agent (the agent object that represents the supervisor). The parameter to the method is an Arguments object with the following key/value pairs.
Table 4-10 Agent.StartMonitoringCall Parameter
Value The UniqueObjectID of the currently monitored agent The UniqueObjectID of the currently monitored call The value 3. For the .NET CIL, this is SupervisoryAction.eSupervisorBargeIn
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-80
Release 8.0(1)
Chapter 4
Upon successfully calling this method, the application will receive many events since this method not only changes the state of the monitored call, but also delivers a call to the supervisor which changes the supervisors state. When a OnButtonEnablementChange event is received, be sure to check the monitored flag. If the flag does not exist or exists and is set to false, apply the event to any application specific logic or UI to control the supervisors state. This is illustrated in SoftphoneForm.OnEvent(). Notice that this method discards any event that is monitored. One or more OnSupervisorButtonChange events will be received by the application. These events notify the application that it is now possible to intercept the agents call. The trickiest piece of handling the events that result from a successful call to Agent.SuperviseCall() is handing the resulting Call and MonitoredCall events. All CallEvents should be applied to whatever application specific object and/or UI element is managing calls directly connected to the supervisors device (SoftphoneForm in the combo desktop). All MonitoredCallEvents should be applied to whatever application specific object and/or UI element is managing calls connected to the supervisors team members/monitored agents (SupervisorUIManager in the combo desktop). Calling SuperviseCall() with the SupervisoryAction set to barge-in, essentially initiates a consultative conference between the caller, agent, and supervisor. This means that whatever UI elements and/or objects that handle monitored calls has to be able to handle the set of events that setup a consultative conference. In general, this is not too difficult. The consultative call is joined to the conference call by sending a MonitoredCallEndEvent to end the consultative call. Then a MonitoredCallDataUpdateEvent is used to change the ID of the call to the conference. The MonitoredCallEndEvent will take care of cleaning up the consultative call. The trick is to check OnMonitoredCallDataUpdateEvents for the OldUniqueObjectID key. If this key exists, it means that the UniqueObjectID of a call has changed. OldUniqueObjectID stores the old/obsolete ID of the call. UniqueObjectID stores the new ID of the call. This new ID will be carried in all future events for the call. Application logic must be updated based on this information or new events for the call will not be tracked correctly.
Intercepting Calls
Once a supervisor has barged into an agents call, the supervisor can intercept the call. This can be done by calling the Agent.SuperviseCall() method. The target of the SuperviseCall() method is the current agent (the agent object that represents the supervisor). The parameter to the method is an Arguments object with the following key/value pairs.
Table 4-11 Agent.SuperviseCall Parameter
Value The UniqueObjectID of the currently monitored agent The UniqueObjectID of the currently monitored call The value 4. For the .NET CIL, this is SupervisoryAction.eSupervisorIntercept
Calling this method will remove the agent from the call. This means that OnMonitoredEndCall events will be received for the agent. Also, OnSupervisorButtonChange events will be sent to reflect the current state of the monitored agent.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-81
.NET Samples
Note
Of all the samples provided in the CTI OS toolkit, the .NET sample applications provide the most complete set of coding examples. Therefore the .NET samples should be used as the reference implementation for custom CTI OS application development regardless of which language you plan to use in your custom development. The Java and Win32 samples should be used asa secondary references to highlight syntactic differences as well as minor implementation differences between the CILs.
Agent mode connection to CTI OS Agent desktop functionality (call control, agent state control, statistics) Supervisor desktop functionality (team state monitoring, barge-in, intercept) Outbound option functionality Button enablement Failover
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-82
Release 8.0(1)
Chapter 4
The user should now be able to edit the file to fill in the appropriate values. Following is an example configuration file.
<?xml version="1.0" encoding="utf-8"?> <configuration> <configSections> <section name="JoeUser" type="System.Configuration.SingleTagSectionHandler" /> <appSettings> <add key="LogFilePath" value=".\CtiOsClientLog" /> <add key="CtiOsA" value="CtiOsServerA" /> <add key="CtiOsB" value="CtiOsServerB" /> <add key="PortA" value="42028" /> <add key="PortB" value="42028" /> </appSettings> </configSections> <JoeUser TraceMask="0xf" AgentID="1003" AgentInstrument="3009" PeripheralID="5000" DialedNumbers="3011,3010" /> </configuration>
The configuration file is composed of the following elements. These elements are as follows. configuration This elements contains the configuration for the desktop. appSettings This section defines configuration settings that are shared by every Windows user that logs into the system. A system administrator needs to configure these values for the appropriate CTI OS Servers and ports. Each of this elements sub-elements defines key value pairs used to configure the desktop. LogFilePath The value for this key is the path to the log file as well as the prefix of the name of the log file. The name of the Windows user, the log files creation time, and the extension .log will be appended to form the complete name of the log file. For example, if the desktop was run at 11:58 AM on May 23, 2005, the log file would have the name CtiOsClientLog.JoeUser.050523.11.58.04.5032.log. CtiOsA The name or IP address of one of the CTI OS Server peers. CtiOsB The name or IP address of the other CTI OS Server peer. PortA The port used to connect to the CTI OS Server specified by the CtiOsA key. PortB The port used to connect to the CTI OS Server specified by the CtiOsB key. configSections This section is used to define Windows user specific sections of the configuration file. These sections are defined using the section element. You will notice in the sample configuration file that there is a section element under configSections corresponding to the element tagged with the Windows user name JoeUser under the configuration element. This section should not need to be manually modified. As different Windows users use the desktop, this section will be modified to include section elements for each of the users. The rest of the configuration file is composed of elements that define configuration specific to different Windows users. For each section element in the configSections element, there is a corresponding element under the configuration element. These elements are used to store information specific to given users such as trace mask, agent login ID, dialed numbers, etc. Most of the attributes in this element should not need to be modified. The one attribute that may need modification is the TraceMask attribute. This attribute is used to control the amount of information logged to the log file.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
4-83
Monitor mode connection to CTI OS When to enable connect and disconnect buttons for a monitor mode application How to handle failover in monitor mode. Filtering for agent events
Monitor mode connection to CTI OS Connect and Disconnect error handling Filtering for call events Filtering for silent monitor call events
Note
For CCM based silent monitoring only. Filtering for silent monitor calls is only applicable to CCM based silent monitoring.
Win32 Samples
CTI Toolkit AgentDesktop - This sample illustrates how to use the Win32 COM CIL's ActiveX controls to create an agent desktop using VisualBasic .NET. CTI Toolkit IPCC SupervisorDesktop - This sample illustrates how to use the Win32 COM CIL's ActiveX controls to create a supervisor desktop using VisualBasic .NET. CTI Toolkit Outbound Desktop - This sample illustrates how to use the Win32 COM CIL's ActiveX controls to create an outbound option desktop using VisualBasic .NET. CTI Toolkit C++Phone - This sample illustrates how to use the C++ CIL to create a rudimentary agent mode application.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
4-84
Release 8.0(1)
CHAPTER
Description Provides UI to for login, logout, ready, not ready and wrapup requests, also enables the use to specify reason codes for logout and Not_Ready (if supported and configured). Provides UI to send text messages to a supervisor or (if allowed) to other agents. Provides UI to place Emergency and Supervisor Assist calls. These calls allow agents to conveniently contact a supervisor if they need help. The corresponding Unified ICM scripts must be configured in order for this control to work. Provides UI for alternate requests. If an agent has Call A active and Call B on hold, alternate will put call A on hold and make Call B active. Useful during consult calls.
ChatCtl EmergencyAssistCtl
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-1
Chapter 5
Table 5-1
Description Provides UI to answer a call. Only a call with state LCS_Alerting (Ringing) can be answered. Provides a UI to report a Bad Line, e.g. bad voice quality or equipment problems. A grid control displaying call information, including call status and context data. Provides UI to place a conference call in single step or consultative mode. Provides UI to put calls on hold and retrieve them. Provides UI to enter a telephone number and place a make call request. Provides a UI for reconnect requests. If an agent has Call A active and Call B on hold, reconnect will hang up call A and make Call B active. Useful during consult calls to return to the original call. Visually displays information about the logged on agent (id, instrument, extension, current state). Provides UI for Call Recording requests (start/stop recording), the requests will be forwarded to CTI Server, so they can be handled by a configured call recording service. Provides UI to transfer a call in single step or consultative mode. A grid control displaying real-time agent statistics. Columns are configurable at CTI OS server (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted). A grid control displaying real time skill group statistics. Columns are configurable at CTI OS server (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted). Supervisor specific; displays all agent team members of a supervisor (configured by Unified ICM), including agent name, agentid, agentstate, timeinstate and skillgroups.
StatusBarCtl RecordCtl
SkillgroupStatisticsCtl
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-2
Release 8.0(1)
Chapter 5
Table 5-1
Control SupervisorOnlyCtl
Description Provides UI for Supervisor functions including Barge-In, Intercept, logout monitored agent and make monitored agent ready. Standalone control that provides the capability of creating a monitoring application that connects to CTI OS, but does not need to login as a supervisor.
SilentMonitorCtl.dll
Property Pages
While most settings in CTI OS are downloaded from CTI OS server to the client, ActiveX controls additionally offer property pages. The activation of the property pages is container dependent (e.g. in Visual Basic, you can right-click on an ActiveX control and select Properties from the pop-up menu). In CTI OS the most common properties selectable via property pages are ButtonType (e.g., The Holdctl can be a hold or retrieve button), as well as fonts and colors.
Statusbarcontrol ChatCtl Utility controls (such as CtiCommonDlgs and SubClassFormCtl) The Utility controls, such as CtiCommonDlgs and SubClassFormCtl (used by the CTI OS Agent and Supervisor desktops), are for Internal Use Only.
Note
As such they share common principles. The following table describes button enablement scenarios only for call control, agent state control and supervisor assist in Unified CCE.
Note
The video control button (under the tools group) is not included in standard Unified CCE desktops. This button is related to controls exercised on the supervisor desktop.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-3
Table 5-2
Scenarios Agent is not logged in to a desktop Agent in the Not ready state
Buttons enabled and Description Only the Log-in button is enabled. The agent is in the Not Ready state. The following buttons are enabled: Ready, Supervisor Assist, Emergency Assist, Statistics and Chat Control and Make Call Control.
Note
The Make Call Control button allows you to dial out only in the Not Ready (NR) state.
The agent is in the Ready state. The following buttons are enabled: Not Ready, Supervisor Assist, Emergency Assist, Statistics and Chat Control and Make call Control.
Note
The Make Call Control button allows you to dial out only in the Not Ready state.
Agent gets an incoming call which is alerted on the agent desktop Agent answers the call
The agent is in the Reserved state. The following buttons are enabled: Statistics, Chat Control and Bad Line Ctrl. The agents is in the Talking state. The following buttons are enabled: Hold, Release, Supervisor Assist, Emergency Assist, Conference, transfer, Statistics, Chat ctl and Badline control.
Note
The Ready, Not Ready and wrap-up buttons are enabled based on the agent desktop settings configured in the Configuration Manager.
The agent is in the On hold state. The following buttons are enabled: Retrieve, Release, Supervisor Assist, Emergency Assist, Statistics, Chat ctl and Badline control.
The agents is in the Talking state. The following buttons are enabled: Hold, Release, Supervisor Assist, Emergency Assist, Conference, transfer, Statistics, Chat ctl and Badline control.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-4
Release 8.0(1)
Chapter 5
Table 5-2
Buttons enabled and Description The agent continues to be in the same state he was in, before talking the call.
Note
If Wrap-up was not configured, then the Ready and Not Ready buttons are enabled. Agent initiates a conference The agent is in the Talking state. The following buttons are enabled: Statistics, Chat ctl, Bad Line Ctrl and Reconnect. Consult conference call is answered Conference Initiator Desktop The agent is in the Talking state. The following buttons are enabled: Statistics, Chat ctl, BadLineCtrl, Alternate, Reconnect and Conference complete.
Note
The Ready, NR and Wrap-up buttons are enabled based on the agent desktop setting.
Conference Receiver Desktop The agent is in the Talking state. The following buttons are enabled: Hold, Release, Supervisor Assist, Emergency Assist, Conference, transfer, Statistics, Chat ctl and Badline control. Complete conference is done for the conference initiator The agent continues to be in the same state he was in, before talking the call.
Note
If Wrap-up was not configured, then the Ready and Not Ready buttons are enabled. Agent initiates a consult transfer The agent is in the Talking state. The following buttons enabled: Statistics, Chat ctl, BadLine Ctrl and Reconnect.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-5
Table 5-2
Buttons enabled and Description Consult transfer Initiator Desktop The agent is in the Talking state. The following buttons are enabled: Statistics, Chat ctl, Bad Line Ctrl, Alternate, Reconnect, Conference complete
Note
The Ready, NR and Wrap-up buttons are enabled based on the agent desktop setting.
Consult transfer Receiver Desktop The agents is in the Talking state. The following buttons are enabled: Hold, Release, Supervisor Assist, Emergency Assist, Conference, transfer, Statistics, Chat ctl and Badline control.
Note
The Ready, Not Ready and wrap-up buttons are enabled based on the agent desktop settings configured in the Configuration Manager.
The agent continues to be in the same state he was in, before talking the call.
Note
If Wrap-up was not configured, then the Ready and Not Ready buttons are enabled. Agent does a Single Step Transfer The agent continues to be in the same state he was in, before talking the call.
Note
If Wrap-up was not configured, then the Ready and Not Ready buttons are enabled. After Initiating an Consult Transfer or a Consult Conference, till the Transfer/Conference is complete, there are two calls on the agent desktop of the initiator of Transfer and Conference.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-6
Release 8.0(1)
Chapter 5
Table 5-2
Scenarios The held call is selected for Consult Conference when the call rings on the conference agent desktop
Buttons enabled and Description The following buttons ar enabled: Statists, Chat ctl, BadLine Ctrl and Reconnect.
Note
The Ready, NR and Wrap-up buttons are enabled based on the agent desktop setting.
The held call is selected for Consult Transfer when the call rings on the conference agent desktop
The following buttons are enabled: Statistics, Chat ctl, BadLine Ctrl and Reconnect.
Note
The Ready, NR and Wrap-up buttons are enabled based on the agent desktop setting.
The button enablement on IPCC desktops based on the agent desk settings depends on:
The button enablement described are common, the only difference being they are enabled upon an incoming call or an outgoing call based on the settings. Agent desk setting configuration is set to Not Allowed The agent is not allowed to go to the Wrap-up state. No state transition buttons are enabled as long as the call is on the agent desktop. Buttons Enabled - Default behavior. Agent desk setting configuration is set to Optional Agent desk setting configuration is set to Required/Required with data The Ready, NR and Wrap-up buttons are enabled once a call is answered and the agent is in the Talking state. No state change buttons are enabled when the agent is talking on a call. After the call, the agent state changes to Wrap-up. In the Wrap-up dialog box, if you select Apply, the Ready and NR buttons are enabled and the agents state changes based on the selection (button click) done by the agent.
Note
Supervisor assist and Emergency assist are not present on a supervisor desktop. The rest of the button enablement are only applicable for different scenarios described above.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-7
These are basic call scenarios and are to be used for reference, only. Customized desktops can have different enablement behaviors.
Button Controls
Button Controls include the AgentStateCtl, AlternateCtl, AnswerCtl, BadLineCtl, ConferenceCtl, EmergencyAssistCtl, HoldCtl, MakeCallCtl, ReconnectCtl, SupervisorOnlyCtl, RecordCtl, and TransferCtl. They provide an UI to perform a certain CTI task (like logging in or answering a call). All of the Button Controls are based on the CTI OS ButtonCtl and share the same characteristics. All CTI OS buttons will enable and disable themselves automatically based on the current state of the system. For example, if an agent is not logged in, the only button available to click is the Login Button (see AgentStateCtl), or if a call has not been answered and is selected in the CallAppearanceCtl, the Answer Button will be enabled (see AnswerCtl and CallAppearanceCtl). All buttons can be configured via their property pages to show custom text captions, custom icons and custom tooltip captions.
Grid Controls
Grid controls include the AgentSelectCtl, CallAppearanceCtl, AgentStatisticsCtl and SkillGroupStatisticsCtl. The Grid Controls are used to display data, select calls (see CallAppearanceCtl) or Agents (AgentSelectCtl), or in some cases enable you to enter data (e.g. Callvariables in the CallAppearanceCtl). The following grid properties can be configured by CTI OS server (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted):
AgentStateCtl
The agentstate control is based on the CTI OS button control and can be one of several button types. To select the button type, bring up the property page (container dependent, for example right click in VB) and select the desired agentstate functionality from the following:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-8
Release 8.0(1)
Chapter 5
Login Button. Click the login button (Figure 5-2) to allow the agent to select a connection profile (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted), agent id and instrument or other switch specific fields.
Login Button
Figure 5-1
Figure 5-2
Login Dialog
The fields displayed can be configured. The dialog shows a login dialog configured for Unified CCE. An agent logging in can select a connection profile for the Connect To: drop down box, enter, agent id, password and instrument and click on OK to send a Login request.
Logout Button. Click the logout button to log out the currently logged in agent. For some switches, including Unified CCE, the agent needs to be in the not ready state in order for this button to be enabled. If Reason Codes are supported on the switch and configured on Unified ICM, a reason code dialog will pop up as shown in Figure 5-4.
Logout Button
Figure 5-3
Figure 5-4
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-9
This dialog lets you select a reason code to be sent along with the logout request. Reason codes can be configured at CTI OS server
Ready Button. Click the ready button to put the agent in ready state (ready to accept calls).
Not Ready Button. Click the not ready button to put the agent in not ready state (Unified ICM will not route calls to an agent in the not ready state). If Reason Codes are supported on the switch and configured on Unified ICM, a reason code dialog will pop up as shown in Figure 5-5.
Figure 5-5
This dialog lets you select a reason code to be sent along with the not_ready request. Reason codes can be configured at the CTI OS Server.
Work Ready Button. Click this button to put the agent in the work ready or wrapup state. The behavior of this button depends on the wrapup mode support of the switch. On Unified CCE, the behavior is controlled by Unified ICM AgentDeskSettings (see the Administration Guide for Cisco Unified Contact Center Enterprise and Hosted Edition).
Work Not Ready Button. Click this button to put the agent in the work not ready or wrapup state. The behavior of this button depends on the wrapup mode support of the switch. On Unified CCE, the behavior is controlled by Unified ICM AgentDeskSettings (see the Administration Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-10
Release 8.0(1)
Chapter 5
Related Methods
The following methods may be of interest to users of the agent state ActiveX control.
ReasonCodeState
This version of the ReasonCodeState method returns the enumReasonCodeState value.
Syntax
COM:HRESULT ReasonCodeState([out, retval] enumReasonCodeState *pVal) VB: ReasonCodeState()As AgentStateCtlLib.enumReasonCodeState .NET:AgentStateCtlLib.enumReasonCodeState ReasonCodeState()
Parameters
None
Return Value
Return value is enumReasonCodeState (This will return an Integer type)
ReasonCodeState
This version of the ReasonCodeState method sets the enumReasonCodeState value.
Syntax
COM:HRESULT ReasonCodeState([in] enumReasonCodeState newVal) VB: ReasonCodeState = AgentStateCtlLib.enumReasonCodeState .NET:ReasonCodeState = AgentStateCtlLib.enumReasonCodeState
Parameters
None
Return Value
None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-11
Related Events
The agent state control handles the following events.
OnAgentStateChanged
The OnAgentStateChanged message is generated when an agent state change event is fired. Syntax
COM:HRESULT OnAgentStateChanged([in] LPDISPATCH vEventParam) VB: .NET:
Parameters
vEventParam Event fired to change the Agent state.
Return Value
None.
OnCtlEnabledChanged
The OnCtlEnabledChanged message is generated when control enabled is changed.
Syntax
COM: VB: .NET: HRESULT OnCtlEnabledChanged(BOOL enabled)
Parameters
enabled This is a control enabled changed value and returns a Boolean value.
OnEnableControlReceived
The OnEnableControlReceived message is generated when button enablement is changed
Syntax
COM: void OnEnableControlReceived(BOOL enabled)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-12
Release 8.0(1)
Chapter 5
VB: .NET:
Parameters
enabled This is a control enabled changed value and returns a Boolean value. Following are the Button enablement masks return by OnEnableControlReceived method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-13
AgentSelectCtl
Table 5-3 OnEnableControlReceived Button Enablement Masks
nButtonMask ENABLE_LOGIN ENABLE_LOGIN ENABLE_LOGOUT or ENABLE_LOGOUT_WITH_ REASON ENABLE_READY ENABLE_NOTREADY or ENABLE_NOTREADY_WITH_REASON ENABLE_WORKREADY ENABLE_WORKNOTREADY
The agent select control is used for supervising agents and becomes active if the currently logged in agent is a supervisor. When a supervisor has logged on, this grid based control will display all agent team members of a supervisor (configured by Unified ICM), including agent name, AgentID, AgentState, TimeInState and SkillGroups. The TimeInState column will be reset in real-time as the agents change state. If an agent remains in a state for more than 10 minutes, the TimeInState figure will be displayed in red.
Figure 5-6 Agent Select Grid Populated with Sample Data
OnNewTeamMember. Informs the supervisor of a new team member or a team member change. This will cause a row in the agentselect grid to be updated (add/remove agent). OnMonitoredAgentStateChange. Informs the supervisor of an agent state change. The new agentstate will be displayed in the State column and the TimeInState Column will be set to zero. OnAgentInfo Event.
A supervisor can select a currently monitored agent by clicking on an agent displayed in the grid. This causes a set monitored agent method call on the agent object. Any supervisory action (for example logout monitored agent see SupervisorOnlyCtl) will be performed on the currently monitored agent.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-14
Release 8.0(1)
Chapter 5
Methods
Table 5-4 Available Methods for AgentSelectCtl
Method get_UserDefinedCell GetCellText GetColumnInfo GetSelectedRow SelectRow set_ColumnHeader set_ColumnType set_ColumnWidth set_ UserDefinedCell SetColumnInfo
Description If the column type is user defined, gets the text from the requested cell. Gets the text from the requested cell in requested row. Gets the information about the requested column. Gets the selected row index. Sets the requested row as selected. Sets the column header of requested column with given text. Sets the column type of requested column with given value. Sets the column width of requested column with given value. Sets the given text into the requested cell. Sets the given information for the requested column.
get_UserDefinedCell
If the column type is user defined, gets the text from the requested cell. Syntax COM: HRESULT UserDefinedCell(short nIndex, [out, retval] BSTR *pVal) VB: get_UserDefinedCell(nIndex As Short) As String .NET: System.String get_UserDefinedCell(System.Int16 nIndex) Parameters nIndex This is a cell index number and an input parameter as type Short. Return Value Return type is String. If the requested cell is not user defined type, it throws an Invalid Argument error.
GetCellText
Gets the text from the requested cell in requested row. Syntax COM: HRESULT GetCellText([in] int nRow, [in] int nCol, [out,retval] BSTR* bstrContent) VB: GetCellText(nRow As Integer, nCol As Integer) As String .NET: System.String GetCellText(System.Int16 nRow, System.Int16 nCol) Parameters nRow This is a row index number and an input parameter as type Integer. nCol
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-15
This is a column index number and an input parameter as type Integer. Return Value Return type is String.
GetColumnInfo
Gets the information about the requested column. Syntax COM: HRESULT GetColumnInfo([in] short nCol, [out] long *plColType, [out] int *iColWidth, [out] int *iColTextAlign, [out] BSTR *bstrColTitle) VB: GetColumnInfo(nCol As Short, ByRef plcoltype As Integer, ByRef icolwidth As Integer, ByRef bstrcoltitle As String)
.NET: GetColumnInfo(System.Int16 nCol, System.Int32 plcoltype, System.Int32 icolwidth, System.String bstrcoltitle) Parameters nCol This is a column index number and an input parameter as type Short. plcoltype This is a column type value and an output parameter as type Integer. icolwidth This is a column width value and an output parameter as Integer. bstrcoltitle This is a column title text and an output parameter as type String. Return Value None.
GetSelectedRow
Gets the selected row index. Syntax COM: HRESULT GetSelectedRow([out,retval] int *nRow) VB: GetSelectedRow() As Integer .NET: System.Int32 GetSelectedRow() Parameters None. Return Value Return type is Integer.
SelectRow
Sets the requested row as selected. Syntax
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-16
Release 8.0(1)
Chapter 5
COM: HRESULT SelectRow([in] int nRow, [out,retval] VARIANT_BOOL * bStatus) VB: SelectRow(nRow As Integer) As Boolean .NET: System.Boolean SelectRow(System.Int32 nRow) Parameters nRow This is a row index number and an input parameter as type Integer. Return Value Return type is Boolean.
set_ColumnHeader
Sets the column header of requested column with given text. Syntax COM: HRESULT ColumnHeader(short nCol, [in] BSTR newVal) VB: set_ColumnHeader(nCol As Short, newVal As String) .NET: set_ColumnHeader(System.Int16 nCol, System.String newVal) Parameters nCol This is a column index number and an input parameter as type Short. newVal This is a user passing header text and an input parameter as type String. Return Value None.
set_ColumnType
Sets the column type of requested column with given value. Syntax COM: HRESULT ColumnType(short nCol, [in] short newVal) VB: set_ColumnType(nCol As Short, newVal As Short) .NET: set_ColumnType(System.Int16 nCol, System.Int16 newVal) Parameters nCol This is a column index number and an input parameter as type Short. newVal This is a user passing column type value and an input parameter as type Short. Return Value None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-17
set_ColumnWidth
Sets the column width of requested column with given value. Syntax COM: HRESULT ColumnWidth(short nCol, [in] short newVal) VB: set_ColumnWidth(nCol As Short, newVal As Short) .NET: set_ColumnWidth(System.Int16 nCol, System.Int16 newVal) Parameters nCol This is a column index value and an input parameter as type Short. newVal This is a user passing column width value and an input parameter as type Short. Return Value None.
set_ UserDefinedCell
Sets the given text into the requested cell. Syntax COM: HRESULT UserDefinedCell(short nIndex, [in] BSTR newVal); VB: set_UserDefinedCell(nindex As Short, newVal As String) .NET: set_UserDefinedCell(System.Int16 nindex, System.String newVal) Parameters nindex This is a cell index number and an input parameter as type Short. newVal This is a user passing text and an input parameter as type String. Return Value None.
SetColumnInfo
Sets the given information for the requested column. Syntax COM: HRESULT SetColumnInfo([in] short nCol, [in] long lColType, [in] int iColWidth, [in] int iColTextAlign, [in] BSTR bstrColTitle) VB: SetColumnInfo(nCol As Short, iColType As Integer,iColWidth As Integer,iColTextAlign As Integer, bstrColTitle As String)
.NET: SetColumnInfo(System.Int16 nCol, System.Int32 iColType, System.Int32 iColWidth, System.Int32 iColTextAlign, System.String bstrColTitle) Parameters nCol
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-18
Release 8.0(1)
Chapter 5
This is a column index number and an input parameter as type Short. iColType This is a column type value and an input parameter as type Integer. iColWidth This is a column width value and an input parameter as type Integer. iColTextAlign This is a column text align value and an input parameter as type Integer. bstrColTitle This is a column title text and an input parameter as type String. Return Value None.
AgentStatisticsCtl
The AgentStatistics control is a grid based control displaying Unified ICM agent real time statistics. The columns displayed are configurable at CTI OS server (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted). Also, the update interval can be adjusted. It defaults to 10 seconds.
Figure 5-7 Agent Statistics Grid
Methods
Table 5-5 Available Methods for AgentStatisticsCtl
Method get_UserDefinedCell GetCellText GetColumnInfo set_ColumnHeader set_ColumnType set_ColumnWidth set_ UserDefinedCell SetColumnInfo
Description If the column type is user defined, gets the text from the requested cell. Gets the text from the requested cell in requested row. Gets the information about the requested column. Sets the column header of requested column with given text. Sets the column type of requested column with given value. Sets the column width of requested column with given value. Sets the given text into the requested cell. Sets the given information for the requested column.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-19
get_UserDefinedCell
If the column type is user defined, gets the text from the requested cell. Syntax COM: HRESULT UserDefinedCell(short nIndex, [out, retval] BSTR *pVal) VB: get_UserDefinedCell(nIndex As Short) As String .NET: System.String get_UserDefinedCell(System.Int16 nIndex) Parameters nIndex This is a cell index number and an input parameter as type Short. Return Value Return type is String. If the requested cell is not user defined type, it throws an Invalid Argument error.
GetCellText
Gets the text from the requested cell in requested row. Syntax COM: HRESULT GetCellText([in] int nRow, [in] int nCol, [out,retval] BSTR* bstrContent) VB: GetCellText(nRow As Integer, nCol As Integer) As String .NET: System.String GetCellText(System.Int16 nRow, System.Int16 nCol) Parameters nRow This is a row index number and an input parameter as type Integer. nCol This is a column index number and an input parameter as type Integer. Return Value Return type is String.
GetColumnInfo
Gets the information about the requested column. Syntax COM: HRESULT GetColumnInfo([in] short nCol, [out] long *plColType, [out] int *iColWidth, [out] int *iColTextAlign, [out] BSTR *bstrColTitle) VB: GetColumnInfo(nCol As Short, ByRef plcoltype As Integer, ByRef icolwidth As Integer, ByRef bstrcoltitle As String)
.NET: GetColumnInfo(System.Int16 nCol, System.Int32 plcoltype, System.Int32 icolwidth, System.String bstrcoltitle) Parameters nCol This is a column index number and an input parameter as type Short.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-20
Release 8.0(1)
Chapter 5
plcoltype This is a column type value and an output parameter as type Integer. icolwidth This is a column width value and an output parameter as Integer. bstrcoltitle This is a column title text and an output parameter as type String. Return Value None.
set_ColumnHeader
Sets the column header of requested column with given text. Syntax COM: HRESULT ColumnHeader(short nCol, [in] BSTR newVal) VB: set_ColumnHeader(nCol As Short, newVal As String) .NET: set_ColumnHeader(System.Int16 nCol, System.String newVal) Parameters nCol This is a column index number and an input parameter as type Short. newVal This is a user passing header text and an input parameter as type String. Return Value None.
set_ColumnType
Sets the column type of requested column with given value. Syntax COM: HRESULT ColumnType(short nCol, [in] short newVal) VB: set_ColumnType(nCol As Short, newVal As Short) .NET: set_ColumnType(System.Int16 nCol, System.Int16 newVal) Parameters nCol This is a column index number and an input parameter as type Short. newVal This is a user passing column type value and an input parameter as type Short. Return Value None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-21
set_ColumnWidth
Sets the column width of requested column with given value. Syntax COM: HRESULT ColumnWidth(short nCol, [in] short newVal) VB: set_ColumnWidth(nCol As Short, newVal As Short) .NET: set_ColumnWidth(System.Int16 nCol, System.Int16 newVal) Parameters nCol This is a column index value and an input parameter as type Short. newVal This is a user passing column width value and an input parameter as type Short. Return Value None.
set_ UserDefinedCell
Sets the given text into the requested cell. Syntax COM: HRESULT UserDefinedCell(short nIndex, [in] BSTR newVal); VB: set_UserDefinedCell(nindex As Short, newVal As String) .NET: set_UserDefinedCell(System.Int16 nindex, System.String newVal) Parameters nindex This is a cell index number and an input parameter as type Short. newVal This is a user passing text and an input parameter as type String. Return Value None.
SetColumnInfo
Sets the given information for the requested column. Syntax COM: HRESULT SetColumnInfo([in] short nCol, [in] long lColType, [in] int iColWidth, [in] int iColTextAlign, [in] BSTR bstrColTitle) VB: SetColumnInfo(nCol As Short, iColType As Integer,iColWidth As Integer,iColTextAlign As Integer, bstrColTitle As String)
.NET: SetColumnInfo(System.Int16 nCol, System.Int32 iColType, System.Int32 iColWidth, System.Int32 iColTextAlign, System.String bstrColTitle) Parameters nCol
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-22
Release 8.0(1)
Chapter 5
This is a column index number and an input parameter as type Short. iColType This is a column type value and an input parameter as type Integer. iColWidth This is a column width value and an input parameter as type Integer. iColTextAlign This is a column text align value and an input parameter as type Integer. bstrColTitle This is a column title text and an input parameter as type String. Return Value None.
AlternateCtl
Figure 5-8 AlternateCtl
The AlternateCtl is a Button type control allowing the agent to send an alternate call request. Alternate is a compound action of placing an active call on hold and then retrieving a previously held call or answering an alerting (ringing) call on the same device. Alternate is a useful feature during a consult call.
AnswerCtl
The Answer Control is a button that provides UI for sending answer and release call requests. The behavior (answer or release) can be set via the ButtonType set from the property page as explained under AgentState controls.
Figure 5-9 Answer Icon:
Figure 5-10
Release Icon:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-23
BadLineCtl
Figure 5-11 BalLineCtl
The Bad Line Control is a button that provides UI for reporting a Bad Line. This request will generate a database entry in Unified ICM and is an indicator for voice/equipment problems.
CallAppearanceCtl
The CallAppearance Control is a grid based control displaying call information, including call status and call context data (i.e., CallVariable1 through CallVariable10 and ECC variables).
Figure 5-12 CallAppearance Control Displaying Two Calls
Each incoming or outgoing call is displayed in one row in the grid. When a call first arrives, it will usually show a status of Ringing, until it is answered. A call can be answered by a double click in the grid, similar to a click on the Answer Button. Some columns in the CallAppearance, grid can be edited if so configured (for example, the Columns displaying Callvariables) by selecting on the cell to be edited. The grid can display multiple calls (see Figure 5-12). If the grid is displaying multiple calls, user can click and select a call anywhere on the row where the call is displayed. This will highlight the whole row displaying this call (e.g. in Figure 5-12 the call with id 16777886 is currently selected). Any button controls (e.g., Answer, Release, Hold,) will enable or disable themselves based on the state the newly selected call is in. The CallAppearance grid handles most call related events. It will display a call as soon as it receives an eCallBeginEvent. It will update the CallStatus and CallContext (CallVariables and ECC variables) on eCallDataUpdate and other call events (eServiceInitiated, eCallEstablished,). It will erase the call from the grid when it receives an eCallEnd event. The CallAppearance grid can be in one of two modes. In normal mode it will show any calls for the agent/supervisor logged in; in monitored mode (only for supervisor), the CallAppearance grid will display all calls for a currently monitored agent (see Agent Select grid). A supervisor can click and then select a monitored call on a row in the grid to perform supervisory functions like barge-in or intercept (see SupervisorOnly control).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-24
Release 8.0(1)
Chapter 5
Related Methods
The following methods may be of interest to users of the call appearance control.
Answer
See Chapter 10, Call Object.
GetValueInt
See Chapter 7, CtiOs Object.
GetValueString
See Chapter 7, CtiOs Object.
Related Events
The call appearance control handles the following events.
OnSetCurrentCallAppearance
The OnSetCurrentCallAppearance event is generated when the current call appearance object is changed.
Syntax
void OnSetCurrentCallAppearance([in] IDispatch * pCall);
Parameters
pCall A Pointer to ICall COM Call object (pCall is a pointer to ICall).
Return Value
None.
Methods
Table 5-6 Available Methods for CallAppearanceCtl
Description Gets the text from the requested cell in requested row. Gets the selected row index. Sets the requested row as selected.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-25
Description Sets the column ECC name of requested column with given text. Sets the column header of requested column with given text. Sets the column width of requested column with given value. Sets the given text to the requested cell in requested row.
set_ColumnECCOffset Sets the column Offset value of requested column with given value.
GetCellText
Gets the text from the requested cell in requested row. Syntax COM: HRESULT GetCellText([in] int nRow, [in] int nCol, [out,retval] BSTR* bstrContent) VB: GetCellText(nRow As Integer, nCol As Integer) As String .NET: System.String GetCellText(System.Int16 nRow, System.Int16 nCol) Parameters nRow This is a row index number and an input parameter as type Integer. nCol This is a column index number and an input parameter as type Integer. Return Value Return type is String.
GetSelectedRow
Gets the selected row index. Syntax COM: HRESULT GetSelectedRow([out,retval] int *nRow) VB: GetSelectedRow() As Integer .NET: System.Int32 GetSelectedRow() Parameters None. Return Value Return type is Integer.
SelectRow
Sets the requested row as selected. Syntax COM: HRESULT SelectRow([in] int nRow, [out,retval] VARIANT_BOOL * bStatus) VB: SelectRow(nRow As Integer) As Boolean .NET: System.Boolean SelectRow(System.Int32 nRow)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-26
Release 8.0(1)
Chapter 5
Parameters nRow This is a row index number and an input parameter as type Integer. Return Value Return type is Boolean.
set_ColumnECCName
Sets the column ECC name of requested column with given text. Syntax COM: HRESULT ColumnECCName(short nCol, [in] BSTR newVal) VB: set_ColumnECCName(nCol As Short, newVal As String) .NET: set_ ColumnECCName (System.Int16 nCol, System.String newVal) Parameters nCol This is a column index number and an input parameter as type Short. newVal This is a user passing ECC Name text and an input parameter as type String. Return Value None.
set_ColumnECCOffset
Sets the column Offset value of requested column with given value. Syntax COM: HRESULT ColumnECCOffset(short nCol, [in] short nNewValue) VB: set_ColumnECCOffset(nCol As Short, nNewValue As Short) .NET: set_ColumnWidth(System.Int16 nCol, System.Int16 nNewValue) Parameters nCol This is a column index number and an input parameter as type Short. nNewVal This is a user passing column width value and an input parameter as type Short. Return Value None.
set_ColumnHeader
Sets the column header of requested column with given text. Syntax COM: HRESULT ColumnHeader(short nCol, [in] BSTR newVal)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-27
VB:
.NET: set_ColumnHeader(System.Int16 nCol, System.String newVal) Parameters nCol This is a column index number and an input parameter as type Short. nNewVal This is a user passing header text and an input parameter as type String. Return Value None.
set_ColumnWidth
Sets the column width of requested column with given value. Syntax COM: HRESULT ColumnWidth(short nCol, [in] short newVal) VB: set_ColumnWidth(nCol As Short, newVal As Short) .NET: set_ColumnWidth(System.Int16 nCol, System.Int16 newVal) Parameters nCol This is a column index value and an input parameter as type Short. newVal This is a user passing column width value and an input parameter as type Short. Return Value None.
SetCellText
Sets the given text to the requested cell in requested row. Syntax COM: HRESULT SetCellText([in] int nRow, [in] int nCol, [in] BSTR bstrContent, [out,retval] VARIANT_BOOL * bStatus) VB: SetCellText(nRow As Integer, nCol As Integer, bstrContent As String) As Boolean .NET: System. Boolean SetCellText(System.Int16 nRow, System.Int16 nCol, System.String bstrContent) Parameters nRow This is a row index number and an input parameter as type Integer. nCol This is a column index number and an input parameter as type Integer. bstrContent This is a user passing cell text and an input parameter as type String.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-28
Release 8.0(1)
Chapter 5
ChatCtl
The Chat Control provides a UI to formulate and send text messages to a supervisor or (if allowed) other agents. The chat privileges are configurable at CTI OS server (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted).
Figure 5-13 Chat Control
You can specify an AgentID in the field labeled Send to AgentID and then enter a message in the Edit Outgoing Message box. Click the Send Button to send the message. Incoming messages will be displayed in the Message Display. Click the Clear button to clear the display. The ChatCtl does not implement a button directly, but may be linked to a button through Visual Basic, so that a click on the button will pop up the ChatCtl.
Methods
Table 5-7 Available Methods for ChatCtl
Description Gets the current Addressee from the Send to Agent ID Combo box. Gets the all chat messages from the Message Display Text Area. Gets the chat message from the Edit Outgoing Message Text Area. When message received from an Agent, appends the received message to the Message Display Text Area. Sends the chat message to current Addressee in the Send to Agent ID Combo box. Sets the current Addressee to the Send to Agent ID Combo box. Sets the chat message to the Edit Outgoing Message Text Area.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-29
GetAddressee
Gets the current Addressee from the Send to Agent ID Combo box. Syntax COM: HRESULT GetAddressee ([out,retval] BSTR* addressee) VB: GetAddressee()As String .NET: System.String GetAddressee() Parameters None. Return Value Return type is String.
GetAllChatMessages
Gets the all chat messages from the Message Display Text Area. Syntax COM: HRESULT GetAllChatMessages ([out, retval] BSTR* Messages) VB: GetAllChatMessages() As String .NET: System.String GetAllChatMessages() Parameters None. Return Value Return type is String.
GetChatMessageText
Gets the chat message from the Edit Outgoing Message Text Area. Syntax COM: HRESULT GetChatMessageText ([out, retval] BSTR* MessageText) VB: GetChatMessageText() As String .NET: System.String GetChatMessageText() Parameters None. Return Value Return type is String.
OnMsgReceived
When message received from an Agent, appends the received message to the Message Display Text Area. Syntax COM: HRESULT OnMsgReceived ([in]BSTR from,[in]BSTR msg)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-30
Release 8.0(1)
Chapter 5
VB:
.NET: OnMsgReceived(System.String from, System.String msg) Parameters from This is an Agent ID, who sends the message and is an input parameter as type String. msg This is a message text received form an Agent and is an input parameter as type String. Return Value None.
SendChatMessage
Sends the chat message to current Addressee in the Send to Agent ID Combo box. Syntax COM: HRESULT SendChatMessage([in] BSTR addressee, [in] BSTR msg) VB: SendChatMessage(addressee As String, msg As String) .NET: SendChatMessage (System.String addressee, System.String msg) Parameters addressee This is as Agent ID, who will receives the message and is an input parameter as type String. msg This is a message test send to an Agent and is an input parameter as type String. Return Value None.
SetAddressee
Sets the current Addressee to the Send to Agent ID Combo box. Syntax COM: HRESULT SetAddressee ([in] BSTR addressee) VB: SetAddressee(addressee As String) .NET: SetAddressee(System.String addressee) Parameters addressee This is as Agent ID, who will receives the message and is an input parameter as type String. Return Value None.
SetChatMessageText
Sets the chat message to the Edit Outgoing Message Text Area.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-31
Syntax COM: HRESULT SetChatMessageText ([in] BSTR MessageText) VB: SetChatMessageText(messageText As String) .NET: SetChatMessageText (System.String messageText) Parameters messageText This is an out going message text and is an input parameter as type String. Return Value None.
ConferenceCtl
The conference control is used to create a conference call. This can be done in either single step or consultative mode.
Figure 5-14 Icon for ConferenceInit:
Figure 5-15
Depending on call status, selecting the Conference button once will bring up the dialog shown in Figure 5-16 (see also MakeCall dialog):
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-32
Release 8.0(1)
Chapter 5
Figure 5-16
This dialog is similar to the Make Call dialog. It allows you to initiate a consultative Conference (Conf Init) or to place a Single Step Conference call. Enter the number you wish to dial by either typing it into the text box labeled Number to Dial or by clicks on the displayed keypad. Once the number is entered you can click on Conf Init to place a consultative conference call or Single Step to initiate a single step conference. This will close this dialog. If you choose to place a consultative call, the conference button will change to Conference Complete. You must click this button to complete the conference after talking to the consult agent. The conference dialog also has a Mute Tones section that allows you to suppress audio output of selected or all tones. The More button brings up an additional section of the dialog displaying all CallVariables along with any values set in the original call. The agent may double click on the appropriate line in the Value column to change or add values to send along with the consult call (see Figure 5-17).
Figure 5-17 Expanded Dialog
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-33
EmergencyAssistCtl
The EmergencyAssistCtl is a button that provides a UI to place emergency or supervisor assist calls to a supervisor. On the Unified ICM side this functionality is implemented with a script (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted). The main difference between the emergency call and supervisor assist requests is the script to be run. An agent may click this control whether he has a call or not. If the agent has an active customer call, clicking this button will place a consult call to the supervisor. The Conference Complete as well as the Transfer Complete will be enabled to allow the agent to either conference the supervisor into the call or to transfer the call to the supervisor. If configured, clicking this button can also cause a single step conference. The behavior (emergency call or supervisor assist) can be set via the ButtonType property set from the Property Page, as described under AgentState controls.
Figure 5-18
Emergency Icon:
Figure 5-19
HoldCtl
The HoldCtl is a button that provides a UI for sending hold and retrieve call requests. The behavior (hold or retrieve) can be set via the ButtonType property set from the Property Page, as described under AgentState controls.
Figure 5-20 Hold Icon
Figure 5-21
Retrieve Icon
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-34
Release 8.0(1)
Chapter 5
MakeCallCtl
Figure 5-22 Make Call Iocn
The MakeCallCtl is used to place calls and to generate DTMF tones. When this button is clicked it will bring up the dialing pad dialog box to enter data and place a makecall request (Figure 5-23).
Figure 5-23 Dial Dialog
Enter the number you wish to dial by either typing it into the textbox labeled Number to Dial or click the numbers on the displayed keypad. Once the number is entered you can click on Make Call to send the MakeCall request. This dialog also has a Mute Tones section that allows you to suppress audio output of selected or all tones. You may enter values for CallVariable1 through CallVariable10 and ECC Call Variables via the Dial Dialog. Click the More button on the dialog extends to display a grid listing all possible Call Variables. A value may be entered for each of these variables by double clicking on the appropriate line in the Value column (see Figure 5-24).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-35
Figure 5-24
Expanded Dialog
If the agent is on a call while selecting the Make Call button, the dialpad will be displayed without the MakeCall feature. The agent can then use the dialpad to play DTMF tones.
ReconnectCtl
The ReconnectCtl is a Button control allowing the agent to send a Reconnect Call request. Reconnect is a useful feature during a consult call. If an agent has Call A held and Call B active, reconnect will hang up Call B and make Call A active. In a consult call scenario, reconnect will hang up the consult call and return to the original call.
SkillgroupStatisticsCtl
The SkillGroupStatistics control is a grid based control displaying Unified ICM real time SkillGroup statistics. The columns displayed are configurable at CTI OS server (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted). The update interval can be configured but defaults to 10 seconds. If an agent belongs to multiple SkillGroups, each row will display statistics for one SkillGroup. For a supervisor this control will display all skillgroups in his team.
Figure 5-25 SkillgroupStatisticsCtl Displaying Sample Data for Three Skillgroups
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-36
Release 8.0(1)
Chapter 5
Methods
Table 5-8 Available Methods for SkillgroupStatisticsCtl
Method get_UserDefinedCell GetCellText GetColumnInfo set_ColumnHeader set_ColumnType set_ColumnWidth set_ UserDefinedCell SetColumnInfo
Description If the column type is user defined, gets the text from the requested cell. Gets the text from the requested cell in requested row. Gets the information about the requested column. Sets the column header of requested column with given text. Sets the column type of requested column with given value. Sets the column width of requested column with given value. Sets the given text into the requested cell. Sets the given information for the requested column.
get_UserDefinedCell
If the column type is user defined, gets the text from the requested cell. Syntax COM: HRESULT UserDefinedCell(short nIndex, [out, retval] BSTR *pVal) VB: get_UserDefinedCell(nIndex As Short) As String .NET: System.String get_UserDefinedCell(System.Int16 nIndex) Parameters nIndex This is a cell index number and an input parameter as type Short. Return Value Return type is String. If the requested cell is not user defined type, it throws an Invalid Argument error.
GetCellText
Gets the text from the requested cell in requested row. Syntax COM: HRESULT GetCellText([in] int nRow, [in] int nCol, [out,retval] BSTR* bstrContent) VB: GetCellText(nRow As Integer, nCol As Integer) As String .NET: System.String GetCellText(System.Int16 nRow, System.Int16 nCol) Parameters nRow This is a row index number and an input parameter as type Integer. nCol This is a column index number and an input parameter as type Integer.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-37
GetColumnInfo
Gets the information about the requested column. Syntax COM: HRESULT GetColumnInfo([in] short nCol, [out] long *plColType, [out] int *iColWidth, [out] int *iColTextAlign, [out] BSTR *bstrColTitle) VB: GetColumnInfo(nCol As Short, ByRef plcoltype As Integer, ByRef icolwidth As Integer, ByRef bstrcoltitle As String)
.NET: GetColumnInfo(System.Int16 nCol, System.Int32 plcoltype, System.Int32 icolwidth, System.String bstrcoltitle) Parameters nCol This is a column index number and an input parameter as type Short. plcoltype This is a column type value and an output parameter as type Integer. icolwidth This is a column width value and an output parameter as Integer. bstrcoltitle This is a column title text and an output parameter as type String. Return Value None.
set_ColumnHeader
Sets the column header of requested column with given text. Syntax COM: HRESULT ColumnHeader(short nCol, [in] BSTR newVal) VB: set_ColumnHeader(nCol As Short, newVal As String) .NET: set_ColumnHeader(System.Int16 nCol, System.String newVal) Parameters nCol This is a column index number and an input parameter as type Short. newVal This is a user passing header text and an input parameter as type String. Return Value None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-38
Release 8.0(1)
Chapter 5
set_ColumnType
Sets the column type of requested column with given value. Syntax COM: HRESULT ColumnType(short nCol, [in] short newVal) VB: set_ColumnType(nCol As Short, newVal As Short) .NET: set_ColumnType(System.Int16 nCol, System.Int16 newVal) Parameters nCol This is a column index number and an input parameter as type Short. newVal This is a user passing column type value and an input parameter as type Short. Return Value None.
set_ColumnWidth
Sets the column width of requested column with given value. Syntax COM: HRESULT ColumnWidth(short nCol, [in] short newVal) VB: set_ColumnWidth(nCol As Short, newVal As Short) .NET: set_ColumnWidth(System.Int16 nCol, System.Int16 newVal) Parameters nCol This is a column index value and an input parameter as type Short. newVal This is a user passing column width value and an input parameter as type Short. Return Value None.
set_ UserDefinedCell
Sets the given text into the requested cell. Syntax COM: HRESULT UserDefinedCell(short nIndex, [in] BSTR newVal); VB: set_UserDefinedCell(nindex As Short, newVal As String) .NET: set_UserDefinedCell(System.Int16 nindex, System.String newVal) Parameters nindex This is a cell index number and an input parameter as type Short. newVal
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-39
This is a user passing text and an input parameter as type String. Return Value None.
SetColumnInfo
Sets the given information for the requested column. Syntax COM: HRESULT SetColumnInfo([in] short nCol, [in] long lColType, [in] int iColWidth, [in] int iColTextAlign, [in] BSTR bstrColTitle) VB: SetColumnInfo(nCol As Short, iColType As Integer,iColWidth As Integer,iColTextAlign As Integer, bstrColTitle As String)
.NET: SetColumnInfo(System.Int16 nCol, System.Int32 iColType, System.Int32 iColWidth, System.Int32 iColTextAlign, System.String bstrColTitle) Parameters nCol This is a column index number and an input parameter as type Short. iColType This is a column type value and an input parameter as type Integer. iColWidth This is a column width value and an input parameter as type Integer. iColTextAlign This is a column text align value and an input parameter as type Integer. bstrColTitle This is a column title text and an input parameter as type String. Return Value None.
StatusBarCtl
The CTI OS statusbar control displays information about the logged on agent as well as CTI OS specific details (Figure 5-26).
Figure 5-26 StatusBar Control Displaying Sample Data
The statusbar is separated into several panes. The panes are defined as follows:
Pane 1: displays current extension and instrument Pane 2: displays Agent ID Pane 3: Message Waiting Indicator. If media termination is used and Voicemail is active, this pane will display Voicemail to indicate Voicemail was left. Pane 4: displays Agent State
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-40
Release 8.0(1)
Chapter 5
Pane 5: displays the CTI OS server currently connected to Pane 6: displays overall status (online, offline)
SupervisorOnlyCtl
The SupervisorOnly Control provides buttons for Supervisor functions including Barge-In, Intercept, Logout Monitored Agent and make Monitored Agent Ready. The behavior of the button can be set in the General tab of the Property Page. Logout Monitored Agent: Logs out the currently monitored agent (set for example via the AgentselectCtl). If the currently monitored agent has a call active, the request will be queued and the agent will be logged out as soon as the call ends
Set Monitored Agent Ready: Forces the currently monitored agent from the not ready state into the ready state:
Barge-In: Lets the supervisor participate in the currently monitored call. The currently monitored call is selected via the CallAppearanceCtl (in monitor mode). Barge-in is really a conference on behalf of the monitored agent
Intercept: Intercept can only be applied on a previously barged in call. The monitored agent will be dropped out of the call and the supervisor is left with the customer in a call.
Together with the AgentSelectCtl and the CallAppearanceCtl (in monitor mode) the SupervisorOnlyCtl is used in the CTI OS Supervisor Desktop application to build the Agent Real Time Status window, as shown in Figure 5-27.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-41
Figure 5-27
This window shows the AgentSelectCtl and the CallappearanceCtl in monitor mode on the right side and four instances of the SupervisorOnlyCtl on the left side. From top to bottom they are: Make Monitored Agent Ready (disabled, since Agent 5101 is talking), Logout monitored Agent], Barge-in and Intercept. Start Silent Monitor: Initiates a silent monitor session with the currently monitored agent
Stop Silent Monitor: Terminates the currently ongoing silent monitored session
RecordCtl
The RecordCtl is a button that provides UI for Call Recording requests (start/stop recording), the requests will be forwarded to CTI Server, so they can be handled by a configured call recording service. To record a call a current call has to be selected (e.g. via the CallAppearanceCtl). Once the record button is clicked, it will turn into record stop button. Icon for Record Start:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-42
Release 8.0(1)
Chapter 5
TransferCtl
The TransferCtl is a button that provides UI to transfer a call in single step or consultative mode. The mechanism is the same as explained for the conference control. Icon for TransferInit:
Depending on call status, selecting the Transfer button once will bring up the dialog shown in Figure 5-28 (see also MakeCall dialog):
Figure 5-28 Dial Dialog
This dialog is similar to the Make Call dialog. It allows you to initiate a consultative Transfer (Transfer Init) or to place a Single Step Transfer call. Enter the number you wish to dial by either typing it into the text box labeled Number to Dial or click the numbers on the displayed keypad. Once the number is entered you can click on Conf Init to place a consultative transfer call or Single Step to initiate a single step transfer. This will close this dialog. If you choose to place a consultative call, the transfer button will change to Transfer Complete. You must click this button to complete the transfer after talking to the consult agent. The transfer dialog also has a Mute Tones section that allows you to suppress audio output of selected or all tones.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-43
The More button brings up an additional section of the dialog displaying all CallVariables along with any values set in the original call. The agent may change or add values to send along with the consult call by double clicking on the appropriate line in the Value column (see Figure 5-17).
Figure 5-29 Expanded Dialog
The Silent Monitor StandAlone ComObject is supported for use on Unified CCE only. The Standalone ComObject wraps calls to the CTI OS Session as well as SilentMonitor manager. It provides the following four methods (displayed in IDL format; IDL is the language used to define COM interfaces).
interface ISilentMonitor : IDispatch { [id(1), helpstring("method Connect to CTIOS")] HRESULT Connect ([in] IArguments * args, [out] int* returnvalue); [id(2), helpstring("method Disconnect to CTIOS")] HRESULT Disconnect (/*[in] IArguments * args, [out] int* returnvalue*/); [id(3), helpstring("method StartMonitoring to CTIOS")] HRESULT StartMonitoring ([in] IArguments * args, [out] int* returnvalue); [id(4), helpstring("method StopMonitoring to CTIOS")] HRESULT StopMonitoring ([in] IArguments * args, [out] int* returnvalue); };
Connect
The Connect method establishes a Monitor Mode Session with the specified CTI OS Server. The syntax and parameters are the same as for the CTI OS session object Connect method (see Returns in Chapter 8, Session Object).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-44
Release 8.0(1)
Chapter 5
Disconnect
The Disconnect method disconnects an established session. This method has no required parameters. See CreateSilentMonitorManager in Chapter 8, Session Objectfor syntax and optional parameters.
StartMonitoring
The StartMonitoing method starts a Silent Monitor Session.The StartMonitoring Arguments array contains the following parameters,
Table 5-9 StartMonitoring Arguments Array Parameters
Value AgentID of the agent to be monitored. PeripheralID of the Peripheral to which the Agent is logged in.
Note
If a pointer to the agent object is available (e.g., a m_MonitoredAgent), The PeriperhalID can be retrieved via m_MonitoredAgent.GetValueInt ("PeripheralID")
StopMonitoring
The StopMonitoring method stops a Silent Monitor Session.The StopMonitoring Arguments array contains the same parameters as the StartMonitoring method (Table 5-9).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-45
Following is a brief description of each event. These events are described in detail in the Session Object and Silent Monitor Object sections of Chapter 6, Event Interfaces and Events.
Table 5-10 SilentMonitor Com Object Events
Description Indicates that the connect method was successful in establishing a connection. Indicates that an active connection has failed. Can also indicate a bad parameter in the Connect method. Signals a successful call to SetMsgFilte. The call to Setmsgfilter is hidden by the Standalone control. Disconnect was called and the connection is now closed. A ControlFailureConf was received and can be handled. A CtiosFailure event was received. This could be Silent Monitor specific error code. RTP events have been received signaling the start and stop of the RTP streams. This event is used to report status from a monitored client to the monitoring application. These confs acknowledge that CTI OS handled the StartMonitoring and StopMonitoring request, respectively. Indicates that the Silent Monitor session has timed out on the monitoring side.
OnMonitorModeEstablished
OnConnectionClosed OnControlFailureConf OnCtiOsFailure OnCallRTPStartedEvent, OnCallRTPStoppedEvent OnSilentMonitorStatusReport Event OnStartSilentMonitorConf, OnStopSilentMonitorConf OnSilentMonitorSession Disconnected
Deployment
The StandAlone Com Object is a COM dll that needs to be registered on the client system via the Regsvr32 Silentmonitorctl.dll. In addition, ccnsmt.dll and the two standard CTI OS COM dlls (CTIOSClient.dll and Arguments.dll) are also required.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-46
Release 8.0(1)
Chapter 5
Private Sub btnConnect_Click() m_Args.clear m_Args.AddItem CtiosA, localhost m_Args.AddItem portA, 42028 Dim nRetVal As Long SilentMonitorCtl.Connect m_Args, nRetVal If nRetVal <> CIL_OK Then MsgBox "Connect returned error " + Str(nRetVal) End If End Sub Private Sub btnDisconnect_Click() Dim nRetVal As Long SilentMonitorCtl.Disconnect End Sub Private Sub btnStartMonitoring_Click() m_Args.clear m_Args.AddItem AgentId, 1000 m_Args.AddItem PeripheralID, 5004 Dim nRetVal As Long SilentMonitorCtl.StartMonitoring m_Args, nRetVal If nRetVal <> CIL_OK Then MsgBox "StartMonitoring returned error " + Str(nRetVal) End If End Sub Private Sub btnStopMonitoring_Click() m_Args.clear m_Args.AddItem AgentId, 1000 m_Args.AddItem PeripheralID, 5004 Dim nRetVal As Long SilentMonitorCtl.StopMonitoring m_Args, nRetVal If nRetVal <> CIL_OK Then MsgBox "StopMonitoring returned error " + Str(nRetVal) End If End Sub Private Sub SilentMonitorCtl_OnSessionDisconnected(ByVal pIArguments As SILENTMONITORCTLLib.IArguments) MsgBox "SilentMonitorSession Disconnected Event" End Sub
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
5-47
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
5-48
Release 8.0(1)
CHAPTER
The CIL event interfaces discussed in this section and the following sections apply only to the C++, COM, and VB interfaces. See Events in Java CIL for a discussion of Java CIL counterpart events and event handling in the Java CIL See Events in .NET CIL, for a discussion of .NET CIL event handling. The Client Interface Library provides a publisher-subscriber model for notifying clients of events. Client applications using the CIL can subscribe to one or more of the CIL event interfaces. For detailed information and examples for how to subscribe and unsubscribe for events, see Chapter 4, Building Your Application. The published CIL event interfaces are organized around the different classes of CTI objects that the CIL provides. The event interfaces described in this chapter are:
ISessionEvents. This interface publishes the events that relate to actions on the Session object. ICallEvents. This interface publishes the events that relate to actions on Call objects. IAgentEvents. This interface publishes the events that relate to actions on Agent objects. ISkillGroupEvents. This interface publishes the events that relate to actions on SkillGroup objects. IButtonEnablementEvents. This interface publishes the events that relate to changes in the enable-disable status of softphone buttons. ISilentMonitorEvents. This interface sends events to subscribers of the Silent Monitor interface. IMonitoredAgentEventsInterface. This interface fires Agent events to a supervisor for his team members. IMonitoredCallEventsInterface. This interface sends Call events to a supervisor for one of his agent team members.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-1
LogEventsAdapter (Java only). This class provides the default implementation for the message handlers in ILogEvents. IGenericEvents. This interface sends generic events to subscribers of the IGenericEvents interface.
The remainder of this chapter provides the detailed description of each event interface available from the CIL.
Note
The data type listed for each keyword is the standardized data type discussed in the section CTI OS CIL Data Types in Chapter 3, CIL Coding Conventions. See Table 3-1 for the appropriate language specific types for these keywords.
ISessionEvents Interface
The Session object fires events on the ISessionEvents interface. The following events are published to subscribers of the ISessionEvents interface.
OnConnection
The OnConnection event is generated after the Connect method succeeds. It returns the name of the connected server and the connection time of day. The client application need not take any special action but may use it to display connection status.
Syntax
C++: COM: VB:
void OnConnection(Arguments& args) void OnConnection (IArguments * args) session_OnConnection (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-1 ISession Event Parameters
Description Integer value with time of day expressed in milliseconds. Name or TCP/IP address of the current connected CTI OS server.
OnConnectionClosed
The OnConnectionClosed message is generated when a connection is terminated by the client. This message has no fields. This event indicates successful completion of an action that was initiated by the client (CIL or application using the CIL). By contrast, the OnConnectionFailure event is generated when the connection terminated for reasons other than that the client closed the connection.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-2
Release 8.0(1)
Chapter 6
OnConnectionFailure
The OnConnectionFailure event is generated when an established connection fails. It returns the name of the failed connected server and the failure time of day. Retry is automatic and can be followed by an OnConnection event when connection is successfully reestablished. The client application need not take any special action but may use this event to display connection status.
Syntax
C++: COM: VB:
void OnConnectionFailure(Arguments& args) void OnConnectionFailure (IArguments * args) session_OnConnectionFailure (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-2 OnConnectionFailure Event Parameters
Description Integer value with time of day expressed in milliseconds. Name or TCP/IP address of the server that has failed to respond. See ReasonCode. SERVER_CONNECTIONBROKEN, SERVER_MISSINGHEARTBEATS
OnConnectionRejected
The OnConnectionRejected event indicates that the client has tried to make a connection using incompatible versions of the CTI OS Server and CTI OS CIL.
Syntax
C++: COM: VB:
void OnConnectionRejected (Arguments& args) void OnConnectionRejected (IArguments * args) Session_OnConnectionRejected (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Not currently used, reserved for future use.
OnCTIOSFailure
The OnCTIOSFailure event indicates that the CTI Server has fired either a FailureConf or a SystemEvent.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-3
Note
CTI OS CIL will send the disconnect request to CTI OS Server when the login attempt fails. Hence CTI OS Server closes the client connection.
Syntax
C++: COM: VB:
void OnCTIOSFailure (Arguments& args) void OnCTIOSFailure (IArguments * args) Session_OnCTIOSFailure (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-3 OnCTIOSFailure Event Parameters
Description A value according to an enumerated value, as shown immediately following this table. Present only if FailureCode equals ServerConnectionStatus. Contains a value according to an enumerated value, as shown immediately following this table. Present only if SystemEventID equals SysPeripheralOnline or SysPeripheralOffline. Contains the peripheral ID of the affected peripheral. An error message.
SystemEventArg1
INT
ErrorMessage
STRING
enum enumCTIOS_FailureCode { eDriverOutOfService eServiceNotSupported eOperationNotSupported eInvalidPriviledge eUnknownRequestID eUnknownEventID eUnknownObjectID eRequiredArgMissing eInvalidObjectState eServerConnectionStatus eInconsistentAgentData eAgentAlreadyLoggedIn eForcedNotReadyForConfigError eMonitorModeConnectionDenied };
= = = = = = = = = = = = = =
1, eDriverOutOfService + 1, eServiceNotSupported + 1, eOperationNotSupported + 1, eInvalidPriviledge + 1, eUnknownRequestID + 1, eUnknownEventID + 1, eUnknownObjectID + 1, eRequiredArgMissing eInvalidObjectState + 1, eServerConnectionStatus + 1, eInconsistentAgentData + 1, eAgentAlreadyLoggedIn + 1 eForcedNotReadyForConfigError + 1
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-4
Release 8.0(1)
Chapter 6
Remarks
See the descriptions of the CtiOs_Enums.FailureCode and CtiOs_Enums.SystemEvent interfaces in the Javadoc for information on Java CIL enumerations.
OnCurrentAgentReset
The OnCurrentAgentReset message is generated when the current agent is removed from the session.
Syntax
C++: void OnCurrentAgentReset(Arguments& args) COM:void OnCurrentAgentReset (IArguments * args) VB: session_OnCurrentAgentReset (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-4 OnCurrentAgentReset Parameters
Keyword UniqueObjectID
Type STRING
Description Unique object ID (if any) of the old current agent that was just removed.
OnCurrentCallChanged
The OnCurrentCallChanged message is generated when the current call has changed to another call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-5
Syntax
C++: COM: VB:
void OnCurrentCallChanged(Arguments& args) void OnCurrentCallChanged (IArguments * args) session_OnCurrentCallChanged (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-5 OnCurrentCallChanged Parameters
Keyword
Type
UniqueObjectID STRING
OnFailure Event
Not supported.
OnGlobalSettingsDownloadConf
You can configure the client once in the CTI OS Server and then download this configuration to each CTI OS client desktop. When an application executes the RequestDesktopSettings method call on the Session, an eGlobalSettingsDownloadRequest event is sent to the server. In response, the server sends an OnGlobalSettingsDownloadConf event back to the calling application. The Arguments object passed as a parameter in this event contains the Desktop Settings configuration information. The Arguments object is an array that can contain up to seven elements, each of which has the value of a nested Arguments array in a hierarchy that closely matches that of the CTI OS server configuration in the Windows registry. Each of these Arguments arrays is a packed version of the configuration contained in the CTI OS Server. Refer to the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted for more detailed information. This section describes the contents of the Arguments array returned in the OnGlobalSettingsDownloadConf event. Custom applications can add values at the lowest level under each key. Custom values added in this way are passed to the client in this event. This section also identifies which keys and values in the CTI OS registry are passed to the client in this event. To gain an understanding of what is available and how to configure these items, see the following sections in the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted.
MainScreen Defining Connection Profiles Declaring ECC Variables Configuring the Call Appearance Grid Automatic Agent Statistics Grid Configuration
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-6
Release 8.0(1)
Chapter 6
Syntax
C++: void OnGlobalSettingsDownloadConf(Arguments & args) COM: void OnGlobalSettingsDownloadConf(IArguments * args)
VB:
Parameters
args An Arguments array containing the Enterprise Desktop Settings configuration from a CTI OS server. For a description of the Enterprise Desktop Settings values listed below, see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted. The following are the top level elements in the Enterprise Desktop Settings registry key. The CTI OS server passes configuration data for these elements to the client in the OnGlobalSettingsConf event.
ECC (Expanded Call Context) variables Grid IPCCSilentMonitor Login ScreenPreferences SoundPreferences
Other keys or values that are added to the EnterpriseDesktopSettings/All Desktops key in the CTI OS server registry are passed to the client in the DesktopSettings Arguments array as empty Arguments arrays. The following sections describe the contents of the args array.
ECC Arguments array that contains the Expanded Call Context (ECC) variables declared on the CTI OS server in the ECC/Name registry subtree. The CTI OS server does not send any registry information contained in the CTI OS registry keys representing the ECC scalar and array names. Thus the ECC Arguments arrays are empty in the OnGlobalSettingsDownloadConf event, regardless of the contents of those keys. ECC, <Arguments array> user.Variable1, <Arguments array> Null user.Array[0], <Arguments array> Null user.Array[1], <Arguments array> ... Null
Each ECC scalar configured in the CTI OS server registry is represented as an empty Arguments array with keyword user.<name>, where <name> is the ECC name as configured on CTI OS server.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-7
Each ECC array configured in the CTI OS server registry is represented as multiple empty Arguments arrays with keywords user.<name>[0] to user.<name>[n-1], where <name> is the ECC name as configured on the CTI OS server and n is the size of the array as configured on the CTI OS server.
Grid Arguments array that contains information from the CTI OS server registrys Grid subtree. The grid element contains an Arguments array of up to three Arguments arrays: - AgentStatistics - CallAppearance - SkillGroupStatistics Each of these arrays contains the keyword columns, an Arguments array that contains multiple nested Arguments arrays with key=<column_number>, where <column_number> corresponds to the name of a key within the Columns/Number registry subtree. The configuration information for any key or value added to the SkillGroupStatistics, AgentStatistics, or CallAppearance registry keys is not passed to the client in the OnGlobalSettingsDownloadConf event. The value for each column number in the AgentStatistics and SkillGroupStatistics element is an Arguments array containing the following key-value pairs:
Table 6-6 Agent Statistics Coloumn Number: Key Values
1. Other registry values added to the <column_number> registry key are passed in the OnGlobalSettingsDownloadConf event. Subkeys added to the <column_number> registry key are not passed in this event.
The value for each column number in the CallAppearance element is an Arguments array containing the following key-value pairs:
Table 6-7 CallAppearance Coloumn Number: Key Values
1. Other registry values added to the <column_number> registry key are passed in the OnGlobalSettingsDownloadConf event. Subkeys added to the <column_number> registry key are not passed in this event.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-8
Release 8.0(1)
Chapter 6
You can add custom keys in the CTI OS Server registrys Grid subtree at the same level as the SkillGroupStatistics, AgentStatistics, and CallAppearance keys. The Grid Arguments array within this event will contain items corresponding to these custom keys. Any custom element that you add must follow the same hierarchy in the registry as that used by the existing top level elements.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-9
...
CallAppearance, <Arguments array>
Custom, CustomValue
...
SkillGroupStatistics, <Arguments array>
...
CustomGridData, <Arguments array>
...
IPCCSilentMonitor Arguments array that contains configuration information from the CTI OS server registrys IPCCSilentMonitor/ Name subtree. The IPCCSilentMonitor Arguments array contains a nested Arguments array with key=settings. This array contains the following key-value pairs:
Table 6-8 IPCCSilentMonitor: Key Values
Configuration information for registry values added to the IPCCSilentMonitor/Settings registry key is passed to the client in the OnGlobalSettingsConf event. Configuration information for subkeys added to the Settings registry key is not passed in this event. You can add custom keys to the CTI OS registry in the IPCCSilentMonitor subtree at the same level as the Settings key. The IPCCSilentMonitor Arguments array within this event will contain items corresponding to these custom keys. Any custom element that you add must follow the same hierarchy in the registry as that used by the existing top level elements.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-10
Release 8.0(1)
Chapter 6
Two silent monitoring types are supported for Unified CCE: CTI OS based CCM based
The silent Monitor type used by CTI OS is configured using the CCMBasedSilentMonitor registry key. If CCMBasedSilentMonitor is present and set to true, CTI OS is using Call Manager's silent monitor implementation. When this is the case, supervisor applications must initiate silent monitor using the Agent.SuperviseCall() method. Agent applications do not need to do anything. If CCMBasedSilentMonitor is not present or set to 0, CTI OS implementation of silent monitor is in use. When this is the case, supervisor and agent applications must invoke silent monitor using the SilentMonitorManager object. The format of the IPCCSilentMonitor Arguments array follows:
IPCCSilentMonitor,<Arguments array> Settings,<Arguments array> HeartbeatInterval, 5
...
CustomName, Custom Value CustomName, Custom Value CustomSettings,<Arguments array> CustomName, CustomValue
Login Arguments array that contains the information from the CTI OS server registrys Login subtree. This array contains a nested Arguments array with key=ConnectionProfiles and with an Arguments array value for each connection profile. The keyword of each array is the name for the Connection Profile listed in the CTI OS servers registry. The value is another Arguments array. The following key-value pairs are contained in each connection profile Arguments array:
Table 6-9 Unified CCE Agent Statistics: Key Values
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-11
Configuration information for keys or values that are added to the Login registry key in the CTI OS servers registry does not appear in the Login Arguments array. The format of the Login Arguments array follows.
Login,<Arguments array> ConnectionProfiles,<Arguments array>
IPCC,<Arguments array> CtiOsA, Machine1 PortA, 42028 ... CustomName, CustomValue Aspect,<Arguments array> CtiOsA, Machine2 PortA, 42028 ... CustomName, CustomeValue ...
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-12
Release 8.0(1)
Chapter 6
SilentMonitorService Subkey The <profile_name>/SilentMonitorService subkey contains parameters that clients use to connect to one of a set of silent monitor services. It contains the following keys.
Note
Description Port on which the silent monitor service is listening for incoming connections. QOS setting for the connection. Amount of time in milliseconds between heartbeats. Number of missed heartbeats before the connection is abandoned. A key that contains a list of silent monitor services to which the CIL tries to connect. The CIL randomly chooses one of the services in this list. This key contains two subkeys.
1 - index of the first silent monitor service N - index of the Nth silent monitor service SilentMonitorService - host name or IP adress of the silent monitor service.
ScreenPreferences Arguments array that contains the information configured in the CTI OS server registrys ScreenPreferences/Name subtree. The ScreenPreferences array contains an element MainScreen, which is an Arguments array that contains the following key-value pairs:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-13
Table 6-11
You can add custom keys to the CTI OS registry in the ScreenPreferences subtree at the same level as the MainScreen key. The ScreenPreferences Arguments array within this event will contain items corresponding to these custom keys. Any custom key that you add must follow the same hierarchy in the registry as that used by the existing top level keys. Registry values added to the MainScreen registry key on the CTI OS server are passed to the client in the OnGlobalSettingsDownloadConf event. Subkeys added to the MainScreen registry key are not passed in this event. The format of the ScreenPreferences Arguments array follows.
ScreenPreferences, <Arguments array> MainScreen, <Arguments array>
BringToFrontOnCall, 1 FlashOnCall, 0
...
SoundPreferences Arguments array that contains information configured on the CTI OS server in the SoundPreferences/Name subtree. This array includes a nested Arguments array that includes a setting for each sound, including .wav files to be played, and whether or not each one is mute. It may also include custom name/value pairs for a custom application. The SoundPreferences array contains the following key-value pairs:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-14
Release 8.0(1)
Chapter 6
Table 6-12
Keyword DTMF
*
DialTone*
* Registry values added to this registry key in the CTI OS server registry are included in the arguments array. Subkeys
added to this registry key are not present.
The DTMF, DialTone, OriginatingTone, RingInTone, and All arrays each contain the keyword Mute, which has a boolean value. Custom registry values added to the DialTone DTMF, DialTone, OriginatingTone, RingInTone, and All registry keys are present in the array. Subkeys added to the these registry keys are not present in the array. You can add custom keys in the SoundPreferences subtree at the same level as the All, DTMF, DialTone, OriginatingTone, and RingInTone keys. The SoundPreferences array contains items corresponding to these custom keys. Any custom element that you add must follow the same hierarchy in the registry as that used by the existing top level elements. The format of the SoundPreferences Arguments array follows.
SoundPreferences,<Arguments array> All,<Arguments array> Mute, 0 CustomName, CustomValue DTMF,<Arguments array> Mute, 0 CustomName, CustomValue CustomerName,<Arguments array> CustomeName, CustomValue ...
This configuration is stored in the Windows System Registry database and many of the values are set when the CTI OS Server Setup is run. Custom configuration can be set at a later time by using the Windows Registry Editor.
OnHeartbeat
The OnHeartbeat event is generated when a heartbeat response is received from a CTI OS server. It returns the time of day.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-15
Syntax
C++:void OnHeartbeat(Arguments& args) COM: void Onheartbeat (IArguments * args) VB: session_OnHeartbeat (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-13 Heartbeat Parameters
Keyword EventTime
Type INT
OnMissingHeartbeat
The OnMissingHeartbeat event is generated when an expected heartbeat is not received. It returns the number of consecutive heartbeats missed and time of day. When the number of heartbeats missed equals or exceeds the maximum number of heartbeats allowed (set in the MaxHeartbeats property), an OnConnectionFailure event is generated instead of an OnMissingHeartbeat event, and the CIL automatically attempts to reconnect to the CTI OS server, alternating between the CtiosA and CtiosB servers passed as parameters in the Connect method.
Syntax
C++: COM: VB:
void OnMissingHeartbeat(Arguments& args) void OnMissingHeartbeat (IArguments * args) session_OnMissingHeartbeat (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-14 OnMissingHeartbeat Parameters
Description Integer value with time of day expressed in milliseconds. Integer value with the number of heartbeats missed. Integer value with the heartbeat interval, in milliseconds.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-16
Release 8.0(1)
Chapter 6
OnMonitorModeEstablished
The OnMonitorModeEstablished event is generated when Monitor Mode is established.
Syntax
C++:void OnMonitorModeEstablished(Arguments& args) COM: void OnMonitorModeEstablished (IArguments * args) VB: session_OnMonitorModeEstablished (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-15 OnMonitorModeEstablished Parameters
Description ID of the clients connection on the server. Arguments array containing the following elements:
StatusCTIServer StatusCtiServerDriver StatusCentralController StatusPeripherals (Arguments array with a peripheral ID for each key and a boolean true/false value indicating if that peripheral is online)
OnSnapshotDeviceConf
The OnSnapshotDeviceConf confirmation message is fired to the client as part of a snapshot operation. For AgentMode clients, the OnSnapshotDeviceConf will arrive at startup time, after the OnQueryAgentStateConf message. The OnSnapshotDeviceConf indicates the number of calls present at the device, and their UniqueObjectIDs.
Syntax
C++:void OnSnapshotDeviceConf (Arguments & args); COM:HRESULT OnSnapshotDeviceConf ([in] IArguments * args); VB:Session_ OnSnapshotDeviceConf (ByVal args as CTIOSCLIENTLIB.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-17
Parameters
args Arguments array containing the following fields.
Table 6-16 OnSnapshotDeviceConf Parameters
Keyword UniqueObjectID
Description Unique ID of the device object on the server. There are no device objects in the CIL, so this keyword cannot be used to retrieve a device object at this point.
Type STRING
NumCalls ValidCalls
The number of active calls associated with this device, up to a SHORT maximum of 16. An arguments array containing the list of calls on the device. ARGUMENTS The Unique ObjectID of each call is a key in the Arguments object. The value is a boolean indicating if the call is valid. Calls not listed are not valid calls on the device.
Remarks
The CIL uses this event to rectify the list of calls on a device when logging in after a failover, in case the status of calls on the device changes during the failure period. An example of such a scenario would be an agent talking on a call on a hardphone and a CTI failure occurs. The agent hangs up the call before CTI is recovered. Once CTI and the CIL recover, they use the snapshot to discover that the call it currently has is no longer on the device. CTI then fires an EndCall event to remove the call from its call list.
OnSnapshotSkillGroupList
Not supported.
OnTranslationRoute
The OnTranslationRoute event is a pre-call indication. The event indicates the pending arrival of a call, and provides early access to the call context information. From a call flow perspective, this event can be used to begin an application or database lookup for the call context data before the call actually arrives at the agents teleset. The contact is uniquely identified by the ICMEnterpriseUniqueID, which is a field based on the Unified ICMs 64-bit unique key (RouterCallKeyDay and RouterCallKeyCallID). This event does not indicate the creation of a Call object on the CTI OS server only that the contact is being tracked. This is sufficient to be able to get and set data, which enables some powerful data-prefetching applications. When a OnCallBeginEvent follows for this same contact, the ICMEnterpriseUniqueID field will be send along with the call data. At that point, a custom application can set the call data on the appropriate call object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-18
Release 8.0(1)
Chapter 6
Syntax
C++:void OnTranslationRoute(Arguments& args) COM:void OnTranslationRoute(IArguments * args) VB: session_OnTranslationRoute(ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-17 OnTranslationRoute Parameters
Keyword
Type
Description This string is a globally unique key for this contact, which corresponds to the Unified ICM 64 bit key. This parameter can be used to match this contact to a follow-on call event. Together with the RouterCallKeyCallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation-routed calls. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight. Together with RouterCallKeyDay and RouterCallKeyCallID fields forms the TaskID. Number of Named variables. Number of Named Arrays. The calling line ID of the caller. The ISDN user-to-user information element. The DNIS number to which this call will arrive on the ACD/PBX. The number dialed. The digits entered by the caller in response to IVR prompting. Call-related variable data. Call-related variable data.
ICMEnterpriseUniqueID STRING
RouterCallKeyDay
INT
RouterCalKeyCallID RouterCallKey SequenceNumber NumNamedVariables NumNamedArrays ANI UserToUserInfo DNIS DialedNumber CallerEnteredDigits CallVariable1 CallVariable10 ECC
INT INT SHORT SHORT STRING STRING STRING STRING STRING STRING STRING
ARGUMENTS A nested Arguments structure of key-value pairs for all of the ECC data arriving with this call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-19
ICallEvents Interface
The Call object fires events on the ICallEvents interface. The following events are published to subscribers of the ICallEvents interface.
Note
Many of the parameters that CTI OS receives from the CTI Server are inconsequential to most customer applications. The most important parameters for doing a screenpop are included with the events described in this section. The more inconsequential parameters are suppressed at the CTI OS Server, to minimize network traffic to the clients. However, you can enable the complete set of available event arguments by setting the following registry setting:
OnAgentPrecallEvent
Note
The OnAgentPrecallEvent event is applicable to Unified CCE only. The equivalent on all other TDM events is TranslationRouteEvent. The OnAgentPrecallEvent event is a pre-call indication that indicates the pending arrival of a call and provides early access to the call context information. From a call flow perspective, this event can be used to begin an application or database lookup for the call context data before the call actually arrives at the agents teleset. The contact is uniquely identified by the ICMEnterpriseUniqueID, which is a field based on the Unified ICMs 64-bit unique key (RouterCallKeyDay and RouterCallKeyCallID). This event does not indicate the creation of a Call object on the CTI OS server only that the contact is being tracked. This is sufficient to be able to get and set data, which enables some powerful data-prefetching applications. When an OnCallBeginEvent follows for this same contact, the ICMEnterpriseUniqueID field will be send along with the call data. At that point, a custom application can set the call data on the appropriate call object.
Syntax
C++:void OnAgentPrecallEvent(Arguments& args) COM: void OnAgentPrecallEvent (IArguments * args) VB: session_OnAgentPrecallEvent (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-20
Release 8.0(1)
Chapter 6
Parameters
args Arguments array containing the following fields.
Table 6-18 OnAgentPrecallEvent Parameters
Keyword
Type
Description This string is a globally unique key for this contact, which corresponds to the Unified ICM 64 bit key. This parameter can be used to match this contact to a follow-on call event. Together with the RouterCallKeyCallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation-routed calls. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight. The agent instrument that the call will be routed to. Number of Named variables. Number of Named Arrays. The service that the call is attributed to, as known to the peripheral. The Unified ICM ServiceID of the service that the call is attributed to. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. The priority of the skill group, or 0 when skill group priority is not applicable or not available. The calling line ID of the caller. The ISDN user-to-user information element. The DNIS number to which this call will arrive on the ACD/PBX. The number dialed. The digits entered by the caller in response to IVR prompting. Call-related variable data. Call-related variable data.
ICMEnterpriseUniqueID STRING
RouterCallKeyDay
INT
RouterCalKeyCallID AgentInstrument NumNamedVariables NumNamedArrays ServiceNumber ServiceID SkillGroupNumber SkillGroupID SkillGroupPriority ANI UserToUserInfo DNIS DialedNumber CallerEnteredDigits CallVariable1 CallVariable10 ECC
INT STRING SHORT SHORT INT INT INT INT SHORT STRING STRING STRING STRING STRING STRING STRING
ARGUMENTS A nested Arguments structure of key-value pairs for all of the ECC data arriving with this call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-21
CallTypeIDTag PreCallInvokeIDTag
INT INT
Specifies CallType of the call and indicates that the agent is reserved via LegacyPreCall. Specifies the invoking of the LegacyPreCall.
OnAgentPrecallAbortEvent
Note
The OnAgentPrecallAbortEvent event is applicable to Unified CCE only. The OnAgentPrecallAbortEvent event is received only if a previously indicated routing (OnAgentPrecallEvent) decision is reversed. The contact is uniquely identified by the ICMEnterpriseUniqueID, which is a field based on the Unified ICMs 64-bit unique key (RouterCallKeyDay and RouterCallKeyCallID). Upon receipt of an OnAgentPrecallAbortEvent, any data pre-fetch work that was started on an OnAgentPrecallEvent should be cleaned up.
Syntax
C++:void OnAgentPrecallAbortEvent(Arguments& args) COM: void OnAgentPrecallAbortEvent (IArguments * args) VB: session_OnAgentPrecallAbortEvent (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-19 OnAgentPrecallAbortEvent Parameters
Keyword
Type
Description This string is a globally unique key for this contact, which corresponds to the Unified ICM 64 bit key. This parameter can be used to match this contact to a follow-on call event. Together with the RouterCallKey CallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation- routed calls. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight. The agent instrument that the call will be routed to.
ICMEnterpriseUniqueID STRING
RouterCallKeyDay
INT
RouterCalKeyCallID AgentInstrument
INT STRING
OnAlternateCallConf
The OnAlternateCallConf event is fired to the client to indicate that an Alternate request was received by the CTI Server
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-22
Release 8.0(1)
Chapter 6
Syntax
C++:void OnAlternateCallConf (Arguments & args); COM: HRESULT OnAlternateCallConf ([in] IArguments * args); VB:Session_ OnAlternateCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-20 OnAlternateCallConf Parameters
Keyword UniqueObjectID
Type STRING
OnAnswerCallConf
The OnAnswerCallConf event is fired to the client to indicate that an Answer request was received by the CTI Server.
Syntax
C++: void OnAnswerCallConf (Arguments & args); COM:HRESULT OnAnswerCallConf ([in] IArguments * args); VB: Session_ OnAnswerCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-21 OnAnswerCallConf Parameters
Keyword UniqueObjectID
Type STRING
OnCallBegin
The OnCallBegin event is generated at the first association between a call and the CTI Client. The event passes the call identifier and the initial call context data. The ConnectionCallID identifies the call. This message always precedes any other event messages for that call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-23
Subsequent changes to the call context data (if any) are signalled by an OnCallDataUpdate event containing the changed call data.
Note
Syntax
C++: COM: VB:
void OnCallBegin(Arguments& args) void OnCallBegin (IArguments * args) session_OnCallBegin (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-22 OnCallBegin Parameters
Description The Unified ICM PeripheralID of the ACD where the call activity occurred. The type of the peripheral. The general classification of the call type. An object ID that uniquely identifies the call object. Together with the RouterCallKeyCallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation-routed calls. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight. Together with RouterCallKeyDay and RouterCallKeyCallID fields forms the TaskID. The Call ID value assigned to this call by the peripheral or the Unified ICM. The calling line ID of the caller. The DNIS provided with the call. The ISDN user-to-user information element. unspecified, up to 131 bytes. The number dialed. The digits entered by the caller in response to IVR prompting. The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available.
RouterCalKeyCallID RouterCallKey SequenceNumber ConnectionCallID ANI (optional) DNIS (optional) UserToUserInfo (Optional) DialedNumber (Optional) CallerEnteredDigits (Optional) ServiceNumber (Optional)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-24
Release 8.0(1)
Chapter 6
Type INT
Description The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_SKILL_ GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The priority of the skill group, or 0 when skill group priority is not applicable or not available. Call-related wrap-up data. Call-related variable data.
SkillGroupNumber (Optional)
INT
SkillGroupID (Optional)
INT
SkillGroupPriority (Optional) CallWrapupData (Optional) CallVariable1 (Optional) CallVariable10 (Optional) CallStatus (optional) ECC (optional)
STRING SHORT
ARGUMENTS Arguments array that contains all of the Expanded Call Context variables in use; for example:
user.ArrayVariable[0] user.ArrayVariable[1] ... user.ArrayVariable[n] user.ScalarVariable CTIClients (optional) ARGUMENTS Arguments array that contains the information about the number of clients that are using the call object; for example: CTIClient[1] CTIClientSignature CTIClientTimestamp ICMEnterprise UniqueID (optional) STRING Required only when the call is pre-routed.
OnCallCleared
An OnCallCleared event is generated when the voice portion of all parties on a call is terminated, normally when the last device disconnects from a call. With this event the connection status becomes LCS_NULL.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-25
Note
If the CallCleared event is received after having received a CallFailed event, note that the event will not include a CallStatus since it is important to preserve the fact that the call failed (maintaining the CallStatus of LSC_Fail). Because of this exception, the CallStatus of the CallCleared event is optional.
Syntax
C++:void OnCallDelivered(Arguments& args) COM: void OnCallCleared (IArguments * args) VB: session_OnCallCleared (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-23 OnCallCleared Parameters
Description Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. An object ID that uniquely identifies the call object. The current status of the call. Required only when the call is pre-routed.
OnCallConnectionCleared
An OnCallConnectionCleared event is generated when a party drops from a call. With this event the connection status becomes LCS_NULL.
Note
If the CallConnectionCleared event is received after having received a CallFailed event, note that the event will not include a CallStatus since it is important to preserve the fact that the call failed (maintaining the CallStatus of LSC_Fail). Because of this exception, the CallStatus of the CallConnectionCleared event is optional.
Syntax
C++: COM: VB:
void OnCallConnectionCleared(Arguments& args) void OnCallConnectionCleared (IArguments * args) session_OnCallConectionCleared (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-26
Release 8.0(1)
Chapter 6
Parameters
args Arguments array containing the following fields.
Table 6-24 OnCallConnectionCleared Parameters
Type INT
Description Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. The current status of the call.
STRING Required only when the call is pre-routed. ICMEnterprise UniqueID (Optional)
OnCallConferenced
The joining of calls into a conference call or the adding of a new call joining a conference may generate an OnCallConferenced event. With this event, the connections at the controllers device merge to become one connection with a status of LCS_CONNECT, and the status of the connections at the original callers device and at the consulted device remain unchanged.
Syntax
C++:void OnCallConferenced(Arguments& args) COM: void OnCallConferenced (IArguments * args) VB: session_OnCallConferenced (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-25 OnCallConferenced Parameters
Description The Unified ICM PeripheralID of the ACD where the call activity occurred. The type of the peripheral. The general classification of the call type. An object ID that uniquely identifies the call object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-27
Keyword RouterCallKeyDay
Type INT
Description Together with the RouterCallKeyCallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation-routed calls. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight. The Call ID value assigned to this call by the peripheral or the Unified ICM. The calling line ID of the caller. The DNIS provided with the call. The ISDN user-to-user information element. unspecified, up to 131 bytes. The number dialed. The digits entered by the caller in response to IVR prompting. The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The priority of the skill group, or 0 when skill group priority is not applicable or not available. Call-related wrap-up data. Call-related variable data.
RouterCalKeyCallID ConnectionCallID ANI (optional) DNIS (optional) UserToUserInfo (Optional) DialedNumber (Optional) CallerEnteredDigits (Optional) ServiceNumber (Optional) ServiceID (Optional)
INT
SkillGroupNumber (Optional)
INT
SkillGroupID (Optional)
INT
SkillGroupPriority (Optional) CallWrapupData (Optional) CallVariable1 (Optional) CallVariable10 (Optional) CallStatus (optional)
STRING SHORT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-28
Release 8.0(1)
Chapter 6
Type
Description
ARGUMENTS Arguments array that contains all of the Expanded Call Context variables in use; for example:
user.ArrayVariable[0] user.ArrayVariable[1] ... user.ArrayVariable[n] user.ScalarVariable CTIClients (Optional) ARGUMENTS Arguments array that contains the information about the number of clients that are using the call object; for example: CTIClient[1] CTIClientSignature CTIClientTimestamp ICMEnterpriseUnique ID (Optional) STRING Required only when the call is pre-routed.
OnCallDataUpdate
Changes to the call context data will generate an OnCallDataUpdate event. Only the items that have changed will be in the event argument array. The initial call context is provided in the OnCallBegin event.
Syntax
C++: COM: VB:
void OnCallDataUpdate(Arguments& args) void OnCallDataUpdate (IArguments * args) session_OnCallDataUpdate (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-29
Parameters
args Arguments array containing the following fields.
Table 6-26 OnCallUpdate Parameters
Description The Unified ICM PeripheralID of the ACD where the call activity occurred. The type of the peripheral. The general classification of the call type. An object ID that uniquely identifies the call object. Together with the RouterCallKeyCallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation-routed calls. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight. Together with RouterCallKeyDay and RouterCallKeyCallID fields forms the TaskID. The Call ID value assigned to this call by the peripheral or the Unified ICM. The calling line ID of the caller. The DNIS provided with the call. The ISDN user-to-user information element. unspecified, up to 131 bytes. The number dialed. The digits entered by the caller in response to IVR prompting. The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The priority of the skill group, or 0 when skill group priority is not applicable or not available.
RouterCalKeyCallI D RouterCallKey SequenceNumber ConnectionCallID ANI (optional) DNIS (optional) UserToUserInfo (Optional) DialedNumber (Optional) CallerEnteredDigits (Optional) ServiceNumber (Optional)
INT
INT
SHORT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-30
Release 8.0(1)
Chapter 6
STRING
ARGUMENTS Arguments array that contains all of the Expanded Call Context variables in use; for example:
user.ArrayVariable[0] user.ArrayVariable[1] ... user.ArrayVariable[n] user.ScalarVariable CTIClients (Optional) ARGUMENTS Arguments array that contains the information about the number of clients that are using the call object; for example: CTIClient[1] CTIClientSignature CTIClientTimestamp ICMEnterprise STRING UniqueID (Optional) Required only when the call is pre-routed.
OnCallDelivered
The OnCallDelivered event may be generated when the call arrives at the agents teleset. Both parties (call connections) receive this event. With this event, the called partys connection status becomes LCS_ALERTING but the calling partys connection status remains LCS_INITIATE.
Note
With certain switches, when a call is made outside of the ACD, this event may not be received. See OnCallReachedNetwork for more detail.
Syntax
C++: COM: VB:
void OnCallDelivered(Arguments& args) void OnCallDelivered (IArguments * args) session_OnCallDelivered (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-31
Parameters
args Arguments array containing the following fields.
Table 6-27 OnCallDelivered Parameters
Keyword ServiceNumber
Type INT
Description The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The priority of the skill group, or 0 when skill group priority is not applicable or not available. Indicates the type of the teleset line. Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. See Table 3-2. An object ID that uniquely identifies the call object. The current status of the call. Required only when the call is pre-routed.
ServiceID
INT
SkillGroupNumber (Optional)
INT
UniqueObjectID CallStatus
STRING SHORT
ICMEnterpriseUniqueID STRING (Optional) TrunkNumber (optional) TrunkGroup Number (optional) INT INT
OnCallDequeuedEvent
The explicit removal of a call from the ACD queue may generate a OnCallDequeuedEvent message to the CTI Client.
Syntax
C++: COM: VB:
void OnCallDequeuedEvent(Arguments& args) void OnCallDequeuedEvent (IArguments * args) session_OnCallDequeuedEvent (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-32
Release 8.0(1)
Chapter 6
Parameters
args Arguments array containing the following fields. Keyword Connection DeviceID ConnectionDevice IDType EventCause LineHandle LineType ServiceID ServiceNumber NumQueued NumSkillGroups Type INT SHORT Description The identifier of the connection between the call and the device. Indicates the type of the connection identifier supplied in the ConnectionDeviceID. The state of the local end of the connection. Indicates a reason or explanation for the occurrence of the event. Identifies the teleset line being used. Indicates the type of the teleset line. The Unified ICM ServiceID of the service that the call is attributed to. The service that the call is attributed to, as known to the peripheral. The number of calls in the queue for this service. The number of Skill Groups that the call has been removed from, up to a maximum of 99.
LocalConnection State SHORT SHORT SHORT SHORT INT INT SHORT SHORT
OnCallDiverted
The removal of a call from one delivery target and forwarded to a different target may generate an OnCallDiverted event.
Syntax
C++: COM: VB:
void OnCallDiverted(Arguments& args) void OnCallDiverted (IArguments * args) session_OnCallDiverted (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields. Keyword UniqueObjectID PeripheralID PeripheralType ConnectionDevice IDType Type STRING INT SHORT SHORT Description Unique reference generated for a call at client. The Unified ICM PeripheralID of the ACD where the call activity occurred. The type of the peripheral. Indicates the type of ConnectionDeviceID value.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-33
Description The device identifier of the connection between the call and the device. The Call ID value assigned to this call by the peripheral or the Unified ICM. The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. Indicates the type of the device identifier supplied in the DivertingDeviceID field. Indicates the type of the device identifier supplied in the CalledDeviceID field. The state of the local end of the connection. Indicates a reason or explanation for the occurrence of the event. The device identifier of the device from which the call was diverted. The device identifier of the device to which the call was diverted.
ServiceID
INT
DivertingDevice Type CalledDeviceType LocalConnection State EventCause DivertingDeviceID (Optional) CalledDeviceID (Optional)
OnCallEnd
The OnCallEnd event is generated when the association between a call and the CTI Client is dissolved. The OnCallEnd event is the last event received for a Call.
Syntax
C++: COM: VB:
void OnCallEnd(Arguments& args) void OnCallEnd (IArguments * args) session_OnCallEnd (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-34
Release 8.0(1)
Chapter 6
Parameters
args Arguments array containing the following fields.
Table 6-28 OnCallEnd Parameters
Description An object ID that uniquely identifies the call object. The current status of the call. Required only when the call is pre-routed.
OnCallEstablished
The OnCallEstablished event may be generated when the call is answered at the agents teleset. Both parties (call connections) receive this event when the call is answered. With this event, the call status of both parties becomes LCS_CONNECT.
Note
With certain switches, when a call is made outside of the ACD, this event may not be received. See OnCallReachedNetwork for more detail.
Syntax
C++: void OnCallEstablished(Arguments& args) COM:void OnCallEstablished (IArguments * args) VB: session_OnCallEstablished (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-29 OnCallEstablished Parameters
Keyword ServiceNumber
Type INT
Description The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_ SERVICE when not applicable or not available. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available.
ServiceID
INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-35
Type INT
Description The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The priority of the skill group, or 0 when skill group priority is not applicable or not available. Indicates the type of the teleset line. Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. See Table 3-2. An object ID that uniquely identifies the call object. The current status of the call. Required only when the call is pre-routed. The number representing a trunk. The number representing a trunk group.
UniqueObjectID CallStatus
STRING SHORT
ICMEnterpriseUniqueID STRING (Optional) TrunkNumber (optional) TrunkGroup Number (optional) INT INT
OnCallFailed
The OnCallFailed event may be generated when a call cannot be completed. With this event the connection status becomes LCS_FAIL. This would most likely happen as a result of a MakeCall or a MakeConsultCall request, but can occur at any other point in the calls lifetime if the call fails on an ACD. In this case, you should perform any required cleanup prior to arrival of an EndCall event.
Note
The events (CallConnectionCleared and CallCleared) received after the CallFailed event will not include a CallStatus, because until the call has ended, it is important to preserve the fact that this is a failed call.
Syntax
C++: COM: VB:
void OnCallFailed(Arguments& args) void OnCallFailed (IArguments * args) session_OnCallFailed (ByVal args As CtiosCLIENTLib.IArguments
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-36
Release 8.0(1)
Chapter 6
Parameters
args Arguments array containing the following fields.
Table 6-30 OnCallFailed Parameters
Description Contains the bit mask that specifies what buttons can be enabled or disabled when this call is the current call. An object ID that uniquely identifies the call object. The current status of the call.
OnCallHeld
Placing a call on hold at the agents teleset may generate an OnCallHeld event. With this event the connection status becomes LCS_HELD.
Syntax
C++:void OnCallHeld(Arguments& args) COM: void OnCallHeld (IArguments * args) VB: session_OnCallHeld (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-31 OnCallHeld Parameters
Description Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. An object ID that uniquely identifies the call object. The current status of the call. Required only when the call is pre-routed.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-37
OnCallOriginated
The initiation of a call from the peripheral may generate an OnCallOriginated event. Only the connection making the call receives this event. With this event the connection status becomes LCS_INITIATE.
Syntax
C++: COM: VB:
void OnCallOriginated(Arguments& args) void OnCallOriginated (IArguments * args) session_OnCallOriginated (ByVal args As CtiosCLIENTLib.IArguments
Parameters
args Arguments array containing the following fields.
Table 6-32 OnCallOriginatedParameters
Keyword ServiceNumber
Type INT
Description The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_ GROUP when not applicable or not available. The priority of the skill group, or 0 when skill group priority is not applicable or not available. Indicates the type of the teleset line. Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. An object ID that uniquely identifies the call object. The current status of the call.
ServiceID
INT
SkillGroupNumber (Optional) SkillGroupID (Optional) SkillGroupPriority (Optional) LineType EnablementMask UniqueObjectID CallStatus
INT
INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-38
Release 8.0(1)
Chapter 6
OnCallQueuedEvent
The placing of a call in a queue pending the availability of some resource may generate an OnCallQueuedEvent message to the CTI Client. Clients with Client Events Service may receive this message when an outbound call is queued waiting for a trunk or other resource. Clients with All Events Service may also receive this message when inbound calls are queued.
Syntax
C++: COM: VB:
void OnCallQueuedEvent(Arguments& args) void OnCallQueuedEvent (IArguments * args) session_OnCallQueuedEvent (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-33 OnCallQueuedEvent Parameters
Keyword Connection DeviceID ConnectionDevice IDType QueuedDeviceID QueuedDeviceIDType CallingDeviceID CallingDeviceIDType CalledDeviceID CalledDeviceIDType
Description The identifier of the connection between the call and the device. Indicates the type of the connection identifier supplied in the ConnectionDeviceID The device identifier of the queuing device. Indicates the type of the device identifier supplied in the QueuedDeviceID. The device identifier of the calling device. Indicates the type of the device identifier supplied in the CalledDeviceID. The device identifier of the called device. Indicates the type of the device identifier supplied in the CalledDeviceID. The device identifier of the redirecting device. Indicates the type of the device identifier supplied in the LastRedirectDeviceID. The state of the local end of the connection. Indicates a reason or explanation for the occurrence of the event. Identifies the teleset line being used. Indicates the type of the teleset line. The Unified ICM ServiceID of the service that the call is attributed to.
LastRedirectedDeviceID STRING LastRedirected DeviceIDType LocalConnection State EventCause LineHandle LineType ServiceID SHORT SHORT SHORT SHORT SHORT INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-39
Description The service that the call is attributed to, as known to the peripheral. The number of calls in the queue for this service. The number of Skill Group queues that the call has queued to, up to a maximum of 50.
OnCallReachedNetworkEvent
The connection of an outbound call to another network may generate an OnCallReachedNetworkEvent. With some switches outside of the ACD, this may be the last event the outbound connection receives. For these switches, you may not assume that when the called party receives and answers the call that the OnCallDelivered and OnCallEstablished events will be received.
Syntax
C++: COM: VB:
void OnCallReachedNetworkEvent(Arguments& args) void OnCallReachedNetworkEvent (IArguments * args) session_OnCallReachedNetworkEvent (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-34 OnCallReachedNetworkEvent Parameters
Description The identifier of the connection between the call and the device. Indicates the type of the connection identifier supplied in the ConnectionDeviceID. The device identifier of the selected trunk. Indicates the type of the device identifier supplied in the TrunkUsedDeviceID. The device identifier of the called device. Indicates the type of the device identifier supplied in the CalledDeviceID. The state of the local end of the connection. Indicates a reason or explanation for the occurrence of the event. Identifies the teleset line being used. Indicates the type of the teleset line.
TrunkUsedDeviceID STRING TrunkUsedDeviceID SHORT Type CalledDeviceID STRING CalledDeviceIDType SHORT LocalConnection State EventCause LineHandle LineType SHORT SHORT SHORT SHORT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-40
Release 8.0(1)
Chapter 6
Type INT
Description The number representing a trunk. The number representing a trunk group.
OnCallRetrieved
Resuming a call previously placed on hold at the agents teleset may generate an OnCallRetrieved event. With this event the connection status becomes LCS_CONNECT.
Syntax
C++: COM: VB:
void OnCallRetrieved(Arguments& args) void OnCallRetrieved (IArguments * args) session_OnCallRetrieved (ByVal args As CtiosCLIENTLib.IArguments
Parameters
args Arguments array containing the following fields.
Table 6-35 OnCallRetrieved Parameters
Description Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. An object ID that uniquely identifies the call object. The current status of the call.
OnCallServiceInitiatedEvent
The initiation of telecommunications service (dial tone) at the agents teleset may generate an OnCallServiceInitiatedEvent to the CTI Client. However, when the call is made through the software there is no way to detect the equivalent of the phone off hook. Therefore, after a call is made this event is received in sequence along with the OnCallOriginated and OnCallDelivered events. With this event the connection status becomes LCS_INITIATE.
Syntax
C++: COM: VB:
void OnCallServiceInitiatedEvent(Arguments& args) void OnCallServiceInitiatedEvent (IArguments * args) session_OnCallServiceInitiatedEvent (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-41
Parameters
args Arguments array containing the following fields.
Table 6-36 OnCallServiceInitiatedEvent Parameters
Keyword ServiceNumber
Type INT
Description The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The priority of the skill group, or 0 when skill group priority is not applicable or not available. Indicates the type of the teleset line. Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. An object ID that uniquely identifies the call object. The current status of the call.
ServiceID
INT
SkillGroupNumber (Optional) SkillGroupID (Optional) SkillGroupPriority (Optional) LineType EnablementMask UniqueObjectID CallStatus
INT
INT
OnCallStartRecordingConf
The OnCallStartRecordingConf event is fired to the client to indicate that a StartRecord request was received by the CTI Server.
Syntax
C++: COM: VB:
void OnCallStartRecordingConf (Arguments & args); HRESULT OnCallStartRecordingConf ([in] IArguments * args); Session_ OnCallStartRecordingConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-37 OnCallStartRecordingConf Parameters
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-42
Release 8.0(1)
Chapter 6
Keyword UniqueObjectID
Type STRING
OnCallStopRecordingConf
The OnCallStopRecordingConf event is fired to the client to indicate that a StopRecord request was received by the CTIServer.
Syntax
C++: COM: VB:
void OnCallStopRecordingConf (Arguments & args); HRESULT OnCallStopRecordingConf ([in] IArguments * args); Session_ OnCallStopRecordingConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-38 OnCallStopRecordingConf Parameters
Keyword UniqueObjectID
Type STRING
OnCallTransferred
The transfer of a call to another destination may generate an OnCallTransferred event. With this event the two connections at the controllers device end and the status of the connections at the original callers device and the consulted device are unchanged.
Syntax
C++: COM: VB:
void OnCallTransferred(Arguments& args) void OnCallTransferred (IArguments * args) session_OnCallTransferred (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-39 OnCallTransferred Parameters
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-43
Description The Unified ICM PeripheralID of the ACD where the call activity occurred. The type of the peripheral. The general classification of the call type. An object ID that uniquely identifies the call object. Together with the RouterCallKeyCallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation-routed calls. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight. The Call ID value assigned to this call by the peripheral or the Unified ICM. The calling line ID of the caller. The DNIS provided with the call. The ISDN user-to-user information element. unspecified, up to 131 bytes. The number dialed. The digits entered by the caller in response to IVR prompting. The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The priority of the skill group, or 0 when skill group priority is not applicable or not available. Call-related wrap-up data. Call-related variable data. Call-related variable data.
RouterCalKeyCallID ConnectionCallID ANI (optional) DNIS (optional) UserToUserInfo (Optional) DialedNumber (Optional) CallerEnteredDigits (Optional) ServiceNumber (Optional) ServiceID (Optional)
INT
SkillGroupNumber (Optional)
INT
SHORT STRING
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-44
Release 8.0(1)
Chapter 6
Type SHORT
ARGUMENTS Arguments array that contains all of the Expanded Call Context variables in use; for example:
user.ArrayVariable[0] user.ArrayVariable[1] ... user.ArrayVariable[n] user.ScalarVariable CTIClients (Optional) ARGUMENTS Arguments array that contains the information about the number of clients that are using the call object; for example: CTIClient[1] CTIClientSignature CTIClientTimestamp ICMEnterpriseUniqueID STRING (Optional) Required only when the call is pre-routed.
OnClearCallConf
The OnClearCallConf event is fired to the client to indicate that a Clear request was received by the CTIServer.
Syntax
C++: void OnClearCallConf (Arguments & args); COM: HRESULT OnClearCallConf ([in] IArguments * args); VB:Session_ OnClearCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-40 OnClearCallConf Parameters
Keyword UniqueObjectID
Type STRING
OnClearConnectionConf
The OnClearConnectionConf event is fired to the client to indicate that a ClearConnection request was received by the CTIServer.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-45
Syntax
C++: void OnClearConnectionConf (Arguments & args); COM:HRESULT OnClearConnectionConf ([in] IArguments * args); VB: Session_ OnClearConnectionConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-41 OnClearConnectionConf Parameters
Keyword UniqueObjectID
Type STRING
OnConferenceCallConf
The OnConferenceCallConf event is fired to the client to indicate that a ConferenceCall or SingleStepConferenceCall request was received by the CTIServer.
Syntax
C++: void OnConferenceCallConf (Arguments & args); COM: HRESULT OnConferenceCallConf ([in] IArguments * args); VB: Session_ OnConferenceCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-42 OnConferenceCallConf Parameters
OnConsultationCallConf
The OnConsultationCallConf event is fired to the client to indicate that a MakeConsultCall request was received by the CTIServer.
Syntax
C++: void OnConsultationCallConf (Arguments & args); COM: HRESULT OnConsultationCallConf ([in] IArguments * args); VB:Session_ OnConsultationCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-46
Release 8.0(1)
Chapter 6
Parameters
args Arguments array containing the following field.
Table 6-43 OnConsulationCallConf Parameters
Keyword UniqueObjectID
Type STRING
OnControlFailureConf
The OnControlFailureConf event is generated when a request to the peripheral (the ACD) fails.
Syntax
C++:void OnControlFailureConf(Arguments& args) COM: void OnControlFailureConf (IArguments * args) VB: session_OnControlFailureConf (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-44 OnControlFailureConf Parameters
Description Peripheral ID. Code ID. Peripheral-specific error data, if available. Zero otherwise. Agent ID that represents a specific client. An object ID that uniquely identifies the call object. Contains the CTI OS Command Request ID that failed to execute. The message types that can be included in this parameter are those to used to control Call, Agent State and Supervisor actions. Refer to Appendix A, CTI OS Keywords and Enumerated Types for a complete list String text containing the description of the failure.
ErrorMessage
STRING
OnHoldCallConf
The OnHoldCallConf event is fired to the client to indicate that a Hold request was received by the CTIServer.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-47
Syntax
C++: void OnHoldCallConf (Arguments & args); COM: HRESULT OnHoldCallConf ([in] IArguments * args); VB: Session_ OnHoldCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-45 OnHoldCallConf Parameters
Keyword UniqueObjectID
Type STRING
OnMakePredictiveCallConf
Not supported.
OnReconnectCallConf
The OnReconnectCallConf event is fired to the client to indicate that a Reconnect request was received by the CTIServer.
Syntax
C++: void OnReconnectCallConf (Arguments & args); COM:HRESULT OnReconnectCallConf ([in] IArguments * args); VB:Session_ OnReconnectCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-46 OnMakePredictiveCallConf Parameters
Keyword UniqueObjectID
Type STRING
OnReleaseCallConf
Not supported.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-48
Release 8.0(1)
Chapter 6
OnRetrieveCallConf
The OnRetrieveCallConf event is fired to the client to indicate that a RetrieveCall request was received by the CTIServer.
Syntax
C++: void OnRetrieveCallConf (Arguments & args); COM:HRESULT OnRetrieveCallConf ([in] IArguments * args); VB: Session_ OnRetrieveCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-47 OnReleaseCallConf Parameters
Keyword UniqueObjectID
Type STRING
OnSendDTMFConf
The OnSendDTMFConf event is fired to the client to indicate that a SendDTMF request was received by the CTIServer.
Syntax
C++: void OnSendDTMFConf (Arguments & args); COM: HRESULT OnSendDTMFConf ([in] IArguments * args); VB: Session_ OnSendDTMFConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Not used; reserved for future use.
OnSetCallDataConf
The OnSetCallDataConf event is fired to the client to indicate that a SetCallData request was received by the CTIServer.
Syntax
C++: void OnSetCallConf (Arguments & args); COM: HRESULT OnClearCallConf ([in] IArguments * args); VB:Session_ OnClearCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-49
Parameters
args Arguments array containing the following field.
Table 6-48 OnReleaseCallConf Parameters
Keyword UniqueObjectID
Type STRING
OnSnapshotCallConf
The OnSnapshotCallConf event is generated when a SnapshotCall request for a specific call is successful. It will contain all the information known about the specific connection at that point in time.
Syntax
C++: COM: VB:
void OnSnapshotCallConf(Arguments& args) void OnSnapshotCallConf (IArguments * args) session_OnSnapshotCallConf (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-50
Release 8.0(1)
Chapter 6
Parameters
args Arguments array containing the following fields.
Table 6-49 OnSnapShotCallConf Parameters
Keyword PeripheralID CallType UniqueObjectID DialedNumber CallerEnteredDigits CallWrapupData CallVariable1 (Optional) CallVariable10 (Optional) CustomerPhone Number CustomerAccount Number ECC
Type INT SHORT STRING STRING STRING STRING STRING STRING STRING STRING ARGUMENTS
Description The Unified ICM PeripheralID of the ACD where the call activity occurred. The general classification of the call type. An object ID that uniquely identifies the call object. The number dialed. The digits entered by the caller in response to IVR prompting. Call-related wrap-up data. Call-related variable data. Call-related variable data. The customer phone number associated with the call. The customer account number associated with the call. Arguments array that contains all of the Expanded Call Context variables in use; for example:
user.ArrayVariable[0] user.ArrayVariable[1] ... user.ArrayVariable[n] user.ScalarVariable CTIClients (Optional) ARGUMENTS Arguments array that contains the information about the number of clients that are using the call object; for example: CTIClient[1] CTIClientSignature CTIClientTimestamp RouterCallKeyDay INT Together with the RouterCallKeyCallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation-routed calls. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight.
RouterCallKeyCallID
INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-51
Keyword NumNamedVariables NumNamedArrays NumCallDevices CalledDeviceID ConnectionCallID CallStatus ANI UserToUserInfo DNIS
Type SHORT SHORT SHORT STRING UINT SHORT STRING STRING STRING
Description Number of Named variables. Number of Named Arrays. Number of devices associated with the call. The device identifier of the called device. The Call ID value assigned to this call by the peripheral or the Unified ICM. The current status of the call. The calling line ID of the caller. The ISDN user-to-user information element associated with the call. The DNIS provided with the call.
If the MinimizeEventArgs registry entry is set to 0, the SnapshotCallConf event contains the following additional fields.
Table 6-50 SnapshotCallConf additional fields
Keyword ICMEnterpriseUnique ID
Type STRING
Description This string is a globally unique key for this contact, which corresponds to the Unified ICM 64 bit key. This parameter can be used to match this contact to a follow-on call event. The CallID value assigned to the call. Indicates the type of the connection identifier supplied in the following CallConnectionDeviceID floating field. This field always immediately follows the corresponding CallConnectionCallID field. The identifier of the call connection. This field always immediately follows the corresponding CallConnectionDeviceIDType field. The active state of the call. This field always immediately follows the corresponding CallConnection DeviceID field. Indicates the type of the device identifier supplied in the CallDeviceID field.
UINT SHORT
STRING
SHORT
CallDeviceType
SHORT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-52
Release 8.0(1)
Chapter 6
OnTransferCallConf
The OnTransferCallConf event is fired to the client to indicate that a TransferCall or SingleStepTransferCall request was received by the CTIServer.
Syntax
C++: void OnTransferCallConf (Arguments & args); COM: HRESULT OnTransferCallConf ([in] IArguments * args); VB: Session_ OnTransferCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following field.
Table 6-51 OnTransferCallConf Parameters
Keyword UniqueObjectID
Type STRING
IAgentEvents Interface
The Agent object fires events on the IAgentEvents interface. The following events are published to subscribers of the IAgentEvents interface.
OnAgentDeskSettingsConf
The OnAgentDeskSettingsConf event confirms successful completion of the request and provides the query response.
Syntax
C++:void OnAgentDeskSettings(Arguments& args) COM:void OnAgentDeskSettings (IArguments * args) VB: session_OnAgentDeskSettings (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-52 OnAgentDeskSettingsConf Parameters
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-53
Keyword InvokeID PeripheralID DeskSettingsMask WrapupData IncomingMode WrapupData OutgoingMode LogoutNon ActivityTime QualityRecordingRate RingNoAnswer Time SilentMonitor WarningMessage SilentMonitor AudibleIndication SupervisorAssist CallMethod
Description Set to the same value as the InvokeID from the corresponding request message. The Unified ICM PeripheralID of the ACD where the device is located. A bitwise combination of the Boolean desk setting Masks listed in Table 6-53. Indicates whether the agent is allowed or required to enter wrap-up data after an inbound call: 0 = Required, 1 = Optional, 2 = Not allowed, 3 = Required With WrapupData. Indicates whether the agent is allowed or required to enter wrap-up data after an outbound call: 0 = Required, 1 = Optional, 2 = Not allowed. Number of seconds on non-activity at the desktop after which the Unified ICM automatically logs out the agent. Indicates how frequently calls to the agent are recorded. Number of seconds a call may ring at the agents station before being redirected. Set when a warning message box will prompt on agent desktop when silent monitor starts. Set for an audio click at beginning of the silent monitor. Set for IPCC PIM will create a blind conference call for supervisor assist request; otherwise will create consultative call. Set for IPCC PIM will create a blind conference call for emergency call request; otherwise create a consultative call. Set for automatically record when emergency call request. Set for the recording request go through Call Manager/PIM. Auto Wrap-up time out. The dialed number identifier for new re-route destination in the case of ring no answer.
UINT
EmergencyCall Method UINT AutoRecordOn Emergency RecordingMode WorkModeTimer RingNoAnswer DN UINT UINT UINT UINT
Table 6-53
DeskSettingsMasks Values
Description Set for automatically consider the agent available after handling an incoming call.
DESK_AVAIL_AFTER_O Set for automatically consider the agent available after UTGOING_MASK handling an outbound call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-54
Release 8.0(1)
Chapter 6
Table 6-53
DeskSettingsMasks Values
Mask Name DESK_AUTO_ ANSWER_ENABLED_ MASK DESK_IDLE_REASON_ REQUIRED_MASK DESK_LOGOUT_ REASON_REQUIRED_ MASK
Description
Numeric Value
Set when the agent must enter a reason before entering the Idle state. Set when the agent must enter a reason before logging out.
0x00000008 0x00000010
DESK_SUPERVISOR_ Set when the agent can initiate supervisor assisted calls. 0x00000020 CALLS_ALLOWED_MA SK DESK_AGENT_TO_ AGENT_CALLS_ ALLOWED DESK_OUTBOUND_AC CESS_INTERNATIONA L_MASK DESK_OUTBOUND_AC CESS_PUBLIC_NET_M ASK Set when calls to other agents are allowed. 0x00000040
0x00000080
Set when the agent can initiate calls through the public network.
0x00000100
DESK_OUTBOUND_AC Set when the agent can initiate calls through the private 0x00000200 CESS_PRIVATE_NET_M network. ASK DESK_OUTBOUND_AC Set when the agent can initiate operator assisted calls. CESS_OPERATOR_ASSI STED_MASK DESK_OUTBOUND_AC CESS_PBX_MASK DESK_NON_ACD_CAL LS_ALLOWED_MASK Set when the agent can initiate outbound PBX calls. 0x00000400
0x00000800
Set when the agent can place or handle non-ACD calls. 0x00001000 0x00002000
DESK_AGENT_CAN_SE Set when the agent can select which groups they are LECT_GROUP_MASK logged into.
OnAgentInfoEvent
The OnAgentInfoEvent event is generated as a response to a query to the Agent Name Lookup Service and carries the agents name. This query is generated by the CTI OS server when it is configured to do agent name lookup. The OnAgentInfoEvent event is sent to the client if the server has obtained the information.
Syntax
C++:void OnAgentInfoEvent(Arguments& args) COM:void OnAgentInfoEvent (IArguments * args) VB: session_OnAgentInfoEvent (ByVal args As CtiosCLIENTLib.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-55
Parameters
args Arguments array containing the following fields
Table 6-54 OnAgentInfoEvent Parameters
Description A unique object ID for the agent object Agents last name Agents first name.
OnAgentStateChange
The OnAgentStateChange event is generated when the agent state at the ACD changes. This may be as a response to a Login, Logout or SetAgentState request.
Syntax
C++:void OnAgentStateChange(Arguments& args) COM: void OnAgentStateChange (IArguments * args) VB: session_OnAgentStateChange (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-55 OnAgentIStateChange Parameters
Description The Unified ICM PeripheralID of the ACD where the agent state change occurred. The type of the peripheral. One of the values in Table 6-56 representing the current overall state of the associated agent. The number of the agent SkillGroup affected by the state change, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup affected by the state change. May contain the special value NULL_SKILL_ GROUP when not applicable or not available. The number of seconds since the agent entered this state (typically 0).
SkillGroupID
INT
StateDuration
INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-56
Release 8.0(1)
Chapter 6
Keyword SkillGroupPriority EventReasonCode SkillGroupState AgentID AgentExtension CTIClientSignature (Optional) Enablement Mask UniqueObjectID AgentInstrument
Description The priority of the skill group, or 0 when skill group priority is not applicable or not available. A peripheral-specific code indicating the reason for the state change. Values representing the current state of the associated agent with respect to the indicated Agent Skill Group.
STRING The agents ACD login ID. STRING The agents ACD teleset extension. STRING The Client Signature of the CTI Client that is associated with this agent. Contains the bit-mask that specifies what buttons can be enabled or disabled when the agent is on this state. STRING A unique object ID for the agent object. STRING The agents ACD instrument number.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-57
enum Value eLogin eLogout eNotReady eAvailable eTalking eWorkNotReady eWorkReady eBusyOther eReserved eUnknown eHold
Description The agent has logged on to the ACD. It does not necessarily indicate that the agent is ready to accept calls. The agent has logged out of the ACD and cannot accept any additional calls. The agent is unavailable for any call work. The agent is ready to accept a call. The agent is currently talking on a call (inbound, outbound, or inside). The agent is performing after call work, but will not be ready to receive a call when completed. The agent is performing after call work, and will be ready to receive a call when completed. The agent is busy performing a task associated with another active SkillGroup. The agent is reserved for a call that will arrive at the ACD shortly. The agent state is currently unknown. The agent currently has all calls on hold.
Numeric Value 0 1 2 3 4 5 6 7 8 9 10
Note
Not all switches support all the states listed in Table 6-56, and no assumptions should be made about which states are supported on a particular switch without verification.
OnAgentStatistics
The OnAgentStatistics event is fired to the client to indicate that a request to enable agent statistics (via the EnableAgentStatistics method) was received by the CTIServer. The arrival of events event is determined by the configuration on the server. The table under Parameters details all the agent statistics that could be received. To optimize bandwidth, the default configuration on the server is set to minimize the agent statistics sent. Only the statistics that the Agent Statistics grid is configured for are sent to the client. Refer to the CTI OS System Managers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted for details on how to configure the agent statistics grid and minimize agent statistics.
Syntax
C++: void OnAgentStatistics (Arguments & args); COM: HRESULT OnAgentStatistics ([in] IArguments * args); VB: Session_ OnAgentStatistics (ByVal args as CTIOSCLIENTLIB.IArguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-58
Release 8.0(1)
Chapter 6
Parameters
args Arguments array containing the following fields.
Table 6-57 OnAgentStatistics Parameters
Description The Unified ICM PeripheralID of the ACD where the agent is located. The agents ACD teleset extension. The agents ACD login ID. The agents ACD instrument number.
The OnAgentStatistics event will contain all the agent statistics fields necessary to display the statistics configured on the CTI OS server.
OnChatMessage
The OnChatMessage event is generated when an asynchronous text message from another user (agent) is received.
Syntax
C++:void OnChatMessage(Arguments& args) COM:void OnChatMessage (IArguments * args) VB: session_OnChatMessage (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-58 OnChatMessage Parameters
Description Currently the only supported value is agent. The AgentID of the message target. The AgentID of the message target. The text message provided by the sender. The AgentID of the message sender.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-59
OnControlFailureConf
The OnControlFailureConf event is generated when the previously issued request, identified by the InvokeID field failed. It is sent in place of the corresponding confirmation message for that request.
Syntax
C++:void OnControlFailureConf(Arguments& args) COM:void OnControlFailureConf (IArguments * args) VB: session_OnControlFailureConf (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-59 OnControlFailureConf Parameters
Description InvokeID of the request that failed A value specifying the reason that the request failed. See Table 6-60 for a list of the Control Failure Codes. Peripheral-specific error data, if available. Zero otherwise.
STRING Agent ID that represents a specific client. INT Contains the CTI OS Command Request ID that failed to execute. The message types that can be included in this parameter are those to used to control Call, Agent State and Supervisor actions. Refer to Appendix A, CTI OS Keywords and Enumerated Types for a complete list.
ErrorMessage
Table 6-60
Status Code E_CTI_NO_ERROR E_CTI_INVALID_ VERSION E_CTI_INVALID_ MESSAGE_ TYPE E_CTI_INVALID_ FIELD_TAG E_CTI_SESSION_ NOT_OPEN No error occurred.
Description The CTI Server does not support the protocol version number requested by the CTI client. A message with an invalid message type field was received. A message with an invalid floating field tag was received. No session is currently open on the connection.
Value 0 1 2 3 4
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-60
Release 8.0(1)
Chapter 6
Table 6-60
Status Code E_CTI_SESSION_ ALREADY_ OPEN E_CTI_REQUIRED_ DATA_ MISSING E_CTI_INVALID_ PERIPHERAL_ID E_CTI_INVALID_ AGENT_ DATA E_CTI_AGENT_NOT_ LOGGED_ON E_CTI_DEVICE_IN_ USE E_CTI_NEW_ SESSION_ OPENED E_CTI_FUNCTION_ NOT_ AVAILABLE E_CTI_INVALID_ CALLID E_CTI_PROTECTED_ VARIABLE E_CTI_CTI_SERVER_ OFFLINE E_CTI_TIMEOUT
Description A session is already open on the connection. The request did not include one or more floating items that are requir ed. A message with an invalid PeripheralID value was received. The provided agent data items are invalid. The indicated agent is not currently logged on. The indicated agent teleset is already associated with a different CTI client. This session is being terminated due to a new session open request from the client. A request message was received for a function or service that was not granted to the client. A request message was received with an invalid CallID value. The CTI client may not update the requested variable. The CTI Server is not able to function normally. The CTI client should close the session upon receipt of this error. The CTI Server failed to respond to a request message within the time-out period, or no messages have been received from the CTI client within the IdleTimeout period.
Value 5 6 7 8 9 10 11 12 13 14 15 16
E_CTI_UNSPECIFIED_ An unspecified error occurred. FAILURE E_CTI_INVALID_ TIMEOUT E_CTI_INVALID_ SERVICE_MASK E_CTI_INVALID_ CALL_MSG_MASK E_CTI_INVALID_ AGENT_ STATE_ MASK E_CTI_INVALID_ RESERVED_ FIELD E_CTI_INVALID_ FIELD_ LENGTH E_CTI_INVALID_ DIGITS The IdleTimeout field contains a value that is less than 20 seconds (4 times the minimum heartbeat interval of 5 seconds). The ServicesRequested field has unused bits set. All unused bit positions must be zero. The CallMsgMask field has unused bits set. All unused bit positions must be zero. The AgentStateMask field has unused bits set. All unused bit positions must be zero. A Reserved field has a non-zero value. A floating field exceeds the allowable length for that field type. A STRING field contains characters that are not digits (0 through 9).
17 18 19 20 21
22 23 24
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-61
Table 6-60
Status Code E_CTI_BAD_ MESSAGE_ FORMAT E_CTI_INVALID_ TAG_FOR_MSG_ TYPE E_CTI_INVALID_ DEVICE_ID_ TYPE E_CTI_INVALID_ LCL_CONN_ STATE E_CTI_INVALID_ EVENT_ CAUSE E_CTI_INVALID_ NUM_ PARTIES E_CTI_INVALID_ SYS_ EVENT_ID E_CTI_ INCONSISTENT_ AGENT_DATA E_CTI_INVALID_ CONNECTION_ID_ TYPE E_CTI_INVALID_ CALL_TYPE E_CTI_NOT_CALL_ PARTY E_CTI_INVALID_ PASSWORD E_CTI_CLIENT_ DISCONNECTED E_CTI_INVALID_ OBJECT_ STATE E_CTI_INVALID_ NUM_ SKILL_GROUPS E_CTI_INVALID_ NUM_LINES E_CTI_INVALID_ LINE_TYPE E_CTI_INVALID_ ALLOCATION_STATE E_CTI_INVALID_ ANSWERING_ MACHINE
Description The message is improperly constructed. This may be caused by omitted or incorrectly sized fixed message fields. A floating field tag is present that specifies a field that does not belong in this message type. A DeviceIDType field contains an invalid. value. A LocalConnectionState field contains an invalid value. An EventCause field contains an invalid value. The NumParties field contains a value that exceeds the maximum (16). The SystemEventID field contains an invalid value. The provided agent extension, agent id, and/or agent instrument values are inconsistent with each other. A ConnectionDeviceIDType field contains an invalid value.
Value 25 26
27 28 29 30 31 32
33
The CallType field contains an invalid value. A CallDataUpdate or Release Call request specified a call that the client is not a party to. The ClientID and Client Password provided in an OPEN_REQ message is incorrect. The client TCP/IP connection was disconnected without a CLOSE_REQ. An invalid object state value was provided. An invalid NumSkillGroups value was provided.
34 35 36 37 38 39
An invalid NumLines value was provided. An invalid LineType value was provided. An invalid AllocationState value was provided. An invalid AnsweringMachine value was provided.
40 41 42 43
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-62
Release 8.0(1)
Chapter 6
Table 6-60
Status Code E_CTI_INVALID_ CALL_MANNER_ TYPE E_CTI_INVALID_ CALL_PLACEMENT_ TYPE E_CTI_INVALID_ CONSULT_ TYPE E_CTI_INVALID_ FACILITY_ TYPE E_CTI_INVALID_ MSG_TYPE_ FOR_ VERSION E_CTI_INVALID_ TAG_FOR_ VERSION E_CTI_INVALID_ AGENT_WORK_ MODE E_CTI_INVALID_ CALL_OPTION E_CTI_INVALID_ DESTINATION_ COUNTRY E_CTI_INVALID_ ANSWER_DETECT_ MODE E_CTI_MUTUALLY_ EXCLUS_DEVICEID_ TYPES E_CTI_INVALID_ MONITORID E_CTI_SESSION_ MONITOR_ ALREADY_EXISTS E_CTI_SESSION_ MONITOR_IS_ CLIENTS E_CTI_INVALID_ CALL_CONTROL_ MASK E_CTI_INVALID_ FEATURE_MASK
Value 44
45
An invalid ConsultType value was provided. An invalid FacilityType value was provided. The provided MessageType is invalid for the opened protocol version. A floating field tag value is invalid for the opened protocol version. An invalid AgentWorkMode value was provided.
46 47 48
49 50
An invalid call option value was provided. An invalid destination country value was provided.
51 52
53
A peripheral monitor request may not specify both a call and a device. An invalid monitorID value was provided. A requested session monitor was already created.
54
55 56
57
58
59
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-63
Table 6-60
Status Code E_CTI_INVALID_ TRANSFER_ CONFERENCE_ SETUP_MASK E_CTI_INVALID_ ARRAY_INDEX E_CTI_INVALID_ CHARACTER E_CTI_CLIENT_NOT_ FOUND E_CTI_SUPERVISOR_ NOT_FOUND E_CTI_TEAM_NOT_ FOUND E_CTI_NO_CALL_ ACTIVE E_CTI_NAMED_ VARIABLE_NOT_ CONFIGURED E_CTI_NAMED_ ARRAY_NOT_ CONFIGURED E_CTI_INVALID_ CALL_VARIABLE_ MASK E_CTI_ELEMENT_ NOT_FOUND
Value 60
An invalid named array index value was provided. An invalid character value was provided. There is no open session with a matching ClientID. The agents supervisor is unknown or does not have an open CTI session. The agent is not a member of an agent team. The specified agent does not have an active call. The specified named variable is not configured in the Unified ICM database. The specified named array is not configured in the Unified ICM database. The specified call variable mask in not valid.
61 62 63 64 65 66 67
68
69
70 71 72 73 74 75
E_CTI_INVALID_ The specified distribution type is invalid. DISTRIBUTION_TYPE E_CTI_INVALID_ SKILL_GROUP E_CTI_TOO_MUCH_ DATA The specified skill group is invalid. The total combined size of named variables and named arrays may not exceed the limit of 2000 bytes.
E_CTI_VALUE_TOO_L The value of the specified named variable or named array element ONG exceeds the maximum permissible length. E_CTI_SCALAR_ FUNCTION_ON_ ARRAY E_CTI_ARRAY_ FUNCTION_ON_ SCALAR A NamedArray was specified with a NamedVariable tag.
76
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-64
Release 8.0(1)
Chapter 6
Table 6-60
Description The value in the NumNamedVariables field is different than the number of NamedVariable floating fields in the message. The value in the NumNamedArrays field is different than the number of NamedArray floating fields in the message.
Value 77
78
OnEmergencyCall
The OnEmergencyCall event indicates that a CTI client (with Supervisory capabilities) is handling the indicated call as an emergency call. This event only applies to ACDs with Supervisor capabilities.
Syntax
C++: void OnEmergencyCall(Arguments& args) COM:void OnEmergencyCall (IArguments * args) VB: session_OnEmergencyCall (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-61 OnEmergencyCall Parameters
Keyword PeripheralID Connection CallID ConnectionDevice IDType SessionID Connection DeviceID ClientID (required) ClientAddress (Required) AgentID (required)
Description The Unified ICM PeripheralID of the ACD where the call is located. The Call ID value assigned to the call by the peripheral or the Unified ICM. Indicates the type of the connection identifier supplied in the ConnectionDeviceID floating field. The CTI client SessionID of the CTI client making the notification. The identifier of the connection between the call and the agents device. The ClientID of the client making the notification. The IP address of the client making the notification. The Agents teleset extension. The Agents ACD login ID. The Agents ACD instrument number.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-65
Remarks
Supported for use with Unified CCE only.
OnLogoutFailed
The OnLogoutFailed ia always generated before (or along with) an OnControlFailureConf event and is identical to it but is generated only when a Logout request fails.
Syntax
C++:void OnLogoutFailed (Arguments& args) COM:void OnLogoutFailed (IArguments * args) VB: session_OnLogoutFailed (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-62 OnLogoutFailed Parameters
Description InvokeID of the request that failed A value specifying the reason that the request failed. See Table 6-60 for a list of the Control Failure Codes. Peripheral-specific error data, if available. Zero otherwise.
OnMakeCallConf
The OnMakeCallConf event confirms the successful completion of the MakeCall request. It conveys the information detailed in the table under Parameters.
Syntax
C++: int OnMakeCallConf (Arguments & args); COM: HRESULT OnMakeCallConf ([in] IArguments * args); VB: Session_ OnMakeCallConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-63 OnMakeCallConf Parameters
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-66
Release 8.0(1)
Chapter 6
Description
Type
The Call ID value assigned to the call by the peripheral or UINT the Unified ICM. Indicates the type of the connection identifier supplied in the New ConnectionDeviceID floating field. This field identifies the teleset line used, if known. Otherwise this field is set to 0xffff. Indicates the type of the teleset line given in the LineHandle field. The identifier of the connection between the call and the device. SHORT SHORT SHORT STRING
OnNewAgentTeamMember
The OnNewAgentTeamMember event informs the supervisor about a new agent team member. The event is typically received in response to a RequestAgentTeamList request from the supervisor object. It is also received when CTI OS Server receives an AGENT_TEAM_CONFIG_EVENT indicating a change in agent team configuration (add/remove).
Syntax
C++: void OnNewAgentTeamMember (Arguments& args) COM:void OnNewAgentTeamMember (IArguments * args) VB: session_OnNewAgentTeamMember (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array that can contain the following fields. Not all fields are always returned. Skillgroup and AgentInstrument are not returned if the agent is not logged in.
Table 6-64 OnNewAgentTeamMember Parameters
Description The Unified ICM PeripheralID of the agents ACD . Unique object ID of the agent object for this agent. One of the values in Table 6-56 representing the current state of the associated agent. The number of skill groups that the agent is currently associated with, up to a maximum of 99. Agents ACD login. Agents ACD teleset extension. Agents ACD instrument number.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-67
Agents last name. Agents first name. Agents full name. The current status of the agents availability to take a call. Contains the bit-mask that specifies what buttons can be enabled or disabled when the agent is on the state specified in the AgentState field. The ID of the agents supervisor. Used to describe the agent carried in this event. The possible values for this field as well as their meanings are as follows.
SupervisorID AgentFlags
STRING INT
TeamMemberFlags.AGENT_FLAG_REGULA R_AGENT - Value is 0. The agent is a regular agent TeamMemberFlags.AGENT_FLAG_PRIMARY _SUPERVISOR - Value is 1. The agent is a primary supervisor TeamMemberFlags.AGENT_FLAG_TEMPOR ARY_AGENT - Value is 2. The agent is a temporary agent TeamMemberFlags.AGENT_FLAG_SUPERVI SOR - Value is 4. The agent is a supervisor
Skillgroup[1}
ARGUMENTS
Arguments array containing information about the agents first skillgroup. The array contains the following arguments.
Skillgroup[n] ConfigOperation
ARGUMENTS USHORT
Arguments array containing information about the agents nth skillgroup. used to describe a change to the team. The possible values for this field as well as their meanings are as follows.
TeamMemberFlags.CONFIG_OPERATION_A DD_AGENT - Value is 1 - The agent belongs to the team TeamMemberFlags.CONFIG_OPERATION_RE MOVE_AGENT - Value is 2 - The agent no longer belongs to the team
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-68
Release 8.0(1)
Chapter 6
OnPostLogout
The OnPostLogout event is generated after the agent has logged out. Arrival of this event guarantees that the agent state event signalling the agent's transition to logout state has been received and handled by all interested event listeners.
Syntax
C++:void OnPostLogout(Arguments& args) COM:void OnPostLogout (IArguments * args) VB: session_OnPostLogout (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-65 OnPostLogout Parameters
Description The Unified ICM PeripheralID of the ACD where the agent state change occurred. The type of the peripheral. One of the values in Table 6-56 representing the current overall state of the associated agent. The number of the agent SkillGroup affected by the state change, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup affected by the state change. May contain the special value NULL_SKILL_ GROUP when not applicable or not available. The number of seconds since the agent entered this state (typically 0). The priority of the skill group, or 0 when skill group priority is not applicable or not available. A peripheral-specific code indicating the reason for the state change. Values representing the current state of the associated agent with respect to the indicated Agent Skill Group. The agents ACD login ID. The agents ACD teleset extension. The Client Signature of the CTI Client that is associated with this agent.
SkillGroupID
INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-69
Description Contains the bit-mask that specifies what buttons can be enabled or disabled when the agent is on this state. A unique object ID for the agent object. The agents ACD instrument number.
Remarks
When PG failover occurs, it is possible that the client application will receive an OnPostLogout event with an EventReasonCode of CTIOS_IPCC_FORCED_LOGOUT_REASON_CODE. For example, this may happen on an Unified CCE system after reconnecting to a different server during a failover, because there is a race condition of the PG logging the agent out and the client reconnecting to the other server before it happens. If this happens, the client application should not disconnect from CTI OS Server.
OnPreLogout
The OnPreLogout event just before the agent is logged out. It allows for any cleanup or logic that needs to be done before logout is completed.
Syntax
C++: void OnPreLogout(Arguments& args) COM:void OnPreLogout (IArguments * args) VB: session_OnPreLogout (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-66 OnPreLogout Parameters
Description The Unified ICM PeripheralID of the ACD where the agent state change occurred. The type of the peripheral. One of the values in Table 6-56 representing the current overall state of the associated agent. The number of the agent SkillGroup affected by the state change, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-70
Release 8.0(1)
Chapter 6
Keyword SkillGroupID
Type INT
Description The Unified ICM SkillGroupID of the agent SkillGroup affected by the state change. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The number of seconds since the agent entered this state (typically 0). The priority of the skill group, or 0 when skill group priority is not applicable or not available. A peripheral-specific code indicating the reason for the state change. Values representing the current state of the associated agent with respect to the indicated Agent Skill Group. The agents ACD login ID. The agents ACD teleset extension. The Client Signature of the CTI Client that is associated with this agent. Contains the bit-mask that specifies what buttons can be enabled or disabled when the agent is on this state.
StateDuration SkillGroupPriority EventReasonCode SkillGroupState AgentID AgentExtension CTIClientSignature (Optional) Enablement Mask UniqueObjectID AgentInstrument
STRING STRING
A unique object ID for the agent object. The agents ACD instrument number.
OnQueryAgentStateConf
The OnQueryAgentStateConf event is generated and returned by the server at login as a response to the QueryAgentState() request. A user cannot issue this request.
Syntax
C++:void OnQueryAgentStateConf(Arguments& args) COM:void OnQueryAgentStateConf (IArguments * args) VB: session_OnQueryAgentStateConf (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-67 OnQueryAgentStateConf Parameters
Description Agents ACD login. Agents ACD teleset extension. Agents ACD instrument number.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-71
One of the values in Table 6-56 representing the current state of the associated agent. The number of skill groups that the agent is currently associated with, up to a maximum of 20. Argument array that contains Skill Group information for the j-th element less than NumSkillGroups. The message will contain up to NumSkillGroups elements of this type. Media Routing Domain ID as configured in Unified ICM and the ARM client. The number of tasks currently assigned to the agent this is the number that Unified ICM compares to the MaxTaskLimit to decide if the agent is available to be assigned additional tasks. This includes active tasks as well as those that are offered, paused, and in wrapup. The mode that the agent will be in when the login completes. ROUTABLE = 0, NOT ROUTABLE = 1 The maximum number of tasks that the agent can be simultaneously working on. The Unified ICM Skill Target ID, a unique agent identifier for Unified ICM. An agent is available to work on a task in this Media Routing Domain if the agent meets all of these conditions: The agent is routable for this Media Routing Domain The agent is not in Not Ready state for skill groups in other Media Routing Domain The agent is temp routable, meaning that the agent is not in Reserved, Active, Work-Ready, or Work-Not Ready state on a non-interruptible task in another Media Routing Domain. The agent has not reached the maximum task limit for this Media Routing Domain An available agent is eligible to be assigned a task. Who can assign a task to the agent is determined by whether or not the agent is Routable. An agent is ICMAvailable in MRD X if he is available in X and Routable with respect to X. An agent is ApplicationAvailable in MRD X if he is available in X and not Routable with respect to X. Otherwise an agent is NotAvailable in MRD X. NOT AVAILABLE = 0, ICM AVAILABLE = 1, APPLICATION AVAILABLE=2
MRDID NumTasks
INT INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-72
Release 8.0(1)
Chapter 6
Keyword SkillGroupNumber
Type INT
Description The number of an agent SkillGroup queue that the call has been added to, as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_GROUP when not applicable or available. The priority of the skill group, or 0 when the skill group priority is not applicable or not available. One of the values representing the current state associated agent with respect to the skill group.
SkillGroupID
INT
SkillGroupPriority SkillGroupState
SHORT SHORT
OnSetAgentModeEvent
The OnSetAgentModeEvent event indicates that the client has made a successful AgentMode connection.
Syntax
C++:void OnSetAgentModeEvent (Arguments& args) COM: void OnSetAgentModeEvent (IArguments * args) VB: Session_OnSetAgentModeEvent (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-69 OnSetAgentModeEven Parameters
Description ID of the Unified ICM Peripheral ACD associated with the agent. The agents ID. The new unique object ID for the agent object. Temporary ID used before server passes the new unique object ID.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-73
STRING ARGUMENTS
ID of the clients connection on the server. Arguments array containing the following elements:
StatusCTIServer StatusCtiServerDriver StatusCentralController StatusPeripherals (Arguments array with a peripheral id for each key and a boolean true/false value indicating if that peripheral is online)
OnSetAgentStateConf
The OnSetAgentStateConf confirmation message is fired to the client to indicate that the SetAgentState request was received by the CTI Server. This confirmation message does not indicate that the agent has changed to the desired state; rather, the programmer should expect one or more OnAgentStateChange events to indicate the change of state.
Syntax
C++:int OnSetAgentStateConf (Arguments & args); COM: HRESULT OnSetAgentStateConf ([out] IArguments * args); VB: Session_ OnSetAgentStateConf (ByVal args as CTIOSCLIENTLIB.IArguments)
Java: void OnSetAgentStateConf (Arguments args);
Parameters
args Not used; reserved for future use.
OnStartMonitoringAgent
The OnStartMonitoringAgent event is generated when a new agent is selected to be monitored in response to a StartMonitoringAgent() request.
Syntax
C++:void OnStartMonitoringAgent (Arguments& args) COM:void OnStartMonitoringAgent (IArguments * args) VB: session_OnStartMonitoringAgent (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-74
Release 8.0(1)
Chapter 6
Table 6-70
OnStartMonitoringAgent Parameters
Description Unique object ID for the supervisor object. String containing the Agent ID for the agent to be monitored. String containing the supervisors AgentID Supervisors unique object ID. If the supervisor has barged in on the agents call, the unique object ID of that call. The supervisors agent state.
Remarks
This is a Supervisor specific event. It is supported for use with Unified CCE only.
OnStopMonitoringAgent
The OnStopMonitoringAgent event is generated when monitoring of an agent is dropped in response to a StopMonitoringAgent() request.
Syntax
C++:void OnStopMonitoringAgent (Arguments& args) COM: void OnStopMonitoringAgent (IArguments * args) VB: session_OnStopMonitoringAgent (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-71 OnStopMonitoringAgent Parameters
Description Unique object ID for the supervisor object. String containing the Agent ID for the agent to be monitored. String containing the supervisors AgentID Supervisors unique object ID.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-75
STRING STRING
If the supervisor has barged in on the agents call, the unique object ID of that call. The supervisors agent state.
Remarks
This is a Supervisor specific event. It is supported for use with Unified CCE only.
OnUserMessageConf
Not supported.
ISkillGroupEvents Interface
The SkillGroup object fires events on the ISkillGroupEvents interface. The following events are published to subscribers of the ISkillGroupEvents interface.
OnSkillGroupStatisticsUpdated
The OnSkillGroupStatisticsUpdated event is generated when skill group statistics are reported. The update frequency of OnSkillGroupStatisticsUpdated can be configured on the CTI OS server (see the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted).
Syntax
C++:void OnSkillGroupStatisticsUpdated (Arguments& args) COM:void OnSkillGroupStatisticsUpdated (IArguments * args) VB: skillgroup_ OnSkillGroupStatisticsUpdated (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-72
.
OnSkillGroupStatisticsUpdated Parameters
Description The Unified ICM PeripheralID of the ACD on which the agent resides. The number of the agent skill group as known to the peripheral. May contain the special value NULL_SKILL_GROUP when not available. The Unified ICM SkillGroupID of the skill group. May contain the special value NULL_SKILL_GROUP when not available.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-76
Release 8.0(1)
Chapter 6
The statistics event will also contain all the statistics fields listed in Table 11-2 in a nested arguments array named STATISTICS.
OnSkillInfoEvent
Provides information about a particular skill group. This event will be sent to any client that has enabled skill group statistics.
C++: void OnSkillInfoEvent(Arguments& args) COM: void OnSkillInfoEvent(IArguments * args) VB:skillgroup_OnSkillInfoEvent(ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-73 OnSkillInfoEVent Parameters
Description Skill group number Skill group name associated with the skill group number above
IButtonEnablementEvents
This interface allows a client application to receive events that indicate what buttons can be enabled on the user interface, given the current agent and current call states.
OnButtonEnablementChange
The OnButtonEnablementChange event is received by a client in agent mode whenever CIL receives an agent or call event that carries the EnablementMask field in its parameters. This event allows the client application to enable or disable elements on the user interface. The fields in the event are the same as in OnButtonEnablementChange.
C++:void OnButtonEnablementChange (Arguments& args) COM:void OnButtonEnablementChange (IArguments * args) VB: session_ OnButtonEnablementChange (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-77
Chapter 6 IButtonEnablementEvents
Table 6-74
OnButtonEnablementChange Parameters
Keyword EnablementMask
Type INT
Description Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. See Table 6-75. ID of the object (e.g., agent, call) that the event is meant for. The event that triggered the button enablement change.
UniqueObjectID MessageID
STRING INT
Note
Table 6-75 represents the C++/COM/VB enumerations. Enumerations for Java can be found in the description of CtiOs_Enums.ButtonEnablement in the Javadoc. It is strongly recommended that bits be referenced by the enumeration rather than the actual number in the bit mask.
Table 6-75 Table of Enablement Bits
Button DISABLE_ALL ENABLE_ANSWER ENABLE_RELEASE ENABLE_HOLD ENABLE_RETRIEVE ENABLE_MAKECALL ENABLE_TRANSFER_INIT ENABLE_TRANSFER_COMPLETE ENABLE_SINGLE_STEP_TRANSFER ENABLE_CONFERENCE_INIT ENABLE_CONFERENCE_COMPLETE ENABLE_SINGLE_STEP_ CONFERENCE ENABLE_ALTERNATE ENABLE_RECONNECT ENABLE_WRAPUP ENABLE_INSIDE_MAKECALL ENABLE_OUTSIDE_MAKECALL ENABLE_SUPERVISOR_ASSIST ENABLE_EMERGENCY_CALL ENABLE_BAD_LINE_CALL ENABLE_STATISTICS ENABLE_CHAT
Bit Mask 0x00400000 0X00000001 0X00000002 0X00000004 0X00000008 0X00000010 0X00000020 0X00000040 0X00000080 0X00000100 0X00000200 0X00000400 0X00000800 0X00001000 0X00002000 0X00004000 0X00008000 0X00010000 0X00020000 0X00040000 0X00080000 0X00100000
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-78
Release 8.0(1)
Chapter 6
Table 6-75
ENABLE_RECORD ENABLE_LOGIN ENABLE_LOGOUT ENABLE_LOGOUT_WITH_REASON ENABLE_READY ENABLE_NOTREADY ENABLE_NOTREADY_WITH_ REASON ENABLE_WORKREADY ENABLE_WORKNOTREADY DISABLE_READY DISABLE_NOTREADY DISABLE_WORKREADY Supervisor Button Enablement Masks ENABLE_SET_AGENT_LOGOUT ENABLE_SET_AGENT_READY ENABLE_SILENTMONITOR ENABLE_BARGE_IN ENABLE_INTERCEPT ENABLE_CLEAR ENABLE_START_SILENTMONITOR ENABLE_STOP_SILENTMONITOR DISABLE_SET_AGENT_LOGOUT DISABLE_SET_AGENT_READY DISABLE_SILENTMONITOR DISABLE_BARGE_IN DISABLE_INTERCEPT DISABLE_CLEAR DISABLE_START_SILENTMONITOR DISABLE_STOP_SILENTMONITOR DISABLE_SUPERVISE_CALL
0X00200000 0X01000000 0X02000000 0x04000000 0X08000000 0X10000000 0X20000000 0X40000000 0x80000000 0xF7FFFFFF 0xCFFFFFFF 0xBFFFFFFF 0x00000001 0x00000002 0x00000004 0x00000004 0x00000008 0x00000010 0x00000020 0x00000040 0xFFFFFFFE 0xFFFFFFFD 0xFFFFFFFB 0xFFFFFFFB 0xFFFFFFF7 0xFFFFFFEF 0xFFFFFFDF 0xFFFFFFBF DISABLE_BARGE_IN & DISABLE_INTERCEPT & DISABLE_CLEAR & DISABLE_SILENTMONIT OR & DISABLE_START _SILENTMONITOR & DISABLE_STOP_SILENT MONITOR
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-79
Table 6-75
DISABLE_SET_AGENT_STATE DISABLE_ALL_AGENT_SELECT
DISABLE_SET_AGENT_ LOGOUT, DISABLE_SET_ AGENT_READY DISABLE_BARGE_IN & DISABLE_INTERCEPT & DISABLE_CLEAR & DISABLE_SILENTMONIT OR & DISABLE_START _SILENTMONITOR & DISABLE_STOP_SILENT MONITOR
OnSupervisorButtonChange
The OnSupervisorButtonChange is received by a client in agent mode working as supervisor whenever CIL receives a Monitored Agent, Monitored call event that carries the SupervisorBtnEnablementMask field in its parameters. This event allows the client application to enable or disable elements on the user interface. The fields in the event are the same as in OnButtonEnablementChange
C++:void OnSupervisorButtonChange (Arguments& args) COM:void OnSupervisorButtonChange (IArguments * args) VB: session_ OnSupervisorButtonChange (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-76 OnSupervisorButtonChange Parameters
Type INT
Description Contains the bit-mask that specifies what buttons can be enabled or disabled when this call is the current call. See Table 6-75.
Remarks
Supported for use with Unified CCE only.
IMonitoredAgentEvents Interface
Note
The events in this section are supported for use with Unified CCE only. This interface fires Agent events to a supervisor for his team members. IMonitoredAgentEvents are triggered by the supervisor sending a StartMonitoringAllAgentTeams request (see Chapter 9, Agent Object). For details on the event parameters please see the IAgentEvents interface.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-80
Release 8.0(1)
Chapter 6
The most common event being handled is the OnMonitoredAgentStateChange event, which informs a supervisor of agent state changes of agents in the supervisors team. All the parameters are the same as for regular OnAgentStateChange events, except for an additional keyword called CTIOS_MONITORED, which indicates that this event is for a monitored agent. List of Monitored Agent events: OnMonitoredAgentStateChange([in] IArguments *pIArguments); OnMonitoredAgentInfoEvent([in] IArguments *pIArguments);
IMonitoredCallEvents Interface
Note
The events in this section are supported for use with Unified CCE only. This interface fires Call events to a supervisor for one of his agent team members. When the supervisor sends a StartMonitoringAgent request (see Chapter 9, Agent Object), the supervisor will start receiving MonitoredCallEvents for this currently monitored agent. Monitored call events will be received until the supervisor sends a StopMonitoringAgent request for this agent. The IMonitoredCallEvents interface includes OnMonitoredCallBegin, OnMonitoredCallEnd, and OnMonitoredCallDataUpdate as well as other call events (see list below). These events are described in detail for the ICallEventsInterface. The only difference is that the arguments array contains an additional keyword call CTIOS_MONITORED, indicating that this event is for a monitored call. List of Monitored Call events: OnMonitoredCallBegin([in] IArguments *pIArguments); OnMonitoredCallEnd([in] IArguments *pIArguments); OnMonitoredCallDataUpdate([in] IArguments *pIArguments); OnMonitoredCallDelivered([in] IArguments *pIArguments); OnMonitoredCallEstablished([in] IArguments *pIArguments); OnMonitoredCallHeld([in] IArguments *pIArguments); OnMonitoredCallRetrieved([in] IArguments *pIArguments); OnMonitoredCallCleared([in] IArguments *pIArguments); OnMonitoredCallConnectionCleared([in] IArguments *pIArguments); MonitoredCallReachedNetworkEvent([in] IArguments *pIArguments); OnMonitoredCallOriginated([in] IArguments *pIArguments); OnMonitoredCallFailed([in] IArguments *pIArguments); OnMonitoredCallTransferred([in] IArguments *pIArguments); OnMonitoredCallConferenced([in] IArguments *pIArguments); OnMonitoredCallDiverted([in] IArguments *pIArguments); OnMonitoredTranslationRoute([in] IArguments *pIArguments); OnMonitoredCallAgentPrecallEvent([in] IArguments *pIArguments); OnMonitoredCallAgentPrecallAbortEvent([in] IArguments *pIArguments); MonitoredCallServiceInitiatedEvent([in] IArguments *pIArguments);
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-81
Chapter 6 ISilentMonitorEvents
ISilentMonitorEvents
The silent monitor manager object fires events on the ISilentMonitorEvents interface. The following events are published to subscribers of the ISilentMonitorEvents interface.
Note
The events in this section are supported for use with Unified CCE only.
Note
The following events only apply to CTI OS based silent monitor unless noted otherwise.
OnCallRTPStarted
The OnCallRTPStarted event indicates that an RTP media stream has been started. This event accompanies the call object in an Unified CCE environment.
Syntax
C++: COM: VB:
void OnCallRTPStarted(Arguments& args) void OnCallRTPStarted (IArguments * args) session_OnCallRTPStarted (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-77 OnCallRTPStarted Parameters
Keyword MonitorID
Type UINT
Description The Monitor ID of the device or call monitor that caused this message to be sent to the client, or zero if there is no monitor associated with the event (All Events Service). The Unified ICM PeripheralID of the ACD where the device is located. The TCP/IP port number of the CTI Client connection The direction of the event. One of the following values: 0: Input; 1: Output; 2: Bi-directional.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-82
Release 8.0(1)
Chapter 6
RTPType
USHORT
The type of the event. One of the following values: 0: Audio; 1: Video; 2: Data.
The media bit rate, used for g.723 payload only on/off In milliseconds The audio codec type Indicates the type of the connection identifier supplied in the ConnectionDeviceID floating field The Call ID value assigned to this call by the peripheral or Unified ICM. The identifier of the connection between the call and the device. The IP address of the phone. The agents ACD login ID. The agents ACD teleset extension The agents ACD instrument number
ConnectionDevice USHORT IDType ConnectionCallID UINT Connection DeviceID ClientAddress AgentID (optional) AgentExtension (optional) AgentInstrument (optional) STRING STRING STRING STRING STRING
OnCallRTPStopped
The OnCallRTPStopped event indicates that an RTP media has been stopped. This event accompanies the call object in an Unified CCE environment.
Syntax
C++: COM: VB:
void OnCallRTPStopped(Arguments& args) void OnCallRTPStopped (IArguments * args) session_OnCallRTPStopped (ByVal args As CtiosCLIENTLib.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-78 OnCallRTPStopped Parameters
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-83
Chapter 6 ISilentMonitorEvents
Value
Data Type
The Monitor ID of the device or call monitor that caused this message UINT to be sent to the client, or zero if there is no monitor associated with the event (All Events Service). The Unified ICM PeripheralID of the ACD where the device is located. The direction of the event. One of the following values: 0: Input; 1: Output; 2: Bi-directional. UINT
The TCP/IP port number of the CTI Client connection that was closed. UINT USHORT
ConnectionDevice Indicates the type of the connection identifier supplied in the ConnectionDeviceID floating field IDType ConnectionCallID The Call ID value assigned to this call by the peripheral or Unified ICM. ConnectionDevice The identifier of the connection between the call and the device. ID ClientAddress AgentID (optional) AgentExtension (optional) AgentInstrument (optional) The IP address of the phone. The agents ACD login ID. The agents ACD teleset extension The agents ACD instrument number
OnStartSilentMonitorConf
The OnStartSilentMonitorConf event is sent to the monitoring application to indicate that a StartSilentMonitorRequest has been processed at the CTI OS server.
Syntax
C++:void OnStartSilentMonitorConf (Arguments & args); COM: HRESULT OnStartSilentMonitorConf ([in] Arguments* args);
VB:
Parameters
args Arguments array containing the following fields.
Table 6-79 OnStartSilentMonitorConf Parameters
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-84
Release 8.0(1)
Chapter 6
Keyword
Type
Description Unique Object ID of the object being monitored Agent ID of the agent to be monitored. This message will contain either AgentID or DeviceID, but not both. Device ID of the agent to be monitored. This message will contain either AgentID or DeviceID, but not both. The Unified ICM PeripheralID of the ACD where the silent monitor start has been requested. TCP/IP address of the monitoring application. TCP/IP port of the monitoring application.
MonitoredUniqueObject STRING ID AgentID DeviceID PeripheralID MonitoringIPAddress MonitoringIPPort SMSessionKey HeartbeatInterval HeartbeatTimeout OriginatingServerID OriginatingClientID STRING STRING INT STRING INT
UNSIGNED Unique identifier for the Silent Monitor Session. SHORT INT INT STRING STRING Heartbeat interval for the silent monitor session. Timeout for no activity. TCP/IP Address:Port of the CTI OS server from which the request originated. Client Identification of the monitoring application.
OnSilentMonitorStartedEvent
For CTI OS Based Silent Monitor
The OnSilentMonitorStartedEvent event is fired to the subscriber to indicate that a silent monitor session has been started on its behalf and that audio transmission to the monitoring client has been started.
Syntax
C++: void OnSilentMonitorStartedEvent(Arguments & args); COM: HRESULT OnSilentMonitorStartedEvent([in] Arguments* args); VB: Session_ OnSilentMonitorStartedEvent(ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-80 OnSilentMonitorStartedEvent Parameters
Keyword
Type
Description Unique Object ID of the object being monitored Agent ID of the agent being monitored. This message will contain either AgentID or DeviceID, but not both.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-85
Chapter 6 ISilentMonitorEvents
Device ID of the agent being monitored. This message will contain either AgentID or DeviceID, but not both. The Unified ICM PeripheralID of the ACD where silent monitoring has started. TCP/IP address of the monitoring application TCP/IP port of the monitoring application
UNSIGNED Unique identifier for the Silent Monitor Session. SHORT INT INT STRING STRING Heartbeat interval for the silent monitor session Timeout for no activity. TCP/IP Address:Port of the CTI OS server from which the request originated Client Identification of the monitoring application
Syntax
C++: void OnSilentMonitorStartedEvent(Arguments & args); COM: HRESULT OnSilentMonitorStartedEvent([in] Arguments* args); VB: Session_ OnSilentMonitorStartedEvent(ByVal args as CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-81 OnSilentMonitorStartedEvent
Description Unique object ID of the agent that initiated silent monitor. ID of the device that initiated silent monitor. Unique object ID of the silently monitored agent. ID of the silently monitored device. Unique object ID of the silent monitor call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-86
Release 8.0(1)
Chapter 6
OnSilentMonitorStartRequestedEvent
The OnSilentMonitorStartRequestedEvent event is fired to the subscriber to indicate that a silent monitor session request has arrived and that it will be established on its behalf if the DoDefaultMessageHandling parameter is set to True. The default behavior is to start sending audio and establish the session automatically. If the subscriber wishes to process the event by itself, it must set the DoDefaultMessageHandling parameter to False and invoke AcceptSilentMonitoring when it is ready to start the session and call ReportSMSessionStatus to the monitoring client. CTI OS server generates this event when ever a remote application calls the StartSilentMonitorRequest method.
Syntax
C++: void OnSilentMonitorStartRequestedEvent(Arguments & args); COM: HRESULT OnSilentMonitorStartRequestedEvent([in] Arguments* args); VB: Session_ OnSilentMonitorStartRequestedEvent(ByVal args as
CTIOSCLIENTLIB.IArguments)
Parameters
args Arguments array containing the following fields.
Table 6-82 OnSilentMonitorStartRequetsedEvent Parameters
Keyword
Type
Description Unique Object ID of the object being monitored. Agent ID of the agent to be monitored. This message will contain either AgentID or DeviceID, but not both. Device ID of the agent to be monitored. This message will contain either AgentID or DeviceID, but not both. The Unified ICM PeripheralID of the ACD where the silent monitor start has been requested. TCP/IP address of the monitoring application TCP/IP port of the monitoring application
MonitoredUniqueObject STRING ID AgentID DeviceID PeripheralID MonitoringIPAddress MonitoringIPPort SMSessionKey HeartbeatInterval HeartbeatTimeout OriginatingServerID STRING STRING INT STRING INT
UNSIGNED Unique identifier for the Silent Monitor Session. SHORT INT INT STRING Heartbeat interval for the silent monitor session Timeout for no activity TCP/IP Address:Port of the CTI OS server from which the request originated
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-87
Chapter 6 ISilentMonitorEvents
STRING BOOLEAN
Client Identification of the monitoring application When this parameter is set to True, it instructs the SilentMonitorManager to immediately start sending audio and establish the silent monitor session. If this parameter is set to False, it instructs the SilentMonitorManager to not send voice and to not establish the silent monitor session. In this case, it is the responsibility of the subscriber to report this status accordingly.
OnSilentMonitorSessionDisconnected
The OnSilentMonitorSessionDisconnected event is sent to the application to report errors if the connection fails between the monitoring and monitored clients
Syntax
C++: void OnSilentMonitorSessionDisconnected (Arguments & args); COM: HRESULT OnSilentMonitorSessionDisconnected ([in] Arguments* args);
VB:
Parameters
args Arguments array containing the following fields.
Table 6-83 OnSilentMonitorSessionDisconnected Parameters
Keyword
Type
UNSIGNED Unique identifier for the Silent Monitor Session. SHORT SHORT One of the ISilentMonitorEvent status codes in Table 6-87.
OnSilentMonitorStopRequestedEvent
For CTI OS Based Silent Monitor
The OnSilentMonitorStopRequestedEvent event is fired to the subscriber to indicate that a silent monitor session was stopped on his behalf. CTI OS server generates this event whenever a remote application calls the StopSilentMonitorRequest method.
Syntax
C++:void OnSilentMonitorStopRequestedEvent(Arguments & args);
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-88
Release 8.0(1)
Chapter 6
COM:
VB:
Parameters
args Arguments array containing the following fields.
Table 6-84 OnSilentMonitorStopRequestedEvent Parameters
Keyword
Type
Description Unique Object ID of the object being monitored. Agent ID of the agent who had been monitored. This message will contain either AgentID or DeviceID, but not both. Device ID of the agent who had been monitored. This message will contain either AgentID or DeviceID, but not both. The Unified ICM PeripheralID of the ACD where silent monitoring has stopped. TCP/IP address of the monitoring application.
INT STRING
UNSIGNED Unique identifier for the Silent Monitor Session. SHORT STRING STRING TCP/IP Address:Port of the CTI OS server from which the request originated. Client Identification of the monitoring application.
Syntax
C++:void OnSilentMonitorStopRequestedEvent(Arguments & args); COM: HRESULT OnSilentMonitorStopRequestedEvent([in] Arguments* args);
VB:
Parameters
args Arguments array containing the following fields.
Table 6-85 OnSilentMonitorStopRequestedEvent Parameters
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-89
Chapter 6 ISilentMonitorEvents
Keyword
Type
Description Unique object ID of the agent that initiated silent monitor. ID of the device that initiated silent monitor. Unique object ID of the silently monitored agent. ID of the silently monitored device. Unique object ID of the silent monitor call. If the silent monitor session failed, the event cause carried by the call failed event is stored here. If the silent monitor session was either terminated by the supervisor or the agents call ended, this field is set to 0.
OnSilentMonitorStatusReportEvent
The OnSilentMonitorStatusReportEvent event indicates a change in status of a silent monitor session. This event sent only to the monitoring application.
Syntax
C++: void OnSilentMonitorStatusReportEvent (Arguments & args); COM: HRESULT OnSilentMonitorStatusReportEvent ([in] Arguments* args);
VB:
Parameters
args Arguments array containing the following fields.
Table 6-86 OnSilentMonitorStatusReportEvent Parameters
Keyword
Type
UNSIGNED Unique identifier for the Silent Monitor Session. SHORT SHORT STRING STRING STRING One of the ISilentMonitorEvent status codes in Table 6-87. TCP/IP Address:Port of the CTI OS server from which the request originated Client Identification of the monitoring application CIL Client ID of the monitoring application
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-90
Release 8.0(1)
Chapter 6
Table 6-87
enum Value
General Codes
Numeric Value (Hex) -1 0 0x00000001 0x00000002 0x00000003 0x00000004 0x00000005 0x00000006 0x00000007 0x00000008 0x00000009 0x0000000A 0x0000000B 0x0000000C 0x0000000D 0x0000000E 0x0000000F 0x00000010 0x00000011 0x00000012 0x00000013 0x00000014 0x00000015 0x10000000 0x10000001 0x10000002 0x10000003 0x10000004 0x10000005 0x10000006 0x10000007 0x10000008 0x10000009
eSMStatusUnknown eSMStatusOK eSMStatusFailed eSMStatusComError eSMStatusMonitorStarted eSMStatusMonitorStopped eSMStatusHeartbeatTimeout eSMStatusOutOfMemory eSMStatusPortUnavailable eSMStatusIncorrectStateForThisAction eSMStatusResourceError eSMStatusRejectedBadParameter eSMStatusWinsockError eSMStatusMediaTerminationNotPresent eSMStatusIPPhoneInformatioNotAvailable eSMStatusMissingParameter eSMStatusSessionNotFound eSMStatusSessionAlreadyExists eSMStatusDisconnected eSMStatusInvalidStateForAction eSMStatusInProgress eSMStatusMaxSessionsExceeded eSMStatusCCMSilentMonitor
Silent Monitor Session Codes
eSMStatusSessionTerminatedAbnormally eSMStatusRejectedAlreadyInSession eSMStatusRejectedWinPcapNotPresent eSMStatusWinPcapError eSMStatusMediaUnknownCodec eSMStatusIncorrectSessionMode eSMStatusPeerSilentMonitorNotEnabled eSMStatusSilentMonitorNotEnabled eSMStatusNoResponseFromPeer eSMStatusPeerLoggedOut
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-91
Chapter 6 ISilentMonitorEvents
Table 6-87
Numeric Value (Hex) 0x1000000A 0x1000000B 0x1000000C 0x1000000D 0x20000000 0x30000000 0x30000001 0x30000002 0x30000003
OnStopSilentMonitorConf
This OnStopSilentMonitorConf event is sent to the monitoring application to indicate that a StopSilentMonitorRequest has been processed at the CTI OS server.
Syntax
C++: void OnStopSilentMonitorConf (Arguments & args); COM: HRESULT OnStopSilentMonitorConf ([in] Arguments* args);
VB:
Parameters
args Arguments array containing the following fields.
Table 6-88 OnStopSilentMonitorConf Parameters
Keyword
Type
Description Unique Object ID of the object being monitored Agent ID of the agent who had been monitored. This message will contain either AgentID or DeviceID, but not both. Device ID of the agent who had been monitored. This message will contain either AgentID or DeviceID, but not both. The Unified ICM PeripheralID of the ACD where silent monitoring has stopped. TCP/IP address of the monitoring application
PeripheralID MonitoringIPAddress
INT STRING
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-92
Release 8.0(1)
Chapter 6
UNSIGNED Unique identifier for the Silent Monitor Session. SHORT STRING STRING TCP/IP Address:Port of the CTI OS server from which the request originated Client Identification of the monitoring application
OnRTPStreamTimedoutEvent
The OnRTPStreamTimedoutEvent event is sent to the monitored application to report that no RTP voice packets have been received from the monitored IP Phone.
Syntax
C++: void OnRTPStreamTimedoutEvent (Arguments & args); COM: HRESULT OnRTPStreamTimedoutEvent ([in] Arguments* args);
VB:
Parameters
args Arguments array containing the following fields.
Table 6-89 OnRTPStreamlinedEvent Parameters
Keyword
Type
UNSIGNED Unique identifier for the Silent Monitor Session. SHORT SHORT One of the ISilentMonitorEvent status codes in Table 6-87.
IGenericEvents Interface
The IGenericEvents interface receives Generic events. Unlike other interfaces that have a callback method for each event, the IGenericEvents interface has one method that passes the CtiOs_Enums.EventID code and the Arguments for the event.
OnEvent
Passes the eventID code and arguments for generic events received by the IGenericEvents interface.
Syntax
JAVA: void OnEvent(int iEventID, Arguments rArgs
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-93
IAllInOne
The following methods subscribe and unsubscribe the CTI OS Session Object for the IAllInOne interface.
int addAllInOneEventListener(IAllInOne allInOneEvents) int removeAllInOneEventListener(IAllInOne allInOneEvents)
IAgentEvents
The following methods subscribe and unsubscribe the CTI OS Session Object for the IAgentEventsinterface.
int addAgentEventListener(IAgentEvents agentEvents) int removeAgentEventListener(IAgentEvents agentEvents)
IButtonEnablementEvents
The following methods subscribe and unsubscribe the CTI OS Session Object for the IButtonEnablementEvents interface.
int addButtonEnablementEventListener(IButtonEnablementEvents buttonEvents) int removeButtonEnablementEventListener(IButtonEnablementEvents buttonEvents)
ICallEvents
The following methods subscribe and unsubscribe the CTI OS Session Object for the ICallEvents interface.
int addCallEventListener (ICallEvents callEvents) int removeCallEventListener (ICallEvents callEvents)
ISkillGroupEvents
The following methods subscribe and unsubscribe the CTI OS Session Object for the ISkillGrouEvents interface.
int addSkillGroupEventListener (ISkillGroupEvents skillGroupEvents) int removeSkillGroupEventListener (ISkillGroupEvents skillGroupEvents)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-94
Release 8.0(1)
Chapter 6
where Listener is the IGenericEvents object that is subscribing for events and iListID is the ID of the subscriber list to add this listener to. Java subscriber list IDs are part of the CtiOs_Enums.SubscriberList interface; each C++/COM/VB event interface has a corresponding Java subscriber list (for example, C++/COM/VB ISessionEvents corresponds to Java eSessionList). See the Javadoc file For more information on the CtiOs_Enums.SubscriberList interface. The IGenericEvents interface, though it contains the C++/COM/VB events documented in this chapter, does not have a callback method for each event. Instead, the OnEvent method passes the event ID code and arguments for each event. The OnEvent method has the following syntax:
void OnEvent(int iEventID, Arguments rArgs)
where iEventID is the event ID code for the event and rArgs is the arguments for the event. The arguments for each Java event are the same as for the corresponding C++/COM/VB event. See the Javadoc file for details on the IGenericEvents interface. To unsubscribe for events in the Java CIL, use the RemoveEventListener method. This method has the following syntax:
int RemoveEventListener(IGenericEvents Listener, int iListID)
where Listener is the IGenericEvents object that is unsubscribing for events and iListID is the ID of the subscriber list to remove this listener from.
where Listener is the IGenericEvents object that is subscribing for events and iListID is the ID of the subscriber list to add this listener to. Subscriber list IDs for .NET are part of the CtiOs_Enums.SubscriberList interface; each C++/COM/VB event interface has a corresponding .NET subscriber list (for example, C++/COM/VB ISessionEvents corresponds to .NET eSessionList). The IGenericEvents interface, though it contains the C++/COM/VB events documented in this chapter, does not have a callback method for each event. Instead, the OnEvent method passes the event ID code and arguments for each event. The OnEvent method has the following syntax:
void OnEvent(Object sender, Cisco.CtiOs.Cil.EventPublisher.EventPublisherEventArgs eventArgs)
where, sender is a null object and eventArgs contains the eventID and arguments for the event. The arguments for each .NET event are the same as for the corresponding C++/COM/VB event. The EventPublisherEventArgs class is a data type that defines the information passed to receivers of the event. This information includes the event ID and an Arguments array containing the arguments for the event. Therefore, event handling code must extract the event arguments from the EventPublisherEventArgs object as shown in the following sample code snippet, which uses the .NET CIL:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-95
Arguments args = eventArgs.rArgs; EventID receivedEvent = (EventID) eventArgs.iEventID; switch(receivedEvent) { case EventID.eQueryAgentStatisticsConf: ProcessQueryConf(args); break; ... }
To unsubscribe for events in the .NET CIL, use the RemoveEventListener method. This method has the following syntax:
CilError RemoveEventListener(IGenericEvents Listener, int iListID)
where Listener is the IGenericEvents object that is unsubscribing for events and iListID is the ID of the subscriber list from which to remove this listener.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-96
Release 8.0(1)
Chapter 6
Table 6-90
eCallHeldEvent
eCallConnectionClearedEvent
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-97
Parameters CTIOS_PRIMARYCALLID CTIOS_SECONDARYCALLID CTIOS_TRANSFERRINGDEVICEID CTIOS_TRANSFERRINGDEVICEIDFULL CTIOS_TRANSFERREDDEVICEID CTIOS_TRANSFERREDDEVICEIDFULL CTIOS_NUMPARTIES ConnectedParty[PartyNumber] CTIOS_ISTRANSFERCONTROLLER GenerateCallDataUpdateArgs()*** CTIOS_ENABLEMENTMASK CTIOS_ICMENTERPRISEUNIQUEID CTIOS_UNIQUEOBJECTID CTIOS_DEVICEUNIQUEOBJECTID CTIOS_FILTERTARGET** CTIOS_CALLSTATUS*
eCallConferencedEvent
CTIOS_PRIMARYCALLID CTIOS_SECONDARYCALLID CTIOS_CONTROLLERDEVICEID CTIOS_CONTROLLERDEVICEIDFULL CTIOS_ADDEDPARTYDEVICEID CTIOS_ADDEDPARTYDEVICEIDFULL CTIOS_PRIMARYDEVICEID CTIOS_PRIMARYDEVICEIDFULL CTIOS_SECONDARYDEVICEID CTIOS_SECONDARYDEVICEIDFULL CTIOS_NUMPARTIES ConnectedParty[PartyNumber] GenerateCallDataUpdateArgs()*** CTIOS_ENABLEMENTMASK CTIOS_ICMENTERPRISEUNIQUEID CTIOS_UNIQUEOBJECTID CTIOS_DEVICEUNIQUEOBJECTID CTIOS_FILTERTARGET** CTIOS_CALLSTATUS*
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-98
Release 8.0(1)
Chapter 6
Parameters GenerateCallDataUpdateArgs()*** CTIOS_DEVICEID CTIOS_DIVERTINGDEVICEID CTIOS_DIVERTINGDEVICEIDFULL CTIOS_ENABLEMENTMASK CTIOS_ICMENTERPRISEUNIQUEID CTIOS_UNIQUEOBJECTID CTIOS_DEVICEUNIQUEOBJECTID CTIOS_FILTERTARGET** CTIOS_CALLSTATUS*
eCallDivertedEvent
eSnapshotCallConf
Includes all the parameters except for: CTIOS_ICMENTERPRISEUNIQUEID CTIOS_CALLCONNECTIONCALLID CTIOS_CALLCONNECTIONDEVICEIDTYPE CTIOS_CALLCONNECTIONDEVICEID CTIOS_CALLDEVICECONNECTIONSTATE CTIOS_CALLDEVICETYPE
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-99
Parameters CTIOS_ANSWERINGDEVICEID CTIOS_ANSWERINGDEVICEIDFULL CTIOS_CALLINGDEVICEID CTIOS_CALLINGDEVICEIDFULL CTIOS_CALLEDDEVICEID CTIOS_CALLEDDEVICEIDFULL CTIOS_SKILLGROUPID CTIOS_SKILLGROUPNUMBER CTIOS_SKILLGROUPPRIORITY CTIOS_SERVICEID CTIOS_SERVICENUMBER CTIOS_LINETYPE CTIOS_MEASUREDCALLQTIME CTIOS_CAMPAIGNID CTIOS_QUERYRULEID CTIOS_ENABLEMENTMASK CTIOS_ICMENTERPRISEUNIQUEID CTIOS_UNIQUEOBJECTID CTIOS_DEVICEUNIQUEOBJECTID CTIOS_FILTERTARGET** CTIOS_CALLSTATUS*
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-100
Release 8.0(1)
Chapter 6
Parameters CTIOS_ALERTINGDEVICEID CTIOS_ALERTINGDEVICEIDFULL CTIOS_CALLINGDEVICEID CTIOS_CALLEDDEVICEID CTIOS_CALLINGDEVICEIDFULL CTIOS_CALLEDDEVICEIDFULL CTIOS_SKILLGROUPID CTIOS_SKILLGROUPNUMBER CTIOS_SKILLGROUPPRIORITY CTIOS_SERVICEID CTIOS_SERVICENUMBER CTIOS_LINETYPE CTIOS_MEASUREDCALLQTIME CTIOS_CAMPAIGNID CTIOS_QUERYRULEID CTIOS_ENABLEMENTMASK CTIOS_ICMENTERPRISEUNIQUEID CTIOS_UNIQUEOBJECTID CTIOS_DEVICEUNIQUEOBJECTID CTIOS_FILTERTARGET** CTIOS_CALLSTATUS*
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-101
Parameters CTIOS_CALLINGDEVICEIDFULL CTIOS_CALLEDDEVICEIDFULL CTIOS_CALLINGDEVICEID CTIOS_CALLEDDEVICEID CTIOS_SKILLGROUPID CTIOS_SKILLGROUPNUMBER CTIOS_SKILLGROUPPRIORITY CTIOS_SERVICEID CTIOS_SERVICENUMBER CTIOS_LINETYPE CTIOS_MEASUREDCALLQTIME CTIOS_CAMPAIGNID CTIOS_QUERYRULEID CTIOS_ENABLEMENTMASK CTIOS_ICMENTERPRISEUNIQUEID CTIOS_UNIQUEOBJECTID CTIOS_DEVICEUNIQUEOBJECTID CTIOS_FILTERTARGET** CTIOS_CALLSTATUS*
eControlFailureConf
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-102
Release 8.0(1)
Chapter 6
eCallEndEvent
* If the eCallFailedEvent notification is received, the CTIOS_CALLSTATUS parameter will not be added to any more events for the call id specified in the eCallFailedEvent. ** If there is an agent on the device, then CTIOS_FILTERTARGET is added to all events listed in table 6-90. *** the GenerateCallDataUpdateArgs() method adds the following parameters to the event: CTIOS_PERIPHERALID, CTIOS_PERIPHERALTYPE, CTIOS_CALLTYPE, CTIOS_UNIQUEOBJECTID, CTIOS_ROUTERCALLKEYDAY, CTIOS_ROUTERCALLKEYCALLID, CTIOS_CONNECTIONCALLID, CTIOS_ANI, CTIOS_USERTOUSERINFO, CTIOS_DNIS, CTIOS_DIALEDNUMBER, CTIOS_CALLERENTEREDDIGITS, CTIOS_SERVICENUMBER, CTIOS_SERVICEID, CTIOS_SKILLGROUPNUMBER, CTIOS_SKILLGROUPPRIORITY, CTIOS_CALLWRAPUPDATA, CTIOS_CAMPAIGNID, CTIOS_QUERYRULEID, CTIOS_CALLVARIABLE1, CTIOS_CALLVARIABLE2, CTIOS_CALLVARIABLE3, CTIOS_CALLVARIABLE4, CTIOS_CALLVARIABLE5, CTIOS_CALLVARIABLE6, CTIOS_CALLVARIABLE7, CTIOS_CALLVARIABLE8, CTIOS_CALLVARIABLE9, CTIOS_CALLVARIABLE10, CTIOS_CUSTOMERPHONENUMBER, CTIOS_CUSTOMERACCOUNTNUMBER, CTIOS_NUMNAMEDVARIABLES, CTIOS_NUMNAMEDARRAYS, CTIOS_ECC, CTIOS_CTICLIENTS
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
6-103
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
6-104
Release 8.0(1)
CHAPTER
Session Object
The Client Interface Librarys Session object is used to establish a connection to an active CTI OS server. The main functions of the Session object are:
Managing the connection to the CTI OS Server Distributing events to the appropriate objects and event subscribers Creating and managing the collections of Agent, Call, and SkillGroup objects Automatically recovering from failures
Typically, an application has a single instance of the Session object, which is used by all other CIL objects to send and receive events. However, there are no restrictions on the number or types of Session objects one application can employ. It is possible, and sometimes desirable, to establish and manage multiple independent Sessions, for example to use multiple current event streams. If there is more than one Session object monitoring the same Agent or Call, each Session object will receive its own events. The order in which events are received is not guaranteed when there are multiple Session objects. For a detailed explanation of using the Session object to connect with CTI OS Server, see the section Connecting to the CTI OS Server in Chapter 4, Building Your Application. The Session object creates new Call, Agent, and SkillGroup objects upon receipt of an event for that object if the targeted object does not already exist. The Session object maintains collections of all Agents, Calls, SkillGroups, and WaitObjects. Object lifetime is managed by the Session object, and thus it is important that the client application not delete the objects, which would render the object reference invalid and lead to unpredictable results. When the Session is Released, the connection to CTI OS server is dropped. Any remaining Agent, Call, Skill Group, or WaitObjects will be released. The remainder of this chapter describes the data properties and interface methods of the Session object.
The data type listed for each keyword is the standardized data type discussed in the section CTI OS CIL Data Types in Chapter 3, CIL Coding Conventions. See Table 3-1 for the appropriate language specific types for these keywords.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-1
Session Object
Table 8-1
Session Properties
Type INT
Description If this value is present and set to true, supervisor applications should initiate silent monitor using the Agent.SuperviseCall() method. Agent applications do not need to do anything. If this value is not present, or set to false, supervisor and agent applications will need to invoke silent monitor using the SilentMonitorManager object. This property only applies to the COM CIL. Time of day in milliseconds when connected. eAgentConnection (1), eMonitorConnection (2), or eNotConnected (0). Name or TCP/IP address passed as CTI OS server A. Name or TCP/IP address passed as CTI OS server B Returns reference to current agent object set by the SetAgent method. Object reference is incremented by one and must be released when no longer used. Valid only if in Agent Connect mode. When there is more than one call, this references the current call. The current call is the call selected. For additional information, refer to CurrentCall in Chapter 10, Call Object. TCP/IP address of the current connected CTI OS server. May be port A or B. Name or TCP/IP address of the current connected CTI OS server. The value is blank when the client is not connected to any server. The name may be blank while attempting to reconnect after a lost connection. Otherwise, the name of the server should be the name of CTI OS server A or B. The presence of this keyword, Heartbeat time, expressed in seconds. If not set, default heartbeats are configurable on the CTI OS server. Last error code, if any. Otherwise this value is 0. Max heartbeats that can be missed before switching CTI OS servers. Default is 3 missed heartbeats. The filter that controls the events received by the CIL.
CurrentCall
CurrentPort CurrentServer
INT STRING
Object References ARGUMENTS Array of object references maintained by the session object. Typically includes Agent References, CallReferences, and SkillGroupReferences. Can also include EmailReferences or Chat References. PortA PortB TryingPort INT INT INT TCP/IP port for ctiosA. TCP/IP port for ctiosB. TCP/IP address of the server where a connection is being attempted. May be port A or B.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-2
Release 8.0(1)
Chapter 8
Table 8-1
Keyword TryingServer
Type STRING
Description Contains the name or TCP/IP address of the server where a connection is being attempted. The value is blank if no connection is being attempted (see CurrentServer). The name of the server should be the name of CTI OS server A or B. Time of day in milliseconds when try began.
TryingSince
INT
Methods
Table 8-2 lists the available session object methods.
Table 8-2 Session Object Methods
Method AddEventListener AddListener methods Connect CreateWaitObject DestroySilentMonitor Manager DestroyWaitObject Disconnect DumpProperties GetAllAgents GetAllCalls GetAllProperties GetAllSkillGroups GetCurrentAgent GetCurrentCall GetCurrentSilentMonitor GetElement GetNumProperties GetObjectFromObjectID GetPropertyName GetPropertyType GetValue
Description Subscribes a .NET IGenericEvents object as a listener on a particular subscriber list. Registers the subscriber for an event listener. Establishes a connection to a CTI OS server. Creates and returns the pointer to a new CWaitObject. Deletes a SilentMonitorManager object instance. Destroys the specified wait object Closes the connection to the CTI OS server. See Chapter 7, CtiOs Object. Returns a collection of all the agents in the session. Returns a collection of all the calls in the session. See Chapter 7, CtiOs Object. Returns a collection of all the skill groups in the session. Returns the currently selected agent. Returns the currently selected call. Returns a pointer to the SilentMonitorManager object instance that is set as the current manager in the CTI OS session object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. Returns a Call, Agent, or SkillGroup, given the objects UniqueObjectID. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-3
Chapter 8 Methods
Session Object
Table 8-2
Description See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. Checks the current agent and returns true if the current agent is an agent and not a supervisor. The IsCCMSilentMonitor method determines whether CTI OS has been configured to use CCM based silent monitor. This method is only supported with the C++, Java, COM, and .Net CILs. Checks the current agent and returns true if the current agent is a supervisor. See Chapter 7, CtiOs Object. Unregisters the subscriber from an event listener. Sends a message request to the CTI OS Server to retrieve the desktop settings configured for this site. Sets an agent to a session object. Associates the current call to a session object. Sets the SilentMonitorManager object instance specified as the current manager in the CTI OS session object. Sets the message filter that controls the set of events sent to the CIL. Forces supervisors into monitored mode. See Chapter 7, CtiOs Object.
IsSupervisor IsValid RemoveListener methods RequestDesktopSettings SetAgent SetCurrentCall SetCurrentSilentMonitor SetMessageFilter SetSupervisorSilentMonitor Mode SetValue
Syntax
JAVA: .NET int AddEventListener(IGenericEvents Listener, int iListID) CilError AddEventListener(IGenericEvents Listener, SubscriberList iListID)
Parameters
Listener The IGenericEvents object that is subscribing for events. ListID The ID of the subscriber list to which the Listener is to be added.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-4
Release 8.0(1)
Chapter 8
Returns
A CtiOs_Enums.CilError code indicating success or failure.
Syntax
int int int int int int int int int int int int int int int AddEventListener(Arguments & rArguments); AddSessionEventListener(ISessionEvents * pSessionEvents); AddCallEventListener(ICallEvents * pCallEvents); AddAgentEventListener(IAgentEvents * pAgentEvents); AddSkillGroupEventListener(ISkillGroupEvents * pSkillGroupEvents); AddButtonEnablementEventListener(IButtonEnablementEvents * pButtonEvents); AddAllInOneEventListener(IAllInOne * pAllInOneEvents); AddSilentMonitorEventListener(ISilentMonitorEvents * pSilentMonitorEvents); AddSessionEventGenericListener(IGenericEvents * pSessionEvents); AddCallEventGenericListener(IGenericEvents * pCallEvents); AddAgentEventGenericListener(IGenericEvents * pAgentEvents); AddSkillGroupEventGenericListener(IGenericEvents * pSkillGroupEvents); AddButtonEnablementEventGenericListener(IGenericEvents * pButtonEvents); AddAllInOneEventGenericListener(IGenericEvents * pAllInOneEvents); AddSilentMonitorEventGenericListener(IGenericEvents * pSilentMonitorEvents);
Remarks
Also, see the section Subscribing for Events in C++ in Chapter 4, Building Your Application.
Connect
The Connect method establishes a connection with a CTI OS server.
Syntax
C++: COM: VB: Java: .NET:
int Connect(Arguments& args) HRESULT Connect(IArguments *args, int * errorcode) Connect(args As CTIOSCLIENTLib.IArguments) As Long int Connect(Arguments args) CilError Connect(Arguments rArgs)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-5
Chapter 8 Methods
Session Object
Parameters
args An arguments array containing the connection parameters listed in Table 8-3.
Table 8-3 Connect Parameters
Keyword CtiosA
Type STRING
Description Name or TCP/IP address of CTI OS server A. If this value is not provided, the value of Ctios B is used.
Note
CtiosB
STRING
Name or TCP/IP address of CTI OS server B. If this value is not provided, the value of Ctios A is used.
Note
TCP/IP port for ctiosA, default = 42028. TCP/IP port for ctiosB, default = 42028. Heartbeat time, expressed in seconds. If not set, default heartbeats are configurable on CTI OS server.
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions..
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
A successful request will result in an OnConnection event. A failure will result in an OnConnectionFailure event. This means that the CIL is in failover. The CIL will continue to attempt to connect, alternating between hosts CTIOS_CTIOSA and CTIOS_CTIOSB until connection succeeds at which point CIL will fire OnConnection. If application wishes to stop failover, it must call Disconnect. In some cases, additional failure codes and events may occur:
Connect will return a failure code of -1 if it cannot connect with the initial side of the duplexed CTI OS server pair chosen from the connect parameters. This error code requires no action on the part of the developer as the CIL will automatically attempt to connect using the parameters corresponding to the other side of the duplexed pair. The CIL will retry the connection attempt five times and then will not attempt to reconnect any longer. The final OnConnectionFailure event will contain the keyword "FinalAttempt" which informs the client application that the CIL has discontinued its attempts to reconnect.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-6
Release 8.0(1)
Chapter 8
Note
This behavior will only occur after global settings download has completed. If global settings download has not completed, the CIL will continue to retry until successful.
The Connect method will cause an OnCTIOSFailure event to be fired to the client indicating the current state of the system. This is in addition to OnConnection or OnConnectionFailure. CIL_OK - no obvious errors, application should wait for an event indicating whether or not Connect has succeeded CIL_FAIL - initial attempt to connect with host has failed. CIL will fire OnConnectionFailure and go into failover mode. CIL will continue to attempt to connect, alternating between hosts CTIOS_CTIOSA and CTIOS_CTIOSB until connection succeeds at which point CIL will fire OnConnection. If application wishes to stop failover, it must call Disconnect. E_CTIOS_INVALID_ARGUMENT - a null Arguments parameter was supplied. Connect is aborted. No events are fired. E_CTIOS_MISSING_ARGUMENT - indicates that method call provided no value for both CTIOS_CTIOSA or CTIOS_CTIOSB. At least one of these values must be provided. Connect is aborted. No events are fired. E_CTIOS_IN_FAILOVER - a previous call to connect failed and CIL is currently in failover attempting to establish a connection. This will continue until a connection is established at which point the CIL will send OnConnection indicating that previous call to Connect has succeeded. If developer wishes to call Connect again with different parameters, he/she must call Disconnect prior to calling Connect again. E_CTIOS_MODE_CONFLICT - Session is not disconnected (i.e a previous call to Connect is in progress or session is already connected). Disconnect must be called before attempting to establish another connection. CIL may fire an OnConnection event corresponding to previous call to Connect if connection was in progress but will not fire one corresponding to this method call. E_CTIOS_SESSION_NOT_CONNECTED - unanticipated error. Connect is aborted. No events are fired.
CreateSilentMonitorManager
The CreateSilentMonitorManager method creates a SilentMonitorManager object instance. To delete the object you must call DestroySilentMonitorManager.
Syntax
C++: CSilentMonitorManager * CreateSilentMonitorManager(Arguments & args); COM: HRESULT CreateSilentMonitorManager ( /*[in]*/ IArguments * args, /*[out,retval]*/
ISilentMonitorManager * * pISilentMonitor); VB: CreateSilentMonitorManager (ByVal args as CTIOSCLIENTLIB.IArguments) As CTIOSCLIENTLIB.ISilentMonitorManager Java: Not available. .NET: Not available.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-7
Chapter 8 Methods
Session Object
Parameters
args Arguments array that contains the parameters listed below. When any of these parameters are specified, the object is constructed with the corresponding property initialized to the specified value. If you want the object to be initialized with the default values specify an empty array.
Table 8-4 CrateSilentMonitorManager Parameters
Description Heartbeat interval for the silent monitor session. Timeout for no activity. Required only if manager will be used in monitoring mode. TCP/IP port where monitored conversation will be sent for playback on system sound card.
Return Value
If successful, a CSilentMonitorManager object is returned. Otherwise, NULL is returned. To identify the specific error, check the value of the LastError Session property (Table 8-1).
Remarks
Supported for use with Unified CCE only.
Syntax
C++: CWaitObject * CreateWaitObject(Arguments & args); Java: WaitObject CreateWaitObject(Arguments rObjParam) .NET: WaitObject CreateWaitObject(Arguments rObjParam)
Parameters
args (C++). rObjParam (Java) A reference to an Arguments object that contains the list of events the object will wait for. The Arguments should contain values where the keys are Event1 through EventN and the values are the enumerated event IDs.
Return Values
If successful it returns a pointer to the new Wait object. Otherwise, it returns NULL. For more information about CWaitObject see Chapter 12, Helper Classes.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-8
Release 8.0(1)
Chapter 8
DestroySilentMonitorManager
The DestroySilentMonitorManager method deletes a SilentMonitorManager object instance.
Syntax
C++: int DestroySilentMonitorManager(CSilentMonitorManager * pSilentMonitor); COM: HRESULT DestroySilentMonitorManager (/*[in]*/ ISilentMonitorManager *
pSilentMonitor, /*[out,retval]*/ int * errorcode);
Parameters
pSilentMonitor Valid pointer to a SilentMonitorManager object created via CreateSilentMonitorManager. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
Supported for use with Unified CCE only.
Syntax
C++: void DestroyWaitObject(CWaitObject * pWaitObject) Java: void DestroyWaitObject(WaitObject rWaitObj) .NET: DestroyWaitObject(WaitObject rWaitObj)
Parameters
WaitObject A pointer to the CWaitObject to be destroyed.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-9
Chapter 8 Methods
Session Object
Return Values
None.
Remarks
For more information about CWaitObject see Chapter 12, Helper Classes.
Syntax
C++, Java:int DisableSkillGroupStatistics(Arguments & args) .NET: CilError DisableSkillGroupStatistics(Arguments rArgs)
Parameters
args This parameter has two required values for PeripheralId and SkillGroupNumber. See the Remarks section for a code example.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
C++ code example:
Arguments & argsStatBroadcast = Arguments::CreateInstance(); argsStatBroadcast.AddItem(CTIOS_SKILLGROUPNUMBER, intSG); argsStatBroadcast.AddItem(CTIOS_PERIPHERALID, m_periphID); m_pSkGrStatSession->DisableSkillGroupStatistics ( argsStatBroadcast ); argsStatBroadcast.Release();
Disconnect
The Disconnect method disconnects the open connection to the CTI OS server. In Java and .NET, you can use the Disconnect method to interrupt failover.
Syntax
void Disconnect (Arguments& args); HRESULT Disconnect (/* [in, optional */ IArguments *args, /*[out]*/ int * errorcode ); VB: Disconnect(args As CTIOSCLIENTLib.IArguments) As Long
C++: COM:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-10
Release 8.0(1)
Chapter 8
Parameters
args An optional arguments array containing the CTIOS_FORCEDDISCONNECT keyword, which forces a disconnect even if the Session object rejects the disconnect. This keyword should be added to the array if the session mode has not yet been set by SetAgent or SetSessionMode at the time of the disconnect. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions..
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
DumpProperties
See Chapter 7, CtiOs Object for a description of the DumpProperties method.
Syntax
C++/Java:int EnableSkillGroupStatistics(Arguments & args) .NET:CilError EnableSkillGroupStatistics(Arguments rArgs)
Parameters
args This parameter has two required values for PeripheralId and SkillGroupNumber. See the Remarks section for a code example.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-11
Chapter 8 Methods
Session Object
Remarks
C++ code example:
Arguments & argsStatBroadcast = Arguments::CreateInstance(); argsStatBroadcast.AddItem(CTIOS_SKILLGROUPNUMBER, intSG); argsStatBroadcast.AddItem(CTIOS_PERIPHERALID, m_periphID); m_pSkGrStatSession->EnableSkillGroupStatistics ( argsStatBroadcast ); argsStatBroadcast.Release();
GetAllAgents
The GetAllAgents method returns an array of object IDs. Each object ID is associated with an Agent object stored in the CIL. The number of object IDs returned from this method depends on the number of agents that the CIL has discovered through agent events. For example, a CIL used in an agent desktop application returns one ID, which is the ID of the agent currently logged into the desktop. A supervisor desktop returns the supervisors ID as well as IDs for all agents on the supervisors team. A monitor mode application filtering all agent events returns IDs for each agent known by the CTI OS Server.
Syntax
C++: COM: VB: Java: .NET:
Arguments & GetAllAgents() HRESULT GetAllAgents(/*[out, retval]*/ VARIANT *args) GetAllAgents (args As VARIANT) Arguments GetAllAgents() Arguments GetAllAgents()
Parameters
args
COM/VB: A pointer to a VARIANT containing a SAFEARRAY of pointers to IAgents.
Return Values
COM/VB: Default CTI OS return values. See Chapter 3, CIL Coding Conventions. Java/.NET: Returns NULL if the value requested is not found or if there is an error. If the method succeeds, it returns a pointer or a reference to an Arguments array where each member has a string key that is the UniqueObjectID of an agent and a value that is a reference to a CilRefArg that is a pointer to the agent object. C++: An empty Arguments array if the value requested is not found or if there is an error. If the method succeeds, it returns a pointer or a reference to an Arguments array where each member has a string key that is the UniqueObjectID of an agent and a value that is a reference to a CilRefArg that is a pointer to the agent object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-12
Release 8.0(1)
Chapter 8
Remarks
The following sample C++ code illustrates how to take the array returned from GetAllAgents() and use it to access the corresponding agents in the CILs object cache. The example uses the C++ CIL.
Arguments &args = m_pSession->GetAllAgents() ; // Iterate through all of the CILRefArg objects // in the Arguments array. // for ( int i = 1 ; i <= args.NumElements() ; i++ ) { CILRefArg *pRefArg = NULL ; // Retrieve the CILRefArg at each position in the // array. // if ( args.GetElement(i, (Arg **)&pRefArg) ) { if ( pRefArg != NULL ) { // The value method will return a pointer // to the agent object referenced by the // CILRefArg. // CAgent *pAgent = (CAgent *)pRefArg->GetValue() ; cout << "-- Agent Properties --" << endl ; if ( pAgent == NULL ) { cout << "NULL" << endl ; } else { cout << pAgent->DumpProperties().c_str() << endl ; } cout << "--" << endl ; } } }
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-13
Chapter 8 Methods
Session Object
The following sample VB.NET code illustrates how to take the array returned from GetAllAgents() and use it to access the corresponding agents in the CILs object cache. The example uses the .NET CIL.
Dim args As Arguments args = m_session.GetAllAgents() ' Iterate through all of the CILRefArg objects ' in the Arguments array. ' Dim i As Integer For i = 1 To args.NumElements() Dim refArg As CilRefArg ' Retrieve the CILRefArg at each position in the ' array. ' If (args.GetElement(i, refArg)) Then If ((refArg Is Nothing) = False) Then ' The value method will return a reference ' to the agent object referenced by the ' CILRefArg. ' Dim agent As Agent refArg.GetValue(agent) Console.Out.WriteLine("--") If (agent Is Nothing) Then Console.Out.WriteLine("Nothing") Else Console.Out.WriteLine(agent.DumpProperties()) End If Console.Out.WriteLine("--") End If End If Next
GetAllCalls
The GetAllCalls method returns an array of object IDs. Each object ID is associated with a Call object stored in the CIL. The number of object IDs returned from this method depends on the number of calls that the CIL has discovered through call events. For example, a CIL used in an agent desktop application will return IDs for all calls in which the agent is involved. A supervisor desktop returns IDs for any call in which the supervisor is involved as well as IDs for monitored calls. A monitor mode application filtering all call events returns IDs for each call known by the CTI OS Server.
Syntax
C++: COM
Arguments & GetAllCalls() HRESULT GetAllCalls(/*[out, retval]*/ VARIANT *args)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-14
Release 8.0(1)
Chapter 8
VB: GetAllCalls (args As VARIANT) Java: Arguments GetAllCalls() .NET: Arguments GetAllCalls()
Parameters
args COM /VB: A pointer to a VARIANT containing a SAFEARRAY of pointers to ICalls.
Return Values
COM/VB: Default CTI OS return values. See Chapter 3, CIL Coding Conventions. Java/.NET: Returns NULL if the value requested is not found or if there is an error. If the method succeeds, it returns a pointer or a reference to an Arguments array where each member has a string key that is the UniqueObjectID of a call and a value that is a reference to a CilRefArg that is a pointer to the call object. C++: An empty Arguments array if the value requested is not found or if there is an error. If the method succeeds, it returns a pointer or a reference to an Arguments array where each member has a string key that is the UniqueObjectID of a call and a value that is a reference to a CilRefArg that is a pointer to the call object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-15
Chapter 8 Methods
Session Object
Remarks
The following sample C++ code illustrates how to take the array returned from GetAllCalls() and use it to access the corresponding calls in the CILs object cache. The example uses the C++ CIL.
Arguments &args = m_pSession->GetAllCalls() ; // Iterate through all of the CILRefArg objects // in the Arguments array. // for ( int i = 1 ; i <= args.NumElements() ; i++ ) { CILRefArg *pRefArg = NULL ; // Retrieve the CILRefArg at each position in the // array. // if ( args.GetElement(i, (Arg **)&pRefArg) ) { if ( pRefArg != NULL ) { // The value method will return a pointer // to the agent object referenced by the // CILRefArg. // CCall *pCall = (CCall *)pRefArg->GetValue() ; cout << "-- Call Properties --" << endl ; if ( pCall == NULL ) { cout << "NULL" << endl ; } else { cout << pCall->DumpProperties().c_str() << endl ; } cout << "--" << endl ; } } }
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-16
Release 8.0(1)
Chapter 8
The following sample VB.NET code illustrates how to take the array returned from GetAllCalls() and use it to access the corresponding calls in the CILs object cache. The example uses the .NET CIL.
Dim args As Arguments args = m_session.GetAllCalls() ' Iterate through all of the CILRefArg objects ' in the Arguments array. ' Dim i As Integer For i = 1 To args.NumElements() Dim refArg As CilRefArg ' Retrieve the CILRefArg at each position in the ' array. ' If (args.GetElement(i, refArg)) Then If ((refArg Is Nothing) = False) Then ' The value method will return a reference ' to the call object referenced by the ' CILRefArg. ' Dim aCall As Cisco.CtiOs.Cil.Call refArg.GetValue(aCall) Console.Out.WriteLine("--") Dim str As String If (aCall Is Nothing) Then Console.Out.WriteLine("Nothing") Else Console.Out.WriteLine(aCall.DumpProperties()) End If Console.Out.WriteLine("--") End If End If Next
GetAllProperties
See Chapter 7, CtiOs Object for a description of the GetAllProperties method.
GetAllSkillGroups
The GetAllSkillGroups method returns an array of object IDs. Each object ID is associated with a skill group stored in the CIL.
Syntax
C++:
Arguments & GetAllSkillGroups()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-17
Chapter 8 Methods
Session Object
COM: HRESULT GetAllSkillGroups(/*[out, retval]*/ VARIANT *args) VB: GetAllSkillGroups (args As VARIANT) Java , .NET: Arguments GetAllSkillGroups()
Parameters
args C++, Java, and .NET: A pointer or a fereence to an Arguments array where each member has a string key that is the UniqueObjectID of a skill group and a value that is a reference to a CilRefArg that is a pointer to the skill group object. COM /VB: A pointer to a VARIANT containing a SAFEARRAY of pointers to ISkillGroups.
Return Values
COM/VB: Default CTI OS return values. See Chapter 3, CIL Coding Conventions. Java/.NET: Returns NULL if the value requested is not found or if there is an error. If the method succeeds, it returns a pointer or a reference to an Arguments array where each member has a string key that is the UniqueObjectID of a skill group and a value that is a reference to a CilRefArg that is a pointer to the skill group object. C++: An empty Arguments array if the value requested is not found or if there is an error. If the method succeeds, it returns a pointer or a reference to an Arguments array where each member has a string key that is the UniqueObjectID of a skill group and a value that is a reference to a CilRefArg that is a pointer to the skill group object.
GetCurrentAgent
The GetCurrentAgent method returns the Agent specified when the Agent Mode connection was established. Use this method rather than GetValue(CurrentAgent).
Syntax
C++: Agent* GetCurrentAgent() COM: HRESULT GetCurrentAgent(/*[out, retval]*/ IAgent *agent) VB: GetCurrentAgent () As CTIOSCLIENTLib.IAgent Java,.NET: Agent GetCurrentAgent()
Parameters
agent An output parameter (return value in VB, C++, Java, and .NET) containing a pointer to a pointer to an IAgent that is the currently selected agent.
Return Values
COM: Default CTI OS return values. See Chapter 3, CIL Coding Conventions. Others: A pointer or reference to an Agent that is the current agent. This method returns NULL if the value requested is not found or if there is an error.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-18
Release 8.0(1)
Chapter 8
The C++, Java, and .NET versions of this method return NULL if the value requested is not found or if there is an error.
GetCurrentCall
The GetCurrentCall method returns the call that is currently selected. This method can be used as a way for controls to communicate between each other which call is selected and therefore should be acted upon. Use this method rather than GetValue(CurrentCall).
Syntax
C++: CCall * GetCurrentCall() COM: HRESULT GetCurrentCall(/*[out, retval]*/ ICall ** call) VB: GetCurrentCall () As CTIOSCLIENTLib.ICall Java/.NET: Call GetCurrentCall()
Parameters
call An output parameter (return value in VB, C++, Java, and .NET) containing a pointer to a pointer to an ICall that is the currently selected call.
Return Values
COM: Default CTI OS return values. See Chapter 3, CIL Coding Conventions. Others: A pointer or reference to a Call that is the current call. This method returns NULL if the value requested is not found or if there is an error. The C++, Java, and .NET versions of this method return NULL if the value requested is not found or if there is an error.
GetCurrentSilentMonitor
The GetCurrentSilentMonitor method returns a pointer to the SilentMonitorManager object instance that is set as the current manager in the session object.
Syntax
C++: COM:
CSilentMonitorManager * GetCurrentSilentMonitor(); HRESULT GetCurrentSilentMonitor (/*[out,retval]*/ ISilentMonitorManager ** pSilentMonitor); VB: GetCurrentSilentMonitor () As CTIOSCLIENTLIB. ISilentMonitorManager Java,.NET: Not available
Return Values
Pointer to the current Silent Monitor Manager in the session object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-19
Chapter 8 Methods
Session Object
GetElement
See Chapter 7, CtiOs Object for a description of the GetElement method.
GetNumProperties
See Chapter 7, CtiOs Object for a description of the GetNumProperties method.
GetObjectFromObjectID
Given a string containing the UniqueObjectID of a call, an agent, or a skill group, the GetObjectFromObjectID method returns a pointer to the associated object.
Syntax
C++:
bool GetObjectFromObjectID (string& uniqueObjectID, CCtiosObject ** object); COM: HRESULT GetObjectFromObjectID (/*[in]*/ BSTR uniqueObjectID, /*[out]*/ IDispatch ** object, /*[out, retval]*/ VARIANT_BOOL * errorcode); VB: GetObjectFromObjectID(uniqueObjectID As String, object as IDispatch) As Boolean Java: CtiOsObject GetObjectFromObjectID(java.lang.String sUID) .NET: System.Boolean GetObjectFromObjectID(System.String sUID, out CtiOsObject rObj)
Parameters
COM/C++/VB: uniqueObjectID A string reference that contains the UniqueObjectID of the requested Call, Agent, or Skillgroup object. .NET: sUID A string reference that contains the UniqueObjectID of the requested Call, Agent, or Skillgroup object. COM/C++: object A pointer to either a CTIOSObject in C++ (which is a CILRefArg) or an IDispatch * pointing to either an ICall, an IAgent, or an ISkillGroup in COM. .NET: rObj A pointer to either a CTIOSObject in C++ (which is a CILRefArg) or an IDispatch * pointing to either an ICall, an IAgent, or an ISkillGroup in COM. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
COM: Default HRESULT return value. See Chapter 3, CIL Coding Conventions. C++, VB, .NET: A boolean indicating success or failure of the method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-20
Release 8.0(1)
Chapter 8
The Java version of this method return NULL if the value requested is not found or if there is an error.
Remarks
Many events use UniqueObjectIDs instead of the objects themselves. Use this method to get the object if it is necessary for processing.
GetPropertyName
See Chapter 7, CtiOs Object for a description of the GetPropertyName method.
GetPropertyType
See Chapter 7, CtiOs Object for a description of the GetPropertyType method.
Syntax
Java/C++: int GetSystemStatus() .NET: SystemStatus GetSystemStatus()
Parameters
None.
Returns
The current system status bitmask. Refer to OnQueryAgentStateConf in Chapter 6, Event Interfaces and Events for a description of the SystemStatus.
GetValue Methods
See Chapter 7, CtiOs Object for a description of the GetValue, GetValueArray, GetValueInt, and GetValueString methods.
IsAgent
The IsAgent method determines whether the current agent is an agent rather than a supervisor.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-21
Chapter 8 Methods
Session Object
Syntax
C++: COM: VB: Java: .NET:
bool IsAgent() HRESULT IsAgent (VARIANT_BOOL *bIsAgent) IsAgent () As Boolean boolean IsAgent() bool IsAgent()
Parameters
bIsAgent Output parameter (return parameter in VB) that returns true if the current AgentMode connection is for an agent and false if it is for a supervisor.
Return Values
If the current agent is an agent and not a supervisor it returns true, otherwise it returns false.
IsCCMSilentMonitor
The IsCCMSilentMonitor method determines whether CTI OS has been configured to use Unified Communication Manager based silent monitor.
Syntax
C++: COM: Java: .NET:
bool IsCCMSilentMonitor() HRESULT IsCCMSilentMonitor (VARIANT_BOOL * IsCCMSilentMonitor) boolean IsCCMSilentMonitor() bool IsCCMSilentMonitor()
Parameters
None.
Return Values
If Unified Communication Manager based silent monitor has been configured, this method returns true, otherwise it returns false.
IsSupervisor
The IsSupervisor method checks if the current agent is a supervisor.
Syntax
C++: COM: VB: Java:
bool IsSupervisor() HRESULT IsSupervisor (VARIANT_BOOL * bIsSupervisor) IsSupervisor () As Boolean boolean IsSupervisorMode()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-22
Release 8.0(1)
Chapter 8
.NET:
bool IsSupervisorMode()
Parameters
bIsSupervisor Output parameter (return parameter in VB) that returns true if the current AgentMode connection is for a supervisor and false if it is for an agent.
Return Values
If the current agent is a supervisor it returns true, otherwise it returns false.
IsValid
See Chapter 7, CtiOs Object for a description of the IsValid method.
Syntax
int RemoveEventListener(IGenericEvents Listener, int iListID)
Parameters
Listener The IGenericEvents object that is unsubscribing from events. ListID The ID of the subscriber list from which the Listener is to be removed.
Returns
A CtiOs_Enums.CilError code indicating success or failure.
Syntax
int RemoveEventListener(Arguments & rArguments); int RemoveSessionEventListener(ISessionEvents * pSessionEvents); int RemoveCallEventListener(ICallEvents * pCallEvents);
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-23
Chapter 8 Methods
Session Object
int RemoveAgentEventListener(IAgentEvents * pAgentEvents); int RemoveSkillGroupEventListener(ISkillGroupEvents * pSkillGroupEvents); int RemoveButtonEnablementEventListener(IButtonEnablementEvents * pButtonEvents); int RemoveAllInOneEventListener(IAllInOne * pAllInOneEvents); int RemoveSilentMonitorEventListener(ISilentMonitorEvents * pSilentMonitorEvents); int RemoveSessionEventGenericListener(IGenericEvents * pSessionEvents); int RemoveCallEventGenericListener(IGenericEvents * pCallEvents); int RemoveAgentEventGenericListener(IGenericEvents * pAgentEvents); int RemoveSkillGroupEventGenericListener(IGenericEvents * pSkillGroupEvents); int RemoveButtonEnablementEventGenericListener(IGenericEvents * pButtonEvents); int RemoveAllInOneEventGenericListener(IGenericEvents * pAllInOneEvents); int RemoveSilentMonitorEventGenericListener(IGenericEvents * pSilentMonitorEvents);
Remarks
Also, see the section Subscribing for Events in C++ in Chapter 4, Building Your Application.
RequestDesktopSettings
The RequestDesktopSettings method sends a request to the CTI OS Server to download the configuration settings defined for a desktop application.
Syntax
C++: int RequestDesktopSettings(Arguments& args) COM: HRESULT RequestDesktopSettings(/* [in] */ IArguments *args, /*[out]*/ int *
errorcode)
VB: RequestDesktopSettings (args As CTIOSCLIENTLib.IArguments) As Long Java: int RequestDesktopSettings(int desktopType) .NET: CilError RequestDesktopSettings(Arguments rArgs)
Parameters
args C++, COM, VB, and .NET: Input parameter in the form of a pointer or reference to an Arguments array containing one number. This number has a keyword of DesktopType and an integer value that is either:
eAgentDesktop (0) eSupervisorDesktop (1)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-24
Release 8.0(1)
Chapter 8
An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
A successful RequestDesktopSettings request results in an OnGlobalSettingsDownloadConf event. For detailed information about the OnGlobalSettingsDownloadConf event, see OnFailure Event section on page 6-6.
SetAgent
The SetAgent method assigns an agent to this Session object. The agent object used as a parameter in this method should have the following properties set:
Syntax
C++: int SetAgent(CAgent& agent) COM: HRESULT SetAgent(/*[in]*/IAgent *agent, /*[out, retval]*/ int * errorcode) VB: SetAgent (agent As CTIOSCLIENTLib.IAgent) As Long Java: int SetAgent(Agent agentObject) .NET: CilError SetAgent(Agent NewAgent)
Parameters
agent The agent to be assigned to the Session object. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
If the SetAgent request is successful, it returns a CIL_OK CtiOs_Enums.CilError code and sends an OnSetAgentMode event to the client application. In CTI OS Release 7.1(1) , the SetAgent request returns the following error codes:
CIL_FAIL - The request to authenticate failed. The SetAgent request will not be sent.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-25
Chapter 8 Methods
Session Object
E_CTIOS_SET_AGENT_SESSION_DISCONNECT_REQUIRED - You attempted to execute SetAgent for a session in monitor mode. The SetAgent request will not be sent. To correct, execute the Disconnect method to disconnect the session, then execute the SetAgent method. E_CTIOS_AGENT_ALREADY_IN_SESSION - You attempted to assign an agent that has already been assigned to this session. The SetAgent request will not be sent. In the above error cases, the SetAgent request will not be sent to the CTI OS server, and the client application will not receive any events in return.
Note
In Java only, if SetAgent () is called on a session where the current agent is different from the agent that SetAgent is trying to set, the following occurs:
The CIL automatically does a Disconnect on the current session object to Reset an agent. An OnCloseConnection event is received. A Connect is then performed. An OnConnection event is received, and the new agent is set.
In Java only, if the SetAgent request is unsuccessful it returns one of the following CtiOs_Enums.CilError codes:
E_CTIOS_INVALID_SESSION -- if session is not connected. E_CTIOS_PROP_ATTRIBUTES_ACCESS_FAILED -- if unable to get the connection mode property E_CTIOS_SET_AGENT_SESSION_DISCONNECT_REQUIRED -- if SetAgent request was during a Monitor Mode session. The client application will need to call Disconnect first to clean up the connection mode and then call Connect again. E_CTIOS_AGENT_ALREADY_IN_SESSION -- if the agent is already assigned to the session object. The client application will need to call Disconnect first to clean up the connection mode and then call Connect again. E_CTIOS_ARGUMENT_ALLOCATION_FAILED -- if the application is unable to allocate memory. E_CTIOS_PROP_ATTRIBUTES_ACCESS_FAILED -- if an error occurred while accessing agent properties.
SetCurrentCall
The SetCurrentCall method assigns a call as the sessions current call.
Syntax
C++: COM: VB: Java: .NET:
int SetCurrentCall(CCall& call) HRESULT SetCurrentCall (/*{in]*/ICall *call, /*[out, retval]*/ errorcode SetCurrentCall (call As CTIOSCLIENTLib.ICall) int SetCurrentCall(Call callObject) CilError SetCurrentCall(Call rCall)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-26
Release 8.0(1)
Chapter 8
Parameters
call Call to assign as current call. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions..
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
A successful request results in an OnCurrentCallChanged event. In Java and .NET, if the call object specified in the call parameter is already the current call, the OnCurrentCallChanged event is not fired to the client application and a E_CTIOS_CALL_ALREADY_CURRENT_IN_SESSION code is returned.
SetCurrentSilentMonitor
The SetCurrentSilentMonitor method sets the SilentMonitorManager object instance specified as the current manager in the CTI OS session object.
Syntax
int SetCurrentSilentMonitor(CSilentMonitorManager * pSilentMonitor); HRESULT SetCurrentSilentMonitor (/*[in]*/ ISilentMonitorManager * pSilentMonitor, /*[out,retval]*/ int * errorcode); VB: SetCurrentSilentMonitor (ByVal pSilentMonitor As CTIOSCLIENTLIB. ISilentMonitorManager) As Long Java: Not available .NET: Not available
C++: COM:
Parameters
pSilentMonitor Valid pointer to a SilentMonitorManager object created via CreateSilentMonitorManager errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-27
Chapter 8 Methods
Session Object
Remarks
Supported for use with Unified CCE only.
SetMessageFilter
The SetMessageFilter method specifies a filter for CTI OS Server to use to determine which events are sent to a monitor mode client.
Syntax
C++: COM: VB: Java: .NET:
int SetMessageFilter(string filter) HRESULT SetMessageFilter(/*{in]*/ BSTR filter, /*[out, retval]*/ int* errorcode) SetMessageFilter (filter As String, retVal As Long) int SetMessageFilter(Arguments messageFilter) CilError SetMessageFilter(Arguments rArgs)
Parameters
filter A string containing the message filter, as explained in the section Notes On Message Filters. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions..
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The Session will receive an OnMonitorModeEstablished event when the filter is set on the server.
SetSupervisorMonitorMode
The SetSupervisorSilentMonitorMode method can be used to force supervisors into monitored mode. It is used, for example, by the CTI OS Agent desktop to indicate that supervisors logging on to the Agent Desktop can be monitored.
Syntax
int SetSupervisorSilentMonitorMode (Arguments & args); HRESULT SetSupervisorSilentMonitorMode (/*[in]*/ IArguments * args, /*[out,retval]*/ int * errorcode); VB: SetSupervisorSilentMonitorMode (args As CTIOSCLIENTLib.IArguments); Java/.NET: Not available
C++: COM:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-28
Release 8.0(1)
Chapter 8
Parameters
args Arguments array that contains the following parameters.
Table 8-5 SetSupervisorSilentMonitorMode Arguments Array Parameters
Type INT
Description One of the following values: 1 -- supervisors can be monitored 0 (default) -- supervisors are put in monitoring mode and cannot be monitored
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Two filter mode applicationss are allowed for each CTI OS Server.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-29
Session Object
A Simple Example
The most basic event filter is for all events for a specific agent. CTI OS uniquely identifies an agent object by its UniqueObjectID (refer to CIL architecture chapter for explanation of the UniqueObjectID). To establish an event stream for a unique agent, the following syntax would be used:
sFilterExpression = UniqueObjectID=agent.5000.22866
In this example, the key is the UniqueObjectID, and the value is agent.5000.22866. This is not the same filter expression created when a CIL client connects to CTI OS in Agent Mode. When a CIL client connects to CTI OS in agent mode, the filter includes events for the agent as well as call events for the agent's extension.
In this form, the filter expression must start with a key name (key). Following the key must be an equal sign (=), and at least one value (value1) must be specified. Optionally, additional values (e.g. value2, ) for the same key might be specified (optional parts of the expression are indicated with square brackets []). This will be interpreted as a logical OR among all of the values specified for that key, e.g. if any of those values is found, the condition will be satisfied. For example, a filter expression with one key and multiple values might look like the following:
sFilterExpression = AgentID=22866, 22867, 22868
The interpretation of this filter is to match on any event with AgentID of 22866, 22867, or 22868.
Combining Filters
Multiple filters expressions (as described above) can be combined to create more complex expressions. The general form allows for any number of filters to be concatenated using the semicolon (;), which produces a logical AND effect. For example, a filter expression with multiple keys, each with multiple values might look like the following:
sFilterExpression = AgentID=22866, 22867, 22868; SkillGroupNumber=20, 21
The interpretation of this filter is to match on any event with AgentID of 22866, 22867, or 22868 and with SkillGroupNumber of 20 or 21.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-30
Release 8.0(1)
Chapter 8
It is also possible to obtain multiple specific events. For example, consider an all calls real-time display application, using eCallBeginEvent and eCallEndEvent to add or remove calls from a view:
register for all eCallBeginEvents, eCallEndEvents sFilterExpression = MessageID = 23, 24
ePreLogoutEvent ePostLogoutEvent eOnConnection eOnConnectionClosed eOnConnectionFailure eOnHeartbeat eOnMissingHeartbeat eOnCurrentCallChanged eOnCurrentAgentReset Events that are part of the IMonitoredAgentEvents interface or the IMonitoredCallsInterface. This includes the following events:
eOnMonitoredAgentStateChange OnMonitoredAgentInfoEvent OnMonitoredCallDeliveredEvent OnMonitoredCallEstablishedEvent OnMonitoredCallHeldEvent OnMonitoredCallRetrievedEvent OnMonitoredCallClearedEvent OnMonitoredCallConnectionClearedEvent OnMonitoredCallOriginatedEvent OnMonitoredCallFailedEvent OnMonitoredCallConferencedEvent OnMonitoredCallTransferredEvent
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-31
Session Object
OnMonitoredCallDivertedEvent OnMonitoredCallServiceInitiatedEvent OnMonitoredCallQueuedEvent OnMonitoredCallTranslationRouteEvent OnMonitoredCallBeginEvent OnMonitoredCallEndEvent OnMonitoredCallDataUpdateEvent OnMonitoredCallReachedNetworkEvent OnMonitoredCallDequeuedEvent OnMonitoredAgentPrecallEvent OnMonitoredAgentPrecallAbortEvent
To circumvent this restriction, use an equivalent message in the filter expression (for example, OnAgentStateEvent instead of OnMonitoredAgentStateChange) and check in the message handler for the CTIOS_MONITORED parameter to be TRUE.
void CMyEventSink::OnAgentStateEvent(Arguments & argParams) { if (argParams.IsValid(CTIOS_MONITORED) && argParams.GetValueBoolean(CTIOS_MONITORED)) { //Do process the event } }
Table 8-6
Keyword
Description
FilterTarget=SkillGroupStats (see When set, this filter indicates that the CTI OS server should forward skill group statistics to the client application, whether or not any agents Filtering Skillgroup Statistics, are logged in. page 8-32) HideSilentMonitorCallEvents (see Filtering CCM Based Silent Monitor Calls, page 8-33) This keyword is used to block call events for silent monitor calls in monitor mode applications.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-32
Release 8.0(1)
Chapter 8
After the filter is set, the client application needs to invoke the EnableSkillGroupStatistics(...) method for each skill group that it is expecting to receive statistics. To stop receiving statistics for a given skill group, the application must invoke the DisableSkillGroupStatistics method.
'register to receive skill group statistics sFilterExpression=FilterTarget=SkillGroupStats" 'call SetMessageFilter m_session.SetMessageFilter sFilterExpression 'Enable statistics for skills 78,89 and 90 in peripheral 5004 Private Sub m_Session_OnMonitorModeEstablished(ByVal pArguments As Arguments) Dim m_Args = new Arguments 'For Skill 78 m_Args.AddItem "SkillGroupNumber",78 m_Args.AddItem "PeripheralID",5004 m_session.EnableSkillGroupStatistics m_Args 'For Skill 89 m_Args.Clear m_Args.AddItem "SkillGroupNumber",89 m_Args.AddItem "PeripheralID",5004 m_session.EnableSkillGroupStatistics m_Args 'For Skill 90 m_Args.Clear m_Args.AddItem "SkillGroupNumber",90 m_Args.AddItem "PeripheralID",5004 m_session.EnableSkillGroupStatistics m_Args 'Don't need arguments any more Set m_Arg = Nothing End Sub Private Sub MyObjectClass_OnCleanupApplication() Dim m_Args = new Arguments 'For Skill 78 m_Args.AddItem "SkillGroupNumber",78 m_Args.AddItem "PeripheralID",5004 m_session.DisableSkillGroupStatistics m_Args 'For Skill 89 m_Args.Clear m_Args.AddItem "SkillGroupNumber",89 m_Args.AddItem "PeripheralID",5004 m_session.DisableSkillGroupStatistics m_Args 'For Skill 90 m_Args.Clear m_Args.AddItem "SkillGroupNumber",90 m_Args.AddItem "PeripheralID",5004 m_session.DisableSkillGroupStatistics m_Args 'Don't need arguments any more Set m_Arg = Nothing End Sub
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
8-33
Session Object
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
8-34
Release 8.0(1)
CHAPTER
CtiOs Object
All of the interface objects in the CTI OS Client Interface Library support some common features, such as the IsValid and GetValue methods. This chapter describes these common features. The CCtiOsObject class is the common base class for the objects in the CTI OS client interface library. It is implemented as follows:
In C++: All interface objects (CAgent, CCall, CCtiOsSession, CSkillGroup) derive from the CtiOS object. Thus, all the interface methods described in this chapter are directly available in the C++ objects. In COM (VB and C++): The COM objects for Agent, Call, Session, and SkillGroup publish a subset of these methods (as appropriate for the language), and the underlying implementation of the objects uses the C++ CCtiOsObject class to provide these features. In Java: All CTI OS interface objects (Agent, Call, Session, and SkillGroup) derive from the CtiOS object. Thus, all the interface methods described in this chapter are directly available in the Java objects. In .NET: All interface objects (Agent, Call, Session, and SkillGroup) derive from the CtiOS object. Thus, all the interface methods described in this chapter are directly available on the .NET objects. Dynamic management of the object properties Object lifetime control using a reference counting mechanism. Run-time class information
Methods
Table 7-1 lists the available CCtiOsObject class methods.
Table 7-1 CCtiOsObject Class Methods
Description Returns a string listing all of an objects properties names and values. Returns all of the objects properties as Args (name/value pairs). Returns the value of an element.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
7-1
Chapter 7 Methods
CtiOs Object
Table 7-1
Returns the last error that occurred on the calling thread. Returns the number of properties of an object. Returns a property name in a string format. Returns the data type of the specified property. Returns the value of a specified property.
DumpProperties
The DumpProperties method returns all the properties of the object. This method builds a string showing all of the properties in the form key1 = value1; key2 = value2;....
Syntax
C++: string DumpProperties () COM:HRESULT DumpProperties (/*[out,retval]*/ BSTR* bstrValue) VB: DumpProperties() As String Java:String DumpProperties() .NET:System.String DumpProperties()
Parameters
bstrValue The output parameter (return parameter in VB) containing a string listing the names and values of the objects properties.
Return Value
COM: Default HRESULT return value. See Chapter 3, CIL Coding Conventions.
All Others: The string listing the names of all the objects properties.
GetAllProperties
The GetAllProperties method returns all of the objects properties and their values. For the properties that are calls, agents, or skillgroups, their string UniqueObjectIDs are returned, not the objects themselves. To get the objects themselves use GetObjectFromObjectID, explained in Chapter 8, Session Object.
Syntax
C++:
bool GetAllProperties (Arguments** arguments)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
7-2
Release 8.0(1)
Chapter 7
COM:HRESULT GetAllProperties (/*[out]*/ IArguments** arguments, /*[out,retval]*/ VARIANT_BOOL* errorcode) VB: GetAllProperties arguments As (CTIOSCLIENTLib.IArguments) As Bool Java, .NET:Arguments GetAllProperties()
Parameters
C++, COM, VB: arguments Output parameter in the form of an arguments array that has all of the property names and values of the object. errorcode An output parameter (return parameter in VB) that contains a boolean indicating success or lack thereof.
Return Value
C++ , VB: True upon success and false upon failure. COM: Always returns S_OK. The errorcode parameter should be used to determine success or failure of the method call. .NET, Java: NULL if the value requested is not found or if there is an error. If the method succeeds, it returns a reference to an Arguments object containing all of the properties of the object.
GetElement
Given a property of type Arguments whose name is specified by the key parameter, the GetElement method returns the Arg at position element of that Arguments array.
Syntax
C++: Arg& GetElement (string& key, int element)
Arg& GetElement (int key, int element) Arg& GetElement (char* key, int element) COM: HRESULT GetElement /*[in]*/ VARIANT* key, /*[in]*/ int element, /*[out,retval]*/ IArg** pIArg) VB: GetElement (key As VARIANT) As CTIOSCLIENTLib.IArg Java: Arg GetElement(String key, int element) Arg GetElement(int key, int element) .NET:System.Boolean GetElement(System.String key, int element, out arg rArg)
Parameters
key A key designating the name of the Arguments property whose element you want. element The integer index of the element to retrieve from the property key. COM, VB:pIArg An output parameter (return parameter in VB) containing an IArg with the value of the desired element.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
7-3
Chapter 7 Methods
CtiOs Object
.NET: rArg An output parameter containing the value of the specified element. This parameter is null if the element is not found.
Return Value
An Arg reference containing the value of the desired element. The C++ and Java versions of this method return NULL if an error occurs, such as the key or element is not found. The .NET version of this method returns true upon success and false upon error.
Syntax
Java:Integer GetLastError() .NET:System.Boolean GetLastError(out System.Int32 nLastError)
Parameters
Java: None. .NET: nLastError Output parameter that is a 32-bit signed integer that contains the returned value of the last error.
Returns
Java:An Integer object containing the error, or null if the object is not found or if there is an error. .NET:The Boolean value true if the value is successfully set; otherwise false.
Remarks
The following example code gets the last error on the current thread and logs the error message. If GetLastError fails, the code writes a warning message to the log file.
// First get the last error System.Int32 myLastError; bool success = GetLastError(out myLastError); if (!success) { // log a message indicating that GetLastError failed } else { //log a message that indicates what the last error was LOGBYID(Cisco.CtiOs.Cil.TraceLevel.WARN, GetLastError returned last error = + myLastError); }
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
7-4
Release 8.0(1)
Chapter 7
GetNumProperties
The GetNumProperties method returns the number of properties in the current object.
Syntax
C++: int GetNumProperties () COM: HRESULT GetNumProperties (/*[out,retval]*/ int * num VB: GetNumProperties () As Long Java, .NET: int GetNumProperties()
Parameters
num In the COM version, an output parameter (return value in VB, C++, Java, and .NET) that contains an integer that is the number of properties in the object.
Return Value
COM: Default CTI OS return values. See Chapter 3, CIL Coding Conventions. All Others: An integer that is the number of properties currently a part of the object.
GetPropertyName
The GetPropertyName method returns the name of a property in a string format.
Syntax
C++: string GetPropertyName (int index) COM: HRESULT GetPropertyName (/* [in] index, /*[out,retval]*/ name) VB: GetPropertyName (index As Integer) As String Java: string GetPropertyName (int iIndex) .NET:virtual System.Boolean GetPropertyName(int iIndex, out System.String name)
Parameters
index An integer parameter specifying the index number of the requested property. name A string output parameter (return value in C++, VB, and Java) containing the propertys name.
Return Value
COM: Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
.NET: Boolean value set to true if the method call succeeds, otherwise false.
All Others: A string that contains the propertys name.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
7-5
Chapter 7 Methods
CtiOs Object
GetPropertyType
The GetPropertyType method returns the data type of the specified property.
Syntax
C++:
int GetPropertyType (string& key) int GetPropertyType (int key) int GetPropertyType (char* key) COM:HRESULT GetPropertyType (/*[in]*/ VARIANT* key, /*[out,retval]*/ int* value) VB: GetPropertyType (key As VARIANT) As Int Java:int GetPropertyType(string sPropName) int GetPropertyType(int key) .NET:virtual ArgDataType GetPropertyType(Enum_CtiOs eKeyID) virtual ArgDataType GetPropertyType(System.String sPropName)
Parameters
key Keyword ID name of the property whose type you want. In .NET, eKeyId is the Enum_CtiOs Keyword ID of the property. COM:value An integer pointer to the value of the type
Return Value
COM: Default HRESULT return value. See Chapter 3, CIL Coding Conventions.
Others: An integer indicating the propertys type with the following possible values:
Table 7-2 GetPropertyType Values
Argument Type ARG_NOTSET ARG_INT ARG_SHORT ARG_BOOL ARG_STRING ARG_ARGARRAY ARG_UINT ARG_USHORT ARG_ARGUMENT
Description Argument type not determined Signed integer 2 bytes signed integer 1 byte integer C++, COM: STL character string VB .NET: String object Variable length array of Arg 32 bit unsigned int 16 bit unsigned short int Arguments array
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
7-6
Release 8.0(1)
Chapter 7
GetValue
The GetValue method returns the value of the specified property. Use this method if you dont know the type of the property. Otherwise, use the more specific GetValue methods discussed later in this chapter. When using the COM CIL, do not use this method for properties of type IDispatch*; instead, use GetCurrentCall, GetCurrentAgent, GetAllCalls, GetAllAgents, and GetAllSkillGroups as explained in Chapter 8, Session Object.
Syntax
C++:Arg& GetValue (string& key)
Arg& GetValue (int key) Arg& GetValue (char* key) COM:HRESULT GetValue (/*[in]*/ VARIANT* key, /*[out,retval]*/ IArg** value) VB: GetValue (key As VARIANT) As CTIOSCLIENTLib.IArg Java:Arg GetValue( String key ) Arg& GetValue (int key) .NETvirtual System.Boolean GetValue(Enum_CtiOs eKeyID, out Arg obArg) virtual System.Boolean GetValue(System.String sKey, out Arg obArg)
Parameters
key The name of the property whose value you want. COM: value An output value of type Arg** containing the property with the designated name. To get the value of the property, call GetType() on the Arg and then call the specific GetValue method, based on the type. .NET: obArg Output parameter (return value in C++, VB, and Java) containing the specified property, as described in the explanation of the value parameter.
Return Value
COM: Default HRESULT return value. See Chapter 3, CIL Coding Conventions.
.NET: Returns true if the value is retrieved, and false if the value is not found. Others: An Arg containing the specified property. To get the value of the property, call GetType() on the Arg and then call the specific GetValue method, based on the type.
GetValueArray
The GetValueArray method returns the Arguments array value of the specified property. Use this method when you know that the property is of Arguments array type, such as ECC call variables.
Syntax
C++:
Arg& GetValueArray (string& key) Arg& GetValueArray (enum_Keywords key)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
7-7
Chapter 7 Methods
CtiOs Object
COM:
value)
Arg& GetValue (char * key) HRESULT GetValueArray (/*[in]*/ VARIANT * key, /*[out,retval]*/ IArguments **
VB: Java:
GetValueArray (key As VARIANT) As CTIOSCLIENTLib.IArguments Arguments GetValueArray( String key ) Arguments GetValueArray (int key) .NET: System.Boolean GetValueArray(Enum_CtiOs eKeyID, out Arguments arArguments)
Parameters
key The name of the property whose value you want. value COM: An output parameter (return value in VB, C++, and Java) containing an arArguments** to the returned value of the property. .NET: An output parameter containing the Arguments array value upon success. Upon failure, this parameter is set to null.
Return Value
COM: Default HRESULT return value. See Chapter 3, CIL Coding Conventions.
.NET: Returns true if the value is retrieved. Returns false if the value is not found. Others: A reference to an Arguments array containing the value of the specified property.
Syntax
Boolean GetValueBoolObj(int iKey) Boolean GetValueBoolObj(String sKey)
Parameters
Key Key ID for the object to be retrieved.
Returns
A Boolean object representation of the contained value or null if error.
GetValueInt
The GetValueInt method returns the integer value of the specified property. Use this method when you know that the property has an integer type.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
7-8
Release 8.0(1)
Chapter 7
Syntax
C++:
int GetValueInt (string& key) int GetValueInt (int key) int GetValueInt (char* key) COM: HRESULT GetValueInt /*[in]*/ VARIANT* key, /*[out,retval]*/ int* value) VB: GetValueInt (key As VARIANT) As Integer Java: Not implemented, use GetValueIntObj .NET: System.Boolean GetValueInt(Enum_CtiOs eKeyID, out System.Int32 nValue) System.Boolean GetValueInt(System.String sPropname, out System.Int32 nValue)
Parameters
C++: key Depending on the method used, either a string or int that contains the name or ID of the property whose value you want to retrieve. COM, VB: key VARIANT containing the ID or name of the prerty to retrieve. COM: value An output parameter (return parameter in VB) containing an integer pointer to the returned value of the property. .NET: sPropName The name of the property. .NET: nValue Upon success, this output parameter contains the value of the specified property. Upon failure, this parameter is set to null. .NET: eKeyID Keyword ID of the property.
Return Value
COM: Default HRESULT return value. See Chapter 3, CIL Coding Conventions. .NET: True if the method succeeds.; false if the method fails.
Syntax
Integer GetValueIntObj( int iKey) Integer GetValueIntObj( String sKey)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
7-9
Chapter 7 Methods
CtiOs Object
Parameters
key Key ID of the value to be retrieved.
Returns
An Integer object containing a 32 bit signed integer value or null if error.
Syntax
Short GetValueShortObj( int iKey) Short GetValueShortObj(short sKey)
Parameters
key Key ID of the value to be retrieved.
Return Value
A Short object containing a 16 bit short value or null if error.
GetValueString
The GetValueString method returns the string value of the property with the specified name. Use this method when you know that the property is of string type. For all CILs and all types, a call to GetValueString for an argument that is of another type, for example Int, returns a string representation of the argument's Int value.
Syntax
C++:string GetValueString (string& key)
string GetValueString (int key) string GetValueString (char* key) COM:HRESULT GetValueString (/*[in]*/ VARIANT* key, /*[out,retval]*/ BSTR* value) VB: GetValueString (key As VARIANT) As String Java:String GetValueString( String key ) String GetValueString (int key) .NET:System.Boolean GetValueString(Enum_CtiOs eKeyID, out System.String strValue) System.Boolean GetValueString(System.String sPropName, out System.String strValue)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
7-10
Release 8.0(1)
Chapter 7
Parameters
C++, Java: key Depending on the method used, either a string or int that contains the name or ID of the property whose value you want to retrieve. COM, VB: key VARIANT containing the ID or name of the property to retrieve. .NET: sPropName The name of the property values to retrieve. .NET: strValue Upon success, this output parameter contains the value of the specified property. Upon failure, this parameter is set to null. .NET: eKeyID Keyword ID of the property. value In COM, an output parameter (return parameter in VB) containing a BSTR pointer to the returned string value of the property.
Return Value
COM: Default HRESULT return value. See Chapter 3, CIL Coding Conventions.
.NET:Boolean value indicating the success or failure of the method call (true, if success; otherwise false). Others: A string containing the value of the specified property.
Syntax
Long GetValueUIntObj( int key) Long GetValueUIntObj( String sKey)
Parameters
key Key ID of the value to be retrieved.
Returns
A Long object containing the 32 bit unsigned integer value or null if error.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
7-11
Chapter 7 Methods
CtiOs Object
Syntax
Integer GetValueUShortObj( int iKey) Integer GetValueUShortObj( String sKey)
Parameters
key Key ID of the value to be retrieved.
Returns
An Integer object containing the 16 bit unsigned short value or null if error.
IsValid
The IsValid method tests to see if the object includes the specified property.
Syntax
C++:
bool IsValid (string& key) bool IsValid (char* key) bool IsValid (int key) COM: HRESULT IsValid (/*[in]*/ VARIANT* key, /*[out,retval]*/ VARIANT_BOOL* value) VB: IsValid (key As VARIANT)as Bool Java: boolean IsValid( String key) boolean IsValid (int key) .NET: virtual bool IsValid(Enum_CtiOs eKeyID) virtual bool IsValid(System.String sKey)
Parameters
C++, Java: key A key containing the name or ID of the property whose validity you are testing. COM, VB: key VARIANT containing the name or ID of the property to retrieve. .NET: eKeyID The ID of the property whose validity you are testing. .NET: sKey The name of the property whose validity you are testing.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
7-12
Release 8.0(1)
Chapter 7
COM: value An output parameter (return parameter in VB) containing a VARIANT_BOOL pointer indicating whether or not a property with the specified name exists for the object.
Return Value
COM: Default HRESULT return value. See Chapter 3, CIL Coding Conventions.
Others: A boolean indicating whether or not a property with the specified name exists for the object.
Syntax
int ReportError(int iError)
Parameters
Error The error to report.
Returns
The same error code that was passed in through iErrCode.
Syntax
boolean boolean boolean boolean boolean boolean boolean boolean boolean boolean boolean boolean boolean boolean boolean SetValue(int iKeyID, Arg rArg SetValue(int iKeyID, Arguments rArgs)boolean SetValue(int iKeyID, boolean bValue) SetValue(int iKeyID, CtiOsObject rObj) SetValue(int iKeyID, int iValue) SetValue(int iKeyID, short nValue) SetValue(int iKeyID, java.lang.String sValue) SetValue(java.lang.String sPropName, Arg rArg) SetValue(java.lang.String sPropName, Arguments rArgs) SetValue(java.lang.String sPropName, boolean bValue) SetValue(java.lang.String sPropName, CtiOsObject rObj) SetValue(java.lang.String sPropName, int iValue) SetValue(java.lang.String sPropName, short nValue) SetValue(java.lang.String sPropName, java.lang.String sValue) SetValueUInt (int key, long value)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
7-13
Chapter 7 Methods
CtiOs Object
boolean SetValueUInt (String key, long value) boolean SetValueUShort (int key, int value) boolean SetValueUShort (String key, int value
Parameters
key The key whose value is to be set. value The value to use in setting the element with the designated key.
Returns
True if successfully added, false if not.
Syntax
C++:bool SetValue( string& key, string& value)
bool SetValue( string& keyValuePair) bool SetValue( string& key, int value) bool SetValue( const char * key, const char * value) bool SetValue( const char * keyValuePair) bool SetValue( const char * key, int value) COM:HRESULT SetValue (/*[in]*/ VARIANT *key, /*[in]*/ VARIANT *value, /*[out,retval]*/ VARIANT_BOOL * errorcode) VB: SetValue (key As Variant, value As Variant) As Bool
Parameters
key An input parameter that contains the name of the property whose value you want to set. value An input parameter containing the value to be used in setting the specified property. keyValuePair An input parameter containing a string in the format key=value where key is a property to set and value is the new value. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
COM: Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
7-14
Release 8.0(1)
Chapter 7
Remarks
This method should only be used when creating a new Agent in preparation for logging in. Therefore, it should be used to set the AgentID, AgentInstrument, AgentPassword, PeripheralID, and AutoLogin only.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
7-15
Chapter 7 Methods
CtiOs Object
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
7-16
Release 8.0(1)
CHAPTER
Agent Object
The Agent object provides developers using the CTI OS Client Interface Library with an interface to Agent behavior. The Agent object exposes methods to perform all agent behaviors, such as logging in and setting the agents state. The object stores specific agent information as properties, including the AgentID, AgentPassword, AgentInstrument, AgentExtension, and SkillGroups. When the agent is logged into an ACD, the agent object receives updates through AgentStateEvents and Agent Statistics updates. The Agent object can be used in two different modes:
In Agent Mode, the application should create an Agent object and inform the Session about the agent using Session.SetAgent(). In Monitor Mode, the client application sets a message filter, and if the event stream involves events for Agent objects, those objects will be dynamically created at the CIL as needed.
The data type listed for each keyword is the standardized data type discussed in the section CTI OS CIL Data Types in Chapter 3, CIL Coding Conventions. See Table 3-1 for the appropriate language specific types for these keywords.
Table 9-1
.
Keyword AgentAvailability Status Agent CallMode AgentExtension AgentID AgentInstrument AgentRemote Number
Type INT
Description One of the following values: UNKNOWN (-1), NOT AVAILABLE (0), ICM AVAILABLE (1), or APPLICATION AVAILABLE (2). A value that indicates the agent's call mode. Valid values are call-by-call (3) and nailed-up (4). Extension associated by ACD to agent. Can be set prior to Login or after Logout. Instrument associated by ACD to agent. The phone number that the agent uses for remote login.
* *
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-1
Agent Object
Description One of the values in Table 6-56 representing the current state of the associated agent. Identifies the type of this object. The unique object ID of the silent monitor call. This is the call that results from calling SuperviseCall() with the SupervisorAction set to eSupervisorMonitor.
Note
This property contains the unique object ID of the agent who the supervisor is currently silent monitoring.
Note
Extension CurrentConnection Profile IsSupervisor LastError PeripheralID PeripheralType SavedAgentID STRING INT INT INT INT STRING
Extension associated by ACD to agent. The last selected agent connection profile. Indicates whether this agent is a supervisor. Last error code, if any. Otherwise this value is 0. ID of peripheral. The type of the peripheral. On Spectrum, contains the user provided data for the agent specified by the AgentID property. On all other switches, this property is identical to the AgentID property.
Statistics
*The CTI OS server imposes no restriction on the maximum length of this string. However, such restrictions are generally imposed by your switch/ACD and Cisco CTI Server. Consult the documentation for the switch/ACD or CTI Server for information on length restrictions for this string.
Agent Statistics
Statistics can be accessed by first using GetValueArray on the Agent object to obtain the Statistics arguments array and then using GetValueInt on the Statistics arguments array to obtain the desired value:
' First get the statistics arguments Dim args As Arguments args = agent.GetValueArray (Statistics) Then get the desired statistics Dim availTimeSession As Integer Dim loggedOnTimeSession As Integer
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-2
Release 8.0(1)
Chapter 9
Note
Not all the statistics values listed in Table 9-2 are present in every system configuration. Whether or not a particular statistic value is available depends both on the protocol version of CTI Server with which CTI OS connects and on the peripheral on which the agent resides.
Table 9-2
Agent Statistics
Statistic AvailTime Session LoggedOnTime Session NotReadyTime Session ICMAvailable TimeSession RoutableTime Session AgentOutCalls Session AgentOutCalls TalkTimeSession
Definition Total time, in seconds, the agent was in the Available state for any skill group. Total time, in seconds, the agent has been logged on. Total time, in seconds, the agent was in the Not Ready state for all skill groups. Total time, in seconds, the agent was in the Unified ICM Available state. Total time, in seconds, the agent was in the Routable state for all skill groups. Total number of completed outbound ACD calls made by agent. Total talk time, in seconds, for completed outbound ACD calls handled by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed outbound ACD calls handled by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound ACD calls the agent has placed on hold at least once. Total number of seconds outbound ACD calls were placed on hold. The number of inbound ACD calls handled by the agent.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-3
Agent Object
Definition Total talk time in seconds for Inbound ACD calls counted as handled by the agent. Includes hold time associated with the call. Total after call work time in seconds for Inbound ACD calls counted as handled by the agent. Total handle time, in seconds, for inbound ACD calls counted as handled by the agent. The time spent from the call being answered by the agent to the time the agent completed after call work time for the call. Includes hold time associated with the call. The total number of completed inbound ACD calls the agent placed on hold at least once. Total number of seconds completed inbound ACD calls were placed on hold. Number of internal calls initiated by the agent. Number of seconds spent on internal calls initiated by the agent. Number of internal calls received by the agent. Number of seconds spent on internal calls received by the agent. The total number of internal calls the agent placed on hold at least once. Total number of seconds completed internal calls were placed on hold. Total number of AutoOut (predictive) calls completed by the agent. Total talk time, in seconds, of AutoOut (predictive) calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call.
IncomingCalls HeldTime Session InternalCallsSession InternalCalls TimeSession InternalCalls RcvdSession InternalCalls RcvdTime Session InternalCalls Held Session InternalCalls HeldTime Session AutoOutCalls Session AutoOutCalls TalkTime Session
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-4
Release 8.0(1)
Chapter 9
Definition Total handle time, in seconds, for AutoOut (predictive) calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed AutoOut (predictive) calls the agent has placed on hold at least once. Total number of seconds AutoOut (predictive) calls were placed on hold. Total number of outbound Preview calls completed by the agent. Total talk time, in seconds, of outbound Preview calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, outbound Preview calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound Preview calls the agent has placed on hold at least once. Total number of seconds outbound Preview calls were placed on hold. Total number of agent reservation calls completed by the agent.
PreviewCalls TimeSession
PreviewCalls HeldSession
Reservation CallsTalk TimeSession Total talk time, in seconds, of agent reservation calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-5
Agent Object
Definition Total handle time, in seconds, agent reservation calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed agent reservation calls the agent has placed on hold at least once. Total number of seconds agent reservation calls were placed on hold. Total number of supervisor call barge-ins completed. Total number of supervisor call intercepts completed. Total number of supervisor call monitors completed. Total number of supervisor whisper calls completed. Total number of emergency calls . Total time, in seconds, the agent was in the Available state for any skill group. Total time, in seconds, the agent has been logged on. Total time, in seconds, the agent was in the Not Ready state for all skill groups. Total time, in seconds, the agent was in the Unified ICM Available state. Total time, in seconds, the agent was in the Routable state for all skill groups. Total number of completed outbound ACD calls made by agent. Total talk time, in seconds, for completed outbound ACD calls handled by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call.
Reservation CallsHeld TimeSession BargeInCalls Session InterceptCalls Session MonitorCalls Session WhisperCalls Session EmergencyCallsSession AvailTimeToday LoggedOnTime Today NotReadyTime Today ICMAvailable TimeToday RoutableTime Today AgentOutCalls Today AgentOutCalls TalkTime Today
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-6
Release 8.0(1)
Chapter 9
Definition Total handle time, in seconds, for completed outbound ACD calls handled by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound ACD calls the agent has placed on hold at least once. Total number of seconds outbound ACD calls were placed on hold. The number of inbound ACD calls handled by the agent. Total talk time in seconds for Inbound ACD calls counted as handled by the agent. Includes hold time associated with the call.
AgentOutCalls HeldToday
HandledCalls AfterCall TimeToday Total after call work time in seconds for Inbound ACD calls counted as handled by the agent. HandledCalls TimeToday Total handle time, in seconds, for inbound ACD calls counted as handled by the agent. The time spent from the call being answered by the agent to the time the agent completed after call work time for the call. Includes hold time associated with the call. The total number of completed inbound ACD calls the agent placed on hold at least once. Total number of seconds completed inbound ACD calls were placed on hold. Number of internal calls initiated by the agent. Number of seconds spent on internal calls initiated by the agent. Number of internal calls received by the agent. Number of seconds spent on internal calls received by the agent. The total number of internal calls the agent placed on hold at least once. Total number of seconds completed internal calls were placed on hold.
IncomingCalls HeldToday
IncomingCalls HeldTime Today InternalCalls Today InternalCalls TimeToday InternalCalls RcvdToday InternalCalls RcvdTime Today InternalCalls HeldToday InternalCalls HeldTime Today
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-7
Agent Object
Definition Total number of AutoOut (predictive) calls completed by the agent. Total talk time, in seconds, of AutoOut (predictive) calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for AutoOut (predictive) calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed AutoOut (predictive) calls the agent has placed on hold at least once. Total number of seconds AutoOut (predictive) calls were placed on hold. Total number of outbound Preview calls completed by the agent. Total talk time, in seconds, of outbound Preview calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, outbound Preview calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound Preview calls the agent has placed on hold at least once. Total number of seconds outbound Preview calls were placed on hold. Total number of agent reservation calls completed by the agent.
AutoOutCalls TimeToday
AutoOutCalls HeldToday
PreviewCalls TimeToday
PreviewCalls HeldToday
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-8
Release 8.0(1)
Chapter 9
Definition Total talk time, in seconds, of agent reservation calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, agent reservation calls completed by the agent. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed agent reservation calls the agent has placed on hold at least once. Total number of seconds agent reservation calls were placed on hold. Total number of supervisor call barge-ins completed. Total number of supervisor call intercepts completed. Total number of supervisor call monitors completed. Total number of supervisor whisper calls completed. Total number of emergency calls . Total time, in seconds, the agent was in the Available state for any skill group. Total time, in seconds, the agent has been logged on. Total time, in seconds, the agent was in the Not Ready state for all skill groups. Total time, in seconds, the agent was in the Unified ICM Available state. Total time, in seconds, the agent was in the Routable state for all skill groups. Total number of completed outbound ACD calls made by agent.
Reservation CallsTimeToday
Reservation CallsHeldToday
Reservation CallsHeld TimeToday BargeInCalls Today InterceptCalls Today MonitorCalls Today WhisperCalls Today EmergencyCalls Today AvailTime Session LoggedOnTime Session NotReadyTime Session ICMAvailable TimeSession RoutableTime Session AgentOutCalls Session
Methods
Table 9-3 lists the Agent object methods.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-9
Chapter 9 Methods
Agent Object
Table 9-3
Method DisableAgentStatistics DisableSkillGroupStatistics DumpProperties EnableAgentStatistics EnableSkillGroupStatistics GetAgentState GetAllProperties GetElement GetMonitoredAgent GetMonitoredCall GetNumProperties GetPropertyName GetPropertyType GetSkillGroups GetValue GetValueArray GetValueInt GetValueString IsAgent IsSupervisor IsValid Login Logout MakeCall MakeEmergencyCall QueryAgentState ReportBadCallLine RequestAgentTeamList RequestSupervisorAssist SendChatMessage
Description Disables agent statistic messages. Disables skill group statistic messages. See Chapter 7, CtiOs Object. Enables agent statistic messages. Enables skill group statistic messages. Returns the current agent state. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. Returns the agent object that is currently being monitored. Returns the call object that is currently being monitored. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. Returns an array of SkillGroups objects See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. Checks the current mode and returns true if agent mode. Checks the current mode and returns true if supervisor mode. See Chapter 7, CtiOs Object. Logs an agent into the ACD. Logs an agent out of the ACD. Initiates a call to a device or agent. Lets an agent makes an emergency call to the supervisor. Gets the current agent state from CTI Server and retrieves it. Informs the CTI OS Server of a bad line. Retrieves the current agent team list. Allows the agent to call an available supervisor for assistance. Send asynchronous messages between CTI clients.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-10
Release 8.0(1)
Chapter 9
Method SetAgentState SetValue StartMonitoringAgent StartMonitoringAgentTeam StartMonitoringAllAgentTeams StartMonitoringCall StopMonitoringAgent StopMonitoringAgentTeam StopMonitoringAllAgentTeams SuperviseCall
Description Requests a new agent state. Sets the value of the property whose name is specified. Enables monitoring of a specified agent. Enables monitoring of a specified agent team. Enables monitoring of all agent teams. Enables monitoring of a specified call object. Disables monitoring of a specified agent. Disables monitoring of a specified agent team. Disables monitoring of all agent teams. Enables monitoring a call of an agent on your team.
Arguments Parameters
The following rules apply to the optional_args and reserved_args parameters in Call Object methods:
In VB, you can ignore these parameters altogether. For example, you can treat the line:
Answer([reserved_args As IArguments]) As Long
as follows:
Answer()
DisableAgentStatistics
The DisableAgentStatistics method is sent by an agent to request that real-time statistics stop being sent to that agent.
Syntax
C++:int DisableAgentStatistics (Arguments& reserved_args) COM:HRESULT DisableAgentStatistics (/*[in]*/ IArguments reserved_args, /* [out,
retval]*/ int * errorcode) VB: DisableAgentStatistics (reserved_args As CTIOSCLIENTLib.IArguments) As Long Java:int DisableAgentStatistics (Arguments reservedargs) .NET:CilError DisableAgentStatistics(Arguments args)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-11
Chapter 9 Methods
Agent Object
Parameters
.NET:args Not currently used, reserved for future use. All Others:reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
DisableSkillGroupStatistics
The DisableSkillGroupStatistics method is sent by an agent to request that real-time statistics stop being sent to that agent.
Syntax
C++:int DisableSkillGroupStatistics (Arguments& optional_args) COM:HRESULT DisableSkillGroupStatistics (/* [in, optional]*/ IArguments * optional_args,
/* [out, retval]*/ int * errorcode) VB: DisableSkillGroupStatistics (optional_args As CTIOSCLIENTLib.IArguments) As Long Java:int DisableSkillGroupStatistics (Arguments optional_args .NET:CilError DisableSkillGroupStatistics(Arguments args)
Parameters
optional_args An optional input parameter containing a pointer or a reference to an Arguments array containing a member that is a nested Arguments array with the keyword SkillGroupNumbers. Within this array, each number has a string key of an integer starting with 1 and an integer value that is a SkillGroupNumber to be disabled. If the parameter is NULL or missing, statistics will be disabled for all skill groups to which the agent belongs. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-12
Release 8.0(1)
Chapter 9
EnableAgentStatistics
The EnableAgentStatistics method is sent by an agent to request that real-time statistics be sent to that agent.
Syntax
int EnableAgentStatistics(Arguments& reserved_args) HRESULT EnableAgentStatistics (/*[in]*/ IArguments* reserved_args, /* [out, retval]*/ int * errorcode) VB: EnableAgentStatistics (reserved_args As CTIOSCLIENTLib.IArguments) As Long Java:int EnableAgentStatistics(Arguments args) .NET:CilError EnableAgentStatistics(Arguments args)
C++: COM:
Parameters
reserved_args Not currently used, reserved for future use. Java/.NET:args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The CTI OS server sends agent statistics in an OnAgentStatistics event. See theOnAgentStatistics section in Chapter 6, Event Interfaces and Eventsfor an explanation of the PollingIntervalSec and PollForAgentStatsAtEndCall registry settings and how these settings affect the refresh rate of agent statistics.
EnableSkillGroupStatistics
The EnableSkillGroupStatistics method is sent by an agent to request that real-time statistics be sent to that agent. If the argument array is empty, then statistics for all skillgroups are sent. This is useful when a monitoring application needs to view all statistics without having to enumerate and loop over each statistic to enable it.
Syntax
C++:int EnableSkillGroupStatistics (Arguments& optional_args) COM: HRESULT EnableSkillGroupStatistics (/*[in]*/ IArguments * optional_args, /* [out,
retval]*/ int * errorcode)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-13
Chapter 9 Methods
Agent Object
VB: EnableSkillGroupStatistics (optional_args As CTIOSCLIENTLib.IArguments) As Long Java:int EnableSkillGroupStatistics(Arguments optional_args) .NET:CilError EnableSkillGroupStatistics(Arguments args)
Parameters
optional_args An optional input parameter containing a pointer or a reference to an Arguments array containing a member that is a nested Arguments array with the keyword SkillGroupNumbers. Within this array, each member has a string key of an integer starting with 1 and an integer value that is a skill group number to be enabled. If the parameter is NULL or missing, statistics will be enabled for all skill groups to which the agent belongs. .NET:args Refer to the description for optional_args above. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The CTI OS server sends SkillGroup statistics in the OnSkillGroupStatisticsUpdated event of the SkillGroup object.
GetAgentState
The GetAgentState method returns the current state of the agent.
Syntax
C++: COM: VB: Java: .NET:
enumCTIOS_AgentState GetAgentState() HRESULT GetAgentState (/*[in]*/ long *state) GetAgentState () As Long int GetAgentState() AgentState GetAgentState()
Parameters
state Output parameter (return parameter in VB) containing the current agent state in the form of one of the values in Table 6-56.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-14
Release 8.0(1)
Chapter 9
Return Value
For C++, VB, Java, and .NET, this method returns the current state of the agent.
GetAllProperties
See Chapter 7, CtiOs Object for a description of the GetAllProperties method.
GetElement
See Chapter 7, CtiOs Object for a description of the GetElement method.
GetMonitoredAgent
The GetMonitoredAgent method returns the agent object that is currently being monitored.
Syntax
C++:CAgent* GetMonitoredAgent() COM:HRESULT GetMonitoredAgent (/*[out, retval]*/IAgent **agent) VB: GetMonitoredAgent () As CTIOSCLIENTLib.IAgent Java:Agent GetMonitoredAgent() .NET:Agent GetMonitoredAgent()
Parameters
agent Output parameter (return parameter in VB) that contains a pointer to a pointer to an Agent object containing the currently monitored agent.
Return Value
This method returns the current monitored agent. The C++, Java, and .NET versions return null if no agent is currently being monitored.
Remarks
Supported for use with Unified CCE only.
GetMonitoredCall
The GetMonitoredCall method returns the call object that is currently being monitored.
Syntax
C++:
CCall* GetMonitoredCall()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-15
Chapter 9 Methods
Agent Object
HRESULT GetMonitoredCall (/*[out, retval]*/ICall **call) GetMonitoredCall () As CTIOSCLIENTLib.ICall Call GetMonitoredCall() Call GetMonitoredCall()
Parameters
call Output parameter (return parameter in VB) that contains a pointer to a pointer to a Call object containing the currently monitored call.
Return Value
This method returns the current monitored call. The C++, Java, and .NET versions return null if no call is currently being monitored.
Remarks
Supported for use with Unified CCE only.
GetNumProperties
See Chapter 7, CtiOs Object for a description of the GetNumProperties method.
GetPropertyName
See Chapter 7, CtiOs Object for a description of the GetNumProperties method.
GetPropertyType
See Chapter 7, CtiOs Object for a description of the GetNumProperties method.
GetSkillGroups
If skillgroupstats is enabled, the GetSkillGroups method allows a client to retrieve a list that contains references to all the skill group objects to which the agent belongs. To retrieve skill groups without enabling skill group statistics, turn off agent event minimization by setting its value to 0 on the CTI OS server in the registry key, for example: HKLM\SOFTWARE\Cisco Systems,Inc.\Ctios\<Customer-Instancename>\CTIOS1\Server\Agent\MinimizeAgentStateEvents The skill group information is available on the agent state change event if the minimization is turned off. The following code example shows how to access the skill group properties of the agent object:
Log m_Agent.DumpProperties Dim i As Integer
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-16
Release 8.0(1)
Chapter 9
For i = 1 To 20 If m_Agent.IsValid("SkillGroup[" & i & "]") Then Set argskills = m_Agent.GetValueArray("SkillGroup[" & i & "]") Log "SkillGroup[" & i & "]:" & argskills.DumpArgs Else Log "SkillGroup[" & i & "] args doesnt exist" End If Next i
Syntax
C++: COM: VB: Java: .NET:
Arguments & GetSkillGroups(); HRESULT GetSkillGroups (/*[out,retval]*/ VARIANT * pVariantArgs); GetSkillGroups () As Variant Arguments GetSkillGroups() Arguments GetSkillGroups()
Parameters
None.
Return Value
This method returns -1 if skillgroupstats is not enabled.
C++
In C++ the GetSkillGroups method returns an arguments array containing references to CSkillGroup objects. Each element in the returned arguments array consists of a key/value pair, in which the element key is the Unique Object Id of the skill group object and the value is a reference to a CILRefArg object instance that contains the actual reference to a CSkillGroup object. To retrieve a reference to a skill group object, you need to do something similar to what is shown in the following code example.
Arguments & arSkills = m_Agent->GetSkillGroups(); if(Arguments::IsValidReference(arSkills)){ for(int nI = 1; nI <= arSkills.NumElements(); nI ++){ string strUOID = arSkills.GetElementKey(nI); CilRefArg & pRefArg = (CilRefArg &) arSkills.GetValue(strUOID); if(Arg::IsValidReference(*pRefArg)){ CSkillGroup * pSkill = pRefArg->GetValue(); pRefArg->Release(); cout << Skill Object ( << strUOID << ) ; cout << Skill Group Number: << ; pSkill->GetValueInt(CTIOS_SKILLGROUPNUMBER); } }
COM
In COM the GetSkillGroups method returns a pointer to a variant that encapsulates a Safearray where each element is a pointer to an ISkillGroup object. To retrieve references to skill group objects, you need to do something similar to what is shown in the following code example.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-17
Chapter 9 Methods
Agent Object
SafeArrayGetUBound(varSkills.parray,1,&lNumElements); for(long nI = 0; nI < lNumElements; nI ++){ ISkillGroup * pSkill= NULL; hr=SafeArrayGetElement(varSkills.parray,&nI,&pSkill); if(SUCCEDED(hr)){ int nSkillGrpNumber = 0; VARIANT vPropKey; VariantInit(&vPropKey); vPropKey.vt = VT_BSTR; vPropKey.bstr = OLESTR(SkillGroupNumber); pSkill->GetValueInt(vPropKey,&nSkillGrpNumber); pSkill->Release(); VariantClear(&vPropKey); } } } }
VB
In VB, the GetSkillGroups method returns a variant array where each element is a reference to a CTIOSClientLib.SkillGroup object. To retrieve references to skill group objects you need to do something similar to what is shown in the following code example.
Dim obSkill As CTIOSClientLib.SkillGroup Dim arSkills As Variant Dim lNumElements as Long arSkills = m_Agent.GetSkillGroups() lNumElements = UBound(arSkills,1) For nI = 0 to lNumElements Set obSkill = arSkills(nI) Print SkillGroup & obSkill.GetValueString(CStr(UniqueObjectId)) & Skill Group Number: & obSkill.GetValueInt(CStr(SkillGroupNumber)) Next End For
GetValue Methods
See Chapter 7, CtiOs Object. for descriptions of the GetValue, GetValueInt, GetValueArray, and GetValueString methods.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-18
Release 8.0(1)
Chapter 9
IsAgent
The IsAgent method determines whether the AgentMode connection is for an agent rather than a supervisor.
Syntax
C++: COM: VB: Java: .NET:
bool IsAgent() HRESULT IsAgent (VARIANT_BOOL *bIsAgent) IsAgent () As Boolean boolean IsAgent() bool IsAgent()
Parameters
IsAgent Output parameter (return parameter in VB) that returns true if the current AgentMode connection is for an agent and false if it is for a supervisor.
Return Value
Returns true if the current AgentMode connection is for an agent and false if the connection is for a supervisor.
IsSupervisor
The IsSupervisor method determines whether the AgentMode connection is for a supervisor.
Syntax
C++: COM: VB: Java: .NET:
bool IsSupervisor() HRESULT IsSupervisor (VARIANT_BOOL * bIsSupervisor) IsSupervisor () As Boolean boolean IsSupervisorMode() bool IsSupervisor()
Parameters
bIsSupervisor Output parameter (return parameter in VB) that returns true if the current AgentMode connection is for a supervisor and false if it is for an agent.
Return Values
If the current session is for a supervisor, this method returns true. Otherwise the method returns false.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-19
Chapter 9 Methods
Agent Object
Login
The Login method performs a login to the ACD (if supported). Generally, the minimum parameters required to log into an ACD are AgentID and AgentInstrument. Often, based on customer configuration, the minimum requirements include an ACD password (AgentPassword). Some switches require PositionID in place of (or in addition to) AgentInstrument. Optional arguments include Extension or AgentWorkMode. To sign on a mobile agent, the following parameters must be set:
Example
rArgs.SetValue(Enum_CtiOs.CTIOS_REMOTELOGIN, "true"); rArgs.SetValue(Enum_CtiOs.CTIOS_AGENTREMOTENUMBER,"777989"); rArgs.SetValue(Enum_CtiOs.CTIOS_AGENTCALLMODE, 4);
Syntax
C++: COM: VB: Java: .NET:
virtual int Login(Arguments & args); HRESULT Login ( /*[in]*/ IArguments * pVariantArgs, /*[out]*/ int * errorcode ); Login (args As CTIOSCLIENTLib.IArguments) As Long int Login(Arguments args) CilError Login(Arguments args)
Input Parameters
args Arguments array that contains the login parameters listed in Table 9-4.
Table 9-4 Login Parameters
Keyword AgentID (required) AgentInstrument LoginName (required)** PositionID AgentExtension AgentPassword (optional)
**
Description The agents login ID. The agents instrument number. The agents login name. Required for Alcatel only. The agents teleset extension. Optional if AgentInstrument is provided. The agents password.
STRING*
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-20
Release 8.0(1)
Chapter 9
Type INT
Description A value representing the desired work mode of the agent. Used by Avaya Communications Manager (ACM) ECS with default value of ManualIn. The number of Skill Groups that the agent is currently associated with, up to a maximum of 20. The Unified ICM Peripheral ID of the ACD the agent is attached to. The number of an agent skill group associated with the agent. The priority of an agent skill group associated with the agent. A value that indicates the agent's call mode. Valid values are call-by-call (3) and nailed-up (4). The phone number that the agent uses for remote login. A value that indicates the agent is configured for remote login as a remote agent.
NumSkillGroups (optional) PeripheralID (optional) SkillGroupNumber (optional) SkillGroupPriority (optional) Agent CallMode
INT
STRING INT
*The CTI OS server imposes no restriction on the maximum length of this string. However, such restrictions are generally imposed by your switch/ACD and Cisco CTI Server. Consult the documentation for the switch/ACD or CTI Server for information on length restrictions for this string. ** Either AgentID or LoginName is required. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
If the Login request is successful, it returns a CIL_OK CtiOs_Enums.CilError code In addition, the requesting client should expect an AgentStateChange event if the request is successful with an Arguments member with keyword AgentState and value of the agents current state. (See GetAgentState for possible values.) If the Login request is unsuccessful, the client will receive an OnControlFailureConf event and the request will return one of the following CtiOs_Enums.CilError codes:
E_CTIOS_INVALID_SESSION -- either the agent is not associated with the session or the session is not connected.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-21
Chapter 9 Methods
Agent Object
E_CTIOS_INVALID_ARGUMENT -- null or invalid arguments were provided. E_CTIOS_LOGIN_INCONSISTENT_ARGUMENTS -- Login request argument values for AgentId and/or PeripheralID do not match the values that were set by SetAgent() prior to the Login request.
Logout
The Logout method logs the agent out of the ACD. If the ACD configuration requires or supports other parameters, these can be passed in as logout parameters. Examples are AgentPassword (required by Alcatel for Logout) or logout reason codes (supported on ACM ECS, Unified CCE).
Syntax
C++: COM: VB: Java: .NET:
int Logout (Arguments& args) HRESULT Logout (/*[in]*/ IArguments args, /*[out,retval]*/ int * errorcode) Logout (args As CTIOSCLIENTLib.IArguments) As Long int Logout(Arguments args) CilError Logout(Arguments args)
Input Parameters
args Input parameter in the form of an Arguments array that contains the Logout parameters listed in Table 9-5.
Table 9-5 Logout Parameters
Keyword EventReasonCode
Type INT
Description Reason for logging out. Required for Unified CCE, optional for all other switches. The agents password. The number of Skill Groups that the agent is currently associated with, up to a maximum of 20. The number of an agent skill group associated with the agent. The priority of an agent skill group associated with the agent. The agents login ID. The agents instrument number. The Unified ICM Peripheral ID of the ACD the agent is attached to.
*
AgentPassword (optional) NumSkillGroups (optional) SkillGroupNumber (optional) SkillGroupPriority (optional) AgentID (optional) AgentInstrument PeripheralID (optional)
STRING* INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-22
Release 8.0(1)
Chapter 9
*The CTI OS server imposes no restriction on the maximum length of this string. However, such restrictions are generally imposed by your switch/ACD and Cisco CTI Server. Consult the documentation for the switch/ACD or CTI Server for information on length restrictions for this string. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
If the request is successful, the client should receive an OnAgentStateChange event with an Arguments member with keyword AgentState and value eLogout. If it is unsuccessful, the client should receive an OnControlFailureConf event. The client should also receive an OnPreLogout event before the OnAgentStateChange event, and an OnPostLogout event afterwards.
MakeCall
The MakeCall method initiates a call to a device or agent. The simplest form of the request requires only a DialedNumber.
Note
You can select and make the call against the skillgroup. Do not set the value if the default skillgroup is desired.
Syntax
C++: COM: VB: Java: .NET:
int MakeCall (Arguments& args) HRESULT MakeCall (/*[in]*/ IArguments *args, /*[out,retval]*/ int * errorcode) MakeCall (args As CTIOSCLIENTLib.IArguments) As Long int MakeCall(Arguments args) CilError MakeCall(Arguments args)
Input Parameters
args Input parameter in the form of an Arguments array that contains the MakeCall parameters listed in Table 9-6.
Table 9-6 MakeCall Parameters
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-23
Chapter 9 Methods
Agent Object
Description The number to be dialed to establish the new call. The Unified ICM Peripheral ID of the ACD the agent is attached to. The agents instrument number. A value specifying how the call is to be placed identified in Table 9-7. A value specifying additional call processing options identified in Table 9-8. The maximum amount of time that the calls destination will remain alerting, specified as an approximate number of rings. A zero value indicates that the peripheral default (typically 10 rings) should be used. A value from Table 9-9 specifying additional peripheral-specific call options. A value from Table 9-10 indicating the type of facility to be used. A value from Table 9-11 specifying the action to be taken if the call is answered by an answering machine. This field should be set to TRUE if the call should receive priority handling. When this field is set to TRUE, the Post-Routing capabilities of the Unified ICM are to be used to determine the new call destination. The ISDN user-to-user information. Call variable data that should be set in the new call in place of the corresponding data in the active call.
PeripheralID (optional)
AlertRings (optional)
INT
CallOption (optional)
INT
FacilityType (optional)
INT
AnsweringMachine (optional)
INT
Priority (optional)
BOOL
PostRoute (optional)
BOOL
UserToUserInfo (optional)
CallVariable1 (optional)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-24
Release 8.0(1)
Chapter 9
Type ...
Description ...
ARGUMENTS ECC data that should be set in the new call in place of the corresponding data in the active call. Call-related wrapup data.
CallWrapupData (optional) STRING, maximum length 40 FacilityCode (optional) STRING, maximum length 40 STRING, maximum length 40 STRING, maximum length 40 INT
A trunk access code, split extension, or other data needed to access the chosen facility. An authorization code needed to access the resources required to initiate the call. A cost-accounting or client number used by the peripheral for charge-back purposes. The number of an agent skill group associated with the agent.
SkillGroupNumber
Table 9-7
Description Use default call placement. An inside line call. An outbound call. An outbound call that will not require an access code. A call placed directly to a specific position. A call placed directly to a specific agent.
Value 0 1 2 3 4 5
CPT_SUPERVISOR_ASSIST A call placed to a supervisor for call 6 handling assistance. *The CTI OS server imposes no restriction on the maximum length of this string. However, such restrictions are generally imposed by your switch/ACD and Cisco CTI Server. Consult the documentation for the switch/ACD or CTI Server for information on length restrictions for this string.
Table 9-8 CallManager Type
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-25
Chapter 9 Methods
Agent Object
Description Use default call manner. Attempt the call only if the originating device is idle. The call should always be attempted, disconnecting any currently active call. Attempt the call only if the originating device is idle or is receiving dial tone.
Value 0 1 2 3
Table 9-9
Description No call options specified, use defaults. Attempt the call only if the calling agent is online (available to interact with the destination party). Attempt the call only if ACDNR on the calling agents set is activated (DMS-100). Attempt the call only if ACDNR on the calling agents set is not activated (DMS-100).
Value 0 1
2 3
COPT_CALLING_ Causes a buzz to be applied to the base of the 4 AGENT_BUZZ_BASE telephone set as the call is initiated (DMS-100). COPT_CALLING_ AGENT_BEEP_HSET COPT_SERVICE_ CIRCUIT_ON Causes a tone to be applied to the agent headset as the call is initiated (DMS-100). Causes a call classifier to be applied to the call (ACM ECS) 5 6
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-26
Release 8.0(1)
Chapter 9
Table 9-10
Facility Types
Description Use default facility type. Facility is a trunk group. Facility is a skill group or split.
Value 0 1 2
Table 9-11
Description Use default behavior. Connect call to agent when call is answered by an answering machine. Disconnect call when call is answered by an answering machine. Do not use answering machine detection. Do not use answering machine detection, but disconnect call if answered by a modem. Connect call when call is answered by an answering machine, disconnect call if answered by a modem.
Value 0 1 2 3 4
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
If the request is successful, the client should receive one or more of the following call related events:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-27
Chapter 9 Methods
Agent Object
MakeEmergencyCall
The MakeEmergencyCall method makes an emergency call to the Agents supervisor.
Syntax
int MakeEmergencyCall () int MakeEmergencyCall (Arguments& reserved_args) COM: HRESULT MakeEmergencyCall (/*[in, optional]*/ IArguments reserved_args, /* [out, retval]*/ int * errorcode) VB: MakeEmergencyCall () As Long MakeEmergencyCall (reserved_args As CTIOSCLIENTLib.IArguments) As Long Java: int MakeEmergencyCall (Arguments args) .NET: CilError MakeEmergencyCall(Arguments args)
C++:
Parameters
reserved_args Not currently used, reserved for future use. Java/.NET: args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The MakeEmergencyCall request is very similar to the RequestSupervisorAssist request in the following two ways:
Both requests place a call from the requesting agent to a supervisor and are routed employing the same script. A typical script might attempt to route the call to the primary supervisor first (if logged in and in available state) and, failing that, to route the call to a skillgroup that all supervisors belong to. Both call requests can be configured through Unified ICM Agent Desk Settings to be performed via a single step conference or consult call. If the consult method is chosen, the agent can complete the established consult call as a transfer or conference. Only Emergency calls are able to be recorded, if so configured in the Unified ICM Agent Desk Settings. The calls are reported separately in Unified ICM reporting.
Having these two separate requests gives a site some flexibility in implementing supervisor help for its agents, instructing agents to use one for certain cases and the other for different situations. In general, use the MakeEmercenyCall method for higher priority calls than calls made with the
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-28
Release 8.0(1)
Chapter 9
RequestSupervisorAssist method. For example, agents can be trained to click the Emergency button if the customer has more than $1,000,000 in an account, and otherwise to click the Supervisor Assist button. The Supervisor will be able to differentiate the agents request by noting the CallType. The MakeEmergencyCall request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only). The client issuing the request receives an OnEmergencyCall event when the request reaches an available supervisor. If the request is unsuccessful the client receives an OnControlFailureConf event.
QueryAgentState
The QueryAgentState method lets a client retrieve the current state of the agent.
Syntax
int QueryAgentState (Arguments & args ); HRESULT QueryAgentState ( /*[in]*/ IArguments * args, /*[out,retval]*/ int * errorcode ); VB: QueryAgentState (ByVal args as CTIOSCLIENTLIB.IArguments) As Long Java: int QueryAgentState (Arguments args) .NET: CilError QueryAgentState(Arguments args)
C++: COM:
Input Parameters
args Arguments array that contains the parameters listed in the following table.
Table 9-12 QueryAgentState Parameters
Type
Description
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
If the request is successful, the client should receive an OnQueryAgentStateConf event. If it is unsuccessful, the client should receive an OnControlFailureConf event.
ReportBadCallLine
The ReportBadCallLine method informs the CTI OS server of the poor quality of the agents line. A note of this is recorded in the database.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-29
Chapter 9 Methods
Agent Object
Syntax
int ReportBadCallLine () int ReportBadCallLine (Arguments& reserved_args) COM: HRESULT ReportBadCallLine (/*[in, optional]*/ IArguments reserved_args, /* [out, retval]*/ int * errorcode) VB: ReportBadCallLine () As Long Java: int ReportBadCallLine (Arguments args) .NET: CilError ReportBadCallLine(Arguments args)
C++:
Parameters
reserved_args Not currently used, reserved for future use. Java/.NET: args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
RequestAgentTeamList
The RequestAgentTeamList method is called by a supervisor to make a request to the CTI OS server for a list of agents in the supervisors team.
Syntax
int RequestAgentTeamList () int RequestAgentTeamList (Arguments& reserved_args) COM: HRESULT RequestAgentTeamList (/*[in, optional]*/ IArguments reserved_args, /* [out, retval]*/ int * errorcode) VB: RequestAgentTeamList () As Long Java: int RequestAgentTeamList () int RequestAgentTeamList (Arguments args) .NET: CilError RequestAgentTeamList(Arguments args)
C++:
Parameters
reserved_args Not currently used, reserved for future use. Java/.NET: args Not currently used, reserved for future use. errorcode
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-30
Release 8.0(1)
Chapter 9
An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
Supported for use with Unified CCE only. If this request is successful, the CTI OS server sends a separate OnNewAgentTeamMember event for each agent in the supervisors team. If this request is unsuccessful, the client receives an OnControlFailureConf event.
RequestSupervisorAssist
The RequestSupervisorAssist method allows the agent to call an available supervisor for assistance.
Syntax
virtual int RequestSupervisorAssist(); int RequestSupervisorAssist (Arguments& reserved_args) COM: HRESULT RequestSupervisorAssist (/*[in, optional]*/ IArguments reserved_args, /* [out, retval]*/ int * errorcode) VB: RequestSupervisorAssist () As Long Java: int RequestSupervisorAssist(Arguments args) .NET: CilError RequestSupervisorAssist(Arguments args)
C++:
Parameters
reserved_args Not currently used, reserved for future use. Java/.NET: args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
Supported for use with Unified CCE only. See MakeEmergencyCall for more information.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-31
Chapter 9 Methods
Agent Object
SendChatMessage
The SendChatMessage method sends asynchronous chat-like messages between CTI OS clients. Users can specify a distribution of one or more clients, and attach a text message.
Syntax
C++: COM:
int SendChatMessage (Arguments& args) HRESULT SendChatMessage (/*[in]*/ IArguments *args, /*[out,retval]*/ int * errorcode) VB: SendChatMessage (args As CTIOSCLIENTLib.IArguments) As Long) Java: int SendChatMessage(Arguments args) .NET: CilError SendChatMessage(Arguments args)
Parameters
args Input parameter in the form of an Arguments array that contains one or more of the SendChatMessage parameters listed in the following table.
Table 9-13 SendChatMessage Parameters
Keyword
Type
Description
Distribution (required) STRING Currently the only supported value is agent. Target (optional) STRING When the Distribution is set to DistributeToAgent, this field must be included with the AgentID of the intended recipient. When the LoginName is set to the LoginName of the agent to receive the chat message, this field must also be set to the login name of the agent to which to chat. STRING The text of the user message. Maximum message size is 255 bytes. STRING Login name of the agent to receive the chat message. To chat to an agent by login name, set LoginName and Target to the login name of the agent to which to chat.
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-32
Release 8.0(1)
Chapter 9
Remarks
The recipient receives the message via the OnChatMessage event.
SetAgentState
The SetAgentState method requests a new agent state. Login and Logout are valid agent states and can be set using the SetAgentState method as well as by using the Login and Logout methods.
Syntax
int SetAgentState(Arguments& args) HRESULT SetAgentState (/*[in]*/ IArguments *args, /*[out,retval]*/ int * errorcode) VB: SetAgentState (args As CTIOSCLIENTLib.IArguments) As Long Java: int SetAgentState(Arguments args) .NET: CilError SetAgentState(Arguments args)
C++: COM:
Input Parameters
args Input parameter in the form of an Arguments array that contains one or more of the SetAgentState parameters listed in the following table.
Table 9-14 SetAgentState Parameters
Type INT
Description The state to which to set the specified agent. The value of this field must be one of the values in Table 6-56. The agents login ID. The agents instrument number. Optional if Agent Extension is provided. Required for Alcatel only. The agents password. A value representing the desired work mode of the agent. Used by ACM ECS with default value of ManualIn. The number of Skill Groups that the agent is currently associated with, up to a maximum of 20. Reason for logging out. Required for Unified CCE, optional for all other switches.
*
STRING* STRING
INT
INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-33
Chapter 9 Methods
Agent Object
Description The Unified ICM Peripheral ID of the ACD the agent is attached to. The number of an agent skill group associated with the agent. The priority of an agent skill group associated with the agent.
*The CTI OS server imposes no restriction on the maximum length of this string. However, such restrictions are generally imposed by your switch/ACD and Cisco CTI Server. Consult the documentation for the switch/ACD or CTI Server for information on length restrictions for this string. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
A successful request will result in an OnAgentStateChanged event. It may also result in OnPreLogout, OnPostLogout, and/or OnLogoutFailed events. If this request is unsuccessful, the client receives an OnControlFailureConf event.
StartMonitoringAgent
The StartMonitoringAgent method allows the client, which must be a supervisor, to start monitoring the specified Agent object. This call will cause the supervisor to receive all of the monitored call events (See IMonitoredCallEvents Interface in Chapter 6, Event Interfaces and Events) for this agent until the supervisor calls StopMonitoringAgent.
Syntax
int StartMonitoringAgent(Arguments& args) HRESULT StartMonitoringAgent (/*[in]*/ IArguments * args, /*[out,retval]*/ int * errorcode) VB: StartMonitoringAgent (args As CTIOSCLIENTLib.IArguments) As Long Java: int StartMonitoringAgent(Arguments args) .NET: CilError StartMonitoringCall(Arguments args)
C++: COM:
Parameters
args Arguments array that contains the constant CTIOS_AGENTREFERENCE set to the string value of the UniqueObjectID of the agent to be monitored.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-34
Release 8.0(1)
Chapter 9
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
This request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only). The following code snippet gets the unique object ID string for an agent, then uses uses the SetValue method to store the agent object id and string constant CTIOS_AGENTREFERENCE in an arguments array.
String StrUID = agent.GetValueString(CTIOS_UNIQUEOBJECTID Id); arg.SetValue(CTIOS_AGENTREFERENCE, StrUID);
StartMonitoringAgentTeam
The StartMonitoringAgentTeam method allows the client, which must be a supervisor, to start monitoring the specified agent team. A client supervisor uses this method to receive all of the OnMonitorAgentStateChange events for every agent on the specified team.
Syntax
int StartMonitoringAgentTeam (Arguments& args) HRESULT StartMonitoringAgentTeam (/*[in]*/ IArguments args, /*[out,retval]*/ int * errorcode) VB: StartMonitoringAgentTeam (args as CTIOSCLIENTLib.IArguments) As Long Java: int StartMonitoringAgentTeam (Arguments args) .NET: CilError StartMonitoringAgentTeam(Arguments args)
C++: COM:
Parameters
args Arguments array that contains the constant CTIOS_TEAMID set to the integer TeamID to be monitored. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-35
Chapter 9 Methods
Agent Object
Remarks
This request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only).
StartMonitoringAllAgentTeams
The StartMonitoringAllAgentTeams method allows the client, which must be a supervisor, to start monitoring all the agents on all the supervisors teams. This will cause the supervisor to receive monitored agent events for all of the agents in the supervisors team (seeIMonitoredAgentEvents Interface in Chapter 6, Event Interfaces and Events).
Syntax
int StartMonitoringAllAgentTeams (Arguments& reserved_args) HRESULT StartMonitoringAllAgentTeams (/*[in, optional]*/ IArguments reserved_args, /*[out,retval]*/ int * errorcode) VB: StartMonitoringAllAgentTeams ([reserved_args as CTIOSCLIENTLib.IArguments]) As Long Java: int StartMonitoringAllAgentTeams (Arguments args) .NET: CilError StartMonitoringAllAgentTeams(Arguments args)
C++: COM:
Parameters
reserved_args Not currently used, reserved for future use. Java/.NET: args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
This request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-36
Release 8.0(1)
Chapter 9
StartMonitoringCall
Description
The StartMonitoringCall method allows the client, which must be a supervisor, to set the value of the currently monitored call that is used in the SuperviseCall method. Since there is no StopMonitoringCall, to clear the value of the currently monitored call, call this method with an empty args parameter.
Syntax
int StartMonitoringCall(Arguments& args) HRESULT StartMonitoringCall (/*[in]*/ IArguments * args, /*[out,retval]*/ int * errorcode) VB: StartMonitoringCall (args As CTIOSCLIENTLib.IArguments) As Long Java: int StartMonitoringCall(Arguments args) .NET: CilError StartMonitoringCall(Arguments args)
C++: COM:
Parameters
args Arguments array that contains the constant CTIOS_CALLREFERENCE set to the string value of the UniqueObjectID of the call to be monitored. errorCode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
This request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only).
StopMonitoringAgent
The StopMonitoringAgent method allows the client, which must be a supervisor, to stop monitoring the specified Agent object. This will stop all Monitored Call events from being sent to the supervisor.
Syntax
int StopMonitoringAgent(Arguments& args) HRESULT StopMonitoringAgent (/*[in]*/ IArguments * args, /*[out,retval]*/ int * errorcode) VB: StopMonitoringAgent (args As CTIOSCLIENTLib.IArguments) As Long Java: int StopMonitoringAgent(Arguments args) .NET: CilError StopMonitoringAgent(Arguments args)
C++: COM:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-37
Chapter 9 Methods
Agent Object
Parameters
args Arguments array that contains the constant CTIOS_AGENTREFERENCE set to the string value of the UniqueObjectID of the agent to stop monitoring. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
This request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only).
StopMonitoringAgentTeam
The StopMonitoringAgentTeam method allows the client, which must be a supervisor, to stop monitoring all the agents on all the supervisors teams.
Syntax
C++:int StopMonitoringAgentTeam (Arguments& args) COM: HRESULT StopMonitoringAgentTeam (/*[in]*/ IArguments args, /*[out,retval]*/ int *
errorcode) VB: StopMonitoringAgentTeam (args as CTIOSCLIENTLib.IArguments) As Long Java:int StopMonitoringAgentTeam(Arguments args) .NET: CilError StopMonitoringAgentTeam(Arguments args)
Parameters
args Arguments array that contains a constant CTIOS_TEAMID set to the integer TeamID of the team to stop monitoring. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-38
Release 8.0(1)
Chapter 9
Remarks
This request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only).
StopMonitoringAllAgentTeams
The StopMonitoringAllAgentTeams method allows the client, which must be a supervisor, to stop monitoring all of the agents on all the supervisors teams.
Syntax
int StopMonitoringAllAgentTeams (Arguments& reserved_args) HRESULT StopMonitoringAllAgentTeams (/*[in,optional]*/ IArguments reserved_args, /*[out,retval]*/ int * errorcode) VB: StopMonitoringAllAgentTeams([reserved_args as CTIOSCLIENTLib.IArguments]) As Long Java: int StopMonitoringAllAgentTeams(Arguments args) .NET: CilError StopMonitoringAgentTeam(Arguments args)
C++: COM:
Parameters
reserved_args Not currently used, reserved for future use. Java/.NET: args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
This request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only).
SuperviseCall
The SuperviseCall method allows the client, which must be a supervisor, to perform a supervisory action specified by the args parameter. The SuperviseCall method is the CTI OS version of the SUPERVISE_CALL_REQ message. This method is used to barge-into and intercept agent calls by specifying a supervisory action of eSupervisorBargeIn and eSupervisorIntercept respectively. To support Cisco Unified Communications Manager silent monitor, the supervisory action eSupervisorMonitor was added. Refer to Enabling Unified CM Based Silent Monitoring in your Application on page 4-57 for additional Information.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-39
Chapter 9 Methods
Agent Object
Syntax
C++: COM:
int SuperviseCall(Arguments& args) HRESULT SuperviseCall (/*[in]*/ IArguments * args, /*[out,retval]*/ errorCode) VB: SuperviseCall (args As CTIOSCLIENTLib.IArguments ) As Long Java: int SuperviseCall(Arguments args) .NET: CilError SuperviseCall(Arguments args) int
Parameters
args An input parameter in the form of a pointer to an Arguments array that contains members with string values that are the UniqueObjectIDs of the desired agent (AgentUniqueObjectID) and call (CallUniqueObjectID). These should be packaged with the keywords AgentReference and CallReference respectively. The third required parameter is one of the following integers representing the desired supervisory action.
Table 9-15 SuperviseCall Parameters
Value 3 4 1 0
Description BargeIn to the specified call of the specified agent. Intercept the specified call of the specified agent. Used to silently monitor the call of the specified agent. Used to clear the silent monitor call.
Note
Both SupervisorMonitor and eSupervisorClear only apply to Cisco Unified Communications Manager based silent monitor.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
This request is specific to the Supervisor feature and should only be used on switches or configurations that have the necessary support (currently, Unified CCE only). A BargeIn action is very similar to a Single Step Conference where the agent is the conference controller. As such, only this agent is able to add other parties to the conference; the supervisor will not be able to do this.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-40
Release 8.0(1)
Chapter 9
An Intercept can only be performed by a supervisor who has already performed a BargeIn. The Intercept simply hangs up the original agent, leaving only the customer and the supervisor talking. E_CTIOS_INVALID_SILENT_MONITOR_MODE is returned when Agent.SuperviseCall() is called when CTI OS Based silent monitor is configured.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
9-41
Chapter 9 Methods
Agent Object
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
9-42
Release 8.0(1)
CHAPTER
10
Call Object
The Call object provides developers using the CTI OS Client Interface Library with an interface to Call behavior and control. The Call object enables you to perform all call behaviors, such as answering, hanging up, or transferring a call. The Call object represents one call connection of a call. For a call between two parties there are two call connections, and thus there would be two distinct CIL Call objects. The object stores specific call information as properties, including the ICMEnterpriseUniqueID, ANI, DNIS, Call variables, and ExpandedCallContext variables. The Call object is created in response to call events received at the CIL. The Call objects properties and state will be updated throughout the lifetime of the call connection. See Chapter 3, CIL Coding Conventions for an explanation of accessing Call and ECC variables via the GetValue mechanism.
The CurrentCall concept does not place any limitations on call control of non-current calls. All of the call behaviors implemented by method calls on the Call object will work on any call object that is available at the CIL, even if it is not the CurrentCall.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-1
Call Object
A consultative transfer is one in which the transferring or forwarding party either connects the caller to a ringing phone or speaks with the third party before connecting the caller to the third party. In a consultative transfer on the same peripheral gateway, if a variable is updated with data during the primary call, and the same variable is then updated with data during the transferred call, the call data from the initial call takes precedence and replaces the call data from the transferred call. For calls that are transferred between peripheral gateways, update call variables on the primary call before transferring the call. Only call variable information from the primary call is included in the route request to the other peripheral gateway. Any call variable information that you change after the call is transferred is lost because the call variable information was not included in the route request when the call was transferred. The Unified ICM call control variable map is a string that describes the mappings of a peripherals call control variables to Unified ICM call control variables. You can edit this string to identify the call variables that an agent can change.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-2
Release 8.0(1)
Chapter 10
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-3
Chapter 10 Properties
Call Object
Properties
Table 10-1 lists the available call object properties.
Note
The data type listed for each keyword is the standardized data type discussed in the section CTI OS CIL Data Types in Chapter 3, CIL Coding Conventions. See Table 3-1 for the appropriate language specific types for these keywords.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-4
Release 8.0(1)
Chapter 10
Table 10-1
Keyword ANI CallerEnteredDigits CallStatus CallType CallVariable1 CallVariable2 CallVariable3 CallVariable4 CallVariable5 CallVariable6 CallVariable7 CallVariable8 CallVariable9 CallVariable10 CallWrapupData ClassIdentifier DialedNumber DNIS ECC
Type STRING STRING SHORT SHORT STRING STRING STRING STRING STRING STRING STRING STRING STRING STRING STRING INT STRING STRING
Description The calling line ID of the caller. The digits entered by the caller in response to IVR prompting. The current status of the call. The general classification of the call type. Call-related variable data. Call-related variable data. Call-related variable data. Call-related variable data. Call-related variable data. Call-related variable data. Call-related variable data. Call-related variable data. Call-related variable data. Call-related variable data. Call-related variable data. Private; for internal use only. The number dialed. The DNIS provided with the call.
ARGUMENTS Arguments structure of key-value pairs of ECC variables. Required only when the call is pre-routed. Indicates the type of the teleset line. Number of seconds this call was in a local queue before being delivered to the agent. The Unified ICM PeripheralID of the ACD where the call activity occurred. The call key created by the Unified ICM. The Unified ICM resets this counter at midnight.
PeripheralID
INT
RouterCallKeyCallID
INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-5
Chapter 10 Methods
Call Object
Table 10-1
Type INT
Description Together with the RouterCall KeyCallID field forms the unique 64-bit key for locating this calls records in the Unified ICM database. Only provided for Post-routed and Translation-routed calls. The Unified ICM ServiceID of the service that the call is attributed to. May contain the special value NULL_SERVICE when not applicable or not available. The service that the call is attributed to, as known to the peripheral. May contain the special value NULL_SERVICE when not applicable or not available. The Unified ICM SkillGroupID of the agent SkillGroup the call is attributed to. May contain the special value NULL_SKILL_ GROUP when not applicable or not available. The number of the agent SkillGroup the call is attributed to, as known to the peripheral. May contain the special value NULL_ SKILL_GROUP when not applicable or not available. An object ID that uniquely identifies the call object. The ISDN user-to-user information element.
ServiceID
INT
ServiceNumber
INT
SkillGroupID
INT
SkillGroupNumber
INT
UniqueObjectID UserToUserInfo
STRING STRING
Methods
Table 10-2 lists the available call object methods.
Table 10-2 Call Object Methods
Description Places the current call on hold and retrieves a previously held call. Answers a call that is in the alerting or ringing state.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-6
Release 8.0(1)
Chapter 10
Table 10-2
Description Clears a call, dropping all parties to the call. Hangs up a call, leaving other parties in a conference call. If there are only two parties on the call it clears the call. Either establishes a three party conference call or adds a new party to an existing conference call. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. Gets data associated with the call other than call and expanded call context (ECC) variables. Obtains call and expanded call context (ECC) variables. See Chapter 7, CtiOs Object. Returns the last error that occurred on the calling thread. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. Retrieve a property from the Call object based on the propertys name key. Places a current call on hold. See Chapter 7, CtiOs Object. Places a current call on hold and makes a new call. Clears the current call and then retrieves a held call. Retrieves a held call. Sets call and expanded call context (ECC) variables. Requests the ACD to send a sequence of DTMF tones. Performs a single step conference. Performs a single step transfer. Issues a server request to get the current call information, including call data and a list of associated devices and the connection state for the call of each device. Starts recording of a call. Stops recording of a call. Transfers a call to a third party.
Conference DumpProperties GetAllProperties GetCallContext GetCallData GetElement GetLastError (.NET only) GetNumProperties GetPropertyName GetPropertyType GetValue methods Hold IsValid MakeConsultCall Reconnect Retrieve SetCallData SendDTMFSignal SingleStepConference SingleStepTransfer Snapshot
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-7
Chapter 10 Methods
Call Object
Arguments Parameters
The following rules apply to the optional_args and reserved_args parameters in Call Object methods:
In VB, you can ignore these parameters altogether. For example, you can treat the line:
Answer([reserved_args As IArguments]) As Long
as follows:
Answer()
Alternate
The Alternate method combines the action of placing a talking call on hold and then retrieving a previously held call at the same device. If there are only two calls at the device, this method may be called via either the current or the held call.
Syntax
int Alternate() int Alternate(Arguments & reserved_args); COM: HRESULT Alternate (/*[in,optional]*/ IArguments *reserved_args, retval]*/ int * errorcode ); VB: Alternate([reserved_args As IArguments]) As Long Java: int Alternate(Arguments rArgs); .NET: CilError Alternate(Arguments args)
C++:
(/*[out,
Parameters
reserved_args A valid Arguments object, which can be empty. Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
For switches that allow more than two calls at a device (for example G3), it is recommended that this request only be made through the desired held call, because of the ambiguity caused by multiple held calls at the device. The Alternate request must be made via a call whose status is either LCS_CONNECT or LCS_HELD or it will fail.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-8
Release 8.0(1)
Chapter 10
The following events will be received if this request is successful. For the call making the Alternate request:
The following events will be received by the call making the Alternate request if this request fails:
Answer
The Answer method answers a call that is in the alerting or ringing state (i.e., call status of LCS_ALERTING).
Syntax
C++:int Answer()
int Answer(Arguments & reserved_args)
(/*[out, retval]*/
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
A call may be answered after the OnCallDelivered event has been received. The Answer request must be made via a call whose call status LCS_ALERTING or it will fail. The following events will be received if this request is successful:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-9
Chapter 10 Methods
Call Object
OnControlFailureConf event
Clear
The Clear method clears the call and drops all parties to the call.
Syntax
C++:int Clear()
int Clear(Arguments & reserved_args); IArguments *reserved_args, int * errorcode ) VB: Clear([reserved_args As IArguments]) As Long Java: int Clear(Arguments rArgs); .NET: CilError Clear(Arguments args);
(/*[out, retval]*/
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions..
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
In the case of a multi-party Conference call, calling Clear() will result in all of the parties to the call being hung up. (If this is not the desired behavior, see the ClearConnection method.) Under certain switches the Clear request will be made via a call whose status is LCS_CONNECT or LCS_INITIATE or it will fail. Many other switches will allow the Clear method to be called via a call whose status is LCS_ALERTING or LCS_HOLD. It may never be made via a call whose status is LCS_NULL indicating that it has already been cleared. The following events will be received if this request is successful:
Note
The Clear method is not supported on Unified CCE. Use of the Clear method with Unified CCE will result in loss of third-party call control. To avoid this error, applications should use the ClearConnection method instead of Clear to hang up a call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-10
Release 8.0(1)
Chapter 10
ClearConnection
The ClearConnection method clears a single connection from a call. If there are only two parties to the call, this effectively clears the call, however for a multi-party conference call, only the one connection is dropped.
Syntax
C++:int ClearConnection()
int ClearConnection(Arguments & reserved_args); IArguments *reserved_args, retval]*/ int * errorcode) VB: ClearConnection([reserved_args As IArguments]) As Long Java: int ClearConnection(Arguments rArgs); .NET: CilError ClearConnection(Arguments args);
(/*[out,
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
As with the Clear method, under certain switches the ClearConnection request must be made via a call whose status is LCS_CONNECT or LCS_INITIATE or it will fail. Many other switches allow the Clear method to be called via a call whose status is LCS_ALERTING or LCS_HOLD. It may never be made via a call whose status is LCS_NULL indicating that it has already been cleared. The following events will be received if this request is successful:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-11
Chapter 10 Methods
Call Object
Conference
The Conference method either begins a new conference call or adds an additional call to an existing conference call. When it begins a new conference call, it combines an original two-party call with a two-party consult call (where the two calls have a common party) into a single three party call. Only the common party (which is called the Conference Controller) can call this method to make the new conference call. This method may be called on either of the Conference Controllers calls.
Syntax
C++:int Conference();
int Conference(Arguments& optional_args)
(/*[out,
Parameters
optional_args An optional input parameter, which is a pointer or reference to an Arguments array that contains a member with the string value that is the UniqueObjectID of the call to which this call should be conferenced. If this argument is used, it should be added to the Arguments parameter with the keyword of CallReferenceObjectID. This would only be necessary in an environment where there are multiple held calls and the request is being made through the talking call. If the request is being made through a specific held call in this scenario, or if there are only two calls at the device, this parameter is unnecessary. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
Before making this request, it is necessary for the original call to be in the held state and the consult call to be in the talking state or the request will fail. Therefore, if the calls are alternated (see Alternate), they must be alternated again to return the two calls to their appropriate states. If there are only two calls at the device, this method may be called using either the current or held call. For switches which allow more than two calls at a device (for example G3), make this request through the desired held call to avoid the ambiguity caused by multiple held calls at the device. Otherwise, indicate the desired held call using the optional parameter. The Conference request must be made via a call whose call status is LCS_CONNECT or LCS_HELD or it will fail. On certain switches (notably Unified CCE), only the Conference Controller (the party that first initiated the conference call) may add additional parties to an existing conference call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-12
Release 8.0(1)
Chapter 10
GetCallContext
The GetCallContext method returns an Arguments array containing the values for call properties other than CallVariables and ECC Variables, such as ANI, DNIS, and the other properties listed in Table 10-3.
Syntax
C++: COM: VB: Java: .NET:
int GetCallContext(Arguments& args) HRESULT GetCallContext (/*[out,retval]*/ IArguments ** args) GetCallContext (CTIOSCLIENTLib.IArguments args) Arguments GetCallContext() Arguments GetCallContext()
Parameters
args C++, COM, and VB: An output parameter containing a reference or a pointer to an Arguments array containing any of the members in Table 10-3 that are present in the call.
Return Value
C++, COM, and VB: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Java/.NET: A reference to an Arguments array that, on return, holds name/value pairs from Table 10-3. Any of these parameters included may be accessed from the Arguments array using the associated keyword.
Table 10-3 GetCallContext Arguments Array Contents
Description The calling line ID of the caller. The digits entered by the caller in response to IVR prompting. The general classification of the call type. Call-related wrapup data. The Call ID value assigned to this call by the peripheral or the Unified ICM. The number dialed. The DNIS provided with the call.
DialedNumber DNIS
STRING STRING
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-13
Chapter 10 Methods
Call Object
Table 10-3
Keyword ICMEnterpriseUniqueID
Type STRING
Description A unique identifier for this contact throughout the enterprise. This can track a single customer contact across multiple sites, e.g., when a call is transferred between agents. The Unified ICM identifier for the Service to which this call was routed. The ACD number of the Service to which this call was routed. The Unified ICM identifier for the SkillGroup to which this call was routed. The number of the SkillGroup at the ACD to which this call was routed. A unique object ID for the call. The ISDN user-to-user information element.
Remarks
This is simply a convenience method to be called to get all of a calls non-CallVariable data at one time. If only certain data members are desired, call the appropriate GetValue method for each instead.
GetCallData
The GetCallData method returns the values ofCallVariable1 through CallVariable10 and all of the ECC (Extended CallContext) variables.
Syntax
C++: int GetCallData(Arguments& args) COM:HRESULT GetCallData (/*[out,retval]*/ IArguments ** args) VB: GetCallData (CTIOSCLIENTLib.IArguments args) Java: Arguments GetCallData() .NET: Arguments GetCallData()
Parameters
args C++, COM, and VB: An output parameter containing a reference or a pointer to an Arguments array containing the call data, as described under Remarks.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-14
Release 8.0(1)
Chapter 10
Return Value
C++, COM, and VB: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Java/.NET: A reference to an Arguments array that, on return, holds parameters described under Remarks.
Remarks
This is simply a convenience method to be called to get all of a calls CallVariables (1 through 10) and ECC Call Variables at one time. If only certain call variables are desired, call the appropriate GetValue method for each instead. Access the data in the following way:
To access the values for individual CallVariables from the arguments parameter, use GetValueString with either the keywords of CallVariable1 through CallVariable10. First, get the ECC variables as a whole from the arguments parameter, using GetValueArray with the keyword ECC. This will return another Arguments array that is nested in the Arguments array returned from GetCallData. To access an individual ECC scalar variable from this Arguments array, use the appropriate GetValueString, GetValueInt, etc. depending on the variables type, using the string keyword user.VariableName. To access an individual ECC array variable from this Arguments array, use the appropriate GetValueString, GetValueInt, etc. depending on the variables type, using the string keyword user.ArrayName[n] where n is a zero based integer that notes the offset in the array.
Hold
The Hold method holds a current call.
Syntax
C++: COM:
int * int Hold() int Hold(Arguments & reserved_args); HRESULT Hold (/*[in,optional]*/ IArguments *reserved_args, errorcode ) Hold([reserved_args As IArguments]) As Long Arguments Hold(Arguments rArgs) Arguments Hold(Arguments args) (/*[out, retval]*/
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-15
Chapter 10 Methods
Call Object
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The Hold request must be made via a call whose call status is LCS_CONNECT or it will fail. The following events will be received if this request is successful:
MakeConsultCall
The MakeConsultCall method initiates the combined action of placing the associated current call on hold and then making a new call. By default, the call context data (including call variables) of the current call is used to initialize the context data of the new consultation call. The application may override some or all of the original call context in the consultation call by providing the desired values in this request. The simplest form of the request only requires a dialed number and a consult type. The request may also include optional parameters, as listed in Table 10-4.
Syntax
C++:int MakeConsultCall (Arguments& args)) COM:HRESULT MakeConsultCall (/*[in]*/ IArguments *args, /*[out, retval]*/ int *
errorcode) VB: MakeConsultCall (args As CTIOSCLIENTLib.IArguments) As Long Java:int MakeConsultCall(Arguments args) .NET:CilError MakeConsultCall(Arguments args)
Parameters
args An output parameter of either a reference or a pointer to an Arguments array that contains parameters from Table 10-4. Any of these parameters included should be added to the Arguments array using the associated key word.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-16
Release 8.0(1)
Chapter 10
Table 10-4
MakeConsultCall Parameters
Description Dialed number; the number to be dialed to establish the new call. A value specifying whether this consult call is in preparation for either a transfer or a conference, as specified in the ConsultType Table. A value specifying how the call is to be placed identified in Table 10-5. A value specifying additional call processing options identified in Table 10-6. The maximum amount of time that the calls destination will remain alerting, specified as an approximate number of rings. A zero value indicates that the peripheral default (typically 10 rings) should be used. A value from Table 10-7 specifying additional peripheral-specific call options. A value from Table 10-8 indicating the type of facility to be used. A value from Table 10-9 specifying the action to be taken if the call is answered by an answering machine. This field should be set to TRUE if the call should receive priority handling. When this field is set to TRUE, the Post-Routing capabilities of the Unified ICM will determine the new call destination. The ISDN user-to-user information. Call variable data that should be set in the new call in place of the corresponding data in the current call.
ConsultType (required)
CallPlacementType (optional)
AlertRings (optional)
INT
CallOption (optional)
INT
FacilityType (optional)
INT
AnsweringMachine (optional)
INT
Priority (optional)
BOOL
PostRoute (optional)
BOOL
UserToUserInfo (optional)
CallVariable1 (optional)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-17
Chapter 10 Methods
Call Object
Table 10-4
Type ...
Description ...
ARGUMENTS ECC data that should be set in the new call in place of the corresponding data in the current call. Call-related wrapup data.
CallWrapupData (optional) STRING, maximum length 40 FacilityCode (optional) STRING, maximum length 40 STRING, maximum length 40 STRING, maximum length 40
A trunk access code, split extension, or other data needed to access the chosen facility. An authorization code needed to access the resources required to initiate the call. A cost-accounting or client number used by the peripheral for charge-back purposes.
Table 10-5
CallPlacementType Values
Description Use default call placement. An inside line call. An outbound call.
Value 0 1 2
An outbound call that will not require 3 an access code. A call placed directly to a specific position. A call placed directly to a specific agent. 4 5 6
Table 10-6
CallMannerType Values
Description Use default call manner. Attempt the call only if the originating device is idle.
Value 0 1
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-18
Release 8.0(1)
Chapter 10
Table 10-6
CMT_BELLIGERENT CMT_SEMI_POLITE
The call should always be attempted, disconnecting any currently active call. Attempt the call only if the originating device is idle or is receiving dial tone.
2 3
Table 10-7
CallOption Values
Description No call options specified, use defaults. Attempt the call only if the calling agent is online (available to interact with the destination party). Attempt the call only if ACDNR on the calling agents set is activated (DMS-100). Attempt the call only if ACDNR on the calling agents set is not activated (DMS-100).
Value 0 1
2 3
COPT_CALLING_ Causes a buzz to be applied to the base of the 4 AGENT_BUZZ_BASE telephone set as the call is initiated (DMS-100). COPT_CALLING_ AGENT_BEEP_HSET COPT_SERVICE_ CIRCUIT_ON Causes a tone to be applied to the agent headset as the call is initiated (DMS-100). Causes a call classifier to be applied to the call (ACM ECS) 5 6
Table 10-8
FacilityType Values
Description Use default facility type. Facility is a trunk group. Facility is a skill group or split.
Value 0 1 2
Table 10-9
AnsweringMachine Values
Description Use default behavior. Connect call to agent when call is answered by an answering machine. Disconnect call when call is answered by an answering machine. Do not use answering machine detection.
Value 0 1 2 3
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-19
Chapter 10 Methods
Call Object
Table 10-9
Description Do not use answering machine detection, but disconnect call if answered by a modem.
Value 4
Connect call when call is answered by an 5 answering machine, disconnect call if answered by a modem.
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The MakeConsultCall request must be made via a call whose call status is LCS_CONNECT or it will fail. Calling MakeConsultCall successfully will result in the same events as a successful MakeCall called on the agent. The following events will be received if this request is successful. For the call making the MakeConsultCallRequest:
OnMakeConsultCallConf event OnCallHeld event OnBeginCall event OnServiceInitiated event OnCallOriginated event OnCallDelivered event OnBeginCall event OnCallDelivered event OnControlFailureConf event
For the new connection that is ringing as a result of the consult call:
Reconnect
The Reconnect method combines the action of releasing a current call and then retrieving a previously held call at the same device. If there are only two calls at the device, this method may be called via either the talking or the held call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-20
Release 8.0(1)
Chapter 10
Syntax
int Reconnect() int Reconnect(Arguments & reserved_args) COM: HRESULT Reconnect (/*[in,optional]*/ IArguments * reserved_args, retval]*/ int * errorcode ) VB: Reconnect([reserved_args As IArguments]) As Long Java: int Reconnect(Arguments rArgs) .NET: CilError Reconnect(Arguments args)
C++:
(/*[out,
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
For switches which allow more than two calls at a device (for example G3), it is recommended that this request only be made through the desired held call, because of the ambiguity caused by multiple held calls at the device. The Alternate request must be made via a call whose status is either LCS_CONNECT or LCS_HELD or it will fail. The following events will be received if this request is successful. For the call making the Reconnect request:
OnReconnectCallConf event OnCallConnectionCleared event OnCallCleared event OnCallEnd event OnCallRetrieved event OnControlFailureConf event
The following events will be received by the call making the Alternate request if this request fails:
Retrieve
The Retrieve method unholds a held call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-21
Chapter 10 Methods
Call Object
Syntax
C++ int Retrieve()
int Retrieve(Arguments & reserved_args) IArguments *reserved_args, retval]*/ int * errorcode ) VB: Retrieve([reserved_args As IArguments]) As Long Java:int Retrieve(Arguments rArgs) .NET:CilError Retrieve(Arguments args)
(/*[out,
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The Retrieve request must be made via a call whose call status is LCS_HELD or it will fail. The following events will be received if this request is successful:
SendDTMFSignal
The SendDTMFSignal method requests that the ACD send a sequence of DTMF tones.
Syntax
C++:int SendDTMFSignal(Arguments& args) COM: HRESULT SendDTMFSignal (/*[in]*/ args *arguments, /*[out, retval]*/ int *
errorcode) VB: SendDTMFSignal (args As CTIOSCLIENTLib.IArguments, errorcode As Long) Java:int SendDTMFSignal(Arguments rArgs) .NET:CilError SendDTMFSignal(Arguments args)
Parameters
args
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-22
Release 8.0(1)
Chapter 10
An input parameter of either a reference or a pointer to an Arguments array containing parameters from following table. Any of these parameters included should be added to the Arguments array using the associated key word.
Table 10-10 SendDTMFSignal parameters
ToneDuration (optional)
Specifies the duration in milliseconds of DTMF digit tones. Use 0 to take the default. May be ignored if the peripheral is unable to alter the DTMF tone timing. Specifies the duration in milliseconds of DTMF inter-digit spacing. Use 0 to take the default. May be ignored if the peripheral is unable to alter the DTMF tone timing.
PauseDuration (optional)
INT
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The OnSendDTMFSignalConf event will be received if this request succeeds. The OnControlFailureConf event will be received if this request fails.
SetCallData
The SetCallData method enables any or all of a calls CallVariables (1 through 10) and ECC data to be set at one time.
Note
When writing a custom application, in any language, call variables are not blanked out if it they are set to a NULL value. While the application attempts to clear any call variable using a NULL value, the CTI OS server application ignores the NULL value call variables and does not pass them to the CTI Server application. As a result, the call variables set to NULL are not reset. To clear the value of a call variable, set its value to a blank character. Setting the call variable to a single space character places a space in the call variables values for the duration of the call. This space is considered a NULL value by the application.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-23
Chapter 10 Methods
Call Object
Syntax
C++: COM: VB: Java: .NET
int SetCallData(Arguments& args) HRESULT SetCallData (/*[in]*/ args *arguments, /*[out]*/ int * errorcode) SetCallData (args As CTIOSCLIENTLib.IArguments, errorcode As Long) int SetCallData(Arguments rArgs) CilError SetCallData(Arguments args)
Parameters
args An input parameter of either a reference or a pointer to an Arguments array containing parameters described under Remarks for GetCallData. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
You must specify the data for all elements in the Arguments array, not just those elements that you want to change. Failure to do so will cause the unchanged elements to disappear. The following events will be sent if this request succeeds:
OnSetCallDataConf OnCallDataUpdate
SingleStepConference
The SingleStepConference method initiates a one-step conference without the intermediate consultative call so that when the called party answers, he will be joined in the current call. This method requires a DialedNumber argument. This method is not supported under all switches.
Note
Syntax
C++:int SingleStepConference(Arguments& args) COM:HRESULT SingleStepConference (IArguments *args, int * errorcode) VB: SingleStepConference (args As CTIOSCLIENTLib.IArguments, errorcode As Long) Java:int SingleStepConference(Arguments rArgs) .NET:CilError SingleStepConference(Arguments args)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-24
Release 8.0(1)
Chapter 10
Parameters
args An output parameter of either a reference or a pointer to an Arguments array containing parameters from Table 10-11. Any of these parameters included should be added to the Arguments array using the associated keyword.
Table 10-11 SingleStepConference Parameters
Type
Description
STRING, maximum Dialed number; the number to be dialed to length 40 establish the new call. STRING, maximum A value specifying how the call is to be length 40 placed identified in Table 10-5. INT A value specifying additional call processing options identified in Table 10-6. The maximum amount of time that the calls destination will remain alerting, specified as an approximate number of rings. A zero value indicates that the peripheral default (typically 10 rings) should be used. A value from Table 10-7 specifying additional peripheral-specific call options. A value from Table 10-8 indicating the type of facility to be used. A value from Table 10-9 specifying the action to be taken if the call is answered by an answering machine. This field should be set to TRUE if the call should receive priority handling. When this field is set to TRUE, the Post-Routing capabilities of the Unified ICM will determine the new call destination.
AlertRings (optional)
INT
BOOL BOOL
STRING, maximum The ISDN user-to-user information. length 40 STRING, maximum Call variable data that should be set in the length 40 new call in place of the corresponding data in the current call. ... ARGUMENTS ... ECC data that should be set in the new call in place of the corresponding data in the current call.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-25
Chapter 10 Methods
Call Object
Table 10-11
Type
Description
STRING, maximum A trunk access code, split extension, or length 40 other data needed to access the chosen facility. STRING, maximum An authorization code needed to access length 40 the resources required to initiate the call. STRING, maximum A cost-accounting or client number used length 40 by the peripheral for charge-back purposes.
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The DialedNumber is the only required member necessary in the Arguments parameter. A SingleStepConference request will fail if the calls status is not LCS_CONNECT. The following events will be received if this request is successful:
OnAgentStateChange event (Hold) OnCallHeld event OnAgentStateChange event (Talking) OnBeginCall event OnServiceInitiated event OnCallOriginated event OnCallDelivered event OnCallConferenced event OnCallEnd event ConferenceCallConf event
SingleStepTransfer
The SingleStepTransfer method initiates a one-step transfer without the intermediate consultative call. When the called party answers the call, the called party will be talking to the party to be transferred and the transferring party will drop out of the call. The method requires a DialedNumber argument.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-26
Release 8.0(1)
Chapter 10
Syntax
C++:int SingleStepTransfer(Arguments& args) COM:HRESULT SingleStepTransfer (/*[in]*/ IArguments * args, /*[out, retval]*/ int *
errorcode) VB: SingleStepTransfer (args As CTIOSCLIENTLib.IArguments, errorcode As Long) Java:int SingleStepTransfer(Arguments rASrgs) .NET:CilError SingleStepTransfer(Arguments args)
Parameters
args An output parameter of either a reference or a pointer to an Arguments array containing parameters from Table 10-11. Any of these parameters included should be added to the Arguments array using the associated keyword. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Snapshot
The Snapshot method issues a server request to retrieve the current call information. If values are passed in the optional args parameter, the snapshot request will return the server's current call values for only the requested arguments. Otherwise all call information is returned, including the fields described under GetCallContext and GetCallData. See OnCallDataUpdate in Chapter 6, Event Interfaces and Events for more information.
Syntax
int Snapshot() int Snapshot(Arguments & optional_args) COM: HRESULT Snapshot (/*[in,optional]*/ IArguments * optional_args, retval]*/ int * errorcode ) VB: Snapshot([optional_args As IArguments]) As Long Java: int Snapshot(Arguments rArgs) .NET: CilError Snapshot(Arguments Args)
C++
(/*[out,
Parameters
optional_args An input parameter of either a pointer or a reference to an Arguments array. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-27
Chapter 10 Methods
Call Object
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The current information about the call will be received in the OnCallDataUpdate event.
The OnCallDataUpdate event will be received if this request is successful. The OnControlFailureConf event will be received if this request fails.
StartRecord
The StartRecord method is used to start recording a call.
Syntax
int StartRecord() int StartRecord(Arguments & reserved_args); COM: HRESULT StartRecord (/*[in,optional]*/ IArguments *reserved_args, retval]*/ int * errorcode ) VB: StartRecord([reserved_args As IArguments]) As Long Java: int StartRecord(Arguments rArgs) NET: CilError StartRecord(Arguments args)
C++:
(/*[out,
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
Calling this method causes the CTI Server to forward the request to one or more server applications that have registered the Cisco:CallRecording service as described in the CTI Server Message Reference Guide (Protocol Version 14) for Cisco Unified ICM/Contact Center Enterprise & Hosted (Protocol Version 14) for Cisco Unified ICM/Contact Center Enterprise & Hosted. It will fail if there is no recording server available to CTIServer.
The OnStartRecordingConf event will be received if this request is successful. The OnControlFailureConf event will be received if this request fails.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-28
Release 8.0(1)
Chapter 10
StopRecord
The StopRecord method is used to stop recording a call.
Syntax
int StopRecord() int StopRecord(Arguments & reserved_args); COM:HRESULT StopRecord (/*[in,optional]*/ IArguments *reserved_args, retval]*/ int * errorcode ) VB: StopRecord([reserved_args As IArguments]) As Long Java: int StopRecord(Arguments rArgs) .NET: CilError StopRecord(Arguments args)
C++:
(/*[out,
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
Calling this method causes the CTIServer to forward the request to the server application with the SessionID received in the OnStartRecordingConf event if non-zero, or if that SessionID is zero, to one or more server applications that have registered the Cisco:CallRecording service as described in the CTI Server Message Reference Guide (Protocol Version 14) for Cisco Unified ICM/Contact Center Enterprise & Hosted. It will fail if there is no recording server available to CTIServer.
The OnStopRecordConf event will be received if this request is successful. The OnControlFailureConf event will be received if this request fails.
Transfer
The Transfer method transfers a call to a third party. This method may be called on either the held original call or the current consult call. If the device has only these two calls, the optional parameter is not necessary. At the end of a successful transfer, both of these calls will be gone from the device. See the Conference method for more information.
Syntax
C++:
int Transfer(); int Transfer(Arguments& optional_args)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
10-29
Chapter 10 Methods
Call Object
COM: HRESULT Transfer ( [in, optional] IArguments *optional_args, retval]*/ int * errorcode ) VB: Transfer([optional_args As IArguments]) As Long Java: int Transfer(Arguments rArgs) .NET: CilError Transfer(Arguments args)
(/*[out,
Parameters
optional_args An optional input parameter containing a member with a string value that is the UniqueObjectID of the call that is participating in the transfer. If this argument is used, it should be added to the Arguments parameter with the keyword of CallReferenceObjectID. This would only be necessary in an environment where there are multiple held calls and the request is being made through the current call. If the request is being made through a specific held call in this scenario, or if there are only two calls at the device, this parameter is unnecessary. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
Before making this request, it is necessary for the original call to be in the held state and the consult call to be in the talking state or the request will fail. Therefore, if the calls are alternated (See Alternate), they must be alternated again to return the two calls into their appropriate states. If there are only two calls at the device, call this method using either the current or held call. For switches that allow more than two calls at a device (for example G3), make this request only through the desired held call to avoid the ambiguity caused by multiple held calls at the device. Otherwise, indicate the desired held call by using the optional parameter. The Transfer request must be made via a call whose call status is LCS_CONNECT or LCS_HELD or it will fail. The following events are received by the transfer initiator if this request is successful:
OnCallTransferred event OnCallEnd event OnCallEnd event OnAgentStateChange event OnTransferCallConf event
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
10-30
Release 8.0(1)
CHAPTER
11
SkillGroup Object
The SkillGroup object provides developers using the CTI OS Client Interface Library with an interface to Skill Group properties and data. The SkillGroup is mainly a representation used for accessing statistics, which can be enabled or disabled via method calls to the SkillGroup object. The SkillGroups are accessible directly from the Session object or the Agent Object. The SkillGroup object methods can be accessed as follows:
Via the Agent object inside the Session in Agent mode Via the Agent object inside the Session in Monitor mode In C++, Java, and .NET, via the session object inside the session in Monitor mode when the special SkillGroupStats filter is set. See the section Filtering Skillgroup Statistics in Chapter 8 for code examples related to the special SkillGroupStats filter.
Properties
Table 11-1 lists the available SkillGroup properties.
Note
The data type listed for each keyword is the standardized data type discussed in the section CTI OS CIL Data Types in Chapter 3, CIL Coding Conventions. See Table 3-1 for the appropriate language specific types for these keywords.
Table 11-1 Skill Group Properties
Description The number of the skill group from the Peripheral. The Unified ICM SkillGroupID of the SkillGroup, if available. The Unified ICM SkillGroupName of the SkillGroup, if available. Values representing the current state of the associated agent with respect to the indicated Agent Skill Group. Value represents skillgroup class.
ClassIdentifier
INT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-1
Chapter 11 Statistics
SkillGroup Object
To access statistics, first use GetValue on the Skill Group object to obtain the Statistics arguments array, then use GetValue to obtain the desired value.
Note
Not all the statistics values listed in Table 11-1 are present in every system configuration. Whether a particular statistic value is available depends both on the protocol version of CTI Server with which CTI OS connects and on the peripheral on which the agent resides.The statistics listed in Table 11-2 are available in Protocol Version 8 of CTI Server. One very important real-time skillgroup statistic is the number of calls currently in queue. Previously, this value was typically provided in CallsQNow. However, the number of calls currently in queue is now stored in RouterCallsQNow.
Statistics
Table 11-2 lists the available SkillGroup statistics.
Table 11-2 Skill Group Statistics
Definition Number of agents that are currently logged on to the skill group. Number of agents for the skill group in Available state ready to take calls. Number of agents in the Not Ready state for the skill group. Number of agents that are in work state (TALKING, HELD, WORK_READY, AVAILABLE, or RESERVED). This statistic is used by the router to determine the number of working agents in the skill group when estimating the expected delay. It is the difference between AgentsLoggedOn and AgentsNotReady. Reference AgentsAvail to get the number of agents that are available to take calls right now. Number of agents in the skill group currently talking on inbound calls. Number of agents in the skill group currently talking on outbound calls. Number of agents in the skill group currently talking on internal (not inbound or outbound) calls. Number of agents in the skill group in the Work Not Ready state.
AgentsWorkNot Ready
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-2
Release 8.0(1)
Chapter 11
Table 11-2
Definition Number of agents in the skill group in the Work Ready state. Number of agents currently busy with calls assigned to other skill groups. Number of agents for the skill group currently in the Reserved state. Number of calls to the skill group currently on hold. Number of agents in the skill group currently in the ICMAvailable state. Number of agents in the skillgroup currently in the Application Available state. Number of calls to the skill group currently talking on AutoOut (predictive) calls. Number of calls to the skill group currently talking on outbound Preview calls. Number of calls to the skill group currently talking on agent reservation calls. The number of calls currently queued by the CallRouter for this skill group. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. The queue time, in seconds, of the currently Unified ICM call router queued call that has been queued to the skill group the longest. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. The number of calls currently queued to the skill group. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. The total queue time, in seconds, of calls currently queued to the skill group. This field is set to 0xFFFFFFFF when this value is unknown or unavailable.
AgentsTalkingAutoOut
AgentsTalking Preview
AgentsTalking Reservation
RouterCallsQNow**
LongestRouterCallQNow**
CallsQNow*
CallsQTimeNow*
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-3
Chapter 11 Statistics
SkillGroup Object
Table 11-2
Statistic LongestCallQNow
*
Definition The queue time, in seconds, of the currently queued call that has been queued to the skill group the longest. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. Total seconds agents in the skill group were in the Available state. Total time, in seconds, agents in the skill group were logged on. Total seconds agents in the skill group were in the Not Ready state. Total number of completed outbound ACD calls made by agents in the skill group. Total talk time, in seconds, for completed outbound ACD calls handled by agents in the skill group. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed outbound ACD calls handled by agents in the skill group. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound ACD calls agents in the skill group have placed on hold at least once. Total number of seconds outbound ACD calls were placed on hold by agents in the skill group. The number of inbound ACD calls handled by agents in the skill group. Total talk time in seconds for Inbound ACD calls counted as handled by agents in the skill group. Includes hold time associated with the call.
AgentOutCallsTalk TimeTo5
AgentOutCallsTimeTo5
AgentOutCallsHeldTo5
AgentOutCallsHeldTimeTo5
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-4
Release 8.0(1)
Chapter 11
Table 11-2
Definition Total after call work time in seconds for Inbound ACD calls counted as handled by agents in the skill group. Total handle time, in seconds, for inbound ACD calls counted as handled by agents in the skill group. The time spent from the call being answered by the agent to the time the agent completed after call work time for the call. Includes hold time associated with the call. The total number of completed inbound ACD calls agents in the skill group placed on hold at least once. Total number of seconds completed inbound ACD calls were placed on hold by agents in the skill group. Number of internal calls received by agents in the skill group. Number of seconds spent on internal calls received by agents in the skill group. The total number of internal calls agents in the skill group placed on hold at least once. Total number of seconds completed internal calls were placed on hold by agents in the skill group. Total number of AutoOut (predictive) calls completed by agents in the skill group. Total talk time, in seconds, for completed AutoOut (predictive) calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call.
HandledCallsTime To5
IncomingCallsHeldTo5
IncomingCallsHeldTimeTo5
InternalCallsHeldTo5
InternalCallsHeld TimeTo5
AutoOutCallsTo5
AutoOutCallsTalk TimeTo5
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-5
Chapter 11 Statistics
SkillGroup Object
Table 11-2
Definition Total handle time, in seconds, for completed AutoOut (predictive) calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed AutoOut (predictive) calls that agents in the skill group have placed on hold at least once. Total number of seconds AutoOut (predictive) calls were placed on hold by agents in the skill group. Total number of outbound Preview calls completed by agents in the skill group. Total talk time, in seconds, for completed outbound Preview calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed outbound Preview calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound Preview calls that agents in the skill group have placed on hold at least once. Total number of seconds outbound Preview calls were placed on hold by agents in the skill group. Total number of agent reservation calls completed by agents in the skill group.
AutoOutCallsHeld To5
AutoOutCallsHeld TimeTo5
PreviewCallsTo5
PreviewCallsTalk TimeTo5
PreviewCallsTime To5
PreviewCallsHeld To5
PreviewCallsHeld TimeTo5
ReservationCallsTo5
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-6
Release 8.0(1)
Chapter 11
Table 11-2
Definition Total talk time, in seconds, for completed agent reservation calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed agent reservation calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of agent reservation calls that agents in the skill group have placed on hold at least once. Total number of seconds agent reservation calls were placed on hold by agents in the skill group. Total number of supervisor call barge-ins completed in the skill group. Total number of supervisor call intercepts completed in the skill group. Total number of supervisor call monitors completed in the skill group. Total number of supervisor call whispers completed by agents in the skill group. Total number of emergency calls completed by agents in the skill group. The number of calls queued to the skill group during the current five-minute. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. The total queue time, in seconds, of calls queued to the skill group during the current five-minute. This field is set to 0xFFFFFFFF when this value is unknown or unavailable.
ReservationCalls TimeTo5
ReservationCalls HeldTo5
ReservationCalls HeldTimeTo5
EmergencyCallsTo5 CallsQ5*
CallsQTime5*
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-7
Chapter 11 Statistics
SkillGroup Object
Table 11-2
Statistic LongestCallQ5
*
Definition The longest queue time, in seconds, of all calls queued to the skill group during the current five-minute. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. Total seconds agents in the skill group were in the Available state. Total time, in seconds, agents in the skill group were logged on. Total seconds agents in the skill group were in the Not Ready state. Total number of completed outbound ACD calls made by agents in the skill group. Total talk time, in seconds, for completed outbound ACD calls handled by agents in the skill group. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed outbound ACD calls handled by agents in the skill group. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound ACD calls agents in the skill group have placed on hold at least once. Total number of seconds outbound ACD calls were placed on hold by agents in the skill group. The number of inbound ACD calls handled by agents in the skill group. Total talk time in seconds for Inbound ACD calls counted as handled by agents in the skill group. Includes hold time associated with the call.
AgentOutCallsTalk TimeToHalf
AgentOutCallsTimeToHalf
AgentOutCallsHeldToHalf
AgentOutCallsHeldTimeToHalf
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-8
Release 8.0(1)
Chapter 11
Table 11-2
Definition Total after call work time in seconds for Inbound ACD calls counted as handled by agents in the skill group. Total handle time, in seconds, for inbound ACD calls counted as handled by agents in the skill group. The time spent from the call being answered by the agent to the time the agent completed after call work time for the call. Includes hold time associated with the call. The total number of completed inbound ACD calls agents in the skill group placed on hold at least once. Total number of seconds completed inbound ACD calls were placed on hold by agents in the skill group. Number of internal calls received by agents in the skill group. Number of seconds spent on internal calls received by agents in the skill group. The total number of internal calls agents in the skill group placed on hold at least once. Total number of seconds completed internal calls were placed on hold by agents in the skill group. Total number of AutoOut (predictive) calls completed by agents in the skill group. Total talk time, in seconds, for completed AutoOut (predictive) calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call.
HandledCallsTime ToHalf
IncomingCallsHeldToHalf
IncomingCallsHeldTimeToHalf
InternalCallsHeldToHalf
InternalCallsHeld TimeToHalf
AutoOutCallsToHalf
AutoOutCallsTalk TimeToHalf
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-9
Chapter 11 Statistics
SkillGroup Object
Table 11-2
Definition Total handle time, in seconds, for completed AutoOut (predictive) calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed AutoOut (predictive) calls that agents in the skill group have placed on hold at least once. Total number of seconds AutoOut (predictive) calls were placed on hold by agents in the skill group. Total number of outbound Preview calls completed by agents in the skill group. Total talk time, in seconds, for completed outbound Preview calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed outbound Preview calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound Preview calls that agents in the skill group have placed on hold at least once. Total number of seconds outbound Preview calls were placed on hold by agents in the skill group. Total number of agent reservation calls completed by agents in the skill group.
AutoOutCallsHeld ToHalf
AutoOutCallsHeld TimeToHalf
PreviewCallsToHalf
PreviewCallsTalk TimeToHalf
PreviewCallsTime ToHalf
PreviewCallsHeldToHalf
PreviewCallsHeld TimeToHalf
ReservationCallsToHalf
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-10
Release 8.0(1)
Chapter 11
Table 11-2
Definition Total talk time, in seconds, for completed agent reservation calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed agent reservation calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of agent reservation calls that agents in the skill group have placed on hold at least once. Total number of seconds agent reservation calls were placed on hold by agents in the skill group. Total number of supervisor call barge-ins completed in the skill group. Total number of supervisor call intercepts completed in the skill group. Total number of supervisor call monitors completed in the skill group. Total number of supervisor call whispers completed by agents in the skill group. Total number of emergency calls completed by agents in the skill group. The number of calls queued to the skill group during the current half hour. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. The total queue time, in seconds, of calls queued to the skill group during the current half hour. This field is set to 0xFFFFFFFF when this value is unknown or unavailable.
ReservationCalls TimeToHalf
ReservationCalls HeldToHalf
ReservationCalls HeldTimeToHalf
CallsQTimeHalf*
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-11
Chapter 11 Statistics
SkillGroup Object
Table 11-2
Statistic LongestCallQHalf
*
Definition The longest queue time, in seconds, of all calls queued to the skill group during the current half hour. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. Total seconds agents in the skill group were in the Available state. Total time, in seconds, agents in the skill group were logged on. Total seconds agents in the skill group were in the Not Ready state. Total number of completed outbound ACD calls made by agents in the skill group. Total talk time, in seconds, for completed outbound ACD calls handled by agents in the skill group. The value includes the time spent from the call being initiated by the agent to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed outbound ACD calls handled by agents in the skill group. The value includes the time spent from the call being initiated by the agent to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound ACD calls agents in the skill group have placed on hold at least once. Total number of seconds outbound ACD calls were placed on hold by agents in the skill group. The number of inbound ACD calls handled by agents in the skill group. Total talk time in seconds for Inbound ACD calls counted as handled by agents in the skill group. Includes hold time associated with the call.
AgentOutCallsTalk TimeToday
AgentOutCallsTimeToday
AgentOutCallsHeldToday
AgentOutCallsHeldTimeToday
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-12
Release 8.0(1)
Chapter 11
Table 11-2
Definition Total after call work time in seconds for Inbound ACD calls counted as handled by agents in the skill group. Total handle time, in seconds, for inbound ACD calls counted as handled by agents in the skill group. The time spent from the call being answered by the agent to the time the agent completed after call work time for the call. Includes hold time associated with the call. The total number of completed inbound ACD calls agents in the skill group placed on hold at least once. Total number of seconds completed inbound ACD calls were placed on hold by agents in the skill group. Number of internal calls received by agents in the skill group. Number of seconds spent on internal calls received by agents in the skill group. The total number of internal calls agents in the skill group placed on hold at least once. Total number of seconds completed internal calls were placed on hold by agents in the skill group. Total number of AutoOut (predictive) calls completed by agents in the skill group. Total talk time, in seconds, for completed AutoOut (predictive) calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call.
HandledCallsTime Today
IncomingCallsHeldToday
IncomingCallsHeldTimeToday
InternalCallsHeld Today
InternalCallsHeld TimeToday
AutoOutCallsToday
AutoOutCallsTalk TimeToday
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-13
Chapter 11 Statistics
SkillGroup Object
Table 11-2
Definition Total handle time, in seconds, for completed AutoOut (predictive) calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed AutoOut (predictive) calls that agents in the skill group have placed on hold at least once. Total number of seconds AutoOut (predictive) calls were placed on hold by agents in the skill group. Total number of outbound Preview calls completed by agents in the skill group. Total talk time, in seconds, for completed outbound Preview calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed outbound Preview calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of completed outbound Preview calls that agents in the skill group have placed on hold at least once. Total number of seconds outbound Preview calls were placed on hold by agents in the skill group. Total number of agent reservation calls completed by agents in the skill group.
AutoOutCallsHeld Today
AutoOutCallsHeld TimeToday
PreviewCallsToday
PreviewCallsTalk TimeToday
PreviewCallsTime Today
PreviewCallsHeld Today
PreviewCallsHeld TimeToday
ReservationCalls Today
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-14
Release 8.0(1)
Chapter 11
Table 11-2
Definition Total talk time, in seconds, for completed agent reservation calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent begins after call work for the call. The time includes hold time associated with the call. Total handle time, in seconds, for completed agent reservation calls handled by agents in the skill group. The value includes the time spent from the call being initiated to the time the agent completes after call work time for the call. The time includes hold time associated with the call. The total number of agent reservation calls that agents in the skill group have placed on hold at least once. Total number of seconds agent reservation calls were placed on hold by agents in the skill group. Total number of supervisor call barge-ins completed in the skill group. Total number of supervisor call intercepts completed in the skill group. Total number of supervisor call monitors completed in the skill group. Total number of supervisor call whispers completed by agents in the skill group. Total number of emergency calls completed by agents in the skill group. The number of calls queued to the skill. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. The total queue time, in seconds, of calls queued to the skill group. This field is set to 0xFFFFFFFF when this value is unknown or unavailable. The longest queue time, in seconds, of all calls queued to the skill group. This field is set to 0xFFFFFFFF when this value is unknown or unavailable.
ReservationCalls TimeToday
ReservationCalls HeldToday
ReservationCalls HeldTimeToday
CallsQTimeToday*
LongestCallQToday*
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-15
Chapter 11 Methods
SkillGroup Object
* This statistic is available for TDM switches only. It is not valid for Unified CCE. ** This statistic is available for Unified CCE only or Network Queuing.
Methods
Table 11-3 lists the SkillGroup object methods.
Table 11-3 SkillGroup Object Methods
Method GroupStatistics DumpProperties EnableSkillGroupStatistics GetElement GetNumProperties GetPropertyName GetValue GetValueInt (C++) GetValueIntObj (Java) GetValueString IsValid SetValue
Description Disables skill group statistic messages. See Chapter 7, CtiOs Object. Enables skill group statistic messages. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object. See Chapter 7, CtiOs Object.
DisableSkillGroupStatistics
The DisableSkillGroupStatistics method requests that sending real-time statistics to the skillgroup object be stopped.
Syntax
C++:int DisableSkillGroupStatistics(Arguments & args) COM:HRESULT DisableSkillGroupStatistics (IArguments * args, int * errorCode) VB: DisableSkillGroupStatistics (args As CTIOSCLIENTLib.IArguments, errorCode As Long) Java:int DisableSkillGroupStatistics(Arguments args) .NET:CilError DisableSkillGroupStatistics(Arguments args)
Parameters
args If this method is called in C++, Java, or .NET via the session object in monitor mode with the special SkillGroupStats filter, the args parameter has two required values for PeripheralId and SkillGroupNumber. See the Remarks section for a code example. Otherwise, this parameter is not used. errorCode An output parameter (return parameter in VB) that contains an error code, if any.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-16
Release 8.0(1)
Chapter 11
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
The CTI OS server sends skillgroup statistics in an OnSkillGroupStatisticsUpdated event. If this request is successful, the OnNewSkillGroupStatistics event is no longer received. The following is a C++ code example where the args parameter contains values for PeripheralID and SkillGroupNumber.
Arguments & argsStatBroadcast = Arguments::CreateInstance(); argsStatBroadcast.AddItem(CTIOS_SKILLGROUPNUMBER, intSG); argsStatBroadcast.AddItem(CTIOS_PERIPHERALID, m_periphID); m_pSkGrStatSession->DisableSkillGroupStatistics ( argsStatBroadcast ); argsStatBroadcast.Release();
DumpProperties
See Chapter 7, CtiOs Object for a description of the DumpProperties method.
EnableSkillGroupStatistics
The EnableSkillGroupStatistics method requests that real-time statistics be sent to the skillgroup object. In an agent mode application, this request is usually made through the agent object (see Chapter 10, Call Object). If the argument array is empty, then statistics for all skillgroups are enabled. This is useful when a monitoring application needs to view all statistics without having to enumerate and loop over each statistic to enable it.
Syntax
C++:int EnableSkillGroupStatistics(Arguments & args) COM:HRESULT EnableSkillgroupStatistics (IArguments * args, int * errorCode) VB: EnableSkillgroupStatistics (args As CTIOSCLIENTLib.IArguments, errorCode As Long) Java:int EnableSkillGroupStatistics(Arguments args) .NETCilError EnableSkillGroupStatistics(Arguments args)
Parameters
args If this method is called via the session object in monitor mode with the special SkillGroupStats filter, the args parameter has two required values for PeripheralId and SkillGroupNumber. See the Remarks section for a code example. Otherwise, this parameter is not used. errorCode An output parameter (return parameter in VB) that contains an error code, if any.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
11-17
Chapter 11 Methods
SkillGroup Object
Return Value
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
CTI OS Server sends skillgroup statistics in an OnSkillGroupStatisticsUpdated event. The following is a C++ code example where the args parameter contains values for PeripheralID and SkillGroupNumber.
Arguments & argsStatBroadcast = Arguments::CreateInstance(); argsStatBroadcast.AddItem(CTIOS_SKILLGROUPNUMBER, intSG); argsStatBroadcast.AddItem(CTIOS_PERIPHERALID, m_periphID); m_pSkGrStatSession->EnableSkillGroupStatistics ( argsStatBroadcast ); argsStatBroadcast.Release();
GetElement
See Chapter 7, CtiOs Object for a description of the GetElement method.
GetValue Methods
See Chapter 7, CtiOs Object for descriptions of the GetValue, GetValueInt, GetValueList, and GetValueString methods.
IsValid
See Chapter 7, CtiOs Object for a description of the IsValid method.
SetValue
See Chapter 7, CtiOs Object for a description of the SetValue method.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
11-18
Release 8.0(1)
CHAPTER
12
Helper Classes
The CTI OS Client Interface Library usesof several custom data structures. This chapter describes the CTI OS Helper Classes (data structures). The following helper classes are distributed with the Client Interface Library:
Arg. The Arg structure is the basic data type used in the CIL for any parameter included in methods or events. Objects of this type allow the CIL to be fully extensible and reusable. Arg supports many useful types including string, integer, Boolean, and Arguments array. Arg is the base class for the Arguments class. In most programming scenarios, programmers will not use Arg directly, but indirectly through the Arguments class. Arguments. The Arguments structure is used to maintain and send a set of key-value pairs between the CIL and CTI OS Server for events and requests. The Arguments array elements must all be of type Arg. The Arguments structure enables future growth of the CTI OS feature set, without requiring changes to the method call signature. CilRefArg. The CilRefArg class is a specialized subclass of Arg. It is used to store a reference to an object derived from CCtiOsObject (C++ only). For instance, it can hold reference to a CAgent, CCall, CSkillGroup, CCtiOsSession, or CWaitObject. CCtiosException. The CCtiosException class is used by CTI OS to provide detailed information when an exception occurs (C++ and Java only). When an exception is caught as CCtiosException, the programmer can query it for details such as error codes and error messages. CWaitObject. CWaitObject is a CIL object that derives from CtiOsObject. It is a utility class (available in all CILs except COM) that enables a thread to wait for one or more CTI events. The user can provide a list of events along with a wait timeout. Wait objects are created with the CreateWaitObject Session Object method and destroyed with the DestroyWaitObject Session Object method. Logger. The Logger class creates a Logger object and a LogManager object, if one does not already exist. Any object that needs to perform logging must instantiate the Logger class. The Logger class communicates with the singleton LogManager object, which acts as the centralized logging facility. The Logger class also defines tracing constants. LogWrapper. The LogWrapper class provides a default Logging mechanism. By default, the LogWrapper traces to the console. If you create the LogWrapper with a filename, then it traces to that file.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-1
Chapter 12
Arg Class
The Arg is a generic class used in parameters or return values in CIL methods. Information sent by CTI OS server to the CIL in an event is packed in an Arguments object where each element of the array is an object of type Arg. An Arg objects absolute data type is determined by the type of data it stores. The basic types an object can store are identified by the enumerated constants in Table 12-2. Arg class methods will do conversion between types whenever possible. For example, you can do a SetValue(25) and then do a GetValueString() which will return the string 25. You can also do a SetValue(25) and then do a GetValueIntObj which will return an Integer object containing the numeric value 25. However, if you call SetValue abc and try to retrieve it as an int, it will fail. Table 12-1 lists the available Arg class methods.
Table 12-1 Arg Class Methods
Method AddRef Clone CreateInstance DumpArg GetType GetValueInt GetValueUInt GetValueUInt GetValueUShort GetValueShort GetValueBool GetValueString SetValue
Description Increments the reference count for the data item. Creates an exact copy of the Arg object. Creates an Arg object. Builds a string containing the value stored in the Arg. Returns the type of the data stored in the argument (one of the values in Table 12-2). Returns the value stored in the argument.
In many scenarios, programmers will stick to Arguments (see the preceding section), which wraps many Arg methods and encapsulates a collection of Arg objects.
AddRef
The AddRef method increments the reference count for the data item. It is necessary to call this if you are storing a pointer to the item for some time (for example, if you plan to store and use Arguments received in an event handler after the event thread has returned to the calling code). When you are finished with the item, you must call the Release method or a memory leak will result.
Syntax
C++: unsigned long AddRef() COM: HRESULT AddRef() VB, Java, .NET: Not used
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-2
Chapter 12
Parameters
None.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. C++: The current reference count after the AddRef() call.
Clone
The Clone method allocates a new Arg in memory and copies its key, value, and type to the new instance. When using the C++ or COM CILs, it is important to release the object when it is no longer needed.
Syntax
C++: COM: VB: Java: .NET:
Arg & Clone() HRESULT Clone(/*[out, retval]*/ IArg** arg); Clone() as CTIOSCLIENTLib.IArg Arg Clone() Ojbect Clone()
Output Parameters
arg Pointer to an IArg instance that is a copy of the object.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: If successful, will return a reference to a new Arg object. If unsuccessful in C++ or VB, it will throw a CCtiosException with iCode set to E_CTIOS_ARGUMENT_ALLOCATION_FAILED. If unsuccessful in Java, it returns null but does not throw an exception.
CreateInstance
The CreateInstance method creates an object of type Arg class and sets the reference count of the object to 1. It is important to release the object when it is no longer in use in the program.
Syntax
C++:
static Arg& CreateInstance(); // static creation mechanism. static Arg& CreateInstance(Arg& arg); // static creation mechanism. static bool CreateInstance(Arg ** arg); // static creation mechanism, // alternate version COM: Wrapped by CoCreateInstance VB: Wrapped by New Java, .NET: Not available
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-3
Chapter 12
Parameters
arg (output) Pointer to the newly created Arg.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: Either a reference to the newly created Arg or a boolean indicating method success. If the methods not returning bool are unsuccessful, they will raise a CCtiosException with iCode set to E_CTIOS_ARGUMENT_ALLOCATION_FAILED.
Remarks
This method increments the Args reference count, so do not call AddRef(). However, you must call Release() after you are finished with the Arg.
DumpArg
The DumpArg method builds a string containing the value stored in the Arg. This involves doing any type conversion required to display the data as a string. For example, it will automatically convert an INTEGER type to a string that can be logged for debugging. In the event that a Arg object is actually an Arguments object, the string returned is the one built by Arguments.DumpArg, and thus enabled printing of nested Arguments structures.
Syntax
C++: string DumpArg() COM: HRESULT DumpArg([out,retval] BSTR* arg_string); VB: DumpArg() as String Java, .NET:Not available. Use the ToString method.
Parameters
arg_string The pointer to the string into which the contents of the Arg object will be written.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: A string containing the contents of the structure.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-4
Chapter 12
Syntax
COM, C++, Java: Use GetType. .NET: ArgDataType GetArgType()
Parameters
None.
Returns
int code for the type of value contained in this Arg.
GetType
The GetType method returns the type of the data stored by the Arg. See Table 12-2 for a list of possible types.
Syntax
C++: COM: VB: Java: .NET:
enumArgTypes GetType() HRESULT GetType(/*[out, retval]*/ int* type); GetType () as Integer int GetType() Use the GetArgType method.
Output Parameters
type Integer that receive the enumerated constant that identifies data type stored in IArg.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-5
Chapter 12
Others: Returns the enumerated value that identifies the data type stored in the Arg (see Table 12-2),
Table 12-2 enumArgTypes
Argument Type ARG_NOTSET ARG_INT ARG_UINT ARG_USHORT ARG_SHORT ARG_BOOL ARG_STRING ARG_ARGARRAY
Description Argument type not determined Signed integer Unsigned integer 2 bytes unsigned integer 2 bytes signed integer 1 byte integer Character string Variable length Arguments array
GetValue Methods
The GetValue method returns the value stored in the object. To extract a specific type of data you invoke the method designated for it. For more detail on GetValueArray, GetValueInt, and GetValueString, see the corresponding methods described in Chapter 7, CtiOs Object.
Syntax
C++:int GetValueInt();
unsigned int GetValueUInt(); unsigned shortGetValueUShort(); short GetValueShort(); string& GetValueString(); bool GetValueBool(); bool GetValueInt(int * value); bool GetValueUInt(unsigned int * value); bool GetValueUShort(unsigned short * value); bool GetValueShort( short * psVallue); bool GetValueBool( bool * value); bool GetValueString(string* value); COM: HRESULT GetValue(/*[out, retval]*/ VARIANT* value); VB: GetValue() as Variant VB: GetValue (key as String, value as Variant) as Boolean Java: Integer GetValueIntObj() Long GetValueUIntObj() Short GetValueShortObj() Integer GetValueUShortObj() Boolean GetValueBoolObj() String GetValueString() .NET:System.Boolean GetValueInt(out System.Int32 nValue) .NET:System.Boolean GetValueUInt(out System.Int64 nValue) .NET:System.Boolean GetValueShort(out System.Int16 nValue) .NET:System.Boolean GetValueUShort(out System.Int32 nValue) .NET:System.Boolean GetValueBool(out System.Boolean bValue) .NET:System.Boolean GetValueString(out System.String strValue)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-6
Chapter 12
Parameters
Value Output parameter of the specified type containing the value of the Arg. For COM, this value is of type VARIANT * whose type is one of the types listed in Table 12-2.
Table 12-3 Variant Types Supported by GetValue (COM)
Standard C++ Type Int Unsigned int Short Unsigned short Bool string, const string and char *
Return Values
C++
Methods taking no parameters, if successful, will return the value in the object; otherwise, they will raise a CCtiosException with iCode set to E_CTIOS_INVALID_ARGUMENT. The methods taking a pointer to the variable receiving the result will return true, if the method was able to get the value, otherwise, false. Java Returns null if method failed. .NET Returns false if method failed. COM If the method was able to set the variant type of the value (i.e., value->vt) to any of the types listed in Table 12-2, it returns the value in the appropriate field of the variant. Otherwise it returns VT_EMPTY.
Release
The Release method decrements the reference count for the data item. It is necessary to call Release when you are finished with a data item that has had its reference count incremented via CreateInstance or AddRef; otherwise, a memory leak will result.
Syntax
C++: unsigned long Release() COM: HRESULT Release() VB, Java, .NET: Not used
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-7
Chapter 12
Parameters
None.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. C++: The current reference count after the Release() call.
SetValue
The SetValue method sets the value in the Arg object.
Syntax
C++:bool SetValue( int value );
bool SetValue( unsigned int value ); bool SetValue( unsigned short value ); bool SetValue( short value ); bool SetValue( bool value ); bool SetValue( char * value ); bool SetValue( string& value); bool SetValue( const string& value); bool SetValue( Arg & value); COM: HRESULT SetValue(/*[in]*/ VARIANT * pVariant, /*[out,retval]*/ VARIANT_BOOL * errorcode ); VB: SetValue(value as Variant) as Boolean
Parameters
value The value of the specified type to assign to the Arg. For COM, this value is of type VARIANT * whose type is one of the types listed in Table 12-4.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-8
Chapter 12
Table 12-4
Variant Type VT_INT VT_UINT VT_I2 VT_UI2 VT_BOOL VT_BSTR VT_DISPATCH errorcode
Standard C++ Type Int Unsigned int Short Unsigned short Bool string, const string and char * Pointer to an IArg interface
An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
C++
If the method was able to set the value it returns true, otherwise it returns false.
COM, VB
If the method was able to set the value it returns VARIANT_TRUE. Otherwise, it returns VARIANT_FALSE. Java, .NET This method returns true if the method succeeds, otherwise false.
Arguments Class
The Arguments structure (class) provides key/value support to form a collection of values. Each value stored in an Arguments structure is associated with a key. To add an item, use the AddItem or SetValue method and pass a key and a value. The key must be a string or an enumerated value, and the value can be almost any type (i.e. all types supported by Arg). To retrieve the item, use the appropriate GetValue method with a key, and the value is returned. Keys are not case sensitive, and leading and trailing spaces are always removed from the key. Arguments also supports access by index. The index is useful for retrieving items sequentially, but may not be as fast as retrieval by key. The Arguments structures index is 1-based, to provide easier support for Visual Basic programmers. Internally, the Arguments structure uses a binary tree and other techniques to provide fast access to any item. Arguments can support a virtually unlimited number of key-value pairs, and supports nested Arguments structure as well.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-9
Chapter 12
Description Adds an item to an Arguments array. Increments the reference count for the data item. Deletes all elements from an Arguments array. Creates a copy of an Arguments array. Creates an Arguments array. Returns Arguments object as a string
Returns the value stored under a specified GetElement (also GetElementInt, index. GetElementUInt, GetElementUShort, GetElementShort, GetElementBool, GetElementString, GetElementArg, GetElementKey GetElementArgType) GetValue (also GetValueInt, GetValueUShort, GetValueShort, GetValueBool, GetValueUInt, GetValueString, GetValueArray, GetValueArg) IsValid NumElements Release RemoveItem SetElement SetValue Returns the value stored under a specified key.
Tests if a key is present in the current Arguments array. Returns the number of arguments in the current Arguments array,. Decrements the reference count for the data item. Removes an item from an Arguments array. Sets the value of an index. Sets the value of a key.
Usage Notes
When writing an application using the CTI OS SDK, the following sequence of steps in the program may produce a problem:
Programmer passes an Arguments array into a CTI OS SDK method (methodA) MethodA returns Programmer modifies the same Arguments array Programmer passes the modified Arguments array into another CTI OS SDK method (methodB)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-10
Chapter 12
When running the application, the call to methodA may behave as if it was passed the modified Arguments array. This is because many CTI OS methods simply place a pointer to the Arguments array on a queue of items to be sent to CTI OS server. When the same Arguments array is later modified, as in the preceding example, the pointer on the queue now points to the modified array and the modified array is sent to CTI OS server. A problem may occur depending on timing, as there are multiple threads involved: the thread pulling items off the queue and the thread modifying the Arguments array. If the queued message is sent to CTI OS before the Arguments array is modified, the problem will not occur. To avoid this problem, call the Clone method on the initial Arguments array and modify the copy rather than modifying the original. For example, the preceding example would change as follows:
Programmer passes an Arguments array (initialArray) into a CTI OS SDK method (methodA) MethodA returns modifiedArray = initialArray.Clone() Programmer modifies modifiedArray Programmer passes the modifiedArray into another CTI OS SDK method (methodB)
Syntax
C++:
bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool bool AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( AddItem( std::string& std::string& std::string& std::string& std::string& std::string& std::string& std::string& std::string& std::string& std::string& char char char char char char char char char char char * * * * * * * * * * * key, key, key, key, key, key, key, key, key, key, key, key, key, key, key, key, key, key, key, key, key, key, int value ); unsigned int value ); unsigned short value ); short value ); bool value ); char * pchar ); std::string& value ); Arg& value ); const Arg& value ); Arguments& value ); const Arguments& value);
int value ); unsigned int value ); unsigned short value ); short value ); bool value ); char * value ); std::string& value ); Arg& cArg ); const Arg& value ); Arguments& value ); const Arguments& value ); key, key, key, key, int value ); unsigned int value ); unsigned short value ); short value );
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-11
Chapter 12
bool AddItem( enum_Keywords key, bool value ); bool AddItem( enum_Keywords key, char * value ); bool AddItem( enum_Keywords key, std::string& value ); bool AddItem( enum_Keywords key, Arg& cArg ); bool AddItem( enum_Keywords key, const Arg& value ); bool AddItem( enum_Keywords key, Arguments& value ); bool AddItem( enum_Keywords key, const Arguments& value) COM: HRESULT AddItem(/*[in]*/ VARIANT *key, /*[in]*/ VARIANT *value, /*[out,retval]*/ VARIANT_BOOL success) As Boolean; VB: AddItem( Key as Variant, Value as Variant) Java, .NET:Not Applicable. Use the SetValue method.
Parameters
key Key name for the item to be added. value Value of the item to be added. success An output parameter (return parameter in C++ and VB) that contains a boolean indicating success or lack thereof.
Return Value
C++: Returns True in if the entry was successfully added, otherwise False. COM and VB: Standard return values are valid; see Chapter 3, CIL Coding Conventions.
Syntax
C++: unsigned long AddRef() COM: HRESULT AddRef() VB, Java, .NET: Not used
Parameters
None.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. C++: Current reference count.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-12
Chapter 12
Others: None.
Clear
The Clear method deletes all the elements from Arguments object.
Syntax
C++: COM: VB: Java, .NET:
void Clear() HRESULT Clear() Clear() void Clear()
Parameters
None.
Return Value
None.
Clone
The Clone method creates a copy of the Arguments structure. Because in C++ this method is implemented in the base class (Arg), it returns a reference to an Arg, but this is actually a reference to an Arguments array. Therefore, it is necessary to cast the return value of this method. The following C++ code sample shows this casting:
Arguments & argsCopy = (Arguments&) argsOrig.Clone ();
Syntax
C++: COM: VB: Java: .NET:
Arg & Clone() HRESULT Clone(/*[out, retval]*/ IArguments ** args); Clone() as CTIOSCLIENTLib.IArguments Arg Clone() object Clone()
Parameters
args An output parameter containing a pointer to an Arguments array that is a copy of the object.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-13
Chapter 12
Return Value
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: A reference to the Arg structure that is a copy of the object.
Syntax
C++:
static Arguments & CreateInstance() static bool CreateInstance(Arguments ** args) COM: Not exposed, called by CoCreateInstance. VB: Not exposed, called by New. Java, .NET:Not implemented.
Parameters
args A pointer to the newly created Arguments structure.
Return Value
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: Either a reference to the newly created Arguments structure or a boolean indicating method success.
Remarks
C++, COM: Internally this method increments the Args reference count, so do not call AddRef(). However, you must call Release() after you are finished with the Arg.
DumpArgs
The DumpArgs method builds a string showing all of the members of the Arguments structure in the form key1 = value1; key2 = value2;.... It is primarily used for debugging.
Syntax
C++: string DumpArgs() COM: HRESULT DumpArgs([out,retval] BSTR* VB: DumpArgs() as String Java, .NET:string DumpArgs()
arg_string);
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-14
Chapter 12
Parameters
arg_string The pointer to the string containing the contents of the Arguments array listing all of the key/value pairs in the format of key1 = value1; key2 = value2;....
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: A string containing the contents of the Arguments array listing all key/value pairs
GetElement Methods
The GetElement method is similar to GetValue, except that it uses an index value instead of a key. The index value is not related to the order in which items are added or removed. The order of items in Arguments is never guaranteed. This method is useful for sequentially iterating over all items in Arguments. The Index is 1-based. The Index should never be less than one or greater than NumElements. see also NumElements method. The GetElementKey returns the key of a given index.
Syntax
C++:
Arg& GetElement( int index ); bool GetElement( int index, Arg ** value); int GetElementInt( int index ); bool GetElementInt( int index, int * value); unsigned int GetElementUInt( int index ); bool GetElementUInt( int index, unsigned int * value); unsigned short GetElementUShort( int index ); bool GetElementUShort( int index, unsigned short * value ); short GetElementShort( int index ); bool GetElementShort( int index, short * value); bool GetElementBool( int index ); bool GetElementBool( int index, bool * value); std::string GetElementString( int index ); bool GetElementString( int index, std::string * value); Arguments& GetElementArg( int index ); bool GetElementArg( int index, Arguments ** key); std::string GetElementKey( int index ); bool GetElementKey( int nIndex, std::string * key); bool GetElementKey( int nIndex, int * key); COM: HRESULT GetElementKey(/*[in]*/ int index, /*[out]*/ BSTR * key); HRESULT GetElement(/*[in]*/ int index, /*[out]*/ VARIANT * value); VB: GetElement (Integer index, Variant value) GetElement (Integer index, String key) Java: Arg GetElement(int iIndex) Arguments GetElementArguments(int iIndex) Integer GetElementIntObj(int iIndex) Long GetElementUIntObj(int iIndex) Short GetElementShortObj(int iIndex) Integer GetElementUShortObj(int iIndex) Boolean GetElementBoolObj(int iIndex) String GetElementString(int iIndex) String GetElementKey(int iIndex) .NET: Boolean GetElement(System.Int32 iIndex, out Arg obArg)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-15
Chapter 12
Boolean GetElementInt(System.Int32 iIndex, out System.Int32 iValue ) Boolean GetElementUInt(System.Int32 iIndex, out System.Int64 nValue) Boolean GetElementUShort(System.Int32 iIndex, out System.Int32 nValue) Boolean GetElementShort(System.Int32 iIndex, out System.Int16 nValue) Boolean GetElementBool(System.Int32 iIndex, out System.Boolean bValue) Boolean GetElementString(System.Int32 iIndex, out System.String strValue) Boolean GetElementArguments(System.Int32 iIndex, out Arguments argArguments) Boolean GetElementKey(System.Int32 iIndex, out System.String strKey)
Parameters
value An output parameter containing the value of the member at the specified index. key An output parameter containing the key of the member at the specified index. index An input parameter containing an index into the Arguments array.
Return Value
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: Returns either the value at the index specified independently from its key, or a boolean indicating success or failure.
GetValue Methods
The GetValue methos return the value stored under a key. The existence of a key can be tested using IsValid. Keys are not case sensitive. Leading and trailing spaces are always removed from the key. For more detail on GetValueArray, GetValueInt, and GetValueString, see the corresponding methods described in Chapter 7, CtiOs Object.
Syntax
C++:
Arg& GetValue( enum_Keywords eKey ); bool GetValue( enum_Keywords key, Arg ** value ); Arg& GetValue( std::string& key); bool GetValue( std::string& key, Arg ** value); Arg& GetValueArg( std::string& key); bool GetValueArg( std::string& key, Arg ** value); int GetValueInt( enum_Keywords key); /*throws exception*/ bool GetValueInt( enum_Keywords key, int * value); unsigned int GetValueUInt( enum_Keywords key); bool GetValueUInt( enum_Keywords key, unsigned int * value);
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-16
Chapter 12
unsigned short GetValueUShort( enum_Keywords key); bool GetValueUShort( enum_Keywords key, unsigned short * value); short GetValueShort( enum_Keywords key); bool GetValueShort( enum_Keywords key, short * value); bool GetValueBool( enum_Keywords key); bool GetValueBool( enum_Keywords key, bool * value); std::string GetValueString( enum_Keywords key); bool GetValueString( enum_Keywords key, std::string * value); int GetValueInt( std::string& key); /*throws exception*/ bool GetValueInt( std::string& key , int * value); unsigned int GetValueUInt( std::string& key ); bool GetValueUInt( std::string& key , unsigned int * value); unsigned short GetValueUShort( std::string& key ); bool GetValueUShort( std::string& key , unsigned short * value); short GetValueShort( std::string& key ); bool GetValueShort( std::string& key , short * value); bool GetValueBool( std::string& key ); bool GetValueBool( std::string& key , bool * value); std::string GetValueString( std::string& key ); bool GetValueString( std::string& key , std::string * value); Arguments& GetValueArray( std::string& key ); bool GetValueArray( std::string& key , Arguments ** value); Arguments& GetValueArray( enum_Keywords key ); bool GetValueArray( enum_Keywords key , Arguments ** value); Arg& GetValue( char * key ); bool GetValue( char * key, Arg ** value); Arguments& GetValueArray( char * key ); bool GetValueArray( char * key, Arguments ** value); int GetValueInt( char * key ); bool GetValueInt( char * key, int * value); unsigned int GetValueUInt( char * key ); bool GetValueUInt( char * key, unsigned int * value); unsigned short GetValueUShort( char * key ); bool GetValueUShort( char * key, unsigned short * value); short GetValueShort( char * key ); bool GetValueShort( char * key, short * value); bool GetValueBool( char * key ); bool GetValueBool( char * key, bool * value); std::string GetValueString( char * key ); bool GetValueString( char * key, std::string * value); Arg& GetValueArg( char * key ); bool GetValueArg( char * key, Arg ** value); COM: HRESULT GetValue(/*[in]*/ BSTR key, /*[out, retval]*/ VARIANT * pVvalue); HRESULT GetValueInt(/*[in]*/ VARIANT *key, /*[out, retval]*/ int *value); HRESULT GetValueString(/*[in]*/ VARIANT *key, /*[out, retval]*/ BSTR *value); HRESULT GetValueArray(/*[in]*/ VARIANT *key, /*[out, retval]*/ IArguments **pArguments); HRESULT GetValueBool(/*[in]*/ VARIANT *key, /*[out, retval]*/ VARIANT_BOOL * value); VB: GetValue (Key as String) as Variant GetValue(key As Variant) As Arg GetValueArray(key As Variant) As Arguments GetValueBool(key As Variant) As Boolean GetValueInt(key As Variant) As Long GetValueString(key As Variant) As String Java: Arg GetValue(int iKey) Arg GetValue(String sKey) Arguments GetValueArray(int iKey)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-17
Chapter 12
.NET:
Arguments GetValueArray(String sKey) Integer GetValueIntObj(int iKey) Integer GetValueIntObj(String sKey) Long GetValueUIntObj(int iKey) Long GetValueUIntObj(String sKey) Short GetValueShortObj(int iKey) Short GetValueShortObj(String sKey) Integer GetValueUShortObj(int iKey) Integer GetValueUShortObj(String sKey) Boolean GetValueBoolObj(int iKey) Boolean GetValueBoolObj(String sKey) String GetValueString(int iKey) String GetValueString(String sKey) Boolean GetValue(System.String sKey, out Arg obArg) Boolean GetValueInt(System.String sKey, out System.Int32 nValue) Boolean GetValueUInt(System.String sKey, out System.Int64 nValue ) Boolean GetValueShort(System.String sKey, out System.Int16 nValue) Boolean GetValueUShort(System.String sKey,out System.Int32 nValue) Boolean GetValueBool(System.String sKey, out System.Boolean bValue) Boolean GetValueString(System.String sKey, out System.String strValue) Boolean GetValueArray(System.String sKey, out Arguments arArguments) Boolean GetValue(Enum_CtiOs eKey, out Arg obArg) Boolean GetValueInt(Enum_CtiOs eKey, out System.Int32 nValue) Boolean GetValueShort(Enum_CtiOs eKey, out System.Int16 nValue) Boolean GetValueUShort(Enum_CtiOs eKey, out System.Int32 nValue) Boolean GetValueBool(Enum_CtiOs eKey, out System.Boolean bValue) Boolean GetValueString(Enum_CtiOs eKey, out System.String strValue) Boolean GetValueArray(Enum_CtiOs eKey, out Arguments arArguments)
Parameters
An enumerated keyword (see Appendix A, CTI OS Keywords and Enumerated Types) or a string specifying the keyword of the value to be retrieved.
Return Values
In C++, the two-parameter version returns a boolean indicating success or failure. The one- parameter version returns the value and throws an exception upon failure. COM returns an HRESULT. See also Chapter 3, CIL Coding Conventions. Java methods return a null object if the method fails.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-18
Chapter 12
Remarks
Visual Basic's Integer type is a 16-bit integer. However, the GetValueInt method returns a 32-bit integer. Thus, in Visual Basic the return type for GetValueInt is actually a Visual Basic type Long. Visual Basic Programmers can use the GetValueInt method and receive the return value as an Integer, and Visual Basic will perform an implicit cast. However, if the value retrieved is a 32-bit integer, an overflow error will occur. To resolve this error, it is recommended that you use a 32-bit integer (Long). Those methods that do not return a bool indicating success or failure will throw a CtiosException if the method fails. The most common reasons for failure are NULL key or element with specified key not found.
IsValid
The IsValid method returns True if the specified key exists in the current Arguments array, otherwise it returns False.
Syntax
C++:
bool IsValid( std::string& key ); bool IsValid( char * key ); bool IsValid( Arg& arg ); bool IsValid( enum_Keywords key ); COM: HRESULT IsValid( /*[in]*/ VARIANT* key, /*[out, retval]*/ VARIANT_BOOL* bIsvalid); VB: IsValid (key as string) as Boolean Java, .NET: boolean IsValid(int key) boolean IsValid(String key) boolean IsValid(Arg rArg)
Parameters
key/arg Either the key of the desired Arguments member or an Arg containing a string key. C++ and COM allow you to specify the key as string or enumerated (see Appendix A, CTI OS Keywords and Enumerated Types); all others expect the key as a string.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: True if key exists in the current Arguments array, otherwise False.
NumElements
The NumElements method returns number of elements stored in the current arguments array. This method is useful in combination with GetElement to implement a for loop to iterate over all values of an arguments array without knowing the keywords (those can be retrieved at the same time using GetElementKey).
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-19
Chapter 12
Syntax
C++: COM: VB: Java: .NET:
int NumElements(); HRESULT NumElements(/*[out, retval]*/ int * num_elements); NumElements as Integer int NumElements() int NumElements()
Parameters
num_elements Pointer to an integer value containing the number of elements in the Arguments array.
Return Value
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: Number of elements in arguments array.
Syntax
C++: unsigned long Release() COM: HRESULT Release() VB, Java, .NET: Not used
Parameters
None.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. C++: The current reference count after the Release() call.
RemoveItem
The RemoveItem method removes a value and its associated key from an arguments array. Subsequent attempts to access a value that was removed using RemoveItem will fail.
Syntax
C++:bool RemoveItem( std::string& key );
bool RemoveItem( char * key );
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-20
Chapter 12
bool RemoveItem( enum_Keywords key ); HRESULT RemoveItem(/*[in]*/ VARIANT* key, /*[out, retval]*/ VARIANT_BOOL* bSuccess); VB: RemoveItem ( key as Variant) as Boolean Java: boolean RemoveItem(int key) boolean RemoveItem(String key)
COM:
Parameters
key The key to use to locate and remove the item in the Arguments array. Leading and trailing spaces are always removed from the key.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: Returns true if the entry was located and removed.
Syntax
C++:
bool SetElement( int index, int value ); bool SetElement( int index, unsigned int value ); bool SetElement( int index, unsigned short value ); bool SetElement( int index, short value ); bool SetElement( int index, bool value ); bool SetElement( int index, std::string& value ); bool SetElement( int index, char * pchar ); bool SetElement( int index, Arg& value ); bool SetElement( int index, Arguments& value ); HRESULT SetElement(/*[in]*/ int index, /*[in]*/ VARIANT * value, /*[out,retval]*/ success); SetElement (index as Integer, value as Variant) as Boolean Not available. Not available.
Parameters
index The index at which the value is to be set. This index value is not related to the order in which items are added or removed. The order of items in Arguments is never guaranteed. This method is useful for sequentially iterating over all items in Arguments. Index is 1-based. Index should never be less than 1 or greater than NumElements (see above). C++ implements several overloaded methods for different value types, while COM and VB use Variants. value The associated value to be set in the element at the designated index.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-21
Chapter 12
success Output parameter (return parameter in C++ and VB) containing a boolean indicating success or failure.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: A boolean indicating success or failure.
SetValue
The SetValue method sets a value for a key. Keys are not case sensitive. Leading and trailing spaces are always removed from the key.
Syntax
C++:
bool SetValue( std::string& key, int value ); bool SetValue( std::string& key, unsigned int value ); bool SetValue( std::string& key, unsigned short value ); bool SetValue( std::string& key, short value ); bool SetValue( std::string& key, bool value ); bool SetValue( std::string& key, std::string& value ); bool SetValue( std::string& key, char * pchar ); bool SetValue( std::string& key, Arg& value ); bool SetValue( std::string& key, Arguments& value ); bool SetValue( std::string& key, const Arguments& value); bool SetValue( char * key, int value ); bool SetValue( char * key, unsigned int value ); bool SetValue( char * key, unsigned short value ); bool SetValue( char * key, short value ); bool SetValue( char * key, bool value ); bool SetValue( char * key, std::string& value ); bool SetValue( char * key, char * value ); bool SetValue( char * key, Arg& value ); bool SetValue( char * key, Arguments& value ); bool SetValue( char * key, const Arguments& value ); bool SetValue( enum_Keywords key, int value ); bool SetValue( enum_Keywords key, unsigned int value ); bool SetValue( enum_Keywords key, unsigned short value ); bool SetValue( enum_Keywords key, short value ); bool SetValue( enum_Keywords key, bool value ); bool SetValue( enum_Keywords key, std::string& value ); bool SetValue( enum_Keywords key, Arg& value ); bool SetValue( enum_Keywords key, const Arg& value ); bool SetValue( enum_Keywords key, Arguments& value ); bool SetValue( enum_Keywords key, const Arguments& cArguments); bool SetValue( enum_Keywords key, char * value ); COM: HRESULT SetValue(/*[in]*/ VARIANT* key, /*[in]*/ VARIANT* value,/*[out, retval]*/ VARIANT_BOOL* success); VB: SetValue (key as String, value as Variant) as Boolean Java: boolean SetValue(Arguments rArguments) boolean SetValue(int iKey, Arg rArg) boolean SetValue(String sKey, Arg rArg) boolean SetValue(int iKey, int iVal) boolean SetValue(String sKey, int iVal) boolean SetValue(int iKey, short nValue)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-22
Chapter 12
boolean SetValue(String sKey, short nValue) boolean SetValue(int iKey, String sValue) boolean SetValue(String sKey, String sValue) boolean SetValueUInt(int iKey, long lValue) boolean SetValueUInt(String sKey, long lValue) boolean SetValueUShort(int iKey, int iValue) boolean SetValueUShort(String sKey, int iValue) boolean SetValue(int iKey, Arg rArg) .NET: System.Boolean SetValueArguments(Arguments rArguments) System.Boolean SetValue(System.String sKey, System.Int32 iValue) System.Boolean SetValueUInt(System.String sKey, System.Int64 lValue) System.Boolean SetValue(System.String sKey, System.Int16 nValue) System.Boolean SetValueUShort(System.String sKey, System.Int32 iValue) System.Boolean SetValue(System.String sKey, System.String sValue) System.Boolean SetValue(System.String sKey, Arg rArg) System.Boolean SetValue(Enum_CtiOs eKey, System.Int32 iValue) System.Boolean SetValueUInt(Enum_CtiOs eKey, System.Int64 lValue) System.Boolean SetValue(Enum_CtiOs eKey, System.Int16 nValue) System.Boolean SetValueUShort(Enum_CtiOs eKey, System.Int32 iValue) System.Boolean SetValue(Enum_CtiOs eKey, System.Boolean bValue) System.Boolean SetValue(Enum_CtiOs eKey, System.String sValue) System.Boolean SetValue(Enum_CtiOs eKey, Arg rArg)
Parameters
key The key whose value is to be set. value The value to use in setting the element with the designated key. success Output parameter (return parameter in C++ and VB) containing a boolean indicating success or failure.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: A boolean indicating success or failure.
Remarks
The C++ methods overload several implementations for different value types and allow to specify a key via enumerated keywords (see Appendix A, CTI OS Keywords and Enumerated Types) as well as string. COM and VB use String keywords and Variants as values.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-23
Chapter 12
Description Returns the ARG_REFERENCE. Returns the UID of the contained CtiOsObject Returns the encapsulated pointer in the object. Encapsulates the pointer to CTI OS object into the CILRefArg object.
GetType
The GetType method returns the type of the data stored by the Arg. For a CilRefArg, this will always be ARG_REFERENCE.
Syntax
C++: COM: VB: Java: .NET:
enumArgTypes GetType() HRESULT GetType(/*[out, retval]*/ int* type); GetType () as Integer int GetType() Use the GetArgType method.
Output Parameters
type Integer that receives the enumerated constant that identifies the data type stored in Arg. In this case, that data type will be ARG_REFERENCE.
Return Values
COM: Default HRESULT return values. See Chapter 3, CIL Coding Conventions. Others: Returns the enumerated value that identifies the data type stored in the Arg (see Table 12-2). For CilRefArg, this will always be ARG_REFERENCE.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-24
Chapter 12
Syntax
String GetUniqueObjectID()
Parameters
None.
Return Values
If successful, it returns the unique objectID of the contained CtiOsObject. If no object is contained in the CilRefArg, it returns null.
Remarks
To obtain a unique object ID in C++, use bool GetValueString(string* pString).
GetValue
The GetValue method returns the reference to CTI OS object encapsulated in the CILRefArg.
Syntax
C++: CCtiOsObject * GetValue(): Java: CCtiOsObject GetValue(); .NET: System.Boolean GetValue(out CtiOsObject sValue)
Output Parameters
.NET:sValue Reference to the contained CtiOsObject derived class.
Return Values
C++: Returns NULL on failure. .NET: Returns false if the method fails. Java: Returns a null reference if the method fails.
SetValue
Sets the reference to the CTI OS Object in the CILRefArg.
Syntax
bool SetValue(CCtiOsObject * pObject);
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-25
Chapter 12
Input Parameters
pObject A pointer to a CtiOsObject to encapsulate (e.g. CCall, CAgent, etc.)
Return Values
If the method was able to set the reference it returns true. Otherwise, it returns false.
Description Class constructor. Returns the error code that generated the exception. Returns the error status that generated the exception. Returns a text string containing the description of the exception. Returns a text string containing the description of the exception, the code of an error and the status.
CCtiosException Constructor
The CCtiosException constructor initializes an object of type CCtiosException.
Syntax
C++, Java, .NET: CCtiosException(const char *pMsg, int iCode, int iStatus); C++: CCtiosException(const string& rstrMsg, int iCode, int iStatus);
Input Parameters
pMsg Pointer to string that holds a description of an error. iCode Number that identifies an error. iStatus Status of an error.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-26
Chapter 12
Return Values
None.
GetCode
The GetCode method returns the error code that generated the exception.
Syntax
C++, Java, .NET: int GetCode();
Parameters
None.
Return Values
Returns an integer error code that generated the exception. The errors are described in the Cilerror.h include file see also Appendix A, CTI OS Keywords and Enumerated Types.
GetStatus
The GetStatus method returns the error status that generated the exception.
Syntax
C++, Java, and .NET: int GetStatus ();
Parameters
None.
Return Values
Returns an integer error status that generated the exception.
GetString
The GetString method returns a text string containing the description of the exception.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-27
Helper Classes
Syntax
C++: const char* GetString(); Java, .NET: String GetString();
Parameters
None.
Return Values
Returns a text string containing the description of the exception.
What
The What method returns a text string containing the description of the exception, the code of an error, and the status.
Syntax
const char* What();
Parameters
None.
Return Values
Returns a text string containing the description of the exception, the code of an error, and the status.
CWaitObject Class
CWaitObject is a CIL object that derives from CtiOsObject. It is a utility class that enables a thread to wait for one or more CTI events. The user can provide a list of events along with a wait timeout. Wait objects are created with the CreateWaitObject Session Object method and destroyed with the DestroyWaitObject Session Object method.
Warning
You must not use a WaitObject instance within an event handler. Events are sent to desktop applications by a single thread in the CIL. If that thread is blocked while waiting for a specific event, the thread will deadlock and the event handler will not receive any more events.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
12-28
Release 8.0(1)
Chapter 12
Methods
Table 12-8 list the CWaitObject class methods.
Table 12-8 CWaitObject Class Methods
Description See Chapter 8, Session Object. See Chapter 8, Session Object. Returns a printable string listing the events in the CWaitObjects mask Sets a user provided pointer to an Arguments object that contains the list of events that the object will wait for. Gets the ID of the event that triggered the WaitOnMultipleEvents method to wake. Returns true if the specified event ID is in the list of events that the object will wait for. Set the list of events that the object will wait for. Waits for the events in the objects event mask for the specified time period or until one of the events occurs.
CreateWaitObject
See Chapter 8, Session Object.
DestroyWaitObject
See Chapter 8, Session Object.
DumpEventMask
The DumpEventMask method returns a printable string listing the events in the CWaitObjects mask.
Syntax
C++ , Java, .NET: string DumpEventMask();
Parameters
None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-29
Helper Classes
Return Values
A printable string object listing the events in the wait mask.
GetMask
The GetMask method gets the list of events that the CWaitObject will wait for.
Syntax
C++: Java, .NET:
bool GetMask(Arguments ** pMask); Arguments GetMask();
Parameters
pMask A pointer to an Arguments object pointer. GetMask will set the value of pMask to a pointer to an Arguments object that contains the event mask.
Return Values
If the method was able to get the mask it returns true; otherwise, it returns false. For Java and .NET, the method returns null upon failure.
GetTriggerEvent
The GetTriggerEvent method returns the ID of the last event in the CWaitObjects mask that triggered the WaitOnMultipleEvents method to wake.
Syntax
C++: EnumCTIOS_EventID GetTriggerEvent() Java: int GetTriggerEvent() .NET: EventID GetTriggerEvent()
Parameters
None.
Return Values
The ID of the event or eUnknownEvent if no event triggered a wakeup.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
12-30
Release 8.0(1)
Chapter 12
InMask
The InMask method checks to see if the specified event is in the mask of events that the CWaitObject will wait for.
Syntax
C++: Java, .NET:
bool InMask(int iEventId); boolean InMask(int iEventId);
Parameters
iEventId The enumerated event ID of the event to check for.
Return Values
If the event is in the mask it returns true. Otherwise, it returns false.
SetMask
The SetMask method sets the list of events that the CWaitObject will wait for.
Syntax
C++: bool SetMask(Arguments & args); Java, .NET: boolean SetMask(Arguments rArgs);
Parameters
args A reference to an Arguments object containing the list of events to wait for. The Arguments should contain values where the keys are Event1 through EventN and the values are the enumerated event IDs.
Return Values
The method returns true if it is able to set the. Otherwise it returns false.
WaitOnMultipleEvents
The WaitOnMultipleEvents method waits for the events in the CWaitObjects wait mask or returns if one of the events has not occurred after the specified timeout period. This is a one of method which returns after one of the specified events occurs.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-31
Helper Classes
Syntax
C++:
int WaitOnMultipleEvents(DWORD dwMilliseconds = INFINITE); Java, .NET: int WaitOnMultipleEvents(long iMilliseconds);
Parameters
Milliseconds The maximum length of time in milliseconds to wait before timing out. The default is INFINITE if called without arguments. For Java and .NET, a value of zero will cause this method to wait infinitely.
Return Values
The WaitOnMultipleEvents method returns one of the values listed in Table 12-9.
Table 12-9 WaitOnMultipleEvents Return Values
When Returned If one of the events in the mask occurred. If the timeout period elapsed. If unable to wait on the events in the mask.
Methods
Table 12-8 list the methods in the Logger class.
Table 12-10 CWaitObject Class Methods
Description Registers a listener with the LogManager. Gets the current trace mask. Trace masks define trace levels, such as TRACE_MASK_CRITICAL, which enables tracing for critical errors.See the LogManager Javadoc for a description of trace masks that define tracing
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
12-32
Release 8.0(1)
Chapter 12
Table 12-10
Description Creates a Logger object and also a LogManager object if one does not already exist. If one has already been created, it just gets a reference to the existing singleton LogManager object. Unregisters a listener from the LogManager. Sets the current trace mask. Send a trace message to the central LogManager with the specified trace mask.
Logger() Constructor
The Logger constructor creates a Logger object and also a LogManager object if one does not already exist. If a LogManager exists, the Logger gets a gets a reference to the existing singleton LogManager object.
Syntax
void Logger()
Parameters
None.
Return Values
None.
GetTraceMask
The GetTraceMask method gets the current trace mask.
Syntax
int GetTraceMask()
Parameters
None.
Return Values
An int containing the current trace mask.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-33
Helper Classes
SetTraceMask
The SetTraceMask method sets
Syntax
void SetTraceMask(int iTraceMask)
Parameters
iTraceMask The binary or combination of trace mask bits.
Note
Refer to Table B-5 for additional information on trace masks available in the .NET CIL.
Return Values
None.
AddLogListener
The AddLogListener method registers a listener with the LogManager.
Syntax
Java: void AddLogListener(ILogListener rListener) .NET: void AddLogListener (LogEventHandler rListener)
Parameters
rListener
Java: Reference to the new listener. .NET: Reference to a LogManager LogEventHandler delegate.
Return Values
None.
RemoveLogListener
The RemoveLogListener method unregisters a listener from the LogManager.
Syntax
Java: void RemoveLogListener(ILogListener rListener)
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
12-34
Release 8.0(1)
Chapter 12
Parameters
rListener
Java: Reference to the listener to be removed. .NET:Reference to a LogManager LogEventHandler delegate to be removed.
Return Values
None.
Trace
The Trace method sends a trace message to the central LogManager with the specified trace mask. If the trace mask set on the Logger contains all the bits in the trace mask that is passed into this method, the LogManager will send the trace string to all log listeners.
Syntax
int Trace(int iTraceMask, String sMessage)
Parameters
traceMask Trace mask for this message. traceMessage String containing trace message.
Return Values
int 0
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-35
Helper Classes
Methods
Table 12-8 list the LogWrapper class methods.
Table 12-11 LogWrapper Class Methods
Method Dispose GetMaxDaysBeforeExpire (.NET Only) GetMaxFileSize(.NET only) GetMaxNumberOfFiles (.NET Only) GetTraceMask LogWrapper() Constructor LogWrapper (String fileName) Constructor
Description Releases system resources used by the LogWrapper. (.NET only) Obtains the current log file age threshold beyond which the active log file will be rolled over into a new file regardless of file size Obtains the current log file size threshold beyond which a new file will be created. Obtains the current number of log files threshold beyond which older files will begin to be deleted. Gets the current trace mask. Creates a new LogWrapper object that writes tracing messages to System.Console.Out. Creates a new LogWrapper object that traces to the file specified in the fileName parameter.
LogWrapper (string, int, int, int) Creates a new LogWrapper object that traces to the file specified in the fileName parameter and sets all the provided tracing properties. If the corresponding parameter value is set to 0 then the default value will be used. SetMaxDaysBeforeExpire Changes the current log file age threshold beyond which the active log file will be rolled over into a new file regardless of file size Changes the current log file size threshold beyond which a new file will be created. Changes the current number of log files threshold beyond which older files will begin to be deleted. Sets the current trace mask. Parses TraceConfig.cfg and imports the settings contained within. Prints a string to the active trace file or to System.Console.Out if no active trace file exists.
SetMaxFileSize SetMaxNumberOfFiles
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
12-36
Release 8.0(1)
Chapter 12
LogWrapper() Constructor
The LogWrapper constructor creates a new LogWrapper object that writes tracing messages to System.Console.Out. This constructor also creates an instance of the LogManager, if one does not already exist. If you are using the .NET CIL, call the Dispose method to release system resources when the LogWrapper is no longer needed.
Syntax
void LogWrapper()
Parameters
None.
Return Values
None.
Syntax
void LogWrapper (string sFileName)
Parameters
sFileName Name of the trace file.
Return Values
None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-37
Helper Classes
Syntax
JAVA: void LogWrapper (string sFileName, long iMaxSize, int iArchives, int iFlushIntervalMs) .NET: void LogWrapper (string sFileName, int maxSizeKB, int maxFiles, int daysUntilExpiration)
Parameters
.NET and Java:sFfileName Name of the trace file. .NET:maxSizeKB Maximum size of a single trace file in KB (default is 2048 KB). Java:iMaxSize Maximum size of a single trace file. .NET:maxFiles Maximum number of trace files to create before older files are deleted (default is 4). Java:iArchives Maximum number of trace files stored. .NET:daysUntilExpiration Maximum age (in days) of the active trace file before it is rolled over to a new file regardless of size (default is 1 day) . Java:iExpires Number of days before the trace file expires. Java:iFlushIntervalMs Number of milliseconds before data is flushed to the trace file. There is no .NET counterpart for this parameter.
Return Values
None.
Syntax
void Dispose ()
Parameters
None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
12-38
Release 8.0(1)
Chapter 12
Return Values
None.
Syntax
int GetMaxDaysBeforeExpire ()
Parameters
None.
Return Values
Current age threshold.
SetMaxNumberFiles
The SetMaxNumberFiles method changes the current number of log files threshold beyond which older files will begin to be deleted. If the provided value is not greater than zero, the default value of 4 is used.
Syntax
.NET:void SetMaxNumberFiles (int maxFiles) Java:void SetMaxNumberFiles (int iArchives)
Parameters
maxTraceFiles New number of files threshold. If 0 is specified, the default value will be used
Return Values
None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-39
Helper Classes
Syntax
int GetMaxNumberFiles ()
Parameters
None.
Return Values
Current number of files threshold.
SetMaxDaysBeforeExpire
The SetMaxDaysBeforeExpire method changes the current log file age threshold beyond which the active log file will be rolled over into a new file regardless of file size.
Syntax
Java:void SetMaxDaysBeforeExpire (int iExpires) .NET:void SetMaxDaysBeforeExpire (int maxDaysUntilExpiration)
Parameters
maxDaysUntilExpiration New age threshold. If value is not greater than zero, the default value of 1 is used.
Return Values
None.
ProcessConfigFile
The ProcessConfigFile method opens the default config file (TraceConfig.cfg) in the parent directory and updates LogWrapper trace settings with data from the config file.
Syntax
boolean ProcessConfigFile()
Parameters
None.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
12-40
Release 8.0(1)
Chapter 12
Return Values
Returns true if operation succeeded and false if unable to open theTraceConfig.cfg file.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
12-41
Helper Classes
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
12-42
Release 8.0(1)
CHAPTER
13
SilentMonitorManager Object
The SilentMonitorManager Object provides developers with an interface to silent monitor behavior. The SilentMonitorManager object exposes methods to perform all silent monitor tasks, such as starting, stopping and managing silent monitor sessions. The SilentMonitorManager object stores specific silent monitor session information as properties. The SilentMonitorManager object can be used in two different modes:
In Monitoring Mode, an application that wants to silent monitor conversation without being noticed by the calling parties must create a SilentMonitorManager object and set it mode to eSMMonitoringMode using the StartSMMonitoringMode method. In Monitored Mode, an application will accept requests to initiate silent monitor sessions to forward the voice conversations to the remote monitoring application. The application will create a SilentMonitorManager object and set the mode to eSMMonitoredMode using the StartSMMonitoredMode method.
For more information on these modes see the section Initiating and Ending a Silent Monitor Session in Chapter 4, Building Your Application.
Note
SilentMonitorManager Object methods and properties are not available in the Java or .NET CILs. SilentMonitorManager Object methods and properties are supported for use with Unified CCE only. SilentMonitorManager Object methods and properties are only supported for CTI OS based silent monitoring.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
13-1
Chapter 13 Properties
SilentMonitorManager Object
Properties
Table 13-1 lists the SilentMonitorManager object properties.
Table 13-1 SilentMonitorManager Object Properties
Description Heartbeat interval for the silent monitor session. Timeout for no activity. This property is only accessible via the GetIPPhoneInfo method. It contains all the information related to the IP Phone used by the application. TCP/IP port where monitored conversation will be sent for playback on system sound card. This property is only accessible via the GetSessionInfo method. It contains all the information related to the current active silent monitor session. Mode in which the manager object will operate (Table 13-2). If SetIPPhoneInfo is used, SMManagerMode attempts to use the information provided.
Note
MediaTerminationPort
INT
SessionInformation
ARGUMENTS
SMManagerMode
SHORT
Table 13-2
SMManagerMode Values
Numeric Value -1
The manager accept request for silent 0 monitor sessions and forward voice to the monitoring application. The manager can make requests to remote client to start a silent monitor session and send voice. 1
eSMMonitoringMode
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
13-2
Release 8.0(1)
Chapter 13
Methods
Table 13-3 lists the SilentMonitorManager object methods.
.
Table 13-3
Description Establishes a silent monitor session and immediately starts sending audio. Retrieves the information of the IP Phone used by the client application. Gets its information from the RTP events that occur when RTP streams are created and modified.
Retrieves the information related to the current silent monitor session. Retrieves a list of all active Silent Monitor sessions. Determines if the device/agent is a target being monitored. Saves the information of the IP Phone used by the client application. Sends a silent monitor session start request to a targeted client. Puts the SilentMonitorManager in Monitored mode. Puts the SilentMonitorManager in Monitoring mode. Sets the SilentMonitorManager mode to eSMModeNotSet. If a silent monitor session is active at this time, the session is terminated. The StartSilentMonitorRequest () method is used to initiate a CTI OS based silent monitor session. When this method is called and Cisco Unified Communications Manager based silent monitor is configured, it returns E_CTIOS_INVALID_SILENT_MONITOR_M ODE. Stops the active silent monitor session.
StartSilentMonitorRequest
StopSilentMonitorRequest
1. GetIPPhoneInfo and SetIPPhone Info are used by SilentMonitorManager in the following manner. The RTPStartedEvent arrives and SilentMonitorManager uses SetIPPhoneInfo to store the IP address and port carried in the RTPStartedEvent. The SilentMonitorStartRequestedEvent arrives and SilentMonitorManager uses GetIPPhoneInfo to retrieve the stored IP address and port to build the packet filter. SetIPPhoneInfo is used internally by the SilentMonitorManager to populate IP phone information carried in RTPStartedEvents.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
13-3
Chapter 13 Methods
SilentMonitorManager Object
In VB, you can ignore these parameters altogether. For example, you can treat the line:
StartSMMonitoringMode([reserved_args As IArguments]) As Long
as follows:
StartSMMonitoringMode()
AcceptSilentMonitoring
The AcceptSilentMonitoring method establishes the silent monitor session requested by the OnSilentMonitorRequestedEvent and immediately starts sending audio to the monitoring client. This method should only be used if the parameter DoDefaultMessageHandling was set to False when the subscriber handled the OnSilentMonitorRequestedEvent event.
Syntax
C++: int AcceptSilentMonitoring(Arguments & args ); COM: HRESULT AcceptSilentMonitoring ( /*[in]*/ IArguments * args, /*[out,retval]*/ int *
errorcode );
Parameters
args Arguments array that contains the parameters listed in Table 13-4:
Table 13-4 AcceptSilentMonitoring Arguments Array Parameters
Keyword
Type
Description Unique Object ID of the object being monitored. TCP/IP address of the monitoring application. TCP/IP port of the monitoring application.
UNSIGNED Unique identifier for the Silent SHORT Monitor Session. INT INT Heartbeat interval for the silent monitor session. Timeout for no activity.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
13-4
Release 8.0(1)
Chapter 13
Table 13-4
Keyword OriginatingServerID
Type STRING
Description TCP/IP Address:Port of the CTI OS server from which the request originated. Client Identification of the monitoring application. When this parameter is set to True, it instructs the SilentMonitorManager to immediately start sending audio and establish the silent monitor session. If this value is set to False, it instructs the SilentMonitorManager to not send voice and not to establish the silent monitor session. It is then the responsibility of the subscriber to report this status accordingly.
STRING BOOLEAN
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
GetIPPhoneInfo
The GetIPPhoneInfo method gets the information about the client application IP Phone.
Note
This method is not necesary to use and defaults to figuring out the information to sniff packets from.
Syntax
C++: Arguments * GetIPPhoneInfo(void); COM: HRESULT GetIPPhoneInfo ( /*[out,retval]*/ IArguments ** IPPhoneInfo); VB: GetIPPhoneInfo () as CTIOSCLIENTLIB.IArguments
Parameters
None.
Return Value
This method returns an arguments array that contain the parameters listed in Table 13-5.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
13-5
Chapter 13 Methods
SilentMonitorManager Object
Table 13-5
Description IP Address of the IP Phone to be used by the client application. Audio transmission bit rate Number of milliseconds of audio stored in a packet. One of the following values that indicates the direction of voice flow between the calling party and the called party: 0: Input 1: Output 2: Bidirectional
RTPTypea
SHORT
One of the following values that indicates the type of RTP messages between the calling party and the called party: 0: audio 1: video 2: data
EchoCancelation
SHORT
One of the following values that indicates whether the echo cancellation feature is enabled on this IP Phone: 0: Off 1: On
PayLoadType
SHORT
GetSessionInfo
The GetSessionInfo method retrieves the information related to the current silent monitor session.
Syntax
C++: Arguments * GetSessionInfo(Arguments & args) ; COM: HRESULT GetSessionInfo ( /*[in]*/ IArguments * args, /*[out,retval]*/ IArguments *
SMSessionInfo ); VB: GetSessionInfo (ByVal args as CTIOSCLIENTLIB.IArguments) As CTIOSCLIENTLIB.IArguments
Parameters
args Arguments array that contains one of the parameters listed in Table 13-6:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
13-6
Release 8.0(1)
Chapter 13
Table 13-6
Keyword SMSessionKey
Description Unique silent monitor session Object ID of the target object that is being monitored. Unique Object ID of the target object that is being monitored.
MonitoredUniqueObjectID
Return Values
This method returns an arguments array containing the key/value pairs listed in Table 13-7:
Table 13-7 GetSessionInfo Return Arguments Array Parameters
Keyword SMSessionKey
Type UNSIGNED SHORT SHORT INT STRING STRING STRING INT STRING INT
Description Unique silent monitor session Object ID of the target object that is being monitored. One of the ISilentMonitorEvent status codes in Table 6-87. Reserved. Specifies the audio mode bitmask. Agent ID or DeviceID of the target being monitored. Unique Object ID of the target object being monitored. TCP/IP Address of the monitored IP Phone. ID of the peripheral associated with the agent and IP phone. TCP/IP Address of the system receiving audio. TCP/IP port on which receiving system is listening for audio.
GetSMSessionList
The GetSMSessionList method returns an Arguments array that contains the parameters listed in Table 13-10. All parameters are required.
Syntax
C++: Arguments * CIL_API GetSMSessionList(void) COM: HRESULT GetSMSessionList([out,retval] IArguments **pIArguments ); VB: GetSMSessionList () as CTIOSCLIENTLIB.IArguments
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
13-7
Chapter 13 Methods
SilentMonitorManager Object
Parameters
None.
Return Values
Arguments array that contains a list of all Silent Monitor sessions. The current version only allows one active session, so the main use for this function is to use the NumElements method on the returned arguments array to determine if the current SilentMonitorManager is in an active Silent Monitor session.
IsMonitoredTarget
The IsMonitoredTarget method determines if the specified device or agent is a target that is being monitored.
Syntax
C++: bool IsMonitoredTarget (Arguments & args); COM: HRESULT IsMonitoredTarget ( /*[in]*/ IArguments * args, /*[out,retval]*/ VARIANT_BOOL * bMonitored ); VB: IsMonitoredTarget () As Boolean
Parameters
args Arguments array that contains the parameter listed in Table 13-8:
Table 13-8 IsMonitoredTarget Arguments Array Parameter
Keyword MonitoredUniqueObjectID
Type STRING
Return Value
True if the specified MonitoredUniqueObjectID corresponds to the monitored agent or device; False otherwise.
SetIPPhoneInfo
The SetIPPhoneInfo method saves the information of the IP Phone used by the client application. The SetIPPhoneInfo() function is used to set the specific ip address/port to sniff on for RTP packets on the agent system. If you call StartSMMonitoredMode() and have not called SetIPPhoneInfo() then the silent monitor library sniffs on all IP interfaces on the agent system and figures out the correct interface. If you set a specific ip address/port to sniff with SetIPPhoneInfo(), then the silent monitor library sniffs for RTP packets on the agent system only on that specific address and specific port. SetIPPhoneInfo() is used externally by the Agent control to set a specific address for silent monitor sniffing.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
13-8
Release 8.0(1)
Chapter 13
Note
AgentState control only uses SetIPPhoneInfo in a Citrix environment. Since the IP address/port that the phone is connected to is not local to the Citrix server, the AgentState control uses terminal services APIs to figure out the IP address of the real network interface.
Syntax
C++: int SetIPPhoneInfo (Arguments & args); COM: HRESULT SetIPPhoneInfo ( /*[in]*/ IArguments * args, /*[out,retval]*/ int *
errorcode ); VB: SetIPPhoneInfo (ByVal args as CTIOSCLIENTLIB.IArguments ) As Long
Parameters
args Arguments array that can contain the parameters listed in Table 13-9:
Table 13-9 SetIPPhoneInfo Arguments Array Parameters
Description IP Address of the IP Phone to be used by the client application. Audio transmission bit rate. Number of milliseconds of audio stored in a packet. One of the following values that indicates the direction of voice flow between the calling party and the called party: 0: Input 1: Output 2: Bidirectional
RTPType (optional)
SHORT
One of the following values that indicates the type of RTP messages between the calling party and the called party: 0: audio 1: video 2: data
EchoCancelation (optional)
SHORT
One of the following values that indicates whether the echo cancellation feature is enabled on this IP Phone: 0: Off 1: On
PayLoadType (optional)
SHORT
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
13-9
Chapter 13 Methods
SilentMonitorManager Object
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
StartSilentMonitorRequest
The StartSilentMonitorRequest method sends a silent monitor session start request to a targeted client
Syntax
C++: int StartSilentMonitorRequest (Arguments & args, unsigned short * SMSessionKey ); COM: HRESULT StartSilentMonitorRequest ( /*[in]*/ IArguments * args, /*/[out]*/ unsigned
short * SMSessionKey, /*[out,retval]*/ int * errorcode );
Parameters
args Arguments array that contains the parameters listed in Table 13-10. All parameters are required.
Table 13-10 StartSilentMonitorRequest Arguments Array Parameters
Type STRING
Description AgentID or DeviceID of the target to monitor. Specify either an AgentID or a DeviceID, not both, ID of the peripheral associated with the agent or device. TCP/IP address of the system receiving audio. TCP/IP port where the monitoring application is listening for audio. Interval in seconds between heartbeats. Seconds elapsing before a Silent Monitor session is aborted because of no heartbeats received from the monitored peer.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
13-10
Release 8.0(1)
Chapter 13
SMSessionKey An output parameter that contains the unique key to the started silent monitor session. This key must be used to perform any action on the currently active silent monitor session. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
Remarks
If the DeviceID is used, there must be an agent associated with the device. The session will timeout if there is no agent logged into the device. An established silent monitor session will end if the associated agent logs out of the device. E_CTIOS_INVALID_SILENT_MONITOR_MODE is returned when SilentMonitorManager.Start SilentMonitorRequest() is called when Cisco Unified Communications Manager based silent monitor is configured. If an application using a version of the CIL that is older than 7.2(1) connects to a 7.2(1) CTI OS Server configured for Cisco Unified Communications Manager Based Silent Monitor and calls SilentMonitorManager.StartSilentMonitor Request(), the application receives an OnSilentMonitorStatusReportEvent carrying a status code of eSMStatusCCMSilentMonitor.
StartSMMonitoredMode
The StartSMMonitoredMode method puts the SilentMonitorManager in Monitored mode.
Syntax
C++: int StartSMMonitoredMode (Arguments & args ); COM: HRESULT StartSMMonitoredMode ( /*[in]*/ IArguments * args, /*[out,retval]*/ int *
errorcode );
Parameters
args Arguments array that contains the following parameters listed in Table 13-11:
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
13-11
Chapter 13 Methods
SilentMonitorManager Object
Table 13-11
Keyword Cluster
Type ARRAY
Description An array of IP addresses and/or hostnames for silent monitor services. These silent monitor service should all be members of the same cluster to ensure that the agent's calls can be silently monitored. The CIL randomly chooses one silent monitor service to which to connect. See the CTI OS System Manager's Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted for information pertaining to silent monitor service cluster configuration. If Cluster is not present, this parameter can be used to specify the address of a silent monitor service to which to connect. The port on which the silent monitor services listen for connections. The QoS setting for the connection. The interval in milliseconds between heartbeat packets. The number of heartbeats that can be missed before the connection is aborted.
SMSAddr
STRING
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
StartSMMonitoringMode
The StartSMMonitoringMode method puts the SilentMonitorManager in Monitoring mode.
Syntax
C++: int StartSMMonitoringMode (Arguments & args ); COM: HRESULT StartSMMonitoringMode ( /*[in]*/ IArguments * args, /*[out,retval]*/ int *
errorcode ); VB: StartSMMonitoringMode (ByVal args as CTIOSCLIENTLIB.IArguments) As Long
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
13-12
Release 8.0(1)
Chapter 13
Parameters
Table 13-12 StartSMMonitoringMode Arguments Array Parameters
Keyword SMSAddr
Type STRING
Description A string that contains the address of the silent monitor service used to decode and play back the agents phone call. The port on which the silent monitor services listen for connections. The QoS setting for the connection. The interval in milliseconds between heartbeat packets. The number of heartbeats that can be missed before the connection is aborted.
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
StopSilentMonitorMode
The StopSilentMonitorMode method sets the SilentMonitorManager mode to eSMModeNotSet. If a silent monitor session is active at the time, the session will be terminated.
Syntax
C++: int StopSilentMonitorMode (Arguments & reserved_args ); COM: HRESULT StopSilentMonitorMode ( /*[in]*/ IArguments * reserved_args,
/*[out,retval]*/ int * errorcode ); VB: StopSilentMonitorMode (ByVal reserved_args as CTIOSCLIENTLIB.IArguments) As Long
Parameters
reserved_args Not currently used, reserved for future use. errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
13-13
Chapter 13 Methods
SilentMonitorManager Object
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
StopSilentMonitorRequest
The StopSilentMonitorRequest method stops the Active silent monitor session.
Syntax
C++: int StopSilentMonitorRequest (Arguments & args); COM: HRESULT StartSilentMonitorRequest ( /*[in]*/ IArguments * args, /*[out,retval]*/
int * errorcode ); VB: StopSilentMonitorRequest (ByVal args as CTIOSCLIENTLIB.IArguments) As Long
Parameters
args Arguments array that contains the parameter listed in Table 13-13:
Table 13-13 StopSilentMonitorRequest Arguments Array Parameters
Keyword SMSessionKey
errorcode An output parameter (return parameter in VB) that contains an error code from Table 3-2 in Chapter 3, CIL Coding Conventions.
Return Values
Default CTI OS return values. See Chapter 3, CIL Coding Conventions.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
13-14
Release 8.0(1)
A P P E NDIX
The enumeration of keywords is presently only available in the C++ CIL. For each string keyword, a corresponding enumerated keyword exists. The enumerated keyword is the same name, preceded by the prefix ekw. For example, the AgentID string keyword is mapped to the enumerated keyword ekwAgentID.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
A-1
The complete set of standard keywords used in CTI OS can be found in the C++ header file ctioskeywords.h, located in the \Distribution\cpp\Include directory on the CTI OS toolkit media.
Enumerated Types
CTI OS employs enumerated types to provide symbolic names for commonly recurring values.
In C++, Visual Basic, and COM, these are presented as enumerated types. In Java, special interfaces are used to simulate enumerated types. See the next section, Java Interfaces. For C++ CIL using static libraries: the complete set of enumerated types is located in the C++ header file cilmessages.h, located in the C:\Program Files\Cisco Systems\CTIOS Client\CTIOS Toolkit\Win32 CIL\Include directory on the CTI OS toolkit media. For COM (Visual Basic and Visual C++): the complete set of enumerated types is located in the CTIOSClient Type Library, which is compiled into the CTIOSClient.dll file, located in the C:\Program Files\Cisco Systems\CTIOS Client\CTIOS Toolkit\Win32 CIL\COM Servers and Activex Controls directory on the CTI OS toolkit media.
The complete set of enumerated types and their values can be found in the following locations:
In the Java CIL, the CTIOS_Enums interface contains the Java CIL enumerated types. See the Java CIL Javadoc file for more information. In the .NET CIL, the CtiOs_Enums class contains the .NET CIL enumerated types.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
A-2
Release 8.0(1)
Appendix A
Java Interfaces
The Java CIL handles the C++ CIL enums is through the use of interfaces. The custom application can then either implement those interfaces and use the static data members without referencing them with the interface name first, or it can access those members through referencing. By convention, the name of the Java interface is the same as the enum tag but with the enumCTIOS_ prefix substituted with CtiOs_I. So for example, the following C++ CIL enum
enum enumCTIOS_AgentState { eLogin = 0, eLogout = 1, eNotReady = 2, eAvailable = 3, eTalking = 4, eWorkNotReady = 5, eWorkReady = 6, eBusyOther = 7, eReserved = 8, eUnknown = 9, eHold=10 };
A Java CIL application can access those defined values in one of two ways; either by implementing the interface, as shown:
public class MyAgent extends CtiOsObject implements CtiOs_IAgentState { .................................................
public int MyLogin(Arguments rArguments) { .................................. //Access eLogin directly rArguments.AddItemInt( "agentstate", eLogin ); .................................. } }
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
A-3
or by referencing as follows:
public class MyAgent extends CtiOsObject { ................................................. public int MyLogin(Arguments rArguments) { .................................. rArguments.AddItemInt( "agentstate", CtiOs_IAgentState.eLogin ); .................................. } }
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
A-4
Release 8.0(1)
A P P E NDIX
CTI OS Logging
This appendix discusses a few issues related to CTI OS logging.
The default filename is CtiosClientLog. Log files are created using the convention <TraceFileName>.<Windows user name>.mmdd.hhmmss.log. The files are created in the current directory of the executing program, such as the directory into which the Agent Desktop is installed. You can provide a fully qualified path for the TraceFileName if you wish to store the files in a different location. For example, setting the following value causes the log files to be stored in the directory C:\Temp, using the naming convention CtiosClientLog.<Windows user name>.mmdd.hhmmss.log.
C:\Temp\CtiosClientLog
Client trace files are formatted in ASCII text that you can open with a conventional text editor such as Notepad.
Copy the tracing executable, ctiostracetext.exe, from the distribution media to the folder in which your application is located. Open a command window and register the tracing mechanism: ctiostracetext.exe /regserver
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
B-1
CTI OS Logging
Trace levels for client processes, such as the Agent Desktop phone are stored under the following registry key:
[HKEY_LOCAL_MACHINE\SOFTWARE\Cisco Systems, Inc.\CTIOS Tracing] "TraceFileName"="%HOMEPATH%\\CtiOsClientLog" "TraceMask"=dword:00000000 "MaxDaysBeforeExpire"=dword:00000007 "MaxFiles"=dword:00000005 "MaxFileSizeKb"=dword:00000800 "FlushIntervalSeconds"=dword:0000001e "TraceServer"="C:\\Program Files\\Cisco Systems\\CTIOS Client\\CTIOS Toolkit\\Win32 CIL\\Trace\\CTIOSTraceText.exe"
Note
CTI OS Tracing can be configured globally for the entire machine (using the TraceMask setting on HKLM) and per user (using the TraceMask setting on HKCU).
Warning
If the TraceMask not set or if it is set incorrectly, the application's performance may be negatively affected. The preferred setting for normal operation is 0x40000307.
Parameter FlushIntervalSeconds
Description Maximum number of seconds before the trace mechanism transfers data to the log file.
Recommended Value 30
MaxDaysBeforeExpire
Maximum number of days before a 7 log file is rolled over into a new log file regardless of the size of the file.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
B-2
Release 8.0(1)
Appendix B
Parameter MaxFiles
Description Maximum number of log files that may exist in the log file directory before the logging mechanism starts overwriting old files.
Recommended Value 5
MaxFileSizeKb
Maximum size of a log file in 2048 kilobytes. When a log file reaches the maximum size, a new log file is created. 0x40000307 Bit mask that determines the categories of events that are traced.
TraceMask
ILogEvents
This interface must be implemented by a class interested in receiving Java CIL LogEvents. It only has one method.
void processLogEvent(LogEvent event)
LogEvent
A custom application that is interested in receiving LogEvents will receive an object of this type whenever a log message is generated. This class extends the Java EventObject, and has one public method:
Table B-2
Method getDescription
String getDescription()
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
B-3
CTI OS Logging
Logger
A custom application that is interested in firing or handling its own LogEvents, can create an instance of this class.
Table B-3 Logger Method Description
Description Public constructor of the Logger object. Lets the custom app fire a LogEvent Gets the trace mask. Determines if a certain trace mask is set. Subscribe to receive LogEvents. Unsubscribe from receiving LogEvents.
Syntax
Logger() int Trace(long nMsgTraceMask, String message) long GetTraceMask() boolean IsTraceMaskEnabled(long nMsgTraceMask) void addLogListener(ILogEvents logEvents
LogEventsAdapter
This is a wrapper class around the Logger facility. A custom application that is interested in tracing but doesnt want to implement its own ILogEvents interface can create an instance of this class. The adapter class provides two constructors, a default one that will automatically log to the Java console and one that takes in an output filename.
Table B-4 LogEventsAdaptor Descriptions
Description Public constructor Start receiving LogEvents Stop receiving LogEvents Handles a LogEvent Does some cleanup
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
B-4
Release 8.0(1)
Appendix B
Syntax
LogEventsAdapter() LogEventsAdapter(String fileName) void startLogging() void stopLogging() void processLogEvent(LogEvent e) void finalize()
LogWrapper() - Creates a new LogWrapper object that writes tracing messages to System.out. LogWrapper(string sFileName) - Creates a new LogWrapper object that writes trace messages to the file specified in sFileName. LogWrapper(string sFileName, long iMaxSize, int iArchives, int iExpires, int iFlushIntervalMs) Creates a new LogWrapper object that traces to the file specified in sFileName and sets all the tracing properties provided:
The maximum size of a single trace file (the default is 2048 Kb) The maximum number of trace files before LoggerManager deletes the oldest file (the default
is 4). If a developer deploys an application and then wants to debug it in the field, they need a way to change the trace mask from the default level if necessary to provide more information for debugging.
Note
You will also need to provide a way to adjust the trace mask at runtime. If you encounter problems, Cisco personnel will need to see this log file in order to assist you with your problem. See the Java CIL Javadoc file for information on the LogWrapper class and its associated methods.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
B-5
CTI OS Logging
logFileName - Name of file in which to write trace events fileMaxSize - The maximum size of the log file numberArchivesFiles - Maximum number of log files that may exist in the log file directory before the logging mechanism starts overwriting old files numberDaysBeforeFileExpired - Maximum number of days before a log file is rolled over into a new log file regardless of the size of the file.
The following code snippet creates an instance of the LogWrapper class that writes trace events to MyLogFile.txt. When MyLogFile.txt reaches 2048 KB, a new log file is created. The Logger creates a maximum of 20 log files in the log file directory before overwriting existing files . After 10 days, the log file is rolled over into a new log file regardless of its size.
// Create a LogWrapper. This will create a file and start // listening for log events to write to the file. String logFileName = "MyLogFile.txt"; int fileMaxSize = 2048; int numberArchivesFiles = 20; int numberDaysBeforeFileExpired = 10; m_logWrapper = new LogWrapper(logFileName, fileMaxSize, numberArchivesFiles, numberDaysBeforeFileExpired);
Step 2
In your application, write trace events. The following example traces a message at the given trace level for the given method. Set the trace level to the desired trace mask. Trace masks are defined in the Logger class. See Table B-1 for a list of available trace mask values.
protected internal static void MyTrace ( int traceLevel, string methodName, string msg) { if ( m_logger.IsTraceMaskEnabled(traceLevel) ) { string tracsMsg = string.Format("{0}: {1}", methodName, msg) ; m_logger.Trace(traceLevel, msg) ; } }
The CTI Toolkit Combo Desktop .NET sample application included with the CTI OS toolkit shows how to use the CIL's LogWrapper class in the context of a complex softphone application. Table B-1 lists the trace masks available in the .NET CIL.
Table B-5 Trace Masks in .NET CIL
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
B-6
Release 8.0(1)
Appendix B
Purpose Mask for major events. Mask for general events and requests. Mask for method entry and exit. Mask for very low lever operations.
TRACE_MASK_ALWAYS TRACE_MASK_CRITICAL TRACE_MASK_WARNING TRACE_MASK_EVT_REQ_HIGH TRACE_MASK_EVT_REQ_HIGH_PARM TRACE_MASK_EVT_REQ_AVG TRACE_MASK_EVT_REQ_AVG_PARM TRACE_MASK_EVT_REQ_LOW TRACE_MASK_EVT_REQ_LOW_PARM TRACE_MASK_METHOD_HIGH TRACE_MASK_METHOD_HIGH_LOGIC TRACE_MASK_METHOD_HIGH_LOGIC TRACE_MASK_METHOD_AVG_LOGIC TRACE_MASK_METHOD_LOW TRACE_MASK_METHOD_LOW_LOGIC TRACE_MASK_METHOD_MAP TRACE_MASK_ARGS_METHODS TRACE_MASK_ARGS_LOGIC TRACE_MASK_PACKETS_METHODS TRACE_MASK_PACKETS_LOGIC TRACE_MASK_SERIALIZE_DUMP TRACE_MASK_SOCKETS_DUMP TRACE_MASK_THREADING TRACE_MASK_CONNECTION
0x00 0x01 0x02 0x04 0x08 0x10 0x20 0x40 0x80 0x0100 0x0200 0x0400 0x0800 0x1000 0x2000 0x4000
Always print. Critical error. Warning. High important events/requests. High important events/requests. Average important events/requests. Average important events/requests. Low important events/requests. Low important events/requests. High visibility method entry/exit trace. High visibility method logic trace. Internal visibility method entry/exit trace. Internal visibility method logic trace. Helper object visibility method entry/exit trace. Helper object visibility method logic trace. Map access.
0x01000000 Method entry/exit for Arguments objects. 0x02000000 Logic trace for Arguments objects. 0x04000000 Method entry/exit for packets objects. 0x08000000 Logic trace for packets objects. 0x10000000 Memory dump of serialize buffer. 0x20000000 Memory dump of sockets buffer. 0x40000000 Threading tracing on or off. 0x80000000 Connection tracing on or off.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
B-7
CTI OS Logging
Step 2
Write a method to handle log events. This method can trace the log events to a file, if desired. For example:
public virtual void ProcessLogEvent(Object eventSender, LogEventArgs Evt) { // Output the trace String traceLine = Evt.Description; // Check that tracing is enabled for this tracelevel if ( m_logger.IsTraceMaskEnabled(traceLevel) ) { WriteTraceLineToFile(traceLine); } }
Step 3
Create a log listener to handle trace events. In the following example, the AddLogListener method registers the LogEventHandler delegate as a listener for trace events. The LogManager will send trace events to the method that you pass to the LogEventHandler. In the following example, the LogManager will send trace events to the ProcessLogEvent method created in Step 2.
m_log.AddLogListener(new LogManager.LogEventHandler(ProcessLogEvent));
Note
The LogManager only calls the method passed as a parameter to the LogEventHandler for a particular trace if the trace level for that trace is enabled. You can use the IsTraceMaskEnabled method in the Logger class to determine whether or not a trace level is enabled.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
B-8
Release 8.0(1)
Appendix B
NumberDaysBeforeFileExpired Maximum number of 1 days before a log file is rolled over into a new log file regardless of the size of the file. NumberArchivesFiles Maximum number of log files that may exist in the log file directory before the logging mechanism starts overwriting old files. Maximum size of a log file in kilobytes. When a log file reaches the maximum size, a new log file is created. 5
FileMaxSize
2048
TraceMask
0x40000307 Bit mask that determines the categories of events that are traced.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
B-9
CTI OS Logging
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
B-10
Release 8.0(1)
A P P E NDIX
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
C-1
Port Build Project Using your development environment utilities port your current application build project to the new platform compatible with Microsoft C\C++ 8.0(1) and made all the adjustments required by the vendor. For example, to port your Microsoft Visual C++ 7.0 *.vcproj project file to the new Microsoft Visual C++ 8.0 *.vcproj format, open the *.dsp project selecting Open\ Project from the File command menu in Microsoft Visual Studio .NET 2005. For details refer to Microsofts Visual Studio.NET help on Visual C++ Porting and Upgrading (http://msdn.microsoft.com/library/default.asp?url=/library/en-us/vccore/html/_vc_porting_home.asp)
Step 2
Set New Compilation Parameters See Project Settings for Compiling and Linking, page 4-15.
Note
Port Build Project Using your development environment utilities port your current application build project to the new platform compatible with Visual Basic .NET and made all the adjustments required by migration tool. For example, to port the Microsoft Visual Basic .NET2003*.vbproj project to the new Microsoft Visual Basic .NET.vbproj format, open the *.vbproj project selecting Open\ Project from the File command menu in Microsoft Visual Studio .NET 2005. For details refer to Microsofts Visual Studio.NET help on Visual Basic Concepts.
Step 2
Verify references to COM CIL Primary Interop Assemblies After the migration toll finishes the new ported project must include references to the COM CIL interop assemblies provided in the CTI OS 8.0(1) Toolkit. Verify that the following assemblies are listed under the project references: Cisco.CTIOSCLIENTLib.dll and Cisco.CTIOSARGUMENTSLib.dll. If these assemblies are not in your reference list remove those included by the migration tool and set the two assemblies described before
Step 3
Apply Ported Code Changes for Visual Basic .NET Following the migration report apply all the suggested changes such that you code complies with the new Visual Basic.NET 2005 programming language. Be aware that there are deprecated classes in .NET 2.0 that your application may have to change to accommodate the new classes.
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
C-2
Release 8.0(1)
Appendix C
Migrating From CTI OS 7.1(x) or 7.2(x) Migrating a Visual Basic 6.0 to Use COM CIL
Step 4
Port Build Project Using your development environment utilities port your current application build project to the new platform compatible with Visual Basic .NET and made all the adjustments required by migration tool. For example, to port the Microsoft Visual Basic .NET 2005*.vbproj project to the new Microsoft Visual Basic .NET 2005.vbproj format, open the *.vbproj project selecting Open\ Project from the File command menu in Microsoft Visual Studio .NET. For details refer to Microsofts Visual Studio.NET help on Visual Basic Concepts
Step 2
Verify references to the CTI OS ActiveX Controls RCW Assemblies After the migration toll finishes the new ported project must include references to the CTI OS ActiveX controls RCW assemblies provided in the CTI OS 8.0(1) Toolkit. Verify that the assemblies for the controls used in your application are listed under the project references. For each control in references there must be two entries for each control one prefixed with AxInterop.ControlName and Interop. ControlName. The RCW starting with AxIntero.p is responsible for hosting the ActiveX control on the .NET Windows Form and the RCW prefixed with Interop. Allows the Visual Basic .NET code to use the properties and methods exported by the control.
Step 3
Apply Ported Code Changes for Visual Basic .NET Following the migration report applies all the suggested changes such that you code complies with the new Visual Basic.NET 2005 programming language.
Step 4
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
C-3
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
C-4
Release 8.0(1)
INDEX
A
AcceptSilentMonitoring SilentMonitorManager object method 13-4 Accessing properties and parameters ActiveX Softphone Controls AddItem Arguments class method Agent mode
2-4 9-9, 9-10 9-14 9-15 9-15 9-16 12-11 5-1 3-8
AgentStateCtl softphone control Alternate call object method AlternateCtl softphone control Answer call object method AnswerCtl softphone control Architecture Arg class Clone
2-1 12-2
10-9 5-23
GetValueType
12-8
12-6
QueryAgentState ReportBadCallLine
Clear Clone
12-13 12-13 12-14 12-15 12-16 12-19 12-19 12-20 12-21 12-22 3-8 1-2
StartMonitoringAgent
StartMonitoringAllAgentTeams
StopMonitoringAllAgentTeam
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
IN-1
Index
B
BadLineCtl softphone control Button controls
5-8 5-24 3-11 5-24
12-13
10-10 10-11
ClearConnection call object method Client Interface Library (CIL) Clone Arg class method Coding conventions COM CIL (C++)
5-24 12-3 12-13 2-1
C
CallAppearanceCtl softphone control call object methods Alternate Answer Clear
10-8 10-9 10-10 10-11 10-6
3-1
Conference call object method ConferenceCtl softphone control Connect session object method CreateInstance Arg class method
12-3
12-14 8-7
CreateSilentMonitorManager session object method CreateWaitObject session object method CTI-enabled applications CTI OS
10-16 1-1 8-8
GetCallContext
10-13
10-14
advantages architecture
1-5 1-5
application architecture
2-1 10-22
SendDTMFSignal SetCallData
10-23
benefits
1-6
10-24
CTIOS Toolkit Agent Desktop (see CD) Built with CTI OS ActiveX Controls 4-9 CWaitObject class methods DumpEventMask GetMask SetMask
12-30 12-30 12-29
10-26
GetTriggerEvent
12-31
CCtiosException class CIL error codes CIL object model GetType GetValue SetValue Clear
3-3 2-3
12-31
D
DestroySilentMonitorManager session object method 8-9 DestroyWaitObject session object method
8-9
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
IN-2
Release 8.0(1)
Index
DisableSkillGroupStatistics Session object method DisableSkillGroupStatistics SkillGroup object method 11-16 Disconnecting from CTI OS Server Disconnect session object method DumpArg Arg class method DumpArgs Arguments class method
12-14 12-29 12-4 4-29 8-10
8-10
CILRefArg class method GetValue Arguments class method CILRefArg class method GetValueType Arg class method Grid controls
5-8 12-6
12-24
12-16 12-25
5-34
E
EmergencyAssistCtl softphone control
5-34 8-11
H
Hold call object method HoldCtl softphone control
10-15 5-34
EnableSkillGroupStatistics Session object method EnableSkillGroupStatistics SkillGroup object method 11-17 Event flow
1-2
I
IAgentEvents interface ICallEvents interface
6-53 6-20 12-31
G
GetAgentState agent object method GetArgType
12-4 10-13 9-14
IsAgent agent object method IsAgent session object method ISessionEvents interface
8-19 6-2
9-19 8-21
10-14
ISkillGroupEvents interface.
6-76
IsMonitoredTarget SilentMonitorManager object method 13-8 IsSupervisor session object method IsValid Arguments class method
12-19 8-22
GetIPPhoneInfo SilentMonitorManager object method 13-5 GetMask CWaitObject class method GetMonitoredCall agent object method
12-30 9-15 9-15 8-20
GetObjectFromObjectID session object method GetSessionInfo SilentMonitorManager object method 13-6 GetSkillGroups agent object method
9-16
L
Login agent object method Login button Logout button
5-9 9-22 9-20
GetSMSessionList SilentMonitorManager object method 13-7 GetTriggerEvent CWaitObject class method GetType Arg class method
12-5 12-30
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
IN-3
Index
M
MakeCall agent object method MakeCallCtl softphone control messages RTP_STARTED_EVENT RTP_STOPPED_EVENT Monitor mode
2-4 6-82 6-83 9-23 5-35 10-16
6-39 6-40
OnCallReachedNetworkEvent event
6-41 6-83
OnCallRTPStopped event
OnCallServiceInitiatedEvent event OnCallStartRecordingConf event OnCallStopRecordingConf event OnCallTransferred event OnClearCallConf event
6-43 6-45
OnClearConnectionConf event
N
Not Ready button NumElements Arguments class method
12-19 5-10
OnConsultationCallConf event
O
Object Interface Framework Object properties setting
3-9 6-22 2-3
OnGlobalSettingsDownloadConf event
6-20
OnAgentPrecallAbortEvent event OnAgentPrecallEvent event OnAgentStatistics event OnAnswerCallConf event OnCallBegin event OnCallCleared event
6-23 6-25 6-27 6-58 6-22 6-23
OnAlternateCallConf event
OnMonitorModeEstablished event
6-48 6-49
6-17
OnCallConferenced event OnCallDataUpdate event OnCallDelivered event OnCallDiverted event OnCallEnd event OnCallFailed event OnCallHeld event
6-34
OnCallConnectionCleared event
6-29 6-31
6-93
OnSetAgentModeEvent event
6-32
OnCallDequeuedEvent event
6-33
OnSilentMonitorSessionDisconnected event
6-35
6-88
OnCallEstablished event
6-36 6-37
OnSilentMonitorStartedEvent event
OnCallOriginated event
OnSilentMonitorStopRequestedEvent event
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
IN-4
Release 8.0(1)
Index
6-76
8-7
DestroySilentMonitorManager
8-9
8-9
6-53
GetObjectFromObjectID
8-21
Q
QueryAgentState agent object method
9-29
8-22
RequestDesktopSettings
8-25 8-26
8-24
R
Ready button
5-10 10-20 5-36
SetCurrentCall SetMessageFilter
SetCurrentSilentMonitor
8-28
8-27
Reconnect call object method ReconnectCtl softphone control RecordCtl softphone control Reference counting RemoveItem Arguments class method
2-5
session object methods GetCurrentSilentMonitor SetAgent session object method SetCallData call object method
8-25 9-33
8-19
5-42
RequestAgentTeamList agent object method RequestDesktopSettings session object method Request-response mechanism Retrieve call object method
1-3
9-31
SetSupervisorSilentMonitorMode session object method 8-28 Setting object properties Setting request parameters
3-9 3-9
S
screen pop
1-1 9-32 10-22
SendChatMessage agent object method SendDTMFSignal call object method Session object methods DisableSkillGroupStatistics EnableSkillGroupStatistics session object methods Connect
8-5 8-3 8-10 8-11
SetSupervisorSilentMonitorMode
8-28
GetSessionInfo
GetSMSessionList IsMonitoredTarget
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted Release 8.0(1)
IN-5
Index
SetIPPhoneInfo
StartSilentMonitorRequest SilentMonitorManager object method 13-10 StartSMMonitoredMode SilentMonitorManager object method 13-11 StartSMMonitoringMode SilentMonitorManager object method 13-12 Static libraries
10-26 4-14 5-40
SingleStepConference call object method SingleStepTransfer call object method SkillGroup object methods
11-16 11-16 11-17
StopMonitoringAgent agent object method StopMonitoringAllAgentTeams agent object method 9-39 StopRecord call object method
10-29
9-37 9-38
DisableSkillGroupStatistics EnableSkillGroupStatistics Snapshot call object method softphone controls AgentStateCtl AlternateCtl AnswerCtl BadLineCtl ButtonCtl ChatCtl
5-8 5-19
StopSilentMonitorMode SilentMonitorManager object method 13-13 StopSilentMonitorRequest SilentMonitorManager object method 13-14 Subscribing for events in C++
4-17 9-39 5-41
AgentStatisticsCtl
5-23 5-23 5-24 5-24
CallAppearanceCtl
5-29 5-32
T
Third-party call control
1-2 10-29 5-43
EmergencyAssistCtl
5-34
5-34
MakeCallCtl
U
UniqueObjectID
3-9
SkillgroupStatisticsCtl
5-40
SupervisorOnlyCtl
5-43
5-41
W
9-34 9-35
StartMonitoringAgent agent object method StartMonitoringAllAgentTeams agent object method 9-36 StartMonitoringCall agent object method StartRecord call object method
10-28
WaitOnMultipleEvents CWaitObject class method Work Not Ready button Work Ready button
5-10 5-10
12-31
9-37
CTI OS Developers Guide for Cisco Unified ICM/Contact Center Enterprise & Hosted
IN-6
Release 8.0(1)