A simple AWS Lambda function that demonstrates how to write a skill for the Amazon Echo using the Alexa SDK.
This sample shows how to create a Lambda function for handling Alexa Skill requests that:
- Multiple slots: has 2 slots (name and score)
- Database Interaction: demonstrates how to read and write data to DynamoDB.
- NUMBER slot: demonstrates how to handle number slots.
- Custom slot type: demonstrates using custom slot types to handle a finite set of known values
- Dialog and Session state: Handles two models, both a one-shot ask and tell model, and a multi-turn dialog model. If the user provides an incorrect slot in a one-shot model, it will direct to the dialog model. See the examples section for sample interactions of these models.
To run this example skill you need to do two things. The first is to deploy the example code in lambda, and the second is to configure the Alexa skill to use Lambda.
- Go to the AWS Console and click on the Lambda link. Note: ensure you are in us-east or you won't be able to use Alexa with Lambda.
- Click on the Create a Lambda Function or Get Started Now button.
- Skip the blueprint
- Name the Lambda Function "Score-Keeper-Example-Skill".
- Select the runtime as Node.js
- Go to the the src directory, select all files and then create a zip file, make sure the zip file does not contain the src directory itself, otherwise Lambda function will not work.
- Select Code entry type as "Upload a .ZIP file" and then upload the .zip file to the Lambda
- Keep the Handler as index.handler (this refers to the main js file in the zip).
- Create a "Basic with DynamoDB" role and click create.
- Leave the Advanced settings as the defaults.
- Click "Next" and review the settings then click "Create Function"
- Click the "Event Sources" tab and select "Add event source"
- Set the Event Source type as Alexa Skills kit and Enable it now. Click Submit.
- Copy the ARN from the top right to be used later in the Alexa Skill Setup.
- Go to the AWS Console and click on DynamoDB link. Note: ensure you are in us-east (same as your Lambda)
- Click on CreateTable: set "ScoreKeeperUserData" as the table name, use Hash for the primary key type and set "CustomerId" as the hash attribute name.
- Continue the steps with the default settings to finish the setup of DynamoDB table.
- Go to the Alexa Console and click Add a New Skill.
- Set "ScoreKeeper" for the skill name and "score keeper" as the invocation name, this is what is used to activate your skill. For example you would say: "Alexa, Ask score keeper for the current score."
- Select the Lambda ARN for the skill Endpoint and paste the ARN copied from above. Click Next.
- Copy the custom slot types from the customSlotTypes folder. Each file in the folder represents a new custom slot type. The name of the file is the name of the custom slot type, and the values in the file are the values for the custom slot.
- Copy the Intent Schema from the included IntentSchema.json.
- Copy the Sample Utterances from the included SampleUtterances.txt. Click Next.
- [optional] go back to the skill Information tab and copy the appId. Paste the appId into the scoreKeeper.js file for the variable APP_ID, then update the lambda source zip file with this change and upload to lambda again, this step makes sure the lambda function only serves request from authorized source.
- You are now able to start testing your sample skill! You should be able to go to the Echo webpage and see your skill enabled.
- In order to test it, try to say some of the Sample Utterances from the Examples section below.
- Your skill is now saved and once you are finished testing you can continue to publish your skill.
User: "Alexa, tell score keeper to reset."
Alexa: "New game started without players. Who do you want to add first?"
User: "Add the player Bob"
Alexa: "Bob has joined your game"
User: "Add player Jeff"
Alexa: "Jeff has joined your game"
(skill saves the new game and ends)
User: "Alexa, tell score keeper to give Bob three points."
Alexa: "Updating your score, three points for Bob"
(skill saves the latest score and ends)
User: "Alexa, ask score keeper what's the current score?"
Alexa: "Jeff has zero points and Bob has three"