Note: Please let me know if you follow the tutorial and are unable to setup a messenger bot successfully; I’d be happy to update the steps to make the tutorial more useful. Please submit an issue describing the problem or if you know the fix please feel free to submit a pull request to the repo with a modified README.
Steps:
I. AWS Stuff
Lambda Stuff
data:image/s3,"s3://crabby-images/2818c/2818ccaba35bc82bd730ee9f5bc1cdf21bd53a23" alt=""
API Gateway Stuff
-
Go to API Gateway
-
Create new api
- After clicking Create New API, select New API, and give your API a name & description
data:image/s3,"s3://crabby-images/044df/044df65c4daec7392810463b1ff86e5d1757ffab" alt=""
- Create a new resource
- Click Actions, select Create Resource from the dropdown menu, and give your resource a name & description
data:image/s3,"s3://crabby-images/88e3c/88e3c606ec7592282f7f63c817d22e091cb7eb26" alt=""
data:image/s3,"s3://crabby-images/84378/843782a2a3c1e13fbc8dc3296cbc8cb4ce91f71a" alt=""
- Deploy your API
- Click on your Resource in the list of Resources, click Actions, and select Deploy API
- Select the deployment stage and a description then click Deploy
- Copy the invoke URL for your API resource
- From the Stages page of your API click on your new resource you just created
- Save the Invoke URL that appears for use later
data:image/s3,"s3://crabby-images/20014/2001469e3b2997cf00ab1f693195ff1679b8c091" alt=""
II. Facebook Stuff
- Login/create account at developers.facebook.com
- Go to your app page & create a new app from the sidebar; fill in a display name and contact email & click create app id
data:image/s3,"s3://crabby-images/d9f4a/d9f4a01a2c7589065c60dd3a44a37cb34cee29ed" alt=""
- Generate Access Token
- Click Add Product in the sidebar of your new app’s dashboard and click Get Started in the messenger section
- Scroll down to the Token Generation section and select/create a page for your bot to send messages from
- Save the access token that is generated for later
data:image/s3,"s3://crabby-images/03e18/03e184545a81f236835595bde28a93748c47a9c3" alt=""
- Set up webhook
- Scroll down to the webhooks section of the messenger product settings and click setup webhooks
- Paste you Invoke URL from the API Gateway setup into the Callback URL field
- Make up a verification token and fill out the Verify Token field; save the token with the access token for use later
- Check all of the subscription fields for now
- Leave the window open, after some setup on the Lambda function we will be able to verify the webhook
data:image/s3,"s3://crabby-images/03c0a/03c0a18fbde672ceccd012bd422b010f26015840" alt=""
III. Deployment
- Define Environment Variables for your acces and verification tokens
- Navigate back to your Lambda function’s code tab and scroll to the bottom to the Environment Variables section
- Define 2 environment variables named
access_token
and verify_token
; paste in the values of your tokens saved during facebook setup
data:image/s3,"s3://crabby-images/ba366/ba366ebf7cabae0f6c63fb79e98a861036b761dd" alt=""
- Verify webhook
- Click Verify and Save on the New Page Subscription window
- The setup we’ve done with API Gateway & Lambda should lead to a successful verification
- Subscibe a page to your webhook
- Select the page who’s access token you set as the environment variable from the dropdown in the webhooks section and click subscribe
data:image/s3,"s3://crabby-images/4f83c/4f83cd0f0cfe53a249a90c1ce7a115d602af3b41" alt=""
- Test the bot
- Message the subscribed page through your facebook account
- If everything is set up correctly the bot should echo your message text back
data:image/s3,"s3://crabby-images/4f4ca/4f4cae980d29a605c9c3b0524f7d0751cf093a51" alt=""
- To make your bot available to other users you will have to submit it for approval
- Click add to submission in the App Review for Messenger section of your app’s messenger product settings
- A current submission section will appear and tell you what items you must take care of before submitting (I used privacypolicies.com for the privacy policy needed for approval)
data:image/s3,"s3://crabby-images/9f750/9f75037a0270ab1f56f2c3f91bda327409d5b8e1" alt=""
IV. Customizing Functionality
- To add more interesting functionality you can edit the lambda_handler function definition in lambda_function.py
- You can add whatever logic you want to produce a customized response
- Once you add the additional logic you can replace msg_txt in the send_message function call
data:image/s3,"s3://crabby-images/e26b4/e26b4f6d130eae15d156791623d85fdfccdedbb2" alt=""
- Sending Attachments
- An example of how to send attachments can be seen in here in a bot written to send a picture response from imgur
- You can try out using this bot yourself by uploading the imgur_lambda_env.zip as the lambda function to be set up just by using steps I-III of the tutorial (you’ll just need to add an imgur client id as the environment variable
imgur_client_id
)
- The imgur bot searches messages received on imgur and responds with a randomly selected picture from the search results
data:image/s3,"s3://crabby-images/1a2fe/1a2fe6216ef1a427c5609b4156014d0fd20a0502" alt=""
- Adding additional modules
- If you need add additional python modules to acheive your desired functionality you can follow this AWS Lambda tutorial for creating a python deployment package