GETTING STARTED
Introduction to AgentAssist
Architecture and Configuration
Glossary
FAQ
Release Notes
Recent Updates
Previous Versions

SET UP AgentAssist
AgentAssist Setup Guide
Sign Up for AgentAssist
Conversation Automation
Automations Board
Create a Bot
Add Multiple Bots
Create Use Cases
Overview
FAQs Setup
Create Dialog Tasks
Welcome Event
LLM and Generative AI
Access Custom Data in Agent AI Bot
Search AI
Agent Coaching
Playbook
Customizing the Agent AI Widget
Configure Auto Summarization with Custom Dialog Tasks
Feedback Settings
Widget Theming (Layout Customization)
Supported Languages

INTEGRATIONS
AgentAssist Integration with Third-Party Applications
Amazon Connect
Amazon Connect with AgentAssist Voice Installation Guide
Amazon Connect with AgentAssist Chat Using Custom CCP
Amazon Connect with AgentAssist – Voice via AWS Third Party Applications
Channels
Voice
Configure Voice Channel
Configure Speech Recognition
Chat
SmartAssist
Configure AgentAssist
Demos
Voice Demo
Chat Demo
Salesforce
OmniChannel
Omni-Channel Configuration - Chat
AgentAssist Configuration - Chat
Genesys CTI
AgentAssist Voice Integration
NICE-CTI
Kore Agent AI with Salesforce NICE CX-CTI
Demos
Voice Demo
Chat Demo
Zendesk
Set up AgentAssist for Zendesk
Genesys
AgentAssist Integration with Genesys - Manual Setup Instructions
Agent AI Integration with Genesys Cloud CX using Kore Data Table
Set Up AgentAssist for Genesys
Change AgentAssist Bot in Genesys
Integrate Kore.ai Bot on Genesys Cloud CX Messaging
ServiceNow
NICE MAX Desktop
Talkdesk
Twilio

AGENT EXPERIENCE
AgentAssist Widget
Bot Override and Automations

ANALYTICS
Conversation Logs
Dashboard
Agent AI ROI Analyzer (Beta)
APIs
Raw Data API v1
Raw Data API v2
Conversation Summary Trigger

Kore Agent AI with Salesforce NICE CX-CTI

Introduction

This document provides an overview of the setup and configuration process of the Kore Agent AI widget with NICE CX Telephony using the Salesforce NICE CX CTI package.

Use Case: Show voice transcripts and provide next best actions from a configured bot, on the Kore Agent AI widget to agents when they receive a phone call from a customer.

When a customer calls a NICE CX phone number, the call is received on the Salesforce NICE CTI interface. Based on the customer’s phone number, CTI rule matches the corresponding Salesforce object (Account/Contact/Case etc.) and displays to the agents. The incoming voice stream is shared with Kore Voice Gateway, which in turn generates transcripts of the voice stream and displays on the Agent AI widget embedded into the matched Salesforce object.

Prerequisites

  • The NICE CX Salesforce package installed in your Salesforce org.
  • NICE CX account set up and can receive calls on the Salesforce Service Console softphone.
  • NICE CX Studio installed on your device.
  • Agent Assist Hub enabled for your NICE CX account.
  • Kore AgentAssist for Salesforce installed on your Salesforce account. (Salesforce AppExchange > Search for “Agent AI By Kore.ai, Inc.”)
  • Have the AgentAssist bot credentials saved separately. You need the Widget URL, Bot ID, Client ID, Client Secret, Account ID, and SIP URI. Read Configure Voice Channel and Chat Channel for a walkthrough.

Shared Responsibilities

Activity Responsibility
CXOne Customer Kore.ai
NICE One Platform
ACD Configuration
  • Skills creation and mapping
  • Hours of Operation
  • Points of Contact
  • Campaign
  • Customization of Scripts and attaching to Number/Chat PoC
CXOne Studio Script
  • Import the voice script and customize (only if needed).
  • Edit the Nodes and provide the Customized Bot details in the script.
  • Provisioning the studio script template
Signal API Auth (only for chat)
  • Configure CXOne Authentication for accessing CXOne Signal API from Kore bot.
    Need signaling API key and secret.
Agent Assist Hub
  • Configure NICE Studio Agent Assist
Kore Agent AI Bot Configuration
  • Bot creation
  • Bot Credentials generation
Kore Bot Configuration Bot creation

Bot Credentials generation

Salesforce Org
Voice/Chat Configuration
  • Enabling NICE Calls/Chats on Salesforce with proper screen pop settings
Installing Kore Agent AI Package
  • Installing the package
  • Providing the package URL
Configuring Kore Agent AI Package
  • Validate prerequisite licenses
  • Configure Bot Details
  • Add NICE Signal Credentials (Only for Chat)
