It turns out that you can not delegate slot collection to Alexa within the LaunchRequest
, because it is not part of a valid response type for LaunchRequest
.
My Initial logic was:
- User says 'Alexa, open party'
- Alexa Skill calls
LaunchRequest
. (At this point I need to ask the user for their pin by delegating Alexa to do slot colleciton)
- In the
LaunchRequest
, immidiately respond with this.emit(':getPinIntent');
where getPinIntent
is another intent existing in my Alexa Skill. The above code is what I saw on the internet for how to call another intent without the user having to provoke using voice.
getPinIntent
gets called and immediately it checks to see if all the required slots are filled (i.e. if the slot PIN
has a value). If they are not and dialogState !== 'COMPLETED'
then I delegate the slot collection to Alexa.
- The above step (#4) is where things go wrong. Because delegation is not a valid response type for
LaunchRequest
's, there is no field dialogueState
which is required for delegation to Alexa. The Alexa Request is still a LaunchRequest
instead of an Intent request because the user did not invoke the intent by saying something to Alexa.
- In conclusion this is not a valid way of completing a dialogue where upon launch the user is asked for a pin and then can reply by only saying that pin, visualized below:
User: "Alexa, open party"
Alexa: "What is your pin" (alexa never gets here, because of #4 and #5 above)
User: "one two three four"
Alexa: "Confirmed, what can I help you with?"
If I have made any mistakes or wrong assumptions please let me know.
My current logic has now changed. If you do not use the Skill Builder Beta you can have a slot exist as an utterance for one of your intents. So I now have getPinIntent
with a slot called {PIN}
and an utterance in the form of {PIN}
. This lets the above type of conversation happen because when the user says his or her pin back ("one two three four") it starts the getPinIntent
where I can then continue OR delegate the dialogue to Alexa because for IntentRequest
dialog is a valid response type.
The only problem I have now is that because I am not using the Skill Builder Beta I can not (or have not found a way) to add Dialogue Models to/inside of my Intent Schema. I have tried copying the JSON text from the Skill Builder Beta into my Intent Schema after adding the correct Dialogue Model, but this always results in build errors.
So now I can complete the user's pin authentication and respond with a "How can I help", but the IntentRequest that comes after that may require delegation to Alexa for slots, and this would cause a crash because without the Skill Builder Beta I am unable to add the appropriate dialogue models for Alexa to use during delegated slot collection.