Sample project to demonstrate how to create a lambda function in Python that can be used in an Alexa Skill.
This project is not meant to be a tutorial on Alexa development. For that please see the Amazon documentation at:
Youtube video for this project.
https://www.youtube.com/watch?v=WFWAK175p2g
https://developer.amazon.com/public/solutions/alexa/alexa-skills-kit
The AlexaBaseHandler class is an abstract class that provides the necessary framework to build the necessary response hooks for an Alexa application.
This method will take the 2 parameters that are sent to the lambda function and determine which of the Alexa handlers to invoke. This method ( from the Alexa color example ) will put together the speechlet portion into a properly formatted json message. This is typically called by the concrete implementations of the AlexaBaseHandler. This method (from the Alexa color example ) will construct a property formatted response message so the Amazon Echo knows what to reponse with. This class is a reference implementation that does nothing useful. All Alexa handlers are handled the same way. This file contains the main entry point of the lambda function that is called for the Alexa skill. This method ( which can be called anything, you just need to configure it in the lambda handler ), is the method that is called with the 2 parameters.This method will typically instantiate an concrete implementation of the AlexaBaseHandler and delegate to the process_request method.
This file is the standard Python requirements file. This file is used by the create_deployment.py script to install the necessary 3rd party libraries that your Alexa skill might need. Any library specified in the requirements.txt file will be installed into your deployment directory. This script creates a zip file per the Amazon lambda specification, such that it is suitable to upload as your lambda function implementation.All deployments are stored in the deployments subdirectory and follow the naming convention of 'deployment_n' and 'deployment_n.zip', where 'n' is automatically calculated to the next largest 'n' in the directory. Right now it does this based on the name of the subdirectories of deployments - NOT - the names of the zip files.
The deployment script will create a deployment directory and zip file for
everything in the requirements.txt file AND the files in the deployment_files
variable in the create_deployment.py file.
When this script is done running, there should be a 'deploment_n.zip' file in the deployments directory. It is that file that needs to be upload to the Amazon Lambda console.
http://docs.aws.amazon.com/lambda/latest/dg/python-programming-model-handler-types.html http://docs.aws.amazon.com/lambda/latest/dg/lambda-python-how-to-create-deployment-package.html