NICE CX Configure Salesforce Agent Settings, select Salesforce Object to embed Kore Agent AI widget.

Definitions

Section Key Definition Reference
Set up NICE AgentAssist Hub to stream voice to Kore Agent AI Agent AI URL The domain of the Agent AI.
Kore Agent AI  package setup and configuration AgentAssist Widget URL URL that points to the Agent AI widget.

For example, https://agentassist.kore.ai/koreagentassist-sdk-v3/UI/agentassist-iframe.html

Channels > Chat section of the Agent AI configuration portal.
Kore Agent AI package setup and configuration BotId A unique identifier assigned to a bot. Channels > Chat section of the Agent AI configuration portal.
Kore Agent AI package setup and configuration ClientId An identifier provided to a client application. Channels > Chat section of the Agent AI configuration portal.
Kore Agent AI package setup and configuration ClientSecret A secret key or password associated with the ClientId. Channels > Chat section of the Agent AI configuration portal.
Set up NICE AgentAssist Hub to stream voice to Kore Agent AI AccountID A unique identifier assigned to an account. Channels > Chat section of the Agent AI configuration portal.
Set up NICE AgentAssist Hub to stream voice to Kore Agent AI Kore Voice Gateway(KVG) For Saas in US region, value is savg-webserver.kore.ai

For on-prem, refer to the corresponding host. 

Region Specific URLs

Region Agent AI URL UXO URL WSS URL DNS
US https://agentassist.kore.ai https://platform.kore.ai  wss://savg-webserver.kore.ai @savg-us-prod-sbc-in-nlb-0d9a4c651955ff47.elb.us-east-1.amazonaws.com
JP https://agentassist-jp.kore.ai https://jp-platform.kore.ai  wss://jp-savg-audiosocket.kore.ai @savg-jp-prod-int-nlb-3989d946fc1ced3b.elb.ap-northeast-1.amazonaws.com

Set up Salesforce-NICE CTI package

Follow this article to install and configure the NICE CTI package on your Salesforce account.

Topics included in the above article:

  • Install Salesforce Agent
  • Install the Salesforce Agent Package
  • Assign Users to Your License
  • Enable Salesforce Agent in Lightning Experience
  • Configure Permission Sets For a Single User
  • Configure Permission Sets For Multiple Users
  • Configure the NICE CXone Call Center
  • Assign Users to the NICE CXone Call Center
  • Configure Softphone Layout
  • Assign Profiles to the Softphone Layout
  • Enable Click2Jack

Set up NICE AgentAssist Hub to stream voice to Kore Agent AI

This app will be used in studio script.

  1. Sign in to your NICE account with the username and password provided by the NICE customer support.
  2. Click the applications launcher button. A menu opens from the left side of the page.

  3. Click OTHERS > Automation & AI.

  4. Click Agent Assist Hub > Add Agent Assist App.

  5. Enter the name of the Agent Assist App in the AGENT ASSIST APP NAME field.
  6. Select Custom Agent Assist Endpoints.
  7. Click Next.

  8. Add the following settings with config parameters provided by the Kore.ai representative:
    1. Agent UI Option: Available by default
    2. App URL: {Agent AI URL}/integrations/nice/iframe/?params={scriptparams}
    3. App Title: Kore Agent AI (change as needed)
    4. Participants: Both
    5. Text Relay Endpoint: (only for chat) {Agent AI URL}/integrations/nice/relay/toKore

    6. Audio Relay Endpoint: {Kore Voice Gateway(KVG)}/audiosocket/nice?sipuri=<Bot SIP URI>&token=<Token>&botId=<Bot ID>&accountId=<Account ID>&agentassist=true
      1. Bot SIP URI: Channels > Voice section of the Agent AI configuration portal.

      2. Bot ID and Account ID: Channels > Chat section of the Agent AI configuration portal.

      3. Token: Create a JSON Web Token on jwt.io with the following details.
        1. Payload: {“appId”: <Bot Client ID>}
        2. Header: {“alg”: “HS256″,”typ”: “JWT”}
        3. Secret: Your Kore.ai Client Secret.
    7. Scroll down and add the following Configuration Parameters. (Only for Chat).

  9. Click Create

Kore Agent AI package setup and configuration

Set up AgentAssist feature

  1. Click the app launcher.

  2. Type “kore” in the search box and select Kore AgentAssist Feature Configuration from the displayed list.

  3. Click New from the top-right corner of the page.

  4. Type Test Configuration in the Configuration Name field.

  5. Select NICE inContact in the CTI Provider list.

  6. Select Active, and click Save.

Set up AgentAssist Configuration

  1. Click the app launcher.
  2. Type “config” in the search box and select Kore AgentAssist Configuration from the displayed list.

  3. Click New from the right-top corner of the page.
  4. Enter the required details.
    Note: AgentAssist URL, Bot ID, Client ID, and Client Secret can be fetched from the Agent AI configuration portal.
  5. Select Active and click Save.

