A sample AWS Lambda function that demonstrates the following use cases for Salesforce:
- Create a new lead
- Check an Opportunity status by name
- Get new leads for today
- Check my calendar for today
See this video for a quick demo.
The application uses nforce with Amazon Lambda in a single user model. I could have easily used Heroku to host the application but most of the AWS samples use Lambda and it's dead simple to use.
"Alexa, ask Salesforce for my new leads"
"Alexa, ask Salesforce to create a lead"
"Alexa, ask Salesforce for opportunity Edge SLA"
"Alexa, ask Salesforce for my calendar for today"
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.
- Name the Lambda Function "Salesforce_Skill".
- Go to the the src directory, select all files and folders and then create a zip file, make sure the zip file does not contain the src directory itself, otherwise Lambda function will not work.
- 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 execution role and click create.
- Return to the main Lambda page, and click on "Events Sources" tab and click "Add Event Source".
- Choose Alexa Skills Kit and click submit.
- Copy the ARN from the upper right to be used later in the Alexa Skill Setup
- Go to the Alexa Console and click Add a New Skill.
- Set "Salesforce" as the skill name and "salesforce" as the invocation name, this is what is used to activate your skill. For example you would say: "Alexa, Ask Salesforce for for my new leads."
- Select the Lambda ARN for the skill Endpoint and paste the ARN copied from above. Click Next.
- 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 index.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.
- Your skill is now saved and once you are finished testing you can continue to publish your skill.