In the first step of this guide, we built the Voice User Interface (VUI) for our Alexa skill. On this page, we will be creating a Lambda function using Amazon Web Services. You can read more about what a Lambda function is, but for the purposes of this guide, what you need to know is that Lambda is where our code lives. When a user asks Alexa to use our skill, it is our Lambda function that interprets the appropriate interaction, and provides the conversation back to the user.
-
Go to http://aws.amazon.com and sign in to the console. If you don't already have an account, you will need to create one. Check out this quick walk-through for setting up a new AWS account.
-
Choose "Services" at the top of the screen, and type "Lambda" in the search box. You can also find it in the list of services. It is in the "Compute" section.
-
Check your AWS region. Lambda only works with the Alexa Skills Kit in four regions: US East (N. Virginia), EU (Ireland), US West (Oregon) and Asia Pacific (Tokyo). Make sure you choose the region closest to your customers.
-
Click the "Create a Lambda function" button. It should be near the top of your screen.
-
Click on "Author from scratch". We will configure our Lambda function next.
-
These values will only ever be visible to you, but make sure that you name your function something meaningful. "sampleJavaHowTo" is sufficient if you don't have another idea for a name.
-
From the "Runtime" dropdown select Java 8.
-
Set up your Lambda function role. If you haven't done this before, we have a detailed walk-through for setting up your first role for Lambda. If you have done this before, you only need to select the Existing role.
-
Click Create function.
-
-
Configure your trigger. There are many different AWS services that can trigger a Lambda function, but for the purposes of this guide, we need to select "Alexa Skills Kit." from the left hand side.
Once you have selected Alexa Skills Kit, scroll down and find the Skill ID verification section. Although you will want to paste your skill's ID in the Skill ID field, however for this tutorial, click Disable. Click the Add button in the lower right. Click the orange Save button in the top right corner.
-
Finish configuring your function. Click on your function's name (you'll find it in the middle) and scroll to
Function code
. You have an option of either uploading your code as a zip file, as a JAR file and from an Amazon S3 bucket.To build the JAR file and properly upload this code to Lambda, you'll need to perform the following:
- This skill uses the ASK SDK for Java for development. To build the sample, open a terminal and go to the directory containing pom.xml, and run
mvn org.apache.maven.plugins:maven-assembly-plugin:2.6:assembly -DdescriptorId=jar-with-dependencies package
. This will generate a JAR file named "HowTo-1.0-jar-with-dependencies.jar" in the target directory. - On the AWS Lambda console, change the code entry type drop-down to Upload a .zip file or .jar file, upload the generated JAR file in AWS lambda console and enter
com.amazon.ask.howto.HowToStreamHandler
(fully qualified name of the stream handler) in theHandler
text box. and click on Save.
(Optional) Follow the ASK Java SDK Getting Started documentation, to check alternative ways of installing the sdk and deploying to AWS Lambda console.
- This skill uses the ASK SDK for Java for development. To build the sample, open a terminal and go to the directory containing pom.xml, and run
-
(Optional) Click the Configure test events dropdown menu on the top of the page.
- Select 'Alexa Start Session' from the 'Event Template' dropdown.
- Type
LaunchRequest
into the 'Event Name' field. - Click the orange 'Create' button at the bottom of the page
- Click the Test button at the top of the page.
- You should see a light green box with the message: Execution result: succeeded at the top of the page.
-
As a final step, copy the ARN value from the top right corner of the screen. You will need this value in the next section of this guide.