Configure NICE CTI Data in Salesforce

  1. Click the app launcher in Salesforce, and then go to Salesforce Agent Settings.
  2. Sign in to your NICE CX account.
  3. Ensure the Store Salesforce Agent Script Variables setting is enabled in the Data Storage section.
  4. In the dropdown list, select a Salesforce object against which the Agent AI widget needs to be configured in its page layout.

Configure Page layout to embed Kore Agent AI Widget to Salesforce object

Assuming the Account Object is mapped above, open the page layout for Account Object.

In the filter field, type “NiceCTI” and drag and drop the object onto the Account Object layout page.

Configure a Visualforce Page to embed Kore Agent AI Widget (If Applicable)

Step-1: Create a Lightning Out App

Create a Lightning Out app, a special type of standalone Aura app:

  1. Open the Developer Console from your Salesforce org.
  2. Navigate to File > New > Lightning Application.
  3. Fill in the Name and Description fields, and then click Submit.
  4. Paste the following code into the editor, and save the Lightning Application:
<aura:application access="GLOBAL" extends="ltng:outApp">

    <!-- Lightning Web Component will be loaded here from Visualforce page -->

    <aura:dependency resource="KAA:niceCTIAgentAssistVoice" />

</aura:application>

Step-2: Create/Edit Visualforce Page

  1. Either create a new Visualforce Page or open an existing one.
  2. To create a new Visualforce Page, navigate to the Setup page > Visualforce Pages, and click New.
  3. In the Visualforce Markup code editor, add <apex:includeLightning /> at the beginning of your Visualforce page. This component loads the JavaScript file that Lightning Components for Visualforce uses.
  4. Paste the following code into the Visualforce Markup code editor at the desired location where you want the Agent AI widget to appear:<div id=”lwc-container”></div>
    <script>
    
    // Initialize Lightning Out with the app you created
    
    $Lightning.use("c:LightningApplication", function() {
    // Create the LWC component inside the div container
    
    $Lightning.createComponent("KAA:niceCTIAgentAssistVoice", { height: '600px', width: '500px'}, "lwc-container");
    });
    
    </script>

    Note: Replace “LightningApplication” with the name of the Lightning Out app you created in Step-1. Modify the height and width of the niceCTIAgentAssistVoice component according to your preference – these are the height and width of the Agent AI widget.

  5. Click Save.

Sample Visualforce Page:

<apex:page >

    <apex:includeLightning />

    <h1>Hello !</h1>

    <p>Welcome to Kore.ai Visualforce page.</p>

    <div id="lwc-container"></div>

    <script>

        // Initialize Lightning Out with the app you created

        $Lightning.use("c:Kore_Lightning_App", function() {

            // Create the LWC component inside the div container

            $Lightning.createComponent("KAA:niceCTIAgentAssistVoice", { height: '600px', width: '500px'}, "lwc-container");

        });

    </script>

</apex:page>


Set this Visualforce page as the screen pop in the Softphone layouts of your Salesforce org, or create a Visualforce tab by following the instructions in this document.

Configure an Aura Component to embed Kore Agent AI widget (If Applicable)

  1. Either create a new Aura Component or open an existing one.
  2. To create a new Aura Component, open Developer Console from your Salesforce org.
  3. In the Developer Console, navigate to File > New > LightningComponent.
  4. Fill in the Name and Description fields, and then click Submit.
  5. Paste the following code into the editor at the desired location where you want the Agent AI widget to appear, and save the Lightning Application:
<KAA:niceCTIAgentAssistVoice height="800px" width="500px" />

Note: Modify the height and width of the niceCTIAgentAssistVoice component according to your preference–these are the height and width of the Agent AI widget.

 

Sample Aura Component:

<aura:component implements="force:appHostable,flexipage:availableForAllPageTypes" access="global" >

    <h1>Hello! Kore Aura Component</h1>

    <KAA:niceCTIAgentAssistVoice height="800px" width="500px" />

    <h1>End of Aura Component</h1>

</aura:component>

Create a Lightning tab by following the instructions in this document.

Enabling OAuth

  1. Go to Setup > OAuth and OpenID Connect Settings and enable Allow OAuth Username-Password Flows.

  2. Create a connected Salesforce app and get the Access Key and Access Token. Follow this guide for help.

Additional Setup Steps for Chat

In addition to all the previous steps, two more steps are required for the Chat setup.

NICE API credentials to be configured for Signaling API (Only for Chat)

Refer to Manage Access Keys to create access keys to use for signaling APIs.

The Access Key Manager page allows you to view all the access keys in your system.

