Dashboard
Quickstart with the Vapi web dashboard.
The Web Dashboard
The Vapi web dashboard gives you a way to quickly create & manage assistants, provision phone numbers, & view conversation data.
One of the easiest ways to get started with Vapi is by using the web dashboard.
The web dashboard gives you the ability to:
- view, create, & modify assistants associated with your account
- provision & manage phone numbers assistants can dial outbound from or receive inbound calls to
- review conversation data (such as audio recordings, call metadata, etc)
- manage your provider keys (used in communication with external TTS, LLM, & STT vendors)
Don’t feel overwhelmed by all of this information (& unfamiliar UI), we will be walking through the core necessities you need to get up and running in this guide.
Vapi’s Pizzeria
In this guide we will be implementing a simple order-taking assistant at a pizza shop called “Vapi’s Pizzeria”.
Vapi’s has 3 types of menu items: pizza
, side
s, & drink
s. Customers will be ordering 1 of each.
Customers will order 3 items: 1 pizza, 1 side, & 1 drink. The assistant will handle the full order taking conversation.
Assistant Setup
First we’re going to set up our assistant in the dashboard. Once our assistant’s transcriber, model, & voice are set up, we can call it to place our order.
0) Sign-up or Log-in to Vapi
If you haven’t already signed-up, you’re going to need an account before you can use the web dashboard. When you visit dashboard.vapi.ai you may see something like this:
Sign-up for an account (or log-in to your existing account) — you will then find yourself inside the web dashboard. It will look something like this:
Your dashboard may look a bit different if you already have an account with assistants in it. The main idea is that we’re in the dashboard now.
1) Create an Assistant
Now that you’re in your dashboard, we’re going to create an assistant.
Assistants are at the heart of how Vapi models AI voice agents — we will be setting certain properties on a new assistant to model an order-taking agent.
Once in the “Assistants” dashboard tab (you should be in it by-default after log-in), you will see a button to create a new assistant.
Ensure you are in the 'Assistants' dashboard tab, then this button will allow you to begin the assistant creation flow.
After clicking the create new assistant button, you will see a pop-up modal that asks you to pick a starter template. For our example we will start from a blank slate so choose the Blank Template
option.
Ensure you are in the 'Assistants' dashboard tab, then this button will allow you to begin the assistant creation flow.
You will then be able to name your assistant — you can name it whatever you’d like (Vapi’s Pizza Front Desk
, for example):
This name is only for internal labeling use. It is not an identifier, nor will the assistant be aware of this name.
Name your assistant.
Once you have named your assistant, you can hit “Create” to create it. You will then see something like this:
The assistant overview. You can edit your assistant’s transcriber, model, & voice — and edit other advanced configuration.
This is the assistant overview view — it gives you the ability to edit different attributes about your assistant, as well as see cost & latency projection information for each portion of it’s voice pipeline (this is very important data to have handy when building out your assistants).
2) Model Setup
Now we’re going to set the “brains” of the assistant, the large language model. We’re going to be using GPT-4
(from OpenAI) for this demo (though you’re free to use GPT-3.5
, or any one of your favorite LLMs).
Set Your OpenAI Provider Key (optional)
Before we proceed, we will make sure we’ve configured our provider key for OpenAI (this is just your OpenAI secret key).
You can see all of your provider keys in the “Provider Keys” dashboard tab. You can also go directly to dashboard.vapi.ai/keys.
Vapi uses provider keys you provide to communicate with LLM, TTS, & STT vendors on your behalf. It is most ideal that we set keys for the vendors we intend to use ahead of time.
If Vapi detects that you are missing a provider key for a vendor (during assistant execution), Vapi will make the request for you with Vapi’s own keys (& your account will be charged for the request at-cost).
We set our provider key for OpenAI so Vapi can make requests to their API.
While we’re here it’d be ideal for you to go & set up provider keys for other providers you’re familiar with & intend to use later.
First Message
Assistants can optionally be configured with a First Message
. This first message will be spoken by your assistant when either:
- A Web Call Connects: when a web call is started with your assistant
- An Inbound Call is Picked-up: an inbound call is picked-up & answered by your assistant
- An Outbound Call is Dialed & Picked-up: an outbound call is dialed by your assistant & a person picks up
Note that this first message cannot be interrupted & is guaranteed to be spoken. Certain use cases need a first message, while others do not.
You may see the term “web call” used here & there — which is an odd term on the face of it since the web involves no telephony. This is just a single term for us to name a conversational session, regardless of platform.
For our use case, we will want a first message. It would be ideal for us to have a first message like this:
Some text-to-speech voices may struggle to pronounce ‘Vapi’ correctly, compartmentalizing it to be spoken letter by letter “V. A. P. I.”
Some aspects of configuring your voice pipeline will require tweaks like this to get the target behaviour you want.
This will be spoken by the assistant when a web or inbound phone call is received (note that this is a fully inbound use case — people will be dialing into our agent, specifically only via phone).
System Prompt
We will now set the System Prompt
for our assistant. If you’re familiar with OpenAI’s API, this is the first prompt in the message list that we feed our LLM (learn more about prompt engineering on the OpenAI docs).
The system prompt can be used to configure the context, role, personality, instructions and so on for the assistant. In our case, a system prompt like this will give us the behaviour we want:
You can copy & paste the above prompt into the System Prompt
field. Now the model configuration for your assistant should look something like this:
Note how our model provider is set to OpenAI & the model is set to GPT-4.
3) Transcriber Setup
Remember that the transcriber is what turns user speech into processable text for our LLM. This is the first step in the end-to-end voice pipeline.
Set Your Deepgram Provider Key (optional)
We will be using Deepgram (which provides blazing-fast & accurate Speech-to-Text) as our STT provider.
We will set our provider key for them in “Provider Keys”:
Set Transcriber
We will set the model to Nova 2
& the language to en
for English.
This is out of scope for this quickstart, but Vapi has full multi-lingual support (if you need to support different user languages).
Now your assistant’s transcriber configuration should look something like this:
Note how our transcriber is set to 'deepgram', the model is set to 'Nova 2', & the language is set to English.
Transcription will be the least “custom” configuration we will touch. Once you solve Speech-to-text with incredibly low latency & high accuracy there isn’t much else to configure (mainly speaker language).
Most customization in our pipeline will come from the model (LLM) & the voice (Text-to-speech).
4) Voice Setup
The final portion of the voice pipeline is turning LLM output-text into speech. This process is called “Text-to-speech” (or TTS for short).
We will be using a voice provider called PlayHT (they have very conversational voices), & a voice provided by them labeled Jennifer
(female
, en-US
).
You are free to use your favorite TTS voice platform here. ElevenLabs is another alternative — by now you should get the flow of plugging in vendors into Vapi (add provider key + pick provider in assistant config).
You can skip the next step(s) if you don’t intend to use PlayHT.
Set Your PlayHT Provider Key (optional)
If you haven’t already, sign up for an account with PlayHT at play.ht. Since their flows are liable to change — you can just grab your API Key
& User ID
from them.
Set Voice
You will want to select playht
in the “provider” field, & Jennifer
in the “voice” field. We will leave all of the other settings untouched.
Each voice provider offers a host of settings you can modulate to customize voices. Here we will leave all the defaults alone.
5) Your Assistant Is Ready!
Our assistant is now ready to use for simple conversation.
For the sake of a quickstart, we only focused on the basics of setting the assistant’s model, transcriber, & voice — but Vapi is capable of tooling your agent much further (we will investigate these elsewhere).
Calling Your Assistant
Now that your assistant is fully setup & configured, we will want to contact it. There are 2 ways to “call in” to an assistant:
- Over the Internet: Network-enabled devices can contact Vapi via the Internet (i.e. web applications, mobile applications). No phone number is involved.
- Via Telephony: Phones can communicate to Vapi over a cellular network (i.e. phone call). One phone number dials to another phone number.
For our use case, it is most appropriate that customers will contact our assistant via an inbound phone call. Though, we will look at both ways of calling in.
Calling in the Dashboard
The quickest way to contact your new assistant is by simply using the call button on the assistant detail page:
Call into your assistant via the dashboard.
This will start a web call with your assistant, you can now speak to it to order your pizza & sides!
Calling in via Phone
Since our assistant is meant to take orders over the phone, we will want to set up inbound calling to our assistant. We will need to do 2 things:
- provision a new phone number to sit our agent behind (it will pick-up calls that come in — hence “inbound calling”)
- place our agent behind that phone number
If you already have your own phone numbers (purchased via Twilio or Vonage, etc), you can import them into Vapi for use. Learn more about telephony on Vapi.
Provision a Phone Number
The quickest way to secure a phone number for your assistant is to purchase a phone number directly through Vapi.
Phone numbers purchased through Vapi will charge directly to your account — learn more about phone calling & our pricing before proceeding.
Navigate to the “Phone Numbers” section & click the “Buy number” button:
Make sure you are in the 'Phone Numbers' dashboard tab.
We will use the area code 415
for our phone number (these are area codes domestic to the US & Canada).
Choose an area code for your phone number.
Currently, only US & Canada phone numbers can be directly purchased through Vapi. Phone numbers in other regions must be imported, see our phone calling guide.
Click “Buy”, after purchasing a phone number you should see something like this:
Here we can attach an assistant to the number for inbound calls (or perform an outbound call, with a select assistant).
Now we are ready to attach our order-taking assistant to the phone number to take orders!
Attach Your Assistant
In the Inbound
area of the phone number detail view, select your assistant in the dropdown under Assistant
.
Your assistant will now pick-up calls made to this phone number.
This will put your assistant behind the phone number for inbound calls. Your assistant is now ready to take calls.
Call the Number
You can now call the phone number & conversate with your assistant. Happy ordering!
Your assistant won’t yet be able to hang-up the phone at the end of the call. We will learn more about configuring call end behaviour in later guides.
Was this page helpful?