Hide

YetaWF Documentation

Display
Print

Softelvdm.IVR Package

Overview

This package implements a complete automated voice attendant and voice mail system for your website. It uses your Twilio account with your phone number(s).

The automated voice attendant is used to answer calls with a greeting ("Press 1 for sales, 2 for support..."), with different greetings for opening/closed hours, weekends and holidays.

The caller can select an extension to call. Depending on the definition of the extension, an automated message is played back or an external phone number is called to connect the caller.

Our demo site at https://demo.yetawf.com has a base install of the IVR package which is active. The phone number to call to use the IVR package is

(941) 212-1700

Of course, no one will answer any extensions so it's safe to try out. The logs will not show your phone number as the incoming phone numbers are not shown on the demo site. A full install will of course show phone numbers also.

Setting Up Your Phone Number

To fully configure the IVR package, a few simple steps must be performed:

Twilio Phone Number Settings

In order to use the IVR package, a phone number must be purchased from Twilio. The overall cost of using Twilio to answer a phone number is quite low and with a moderately used phone number is just a few dollars per month. The cost of purchasing a phone number is currently $1 per month.

First, an account needs to be created at Twilio so a phone number can be purchased. A wide range of phone numbers is available.

Once the number has been purchased, it needs to be configured. At Twilio's Active Numbers page select your number to access the settings.

Twilio Phone Number Settings

Enter a suitable description for your phone number. The only relevant section to configure is labeled "Voice & Fax". The Messaging section is not used.

Select "Voice Calls" for Accept Incoming Calls.

Select "Webhooks, TwiML Bins, Functions, Studio, or Proxy" for Configure With.

Enter the full URL with your domain name for A Call Comes In. This is the URL Twilio uses to communicate with your site to allow it answer a phone call. The path is "/Softelvdm_IVR/Call/Process" which must be provided as-is. https:// is required. It is not possible to use http://. Make sure to update your domain name to match.

https://yourdomain.com/Softelvdm_IVR/Call/Process

Configuring The TwilioProcessor Package

The IVR package requires the TwilioProcessor package to be installed and configured.

The TwilioProcessor package documentation describes all the needed steps.

Configuring The IVR Package

Using Admin > Settings > IVR Settings (standard YetaWF site) the IVR package can be customized.

The IVR Settings page shows several tabs with configuration settings.

Accounts Tab

The Accounts tab displays the TwilioProcessor package settings. They cannot be modified and are for informational purposes only.

Accounts Tab

IVR Tab

The IVR tab is used to modify the voice used by the IVR package when answering calls. Visit https://www.twilio.com/console/voice/twiml/text-to-speech to view and test all available voices.

The "Max. Errors" field is used to define how many times the caller can enter an invalid extension before the IVR system hangs up.

The "Live/Test Call Process Url" fields are used to define the URL that processes calls. This is only used for verification/security purposes to decrypt the Twilio security token and only needs to be specified when the request URL is modified before reaching your site. This typically is the case when using load balancers or proxies.

IVR Tab

Voice Mail Tab

The Voice Mail tab is used to define a page to display information for one voice mail and to listen to the voice mail. This is used when displaying voice mails using User > Voicemails (standard YetaWF site). A designed page is not required as YetaWF will show a generated page automatically. This can be used to show additional information to a user when reviewing voice mails.

Voice Mail Tab

Hours Tab

The Hours tab is used to define when your business is open, which determines the greeting played when someone calls. Holidays defined using Admin > Settings > IVR Holidays take precedence, in which case the holiday greeting is played in all cases.

Hours Tab

Security Tab

The Security tab is used to define RSA public and private keys which are used by the IVR package during an active call to insure all requests from Twilio are legitimate request. It is possible to generate new keys using the "Generate Keys" check box. When new keys are generated, an in-progress calls become invalid and are terminated.

IVR Script