Configure NICE API Credentials (Only for Chat)

  1. Click the app launcher.
  2. Type “nice” in the search box, and select Nice Signal Credentials from the displayed list.

  3. Click New from the top-right corner of the page.

  4. Add the required parameters.
    • Credentials Set Name: NICE CX credentials (change as needed)
    • Proxy Tunnel Endpoint: {Agent AI URL}/integrations/nice/relay/toNice
    • NICE CX Credentials: 
      • Nice Token Base URL: NICE Token Base URL is the Host URL of the login page.
      • Nice API URL: If the URL for ACD is https://home-abc.nice-incontact.com, then the API URL would be https://api-abc.nice-incontact.com . Also, it is necessary to use the URL without the trailing slash.
      • NiceCX Signal API Access Key (generated in above step)
      • NiceCX Signal API Access Key Secret (generated in above step)
  5. Click Save.

NICE CTI Studio Script for Salesforce

For Voice

Import and configure the NICE Studio Script for Salesforce Integration.

Download Script For Voice: kore.ai_nicecti_sf_voice.XML

Open the Studio, import the above script, and customize as per the following table definition:

Node Activity Fields Updated
Set Credentials Update the credentials to connect to Salesforce Org Salesforce_key (created in step “Enabling OAuth”)

Salesforce_secret (created in step “Enabling OAuth”)

Salesforce_username

Salesforce_password

Note: The password is your Salesforce password appended with your Security Token. Refer to this guide for help.

User Auth Configure Salesforce org credentials and generate oauth Token salesforceBaseURI

Note: You can get it by running the following curl:

curl –location –request POST ‘https://login.salesforce.com/services/oauth2/token?grant_type=password&client_id=<Salesforce Client ID>&client_secret=<Salesforce Client_Secret>&username=<Salesforce_Username>&password=<Salesforce Password + Salesforce Security Token>’

ReqAgent Update Skill for Agent Routing Skill and other attributes as needed
AgentAssist Map the AgentAssist Hub Instance Select the AgentAssist Hub app created in the above step.

AgentAssist Hub Reference:

Click the checkbox on the specific instance. Only one can be active.

After selecting the AgentAssist app, click the Close button on the bottom-right corner of the page.
Note: Do not click the “X” button to close the window as this will not save the changes.

Save the Studio Script and make sure there are no errors on Save.

For Chat

Import and configure the NICE Studio Script for Salesforce Integration.

Download Script For Chat: kore.ai_nicecti_sf_chat.XML

Open the Studio, import the above script, and customize as per the following table definition:

Node Activity Fields Updated
Salesforce Auth Update the credentials to connect to Salesforce Org
  • salesforceBaseURI

Note: You can get it by running the following curl:

curl –location –request POST ‘https://login.salesforce.com/services/oauth2/token?grant_type=password&client_id=<Salesforce Client ID>&client_secret=<Salesforce Client_Secret>&username=<Salesforce_Username>&password=<Salesforce Password + Salesforce Security Token>’

Note: The password is your Salesforce password appended with your Security Token. Refer to this guide for help.

ReqAgent Update Skill for Agent Routing Skill and other attributes as needed
AgentAssist Map the AgentAssist Hub Instance Select the AgentAssist Hub App created in the above step.

NICE Account setup for Incoming Phone Call/Chat

On the NICE Incontact home page, click the application launcher button and select ACD.

Create a Campaign

Create a Skill

Create a Disposition

Create a new single Point of Contact (For Voice)

  • Media Type – Phone Call
  • Name – <Provide a name for the contact>
  • Point of Contact – Select a provisioned NICE phone number.
  • Skill – Select a predefined skill, else create one and select here.
  • Script – From the dropdown list, select the studio script created for Salesforce-NICE CTI above.
  • IVR Reporting Enabled – Select the checkbox.
  • Click Create Point of Contact button to save it.

Create a new single Point of Contact (For Chat)

  • Media Type – Chat
  • Name – <Provide a name for the contact>
  • Skill – Select a predefined skill, else create one and select here.
  • Script – From the dropdown list, select the studio script created for Salesforce-NICE CTI above.
  • IVR Reporting Enabled – Select the checkbox.
  • Click Create Point of Contact button to save it.

Make a Test Call / Chat

  1. Sign in to the Kore Agent AI account and prepare a bot to handle agents’ queries.
  2. Validate the bot credentials are correctly mapped in the above settings.
  3. Validate the AgentAssist URL is correctly mapped in the above settings.
  4. Sign in to the NICE-Incontact account, and check if the point of contact is properly configured.
  5. Sign in to your Salesforce org.
  6. From the app launcher, select Service Console.
  7. Sign in with NICE CX credentials for the agent.

  8. Install the softphone: https://help.nice-incontact.com/content/agent/cxoneagent/addcxawebrtcext.htm
  9. Refresh the screen, and click the phone icon on the status bar.
  10. Select Integrated Softphone, and click Connect.

  11. Change the status to Available.

