Work with Dialog Acts in Alexa Conversations
• GA:
en-US
, en-AU
, en-CA
, en-IN
, en-GB
, de-DE
, ja-JP
, es-ES
, es-US
• Beta:
it-IT
, fr-CA
, fr-FR
, pt-BR
, es-MX
, ar-SA
, hi-IN
Dialog acts describe how the user and Alexa interact to accomplish the task of invoking APIs to achieve a specific goal in a sample conversation.
There are two types of dialog acts: request acts and response acts. Request acts represent the purpose of user utterances. Response acts represent the purpose of Alexa responses.
The following sections describe supported flows of dialog acts within Alexa Conversations.
For a way to author your dialog to follow these guidelines, see Best Practices for Authoring Dialogs in Alexa Conversations. For details about all dialog acts, see Dialog Act Reference for Alexa Conversations.
- How to work with dialog acts at different stages
- Stage 1: The user or Alexa triggers the intention to invoke an API
- Stage 2: Alexa asks questions
- Stage 3: The user responds to Alexa
- Stage 4: Stages 2 and 3 repeat as needed
- Stage 5: Alexa invokes API(s)
- Related topics
How to work with dialog acts at different stages
The use of dialog acts is best described as a loop with five major stages and a goal of invoking API(s). At the beginning of the loop, assume that the dialog is in one of the following places:
- The first turn of a dialog (that is, the user input turn)
- After an Alexa response turn with the API Success or API Failure response act
- After an Alexa response turn with the built-in AlexaConversationsRequestMore response
From there, the stages are as follows:
- The user or Alexa triggers the intention to invoke an API.
- Alexa asks questions.
- The user responds to Alexa.
- Stages 2 and 3 repeat as needed.
- Alexa invokes API(s).
Stage 1: The user or Alexa triggers the intention to invoke an API
Because dialog authoring in Alexa Conversations is API-centric, you generally start by triggering the intention to invoke an API. As shown in the following table, you can accomplish this in one of the two ways.
If this... | ...then do this |
---|---|
The user input and sample utterances associated with the utterance set express an intention by the user to eventually invoke an API. |
Use the Invoke APIs request act and then go to Stage 2. |
The Alexa response expresses an offer to the user to eventually invoke another API with certain arguments pre-filled. |
Use the Offer Next API response act and then go to Stage 3. |
Stage 2: Alexa asks questions
The following table shows the priority of request acts you should follow in this stage to ensure a consistent user experience.
If this... | ...then do this |
---|---|
On the last user input turn, the user denied the previous Confirm API or Offer Next API response act. |
Set a response with the built-in AlexaConversationsRequestMore response and then go to Stage 3. |
The user denied a previous Confirm Args response act, and Alexa hasn't requested all the arguments to confirm yet. (There might be multiple requests to cover the entire set of arguments to confirm.) |
Go to Stage 3. |
Alexa already has sufficient information to invoke the API with the required arguments, and you want to make sure that all the required (and any number of optional) arguments are confirmed. |
Use the Confirm API response act and then go to Stage 3. |
Alexa doesn't have sufficient information to invoke the API with the required arguments, but you want to confirm a set of these arguments whenever the user provides them (and has a Request Args response act to fill the same set of arguments). |
Use the Confirm Args response act and then go to Stage 3. |
Alexa doesn't meet any of the previous criteria. That is, Alexa doesn't have enough information to call an API with the desired arguments and no user-informed value to fill for any argument. |
Use the Request Args response act to ask the user for a slot value to fill an API argument and then go to Stage 3. The user answers with a slot value or a full utterance that includes the slot value. |
None of these conditions are met. Alexa is ready to call an API with all desired arguments and nothing needs to be confirmed. |
Go to Stage 5. |
Stage 3: The user responds to Alexa
In this stage, the user responds to Alexa.
If this... | ...then do this |
---|---|
The previous Alexa response had the Offer Next API (with no arguments to request), Confirm API, or Confirm Args response act, and the user wants to affirm the arguments and/or the API. |
|
The previous Alexa response had the Offer Next API (with no arguments to request), Confirm API, or Confirm Args response act, and the user wants to deny the arguments and/or the API. |
|
The previous Alexa response had the Offer Next API response act (with arguments to request) and the user wants to provide arguments for the next API and then go to Stage 4. |
Use the Inform Args request act and then go to Stage 4. |
The previous Alexa response had the Offer Next API response act (with arguments to request) and the user wants to deny the arguments and/or the API. |
|
The previous Alexa response had the Request Args response act and the user wants to provide arguments. |
Use the Inform Args request act and then go to Stage 4. |
The user is responding to the built-in AlexaConversationsRequestMore response. |
Go to Stage 1 or end the dialog. |
Stage 4: Stages 2 and 3 repeat as needed
Repeat stages 2 and 3 until you are ready to invoke API(s).
Stage 5: Alexa invokes API(s)
In this stage, Alexa invokes API(s) and renders the API Success or API Failure response for the previous API.
If this... | ...then do this |
---|---|
Alexa is informing the user of the result of an API. |
Use the API Success or API Failure response act. |
You checked the slot value against pre-defined rules and prompt the user if it fails. The user can then respond with a corrected value. |
Use the API Failure response act followed by the Request Alt response act, and then go to Stage 3. |
Repeat stages 1 through 5 until all tasks in the dialog are accomplished.
Related topics
- Dialog Act Reference for Alexa Conversations
- Write Dialogs for Alexa Conversations
- Get Started with Alexa Conversations
Last updated: Nov 27, 2023