Amazon EventBridge - Slack Notification on Event
data:image/s3,"s3://crabby-images/1de6f/1de6fc71b77cd4a3bca7e8749d9dc72a402b5f61" alt="Amazon EventBridge - Slack Notification on Event"
Amazon EventBridge is the solution to an ever-growing demand for globally managed events as a service. The primary use case for EventBridge, and where most of the hype is; is in the SaaS space, which aims to provide a decoupled way for vendors and customers to share a common event bus. In this example we're only going to cover a simple use case that was already possible with CloudWatch events; I figure it's still useful to give people a basic use case for EventBridge while they get their head around it.
Overview
We're going to be deploying a very simple Slack bot that alerts our channel on a log-in Event from CloudTrail. The code for this exercise is available at waanimalsinc/waanimals-sign-in-event-bridge.
Slack Setup
To start with we need a Slack bot setup that can be used to send messages to our channel. To set up a new Slack App, navigate to https://api.slack.com/apps and create a new app.
data:image/s3,"s3://crabby-images/a9a04/a9a04096bba79a2c3bd9357fca46b07748187d44" alt="EventBridge Slack Setup 1"
Once you've named and selected your Slack group, go to the OAuth scope section of the app setup and ensure chat:write:bot is selected
data:image/s3,"s3://crabby-images/39e98/39e98148f7914b3b2deb50fd1f290b868065d4c4" alt="EventBridge Slack Setup 2"
Then click Install App to Workspace
data:image/s3,"s3://crabby-images/2258e/2258e85b12958b2d31b7578774321cf7503c8266" alt="EventBridge Slack Setup 3"
Finally, make note of the OAuth token you are provided; we'll be using this shortly in our Serverless code
data:image/s3,"s3://crabby-images/9ab8b/9ab8b309425911c8917643bd69b5ba3c9707c192" alt="EventBridge Slack Setup 4"
Serverless Lambda Setup
Next, we need to create a simple Lambda function that will be triggered by the Amazon EventBridge. To do this we'll use Serverless.
I recommend pulling down my repository to work with:
git clone https://github.com/waanimalsinc/waanimals-sign-in-event-bridge.git
If you choose to create a new Serverless project to work with, ensure you have the following:
serverless.yml
service: waanimals-sign-in-event-bridge
custom:
pythonRequirements:
dockerizePip: true
environment: ${file(env.yml):dev}
provider:
name: aws
stage: dev
region: ap-southeast-2
runtime: python3.7
environment:
SLACK_API_TOKEN: ${self:custom.environment.SLACK_API_TOKEN}
SLACK_CHANNEL_ID: ${self:custom.environment.SLACK_CHANNEL_ID}
functions:
alert:
handler: handler.alert
plugins:
- serverless-python-requirements
requirements.txtEventBridge Setup 1
requests
handler.py
import json
import requests
import os
slack_token = os.environ['SLACK_API_TOKEN']
slack_channel_id = os.environ['SLACK_CHANNEL_ID']
def alert(event, context):
account = event['account']
user = event['detail']['userIdentity']['arn']
data = {
"channel": slack_channel_id,
"text": "Login to account %s with the identity %s" % (account, user)
}
resp = requests.post("https://slack.com/api/chat.postMessage", headers={
'Content-Type': 'application/json;charset=UTF-8', 'Authorization': 'Bearer %s' % slack_token}, json=data)
return {}
env.yml
Replace the SLACK_API_TOKEN
with the OAuth token you received when creating the Slack bot.
dev:
SLACK_API_TOKEN: "xoxp-xxxxxxxxxxxx-xxxxxxxxxxxxx-xxxxxxxxxxx-xxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
SLACK_CHANNEL_ID: "tech_development"
Other
Also, ensure that the serverless-python-requirements plugin is installed in the serverless project by running the following:
serverless plugin install -n serverless-python-requirements
Serverless Lambda Deploy
Deploy the lambda by running the following command
serverless deploy --stage dev
EventBridge Setup
Head over to the EventBridge portal and create a new Rule.
data:image/s3,"s3://crabby-images/b0035/b0035245d0d77fc9ab2b91b42678857eef622c9b" alt="EventBridge Setup 1"
Define a new Pattern and ensure you setup an AWS Console Sign-in service event
data:image/s3,"s3://crabby-images/e3452/e3452197cea52d8e0e20f41f3acee014d419e86a" alt="EventBridge Setup 2"
Finally, select the Lambda function that we just deployed with Serverless
data:image/s3,"s3://crabby-images/19abd/19abd923fd065d2d116901c7da1e3ecfad79adb7" alt="EventBridge Setup 3"
Testing
To test the event, log in to the account you deployed the resources in and you should see a message similar to below
data:image/s3,"s3://crabby-images/629a1/629a13ca501a5e4b80c9970988aa44dd4f332ad0" alt="EventBridge Slack message test"