For Call:

  1. Make a call to the Point of Contact phone number.
  2. Accept the call.

    1. The Contact page appears.

  3. When the End button is clicked, Summary is generated and displayed on the Agent AI widget.

  4. Upon clicking the Submit button on the Agent AI widget, Summary is stored in the Kore Agent AI Conversation Summaries.

For Chat:

  1. In the Salesforce App Launcher, search for Nice Chats Handler and select it.

    1. The following page opens and monitors active chats. It remains open for the Agent AI widget to render when an agent accepts a chat request.

  2. Make a chat request by opening the Point of Contact link in the browser.

  3. Send a message and the chat request is sent to the agent.

  4. Click Accept.

  5. The Agent AI widget opens for the ongoing chat conversation.

  6. When the End button is clicked, Summary is generated and displayed on the Agent AI widget.

  7. Upon clicking the Submit button in the Agent AI widget, Summary is stored in the Kore Agent AI Conversation Summaries.

  8. When Disposition is selected and clicked Save, Chat transcript is stored in Salesforce.

 

Kore Agent AI with Salesforce NICE CX-CTI

Introduction

This document provides an overview of the setup and configuration process of the Kore Agent AI widget with NICE CX Telephony using the Salesforce NICE CX CTI package.

Use Case: Show voice transcripts and provide next best actions from a configured bot, on the Kore Agent AI widget to agents when they receive a phone call from a customer.

When a customer calls a NICE CX phone number, the call is received on the Salesforce NICE CTI interface. Based on the customer’s phone number, CTI rule matches the corresponding Salesforce object (Account/Contact/Case etc.) and displays to the agents. The incoming voice stream is shared with Kore Voice Gateway, which in turn generates transcripts of the voice stream and displays on the Agent AI widget embedded into the matched Salesforce object.

Prerequisites

  • The NICE CX Salesforce package installed in your Salesforce org.
  • NICE CX account set up and can receive calls on the Salesforce Service Console softphone.
  • NICE CX Studio installed on your device.
  • Agent Assist Hub enabled for your NICE CX account.
  • Kore AgentAssist for Salesforce installed on your Salesforce account. (Salesforce AppExchange > Search for “Agent AI By Kore.ai, Inc.”)
  • Have the AgentAssist bot credentials saved separately. You need the Widget URL, Bot ID, Client ID, Client Secret, Account ID, and SIP URI. Read Configure Voice Channel and Chat Channel for a walkthrough.

Shared Responsibilities

Activity Responsibility
CXOne Customer Kore.ai
NICE One Platform
ACD Configuration
  • Skills creation and mapping
  • Hours of Operation
  • Points of Contact
  • Campaign
  • Customization of Scripts and attaching to Number/Chat PoC
CXOne Studio Script
  • Import the voice script and customize (only if needed).
  • Edit the Nodes and provide the Customized Bot details in the script.
  • Provisioning the studio script template
Signal API Auth (only for chat)
  • Configure CXOne Authentication for accessing CXOne Signal API from Kore bot.
    Need signaling API key and secret.
Agent Assist Hub
  • Configure NICE Studio Agent Assist
Kore Agent AI Bot Configuration
  • Bot creation
  • Bot Credentials generation
Kore Bot Configuration Bot creation

Bot Credentials generation

Salesforce Org
Voice/Chat Configuration
  • Enabling NICE Calls/Chats on Salesforce with proper screen pop settings
Installing Kore Agent AI Package
  • Installing the package
  • Providing the package URL
Configuring Kore Agent AI Package
  • Validate prerequisite licenses
  • Configure Bot Details
  • Add NICE Signal Credentials (Only for Chat)
NICE CX Configure Salesforce Agent Settings, select Salesforce Object to embed Kore Agent AI widget.

Definitions

Section Key Definition Reference
Set up NICE AgentAssist Hub to stream voice to Kore Agent AI Agent AI URL The domain of the Agent AI.
Kore Agent AI  package setup and configuration AgentAssist Widget URL URL that points to the Agent AI widget.

For example, https://agentassist.kore.ai/koreagentassist-sdk-v3/UI/agentassist-iframe.html

Channels > Chat section of the Agent AI configuration portal.
Kore Agent AI package setup and configuration BotId A unique identifier assigned to a bot. Channels > Chat section of the Agent AI configuration portal.
Kore Agent AI package setup and configuration ClientId An identifier provided to a client application. Channels > Chat section of the Agent AI configuration portal.
Kore Agent AI package setup and configuration ClientSecret A secret key or password associated with the ClientId. Channels > Chat section of the Agent AI configuration portal.
Set up NICE AgentAssist Hub to stream voice to Kore Agent AI AccountID A unique identifier assigned to an account. Channels > Chat section of the Agent AI configuration portal.
Set up NICE AgentAssist Hub to stream voice to Kore Agent AI Kore Voice Gateway(KVG) For Saas in US region, value is savg-webserver.kore.ai

