Learn more about how to implement the Alexa CanFulfillIntentRequest
feature in your Jovo project.
The name-free interaction allows Amazon to map user requests, which don't specify a skill and can't be handled by Alexa's built in features, to be mapped to a developer's skill that can handle it.
For example, the user might make the following request: Alexa, play relaxing sounds with crickets. Alexa's built-in features can't handle the request so the system looks for third party skills to fulfill it.
The system will then send CanFullIntentRequests
the skills it believes might be able to fulfill the request. According to the response to that requests (yes
, no
or maybe
) your skill will receive an IntentRequest
just as if it the skill was invoked my the customer directly.
To enable the CanFulfillIntentRequest
feature you have to enable the interface in your skill's information. You can do that either in the Alexa Developer Console in the Interfaces
subcategory or you do it with the Jovo CLI.
Open your project.js
file and add the following to your alexaSkill
object:
alexaSkill: {
manifest: {
apis: {
custom: {
interfaces: [
{
type: 'CAN_FULFILL_INTENT_REQUEST',
}
],
},
},
},
},
Don't forget to build and deploy your project after you've added the interface:
# Build platform specific files
$ jovo build
# Deploy to platforms
$ jovo deploy
Incoming CanFulfillIntentRequests
will be mapped to the Jovo built in CAN_FULFILL_INTENT
.
CAN_FULFILL_INTENT() {
},
After receiving an CanFulfillIntentRequest
you have to answer the following question: Can my skill understand and fulfill every slot as well as understand and fulfill the whole request?.
Since every Skill is different, there is no universal recipe to use. You have to come up with our own way to handle these requests, which suits your skill, but there is a rough guideline:
The first step should be to check if the incoming intent is one, that your skill can handle. You can get the incoming intent name using this.getIntentName()
You also have to go over every slot in the request and decide if you can understand (YES
, NO
or MAYBE
) and fulfill (YES
or NO
) the slot.
Use this.$inputs
to get an object containing every slot. Iterate over the object and decide for each slot if you can understand it or not using:
this.canFulfillSlot(slotName, canUnderstandSlot, canFulfillSlot);
After going through the slots, you have to decide if you can also handle the whole request (YES
, NO
or MAYBE
):
this.canFulfillRequest();
// or
this.cannotFulfillRequest();
// or
this.mayFulfillRequest();
It is recommended to go over the official Amazon documentation (here and here) to get a better grasp about when to respond with YES
, NO
or MAYBE
as well as other guidelines.