YetaWF uses Twilio's TwiML responses to control the phone call. This is done by providing TwiML responses using a script, which contains various TwiML snippets for the different stages of a phone call.

The script is located in the IVR package folder

./Website/wwwroot/IVR/Addons/_Main/Scripts

When the sample package script is installed it is named

TWIML+14075551212.txt

The script must be renamed to match your phone number, i.e., the phone number you purchased above (Setting Up Your Phone Number). Make sure to include the country code also (+1). If the script is not renamed, calls will be rejected.

Once renamed, the file must be moved to

./Website/wwwroot/AddonsCustom/(yourdomain.com)/Softelvdm/IVR/_Main/Scripts

Moving it to the AddonsCustom folder insures that the script is not erased when the Softelvdm.IVR package is updated when a new version becomes available.

Assuming your phone number is +18885551212, the final location, full path of your script should be

./Website/wwwroot/AddonsCustom/(yourdomain.com)/Softelvdm/IVR/_Main/Scripts/TWIML+18885551212.txt

Initially, no changes to the script are needed. But once it's working correctly you can customize it further by modifying the <Say> tags to change the announcements.

When script changes are made, the site needs to be restarted for them to take effect as the script is cached.

Multiple Phone Numbers

The IVR package can process multiple phone numbers. To add an additional phone number, copy the script and rename it to the addition phone number. All phone numbers use the same IVR settings, but individual scripts.

Using the IVR Package

Defining Extensions

Admin > IVR Extensions (standard YetaWF site) is used to define all extensions. Each extensions has one or more external phone numbers associated with it.

Extensions

When a caller enters an extension, all phone numbers associated with the extension are called at the same time. The first phone number that answers will be the recipient and take over the call.

The caller is announced to the recipient: "I have a call for extension extension from caller's number in caller's city, caller's country. Press 1 to accept, 2 to reject.". The recipient can press 1 to accept the call, which finally connects the caller to the recipient. If the recipient presses 2, the caller is sent to voice mail and can leave a message for the extension.

Adding an Extension

When adding an extension, multiple external phone numbers can be added which are called when the caller selects the extension.

Each extension can also have one or multiple associated users. Each of these users will be able to review the extension's voice mails using User > Voicemails (standard YetaWF site). A user can be associated with multiple extensions. All voice mails for all extensions the user is associated with are shown when using User > Voicemails (standard YetaWF site).

Extensions

Defining Holidays

The automated voice attendant will play a different greeting on holidays, to inform the caller that the company is closed.

The list of holidays can be defined using Admin > IVR Holidays (standard YetaWF site).

Holidays

Adding a Holiday

When adding a holiday only the date is relevant. The description is not used by the automated attendant and is only intended for documentation.

Add Holiday

Voice Mails

Users can review the voice mails for all extensions that they are authorized to access (see Adding an Extension). The voice mails can be accessed using User > Voicemails (standard YetaWF site). This is the only way to access emails. It is not currently possible to access voice mails by phone.

Voicemails

Modules

Module NameDescription
Add New Blocked Number ModuleAdds a new blocked number.
Add New Extension ModuleAdds a new extension.
Add New Holiday Entry ModuleAdds a new holiday.
Blocked Numbers ModuleDisplays and manages blocked numbers.
Call Log Entries ModuleDisplays and manages call log entries.
Call Log Entry ModuleDisplays an existing call log entry.
Edit Blocked Number ModuleEdits an existing blocked number.
Edit Extension ModuleEdits an existing extension.
Extensions ModuleDisplays and manages extensions.
Holiday Entries ModuleDisplays and manages holiday entries.
IVR Settings ModuleEdits a site's IVR settings.
Voice Mail Entries ModuleDisplays and manages voice mail entries.
Voice Mail Entry ModuleDisplays an existing voice mail entry.

License

The Softelvdm.IVR package is part of YetaWF, an open source product licensed under the GNU General Public License, version 3 (GPL-3.0) - Copyright - Softel vdm, Inc.