Retell
Using jambonz to connect custom telephony to Retell.ai
The jambonz application referenced in this article can be
found here.
You can deploy this application to your Heroku account with just a few clicks.
Installing
Having checked out this repo, do the usual:
Provisioning jambonz
Add a carrier for Retell
You may wish to review this article before continuing in order to learn the basics about provisioning a carrier in the jambonz portal.
First, create a Carrier named ‘Retell’ in jambonz.
This carrier will have one outbound gateway and no inbound gateways.
Check the box for E.164 syntax, uncheck outbound authentication, and then add one outbound SIP gateway
with the network address of 5t4n6j0wnrl.sip.livekit.cloud
.
data:image/s3,"s3://crabby-images/b31d3/b31d345d41ee38cbc1bf71f1ef21d8348307f805" alt="Provisioning carrier for Retell"
Add a carrier for your SIP trunking provider
Next, add a second Carrier for your SIP trunking provider. This carrier should have both inbound gateways and outbound gateways. Your SIP trunking provider should be able to provide you either with the static IP addresses that they will be sending you traffic from, or a sip username and password to authenticate with.
Create a sip credential
Next, add a SIP client credential. Click on “Clients” and add a sip client with a name and password.
data:image/s3,"s3://crabby-images/67beb/67beb20b0433d1e0fbc5ccee829fc076b41986bf" alt="Creating a sip credential"
Create a jambonz application
Create a new application in jambonz, providing the websocket URL of your application for the calling webhook field as well as the call status field. Leave all other fields at their default settings.
Add a phone number
Your sip trunking provider should have provided you with one or more phone numbers that will be routed to your jambonz account. In the jambonz portal, add a phone number and route incoming calls on these numbers to your application.
Route sip device calls to your application
Finally, on the Accounts page, set the dropdown for Application for SIP device calls
to the
application you created above.
Configuring Retell
Retell calls an inbound call webhook to get dynamic variables for incoming calls, and
this application provides a endpoint for that at
/inbound-webhook.js,
so log into the Retell console and add this webhook.
data:image/s3,"s3://crabby-images/1c475/1c47544c5fed320926ec750fea22dda147b5a34c" alt="Retell webhook"
You’ll note that this application also provides a webhook to receive agent events from Retell. Currently these are simply logged for informational purposes, but you may want to use this information in your application.
Finally, you need to add the phone number that you are receiving calls on from your SIP trunking/DID provider in the Retell console. In the Retell Dashboard, select “Phone Numbers” and click the plus sign. In the dropdown select “Connect to your number via SIP trunking”.
- Add the phone number in E.164 format (ie leading + followed by country code)
- For termination URI enter a URI with the ‘sip’ scheme and the DNS of your sip realm in jambonz (you can find that under the Account tab), e.g. ‘sip:mydomain.sip.jambonz.cloud’
- For sip trunk username and password enter the username and password you created above on jambonz.
After creating the phone number, associate it with the Retell agent you want to use.
Running the application
environment variables
You must set the following environment variables when running the application:
RETELL_API_KEY
- the API key for your Retell accountRETELL_TRUNK_NAME
- the name of the Carrier you created for Retell in jambonzPSTN_TRUNK_NAME
- the name of the Carrier you created for your SIP trunking provider in jambonzRETELL_SIP_CLIENT_USERNAME
- the username of the SIP client you created in jambonz
Now, when an incoming call arrives from Retell it will be sent out your PSTN provider. Conversely, when an incoming call arrives from the PSTN it will be connected to Retell.
For a detailed explanation of how this works, please watch this video.