Slack
Slack integration let you act on connections that has review or jit plugin enabled, it sends notification letting you approve sessions directly from a channel in slack.
Requirements
- Privileges to create an application on slack
- Privileges to install the new app in a workspace
- Admin user on hoop
App Installation - Slack
- Create a slack app from an app manifest
- Select the workspace and click next and paste the manifest below
{"display_information":{"name":"hoop","description":"An app to interact with a hoop gateway instance","background_color":"#7a7879"},"features":{"bot_user":{"display_name":"Hoop Bot","always_online":true},"slash_commands":[{"command":"/hoop","description":"Subscribe to notifications sent by Hoop","usage_hint":"subscribe","should_escape":false}]},"oauth_config":{"scopes":{"bot":["app_mentions:read","channels:read","chat:write","commands","im:write","channels:manage","groups:write","mpim:write"]}},"settings":{"event_subscriptions":{"bot_events":["app_mention"]},"interactivity":{"is_enabled":true},"org_deploy_enabled":false,"socket_mode_enabled":true,"token_rotation_enabled":false}}
- Follow the guide and click on Install to Workspace
- Scroll below and create an App-Level Token and copy the token
- Token Name:
hoop
- Scopes:
connections:write
,app_configurations:write
- Token Name:
- Go to Install App on the left side bar and copy the Bot User Oauth Token
Lastly, invite the bot in the slack channel that you wish to receive notifications typing the name of the bot @hoop
App Installation - Hoop
In this step the slack bot and app level tokens are required to configure the plugin.
- Login to your hoop instance:
hoop login
- Create the slack plugin
hoop admin create plugin slack \
--overwrite \
--config SLACK_BOT_TOKEN=xoxb-... \
--config SLACK_APP_TOKEN=xapp-... \
--config SLACK_CHANNEL=<your-slack-channel>
Now it's possible to associate connections to the slack plugin in the webapp
Subscribe to Notifications
To subscribe and signup to receive notifications from the Hoop Bot, type /hoop subscribe
and access the generated link. After sign in the user will start to receive notification when there's a review approved and ready to be executed.
Subscribing Manually
To add approvers that are allowed to review sessions, fetch the slack id of the user and update it using the command line.
hoop admin create user <approver@domain.tld> --overwrite \
--groups admin,sre \
--slackid <SLACK-USER-ID>
Copy the Slack ID
- In the slack app, click on the top right corner in your profile photo
- Select Profile
- Click on the more options button (see image below) and copy the member's ID
You can copy the id of other members too on slack.
Usage
To be able to use it, the review plugins must be enabled for a connection. When trying to interacting with it, it will send a message to the configured slack channel.
- Enable the review plugin
hoop admin create plugin review --overwrite
- Associate the connection with the
review
andslack
plugin
hoop admin create conn bash \
--overwrite \
--agent default \
--plugin 'review:admin;sre' \
--plugin slack \
-- bash
Then, interacting with the connection will send a message on your slack channel. After it's approved it will send a message to the creator.
# jit notification
hoop connect bash
# exec notificattion
hoop exec bash 'ls'