reception-bot is the main repo for an Alexa-based reception that connects to Slack. There are five different components to allow Alexa to connect to Slack for two way communication. This repo is the starting point and will outline the primary setup of Slack, the Alexa Skill and necessary AWS services. There are two other repos for the backend which connects the Alexa Skill to your Slack users and allows user management.
The basic use case we developed for is enabling a visitor to your company to contact an employee via Alexa and Slack. Once the visitor finds the employee they are meeting, Alexa will send the employee a message with the visitor's name and reason for visit. The employee will be able to respond with one of three pre-determined responses, which Alexa will then relay to the visitor. If the employee does not respond within 30 seconds Alexa will interrupt to see if the visitor would like to continue, restart, exit or needs help.
- Log into https://api.slack.com/apps
- Click Create New App. Enter an app name and select the workspace associated with the app
- Add a Bot User by clicking the Bot Users item in the menu, change the name as needed and click Save Changes, you can optionally set Always Show My Bot as Online to On.
- Activate App to Workspace. Click on Install App on left hand menu and then click Install App to Workspace and then click Authorize
- In OAuth & Permissions menu you should now see tokens for OAuth Access Token and Bot User OAuth Access Token. You will need these later.
Clone or download https://github.com/thebarbariangroup/receptionbot-slackbot-be and https://github.com/thebarbariangroup/receptionbot-slackbot-fe. Further details on how to build and set up the apps are within the READMEs of the respective repos.
Create an account at https://developer.amazon.com/alexa
- In the main nav, go to Alexa Skill Kit, then Start a Skill.
- In the Alexa Developer Console, click Create Skill.
- Then enter a name for your skill and click Next.
- Select the "Custom Model" and click Create Skill. You will be taken to the Skill Builder interface.
- Click "JSON Editor" in the left panel under Interaction Model.
- Paste in the contents of this repo's
baseInteractionModel.json
, update the invocation name, then click "Save Model", then "Build Model". This will add the base data needed to run the skill, including intents, utterances, slots, and slot values.- Replace our placeholder invocation name with one of your choosing or the Build will error & fail
- We call ours "Barb" - RIP (???).
- Click "Interfaces" in the left panel below the "Interaction Model" tab, then toggle on the "Display Interface"
- Customize the model for your purposes
- Add to the "EmployeeFirstNames" slot values array
- It is not necessary to add an object (w/ value prop) for every unique first name in your directory, but it can help Alexa better understand the conversation.
- However, for names that are less common, foreign/"non-traditional" to the U.S., have a special/unique pronunciation, often mispronounced, nicknames, or are associated with nicknames, it is highly recommended that you add alternate pronunciations as
synonyms
in the slot's synonyms array. This allows Alexa to associate the pronunciation with the name value such that, when Alexa then matches the synonym during the visitor dialog, our skill will correctly display the desired value for the name. - Examples:
"name": { "value": "Will", "synonyms": [ "William", "Bill", "Billy"] }
"name": { "value": "Kyu", "synonyms": [ "Q", "Cue", "Kai you", "Key oo" ] }
- Add to the "EmployeeFirstNames" slot values array
- Build Model by clicking the Build Model button in the checklist
- After the model builds successfully, click on Endpoint
- Select AWS Lambda ARN
- Grab the Skill ID as an "AWS Lambda ARN" - you will need this to create your Lambda function.
- Create an AWS account and add a new Lambda Function via the AWS Developer Console
- Click the region drop-down (in the upper-right corner of the console) and select the appropriate region for your Alexa skill(s).
- Only 4 regions support Alexa Skills: Asia Pacific (Tokyo), EU (Ireland), US East (N. Virginia), or US West (Oregon)
- Click the region drop-down (in the upper-right corner of the console) and select the appropriate region for your Alexa skill(s).
- Name your function however you want
- Select "Node.js 6.10" runtime
- Defining a Role for the Lambda
- For Role (under Lambda function handler and role), select Create new role from template(s).
- Enter the Role Name.
- From the Policy templates list, select "Simple Microservice permissions".
- Click "Create Function"
- Add an "Alexa Skills Kit" trigger to the Lambda
- In "Configure Triggers", paste the Skill ID of your Alexa Skill that you copied from the Skill Builder.
- Add Environmental Variables. Create these new keys:
SLACK_API_TOKEN
- paste in the OAuth Access Token from your Slack app.SLACK_BOT_TOKEN
- paste in the Bot User OAuth Access Token from your Slack app.USER_API_TOKEN
- paste in the code generated in the backend application you set up earlier.APP_ID
- paste in the Alexa Skill ID.SERVER_URL
- the URL where you are hosting thereceptionbot-slackbot-be
FALLBACK_ID
- paste in the Slack ID for whichever user or channel you would like to set up as a "fallback", when the desired employee is unavailable.COMPANY_NAME
- your company name
- Under Basic Settings change the timeout to 1 minute.
- Save changes and copy the ARN which is located at the top right of the console. For reference: the code should start with
arn:aws:lambda:[selected-region]
and end with the name of your Lambda function - Return to your Alexa Skill in the Skill Builder.
- Paste your lambda ARN code into the Default Region field and click Save Endpoints
- Follow these installation instructions: https://docs.aws.amazon.com/cli/latest/userguide/installing.html
- Follow these configuration insturctions: https://docs.aws.amazon.com/cli/latest/userguide/cli-chap-getting-started.html
- Optional: install
cwtail
so you can view the Amazon AWS CloudWatch Logs from the command line. This comes in handy when debugging the skill. https://www.npmjs.com/package/cwtail
Pull down this repo, navigate into the lambda/
folder, and run npm install
. Make sure that you are using the same Node version being used for your Lambda's runtime.
- In
publish_lambda.sh
, replace[yourLambdaFunctionName]
and[yourProfileName]
with the name of your Lambda function name and your AWS profile name, respectively (if applicable). - Whenever you are ready to push your changes to your Lambda, run the
bash publish_lambda.sh
in the project root.
You can test your skill by using an actual Alexa View device, or by using the testing utility in the Skill Builder located under the "Test" tab.
Depending on your workflow, you may need the ability to develop separately in parallel with QA, or simply have testing and production codebases. You will need to create a separate skill (with unique invocation names) for each branch. These separate skills will then leverage the different branches/"aliases" of your lambda function.
- In a new tab, navigate to the Alexa Developer console and create a new skill
- If you intend to use the same skills on any single Alexa compatible device, the invocation name(s) need to be unique.
- Follow these instructions for creating Lambda aliases
- IMPORTANT: Before you publish a new version of your function, update the lambda's environment variable
APP_ID
with the new Alexa Skill ID and save. - Assign the alias to the new version
- Don't forget to set the APP_ID env variable back on your
$LATEST
version - Each alias now has a unique, qualified ARN
- IMPORTANT: Before you publish a new version of your function, update the lambda's environment variable
- In the lambda "Configuration" interface, you will need to add the "Alexa Skills Kit" trigger to your lambda alias
- Add the new Alexa Skill ID to the "Alexa Skills Kit" trigger configuration on the new lambda alias
NOTE: Amazon does not currently support custom environment variables by alias, only by version. :(
Since the default session management used by Alexa is per device we needed to find a way to track a session and the responses. Our solution is to record the sessionID created and the response in DynamoDB and check against the existing of the value. If the session has no response we continue contacting the user, if a response is found we alert the visitor to the response and end the session. In order to finish the conversation loop you will need to setup another lambda function, API Gateway and DynamoDB to track if a user has responded and get the response.
Log into your AWS Console and Click on DynamoDB.
- Click "Create a Table"
- Name the table "slackResponses" and use
sessionID
as the Primary key. - Click "Create"
##IAM From the AWS console select IAM
- Click on "Roles" on the left
- Click "Create Role"
- Select Lambda and click "Next: Permissions"
- Search for "AWSLambdaFullAccess" in the filter
- Check the box next to "AWSLambdaFullAccess" and click "Next: Review"
- Name the role and click "Create Role"
Log into your AWS Console and select Lambda
- Name your function however you want, we chose "reception_slack_response"
- Select "Node.js 6.10" runtime
- Keep Role as "Choose Existing Role" and then select the role created above
- Click "Create function"
- Add "API Gateway" as a trigger and then click "Save"
Return to the Services page of your AWS Console and open API Gateway
- Click on "+Create API"
- Enter "slack_responses" as the API name, use "Proxy for Lambda" as the description and leave all other values at default
- Click "Create API"
- In the page that opens click the "Actions" dropdown and select "Create Resource"
- In the new page enter "reception_slack_response" as the Resource Name and click "Create"
- Click on the "Actions" dropdown again and select "Create Method"
- A row with a select field will appear, click on the select field and choose ANY and then click the checkmark icon that appears
- In the new page that appears keep the Integration Type as-is, check "Use Lambda Proxy integration" and enter the name of the Lambda created in above.
- Click "Actions" and select "Deploy API"
- In the pop up modal, select the Deployment Stage select field and choose "[New Stage]"
- Enter whatever you want in the Stage name, "prod" or "stage" are common
- Copy the "Invoke URL" on the new page
Return to your slack app
- Go to "Interactive Components"
- Enter the Invoke URL you copied from API Gateway and paste into Request URL and add "/"
- Click "Save changes"