This document provides description of Voice Bots feature, setup instructions, use cases and overview of how you can benefit from using Voice Assistant.

Created: November 2024

Updated: January 2025

Permalink: https://x-hoppers.atlassian.net/wiki/x/DAD8B

Introduction

Voice Bots is a powerful tool that allows automated responses and routes customers' and your team’s queries via bot assistance. There are several Voice Bot integration types:

Use Cases

Voice Bots can be used in a variety of ways. Here are some examples: 

1. Create Voice Bot

It is possible to create up to 100 Voice Bots per organization.

To create a Voice Bot, proceed with the following steps:

x-hoppers-Voice bots.jpgadd-new-voicebot.pngvoice-bot-name-message.png

To add a tool:

  1. Click Add Tool -> choose the necessary option:

voice-bots-add-tool.png
  1. Fill out the necessary details:

hangup-tool.pngsilence-timeout-transfer-option.pngvoice-bot-additional-configuration.png

Types of Voice Bots

Generative AI

When configuring Generative AI as the integration type, you need to create a clear and precise prompt with instructions for AI agents, which directly impacts Voice Bot performance and reliability. Prompt engineering is an iterative process, so based on user feedback, you can refine your prompts for even better Voice Bot efficiency.

You can divide your system prompts into the distinct sections, each focusing on a specific element of the AI agent's behavior. For example:

  1. Identity: define who the AI agent is, outline its persona and role to set the context for interactions.

  2. Style: establish guidelines for the agent's communication style, including tone, language, and formality.

  3. Response Guidelines: specify preferences for the response format, including any limitations or requirements in terms of the response structure.

  4. Task and Goals: indicate the objectives the agent should achieve and outline the steps it should follow.

generative-ai-voice-bot.png

Webhook

Specify the following fields, when configuring Webhook as the integration type:

  1. Target: enter the URL that the Webhook will use to send POST requests with the event payload.

  2. Secret: the secret ensures that only requests from Wildix system are accepted, preventing unauthorized access or potential security breaches. The secret key is included in the headers of each POST request sent by the Webhook. Your server should validate this key to ensure the request is legitimate before processing the event data

voice-bot-webhook.jpg

Important: The endpoint should be publicly accessible with a valid HTTPS certificate, accept HTTP POST requests with JSON payloads, respond with codes from 200 to 299 as quickly as possible, and handle multiple identical calls in case of retries due to network or server failures (up to 3 times).

AWS SQS

If you configure AWS SQS as integration type, you need to provide the following details to establish the connection with your AWS SQS queue:

aws-sqs-voice-bot.png

Dialogflow CX

If you configure Dialogflow CX as the integration type, you need to fill out the following fields to establish the connection between x-hoppers and your Dialogflow CX agent:

voice-bot-dialogflowcx.jpg

OpenAI Assistant

If you configure OpenAI Assistant as integration type, you need to fill out the following fields to enable the connection between x-hoppers and OpenAI's API:

  1. API Key: enter the unique identifier that allows to grant access to the OpenAI API, which lets to send requests and receive responses from the Assistant

  2. Assistant ID: fill out the unique identifier of a specific OpenAI Assistant you created.

openaiassistant-voice-bot.jpg

Dial by Name Setup

Setting up Dial by name option in Voice bot allows to ask the bot to dial colleagues just by pronouncing their name / extension. To configure the option, follow the steps below:

voice-bot-add-transfer-tool.png
  1. Description: enter instructions for the transfer, e.g. “Transfer the call to the extension number of the colleague from the same organization if asked by the caller.“

  2. Context: enter the name of the Dialplan to which the call should be transferred

The Dialplan should include the Dial the phone application:

dial-by-name-dialplan.png
  1. Destination: select the option Directory, in this case the AI utilizes the Organization Directory for the transfer

  2. Pipeline: choose the Voice bot should generate a reply and transfer the call or transfer the call without replying

voice-bot-transfer-tool-configuration.png

2. Configure Dialplan

To let store associates access Voice bot from the headset, you can add the Voice bot to the *wair* section of x-hoppers Dialpan. In this case, users can just double-press the AUX Function button on the headset and get into the menu with the Voice bot. Add the following applications under *wair* number:

Note:

  • The following languages are supported:

    • English (British), English (US), French, Italian

    • Spanish, Dutch, German, Arabic, Catalan, Danish, Swedish, Portuguese - starting from WMS 6.09.20241106.2

    • Swiss German - starting from WMS 6.09.20241211.2

  • Arabic (ar), Swedish (se) are not present in the drop-down list, but you can enter them manually, for example:

setting-language-manually.png
  • Basque and Estonian languages are not supported

voice-bot-dialplan-in-wair.png

In case you need to make Voice bot available by calling a specific number, you can enter the number and add the same applications mentioned above:

voice-bot-setup-in-dialplan.png

Choose speaker

Note: The support starts from WMS 6.09.20241129.1.

You can change the default speaker by adding the following applications before the Voice Bot application in the Dialplan:

  1. Set application -> choose the parameter Language - > choose language

  2. Set application -> choose the parameter TTS Voice - > select speaker: 

voice-bot-set-speaker.png

Manage Voice Bots

The Voice Bots that you have created are displayed in x-hoppers admin -> PBX -> Integrations -> Cloud integrations -> Voice Bots section. You can see the Voice Bot name, Bot ID, and Integration type.

voice-bots-lists.jpg

Edit a Voice Bot

  1. To edit a Voice Bot, click on the Edit (pencil) icon:

voice-bot-edit.png
  1. Make the necessary changes and click Save:

save-edited-voice-bot.png

Delete a Voice Bot

  1. To delete a Voice Bot, click on the Delete icon:

delete-voice-bot.png
  1. On the screen that pops up, type the word “delete” and click Delete:

confirm-voice-bot-deletion.png

Traces

In Traces section you can see a table with the following information: Session ID, Voice Bot name, Caller, Duration of the call, date and language:

traces-table.png

Clicking on a session in Traces, you can view events of the session:

traces-events-of-the-session.png

Voice Bots API

You can find Voice Bots API here: https://docs.wildix.com/api-reference/rest/wim/voicebots/#/

Use Case: Using Voice Bots with Chat Bots

You can enhance your experience of using Voice Bot feature by combining it with Chat Bots (you can find Chat Bots documentation here: https://wildix.atlassian.net/wiki/x/4APOAQ ). For example, you can set up Voice Bot that would gather information from a customer and send it to the conversation with managers via a Chat Bot:

Step 1. Create a Chat Bot

  1. Go to x-hoppers admin -> PBX -> Integrations -> Cloud integrations

  2. Select Chat Bots and click Add new Chatbot

  3. Enter a name for your chatbot

  4. Select the Webhook integration type for processing chat events

  5. Fill out the Target field

  6. Enable Allow users to find the bot using search checkbox to let users interact with the bot

  7. Click Add to save and activate your chatbot

step1-create-chatbot.jpg

After creating the bot, click on Manage API keys to create API key:

  1. Click Create new API Key

  2. Enter a name for identification

  3. Click Create and copy the secret using the Click to reveal button. You will need the secret when configuring Voice Bot.

chatbot-api-keys.png

Step 2. Create a conversation

Create a conversation in x-bees where you need to add the Chat Bot you’ve created as well as the managers who should receive the notifications.

Also, make sure to copy conversation ID, which will be required during Voice Bot creation:

copy-conversation-id.png

Step 3. Create Voice Bot

Configure Voice Bot of Generative AI integration type.

In our example, we’ve used the following text as the First Message:
Hello! Do you have any complaints or suggestions regarding Wildix products?

And added the following instructions:

You are a customer care agent that collects all the complaints and suggestions about Wildix products. Try to understand with which product customer is having problems or has a suggestion. Carefully collect all the details. Then pass them to the manager in the chat.
Share with the manager any emotions or sentiments the customer had if any. Ask the customer their name before passing the information to the manager and remember to pass the customer's name as well. Hang up after saying thank you and good-bye if the customer says they have nothing else to add.

voice-bot-generative-ai-example.png

In Tools section, add Hangup and Third-party Function options:

voice-bot-example-tools.png

We’ve used the following parameters in the Parameters section of Third-party Function section:

{
  "type": "object",
  "properties": {
    "text": {
      "type": "string",
      "description": "The message to the manager containing all the details about complains and suggestions collected from a customer"
    }
  },
  "required": [
    "text"
  ]
}

In Integration section, in the URL field (1) next to the POST Method, entered the following data:

https://api.x-bees.com/v2/conversations/channels/{Conversation_ID}/messages

Where {Conversation_ID} is the ID of the conversation from Step 2.

Click Add authorization and enter the Secret from Step 1 into the Bearer field (2):

voice-bot-post-and-bearer.png

Click Save to save the changes.

Step 4. Configure Dialplan

Set up Voice Bot in the Dialplan:

set-up-voice-bot-in-dialplan.png

When calling the number set in the Dialplan, the call is answered by Voice Bot, which gathers the required information and send it to the conversation:

messages-from-voicebot-in-conversation.png