For on-prem, refer to the corresponding host. 

Region Specific URLs

Region Agent AI URL UXO URL WSS URL DNS
US https://agentassist.kore.ai https://platform.kore.ai  wss://savg-webserver.kore.ai @savg-us-prod-sbc-in-nlb-0d9a4c651955ff47.elb.us-east-1.amazonaws.com
JP https://agentassist-jp.kore.ai https://jp-platform.kore.ai  wss://jp-savg-audiosocket.kore.ai @savg-jp-prod-int-nlb-3989d946fc1ced3b.elb.ap-northeast-1.amazonaws.com

Set up Salesforce-NICE CTI package

Follow this article to install and configure the NICE CTI package on your Salesforce account.

Topics included in the above article:

  • Install Salesforce Agent
  • Install the Salesforce Agent Package
  • Assign Users to Your License
  • Enable Salesforce Agent in Lightning Experience
  • Configure Permission Sets For a Single User
  • Configure Permission Sets For Multiple Users
  • Configure the NICE CXone Call Center
  • Assign Users to the NICE CXone Call Center
  • Configure Softphone Layout
  • Assign Profiles to the Softphone Layout
  • Enable Click2Jack

Set up NICE AgentAssist Hub to stream voice to Kore Agent AI

This app will be used in studio script.

  1. Sign in to your NICE account with the username and password provided by the NICE customer support.
  2. Click the applications launcher button. A menu opens from the left side of the page.

  3. Click OTHERS > Automation & AI.

  4. Click Agent Assist Hub > Add Agent Assist App.

  5. Enter the name of the Agent Assist App in the AGENT ASSIST APP NAME field.
  6. Select Custom Agent Assist Endpoints.
  7. Click Next.

  8. Add the following settings with config parameters provided by the Kore.ai representative:
    1. Agent UI Option: Available by default
    2. App URL: {Agent AI URL}/integrations/nice/iframe/?params={scriptparams}
    3. App Title: Kore Agent AI (change as needed)
    4. Participants: Both
    5. Text Relay Endpoint: (only for chat) {Agent AI URL}/integrations/nice/relay/toKore

    6. Audio Relay Endpoint: {Kore Voice Gateway(KVG)}/audiosocket/nice?sipuri=<Bot SIP URI>&token=<Token>&botId=<Bot ID>&accountId=<Account ID>&agentassist=true
      1. Bot SIP URI: Channels > Voice section of the Agent AI configuration portal.

      2. Bot ID and Account ID: Channels > Chat section of the Agent AI configuration portal.

      3. Token: Create a JSON Web Token on jwt.io with the following details.
        1. Payload: {“appId”: <Bot Client ID>}
        2. Header: {“alg”: “HS256″,”typ”: “JWT”}
        3. Secret: Your Kore.ai Client Secret.
    7. Scroll down and add the following Configuration Parameters. (Only for Chat).

  9. Click Create

Kore Agent AI package setup and configuration

Set up AgentAssist feature

  1. Click the app launcher.

  2. Type “kore” in the search box and select Kore AgentAssist Feature Configuration from the displayed list.

  3. Click New from the top-right corner of the page.

  4. Type Test Configuration in the Configuration Name field.

  5. Select NICE inContact in the CTI Provider list.

  6. Select Active, and click Save.

Set up AgentAssist Configuration

  1. Click the app launcher.
  2. Type “config” in the search box and select Kore AgentAssist Configuration from the displayed list.

  3. Click New from the right-top corner of the page.
  4. Enter the required details.
    Note: AgentAssist URL, Bot ID, Client ID, and Client Secret can be fetched from the Agent AI configuration portal.
  5. Select Active and click Save.

Configure NICE CTI Data in Salesforce

  1. Click the app launcher in Salesforce, and then go to Salesforce Agent Settings.
  2. Sign in to your NICE CX account.
  3. Ensure the Store Salesforce Agent Script Variables setting is enabled in the Data Storage section.
  4. In the dropdown list, select a Salesforce object against which the Agent AI widget needs to be configured in its page layout.

Configure Page layout to embed Kore Agent AI Widget to Salesforce object

Assuming the Account Object is mapped above, open the page layout for Account Object.

In the filter field, type “NiceCTI” and drag and drop the object onto the Account Object layout page.

Configure a Visualforce Page to embed Kore Agent AI Widget (If Applicable)

Step-1: Create a Lightning Out App

Create a Lightning Out app, a special type of standalone Aura app:

  1. Open the Developer Console from your Salesforce org.
  2. Navigate to File > New > Lightning Application.
  3. Fill in the Name and Description fields, and then click Submit.
  4. Paste the following code into the editor, and save the Lightning Application:
<aura:application access="GLOBAL" extends="ltng:outApp">

    <!-- Lightning Web Component will be loaded here from Visualforce page -->

    <aura:dependency resource="KAA:niceCTIAgentAssistVoice" />

</aura:application>

Step-2: Create/Edit Visualforce Page

  1. Either create a new Visualforce Page or open an existing one.
  2. To create a new Visualforce Page, navigate to the Setup page > Visualforce Pages, and click New.
  3. In the Visualforce Markup code editor, add <apex:includeLightning /> at the beginning of your Visualforce page. This component loads the JavaScript file that Lightning Components for Visualforce uses.
  4. Paste the following code into the Visualforce Markup code editor at the desired location where you want the Agent AI widget to appear:<div id=”lwc-container”></div>
    <script>
    
    // Initialize Lightning Out with the app you created
    
    $Lightning.use("c:LightningApplication", function() {
    // Create the LWC component inside the div container
    
    $Lightning.createComponent("KAA:niceCTIAgentAssistVoice", { height: '600px', width: '500px'}, "lwc-container");
    });
    
    </script>

    Note: Replace “LightningApplication” with the name of the Lightning Out app you created in Step-1. Modify the height and width of the niceCTIAgentAssistVoice component according to your preference – these are the height and width of the Agent AI widget.

  5. Click Save.

Sample Visualforce Page:

<apex:page >

    <apex:includeLightning />

    <h1>Hello !</h1>

    <p>Welcome to Kore.ai Visualforce page.</p>

    <div id="lwc-container"></div>

    <script>

        // Initialize Lightning Out with the app you created

        $Lightning.use("c:Kore_Lightning_App", function() {

            // Create the LWC component inside the div container

            $Lightning.createComponent("KAA:niceCTIAgentAssistVoice", { height: '600px', width: '500px'}, "lwc-container");

        });

    </script>

</apex:page>


Set this Visualforce page as the screen pop in the Softphone layouts of your Salesforce org, or create a Visualforce tab by following the instructions in this document.

Configure an Aura Component to embed Kore Agent AI widget (If Applicable)

  1. Either create a new Aura Component or open an existing one.
  2. To create a new Aura Component, open Developer Console from your Salesforce org.
  3. In the Developer Console, navigate to File > New > LightningComponent.
  4. Fill in the Name and Description fields, and then click Submit.
  5. Paste the following code into the editor at the desired location where you want the Agent AI widget to appear, and save the Lightning Application:
<KAA:niceCTIAgentAssistVoice height="800px" width="500px" />

Note: Modify the height and width of the niceCTIAgentAssistVoice component according to your preference–these are the height and width of the Agent AI widget.

 

Sample Aura Component:

<aura:component implements="force:appHostable,flexipage:availableForAllPageTypes" access="global" >

    <h1>Hello! Kore Aura Component</h1>

    <KAA:niceCTIAgentAssistVoice height="800px" width="500px" />

    <h1>End of Aura Component</h1>

</aura:component>

Create a Lightning tab by following the instructions in this document.

Enabling OAuth

  1. Go to Setup > OAuth and OpenID Connect Settings and enable Allow OAuth Username-Password Flows.

  2. Create a connected Salesforce app and get the Access Key and Access Token. Follow this guide for help.

Additional Setup Steps for Chat

In addition to all the previous steps, two more steps are required for the Chat setup.

NICE API credentials to be configured for Signaling API (Only for Chat)

Refer to Manage Access Keys to create access keys to use for signaling APIs.

The Access Key Manager page allows you to view all the access keys in your system.

Configure NICE API Credentials (Only for Chat)

  1. Click the app launcher.
  2. Type “nice” in the search box, and select Nice Signal Credentials from the displayed list.

  3. Click New from the top-right corner of the page.

  4. Add the required parameters.
    • Credentials Set Name: NICE CX credentials (change as needed)
    • Proxy Tunnel Endpoint: {Agent AI URL}/integrations/nice/relay/toNice
    • NICE CX Credentials: 
      • Nice Token Base URL: NICE Token Base URL is the Host URL of the login page.
      • Nice API URL: If the URL for ACD is https://home-abc.nice-incontact.com, then the API URL would be https://api-abc.nice-incontact.com . Also, it is necessary to use the URL without the trailing slash.
      • NiceCX Signal API Access Key (generated in above step)
      • NiceCX Signal API Access Key Secret (generated in above step)
  5. Click Save.

NICE CTI Studio Script for Salesforce

For Voice

Import and configure the NICE Studio Script for Salesforce Integration.

Download Script For Voice: kore.ai_nicecti_sf_voice.XML

Open the Studio, import the above script, and customize as per the following table definition:

Node Activity Fields Updated
Set Credentials Update the credentials to connect to Salesforce Org Salesforce_key (created in step “Enabling OAuth”)

Salesforce_secret (created in step “Enabling OAuth”)

Salesforce_username

Salesforce_password

Note: The password is your Salesforce password appended with your Security Token. Refer to this guide for help.

User Auth Configure Salesforce org credentials and generate oauth Token salesforceBaseURI

Note: You can get it by running the following curl:

curl –location –request POST ‘https://login.salesforce.com/services/oauth2/token?grant_type=password&client_id=<Salesforce Client ID>&client_secret=<Salesforce Client_Secret>&username=<Salesforce_Username>&password=<Salesforce Password + Salesforce Security Token>’

ReqAgent Update Skill for Agent Routing Skill and other attributes as needed
AgentAssist Map the AgentAssist Hub Instance Select the AgentAssist Hub app created in the above step.

AgentAssist Hub Reference:

Click the checkbox on the specific instance. Only one can be active.

After selecting the AgentAssist app, click the Close button on the bottom-right corner of the page.
Note: Do not click the “X” button to close the window as this will not save the changes.

Save the Studio Script and make sure there are no errors on Save.

For Chat

Import and configure the NICE Studio Script for Salesforce Integration.

Download Script For Chat: kore.ai_nicecti_sf_chat.XML

Open the Studio, import the above script, and customize as per the following table definition:

Node Activity Fields Updated
Salesforce Auth Update the credentials to connect to Salesforce Org
  • salesforceBaseURI

Note: You can get it by running the following curl:

curl –location –request POST ‘https://login.salesforce.com/services/oauth2/token?grant_type=password&client_id=<Salesforce Client ID>&client_secret=<Salesforce Client_Secret>&username=<Salesforce_Username>&password=<Salesforce Password + Salesforce Security Token>’

Note: The password is your Salesforce password appended with your Security Token. Refer to this guide for help.

ReqAgent Update Skill for Agent Routing Skill and other attributes as needed
AgentAssist Map the AgentAssist Hub Instance Select the AgentAssist Hub App created in the above step.

NICE Account setup for Incoming Phone Call/Chat

On the NICE Incontact home page, click the application launcher button and select ACD.

Create a Campaign

Create a Skill

Create a Disposition

Create a new single Point of Contact (For Voice)

  • Media Type – Phone Call
  • Name – <Provide a name for the contact>
  • Point of Contact – Select a provisioned NICE phone number.
  • Skill – Select a predefined skill, else create one and select here.
  • Script – From the dropdown list, select the studio script created for Salesforce-NICE CTI above.
  • IVR Reporting Enabled – Select the checkbox.
  • Click Create Point of Contact button to save it.

Create a new single Point of Contact (For Chat)

  • Media Type – Chat
  • Name – <Provide a name for the contact>
  • Skill – Select a predefined skill, else create one and select here.
  • Script – From the dropdown list, select the studio script created for Salesforce-NICE CTI above.
  • IVR Reporting Enabled – Select the checkbox.
  • Click Create Point of Contact button to save it.

Make a Test Call / Chat

  1. Sign in to the Kore Agent AI account and prepare a bot to handle agents’ queries.
  2. Validate the bot credentials are correctly mapped in the above settings.
  3. Validate the AgentAssist URL is correctly mapped in the above settings.
  4. Sign in to the NICE-Incontact account, and check if the point of contact is properly configured.
  5. Sign in to your Salesforce org.
  6. From the app launcher, select Service Console.
  7. Sign in with NICE CX credentials for the agent.

  8. Install the softphone: https://help.nice-incontact.com/content/agent/cxoneagent/addcxawebrtcext.htm
  9. Refresh the screen, and click the phone icon on the status bar.
  10. Select Integrated Softphone, and click Connect.

  11. Change the status to Available.

For Call:

  1. Make a call to the Point of Contact phone number.
  2. Accept the call.

    1. The Contact page appears.

  3. When the End button is clicked, Summary is generated and displayed on the Agent AI widget.

  4. Upon clicking the Submit button on the Agent AI widget, Summary is stored in the Kore Agent AI Conversation Summaries.

For Chat:

  1. In the Salesforce App Launcher, search for Nice Chats Handler and select it.

    1. The following page opens and monitors active chats. It remains open for the Agent AI widget to render when an agent accepts a chat request.

  2. Make a chat request by opening the Point of Contact link in the browser.

  3. Send a message and the chat request is sent to the agent.

  4. Click Accept.

  5. The Agent AI widget opens for the ongoing chat conversation.

  6. When the End button is clicked, Summary is generated and displayed on the Agent AI widget.

  7. Upon clicking the Submit button in the Agent AI widget, Summary is stored in the Kore Agent AI Conversation Summaries.

  8. When Disposition is selected and clicked Save, Chat transcript is stored in Salesforce.