Deploying the Metaflowbot involves -
- Setting up the Metaflowbot on Slack, and
- Running the Metaflowbot server
- locally
- on AWS:
-
Create an App on Slack UI using the provided manifest. The default name of the Metaflowbot is
@flowey
. To customize the name of the Metaflowbot, changedisplay_information.name
andbot_user.display_name
in the manifest. -
Generate an App token (
SLACK_APP_TOKEN
): This token allows the Metaflowbot to make a socket connection to Slack and will be used later to configure the bot. -
Generate Bot token (
SLACK_BOT_TOKEN
) : This token allows the Metaflowbot to make web API calls and will be used later to configure the bot.
The Metaflowbot server is available as a pip package from PyPI and can be directly invoked.
-
Install
metaflowbot
Python package from PyPIpip install metaflowbot pip install metaflowbot-actions-jokes # Optional dependency
-
Launch the Metaflowbot server by providing
--admin
argument with the email address of your slack account; Metaflowbot will open a message thread with you to maintain it's state (as a poor man's database). ReplaceSLACK_APP_TOKEN
&SLACK_BOT_TOKEN
with the values obtained while setting up the Metaflowbot on Slack.SLACK_APP_TOKEN=xapp-foo SLACK_BOT_TOKEN=xoxb-bar python -m metaflowbot server --admin me@server.com
The Metaflowbot server is also available as a docker image from Docker Hub. There are multiple ways to configure the image; just ensure that ADMIN_USER_ADDRESS
environment variable points to your email address in the Slack workspace -
- through environment variables
docker run -i -t --rm \
-e SLACK_BOT_TOKEN=$(echo $SLACK_BOT_TOKEN) \
-e ADMIN_USER_ADDRESS=admin@server.com \
-e SLACK_APP_TOKEN=$(echo $SLACK_APP_TOKEN) \
-e AWS_SECRET_ACCESS_KEY=$(echo $AWS_SECRET_ACCESS_KEY) \
-e AWS_ACCESS_KEY_ID=$(echo $AWS_ACCESS_KEY_ID) \
-e USERNAME=metaflowbot \
-e METAFLOW_SERVICE_AUTH_KEY=$(echo $METAFLOW_SERVICE_AUTH_KEY) \
-e METAFLOW_SERVICE_URL=$(echo $METAFLOW_SERVICE_URL) \
-e METAFLOW_DATASTORE_SYSROOT_S3=$(echo $METAFLOW_DATASTORE_SYSROOT_S3) \
-e METAFLOW_DEFAULT_DATASTORE=s3 \
-e METAFLOW_DEFAULT_METADATA=service \
outerbounds/metaflowbot
- through
~/.metaflowconfig
.
docker run -it \
-v ~/.metaflowconfig:/metaflowconfig --rm \
-e SLACK_BOT_TOKEN=$(echo $SLACK_BOT_TOKEN) \
-e ADMIN_USER_ADDRESS=admin@server.com \
-e SLACK_APP_TOKEN=$(echo $SLACK_APP_TOKEN) \
-e AWS_SECRET_ACCESS_KEY=$(echo $AWS_SECRET_ACCESS_KEY) \
-e AWS_ACCESS_KEY_ID=$(echo $AWS_ACCESS_KEY_ID) \
-e USERNAME=metaflowbot \
-e METAFLOW_HOME=/.metaflowconfig \
outerbounds/metaflowbot
Metaflow bot ships with an AWS CloudFormation template that automates the deployment of all the necessary AWS resources. The template is provided in the deployment folder.
The major components of the template are:
- AWS Identity and Access Management - Set policies for accessing cloud resources and secrets needed for deployment.
- AWS VPC Networking - A VPC with public subnet and internet gateway to deploy Metaflowbot.
- AWS VPC Security Groups - Outbound traffic access for Metaflowbot's container.
- AWS ECS - Deploying the Metaflowbot's container as a Fargate task.
- AWS SecretsManager - Access to secrets holding authentication information about Slack and Metadata service.
Deploying the template requires a few auth tokens (for Slack and Metaflow Service); these need to be created in AWS Secrets Manager which are referenced in the CloudFormation template.
-
In your AWS Console for AWS Secrets Manager, create a secret with the auth tokens for Slack (
SLACK_APP_TOKEN
,SLACK_BOT_TOKEN
, ) and Metaflow Service (METAFLOW_SERVICE_AUTH_KEY
). Copy the ARN of the secret -
Paste the ARN of the secret along with other metadata + s3 related deployment details.
If you cannot use the AWS CloudFormation template, follow these steps for a manual deployment of Metaflowbot on AWS.
Please note that Metaflow bot can re-use existing AWS resources - for example, your existing ECS cluster for container deployment. The instructions listed here will create these resources from scratch. If you have a strong background in administering AWS resources, you will notice that many of the security policies are fairly permissive and are intended to serve as a starting point for more complex deployments. Please reach out to us if you would like to discuss more involved deployments.
- Open the Amazon VPC console and in the left navigation pane, choose VPC Dashboard.
- Choose Launch VPC Wizard,
- Choose VPC with a Single Public Subnet and press Select.
- For VPC name, give your VPC a unique name.
- Choose Create VPC.
- When the wizard is finished, choose OK.
- Open the IAM console and in the navigation pane, choose Roles, Create role.
- For Select type of trusted entity section, choose AWS service.
- For Choose the service that will use this role, choose Elastic Container Service.
- For Select your use case, choose Elastic Container Service Task and choose Next: Permissions.
- Choose AmazonECSTaskExecutionRolePolicy.
- Choose Next:tags.
- For Add tags (optional), enter any metadata tags you want to associate with the IAM role, and then choose Next: Review.
- For Role name, enter a name for your role and then choose Create role to finish. Note the ARN of the IAM role you just created.
- Open the IAM console and in the navigation pane, choose Roles, Create role.
- For Select type of trusted entity section, choose AWS service.
- For Choose the service that will use this role, choose Elastic Container Service.
- For Select your use case, choose Elastic Container Service Task and choose Next: Permissions.
- Next, we will create a policy for Amazon S3 and attach it to this role:
- Amazon S3 for data storage
- Choose Create Policy to open a new window.
- Use the visual service editor to create the policy
- For Service, choose S3.
- For Actions, add GetObject and ListBucket as allowed actions
- For resources, the bucket name should be the same as metaflow datastore S3 bucket. For object choose any for object name. Choose Save changes.
- Choose Review policy. On the Review policy page, for Name type your own unique name and choose Create policy to finish.
- Amazon S3 for data storage
- Click the refresh button in the original pane (in Step 4.) and choose the policy that you just created (in Step 5.). Choose Next:tags.
- For Add tags (optional), enter any metadata tags you want to associate with the IAM role, and then choose Next: Review.
- For Role name, enter a name for your role and then choose Create role to finish.
- Open the ECS console and from the navigation bar, select the region to use.
- Choose Create Cluster under Clusters.
- Choose Networking only, Next step.
- Pick a name for Cluster name. Don't enable Create VPC. We will use the VPC we have created previously. You can choose to check Enable Container Insights. Choose Create.
- Choose View Cluster and choose Task Definitions on the left side pane.
- Choose Create new Task Definition, Fargate and Next step.
- Under Configure task and container definitions,
- Choose a Task Definition Name.
- Choose the Task Role as the one you just created above.
- Under Task execution IAM role, set the Task execution role to ecsTaskExecutionRole or set it to the IAM role created for ECS execution. Leave it empty otherwise.
- Under Task size,
- Choose 8 GB for Task memory (GB)
- Choose 4 vCPU for Task CPU (vCPU).
- Under Container Definitions, choose Add container
- Set metaflowbot as the Container name.
- Set outerbounds/metaflowbot as the Image.
- Leave other options as is.
- Under Advanced container configuration, in Environment variables add the following values
- Set Key as ADMIN_USER_ADDRESS and the Value as the email address of the user in the slack workspace with whom the bot will open a message thread to store state related information.
- Set Key as METAFLOW_SERVICE_URL and the Value as the URL to the metadata service.
- Set Key as METAFLOW_DATASTORE_SYSROOT_S3 and the Value as S3 bucket URL for metaflow datastore.
- Set Key as METAFLOW_DEFAULT_DATASTORE and Value as s3.
- Set Key as METAFLOW_DEFAULT_METADATA and Value as service.
- Set Key as USERNAME and Value as slackbot.
- Set Key as SLACK_APP_TOKEN and Value as the SLACK_APP_TOKEN retrieved from [Slack].
- Set Key as SLACK_BOT_TOKEN and Value as the SLACK_BOT_TOKEN retrieved from [Slack].
- If your metadata service has an authentication key to it then Set Key as METAFLOW_SERVICE_AUTH_KEY and value as the authentication token of the metadata service.
- Choose Add.
- Choose Create.
- Under Configure task and container definitions,
- Choose Clusters in the left side pane and select the cluster you created in Step 4.
- Choose Create under Services,
- Choose Fargate as Lauch type.
- Choose the task definition that you created in Step 6. for Task Definition. Pick the latest for Revision.
- For Platform version choose Latest.
- Leave the Cluster as is (pointing to the cluster that you are configuring).
- Pick a name for Service name.
- Set 1 for Number of tasks.
- Choose Rolling update for Deployment type.
- Choose Next step.
- For Configure network,
- For Cluster VPC, choose the VPC that you have created previously.
- Choose the only public subnet.
- For Load balancing, choose None as Load balancer type.
- For Auto-assign public IP keep it as ENABLED.
- Choose Next step.
- Leave options in Set Auto Scaling (optional) to the default : Do not adjust the service’s desired count
- Choose Next step and Create Service.
- Choose View Service and wait for the task to get to the running state.
- Once the task is running, check if the slack bot is responding to messages in DM's or in a channel it is invited to.