-
Notifications
You must be signed in to change notification settings - Fork 3
Slack App Setup
To speed up app configuration, you can use the App Manifest. Make sure you replace <your-karmachest-domain>
with the appropriate value before importing.
First you'll want to setup the name of the app. You can provide anything you want, but KarmaChest
is recommended. You can set the bot display name separately (see below) so don't worry if that name is not available. Enter a description such as Team engagement through micro gratitude
. Select a color - the recommended default is blue (#3491c7
).
You may use the following avatar if you wish:
data:image/s3,"s3://crabby-images/14808/14808c9c7e1f04beaa47de1a89266404d10ab5ce" alt="display_info"
Ensure the following options are active:
- Enable Events
- Always Show My Bot as Online
data:image/s3,"s3://crabby-images/1b545/1b54592e948a17dab921e278d4612cfe0ec59633" alt="basic_info2"
You can name your bot separately from the app. Go to "App Home" and click "Edit" next to "App Display Name". Set the bot name to "KarmaChest" and the Default Name to "karmachest".
data:image/s3,"s3://crabby-images/07524/07524a7a97ac0cb2ae892903b676d570cf27783e" alt="app_display_name"
Ensure Home Tab is disabled. Enable Message Tab and allow users to send Slash commands from there.
data:image/s3,"s3://crabby-images/490d9/490d9adfe6347286d82fc86d7d29baacdfc26e9c" alt="show_tabs"
To enable the User ++
context action, enter it with reply_tip
Callback ID. Description should be Give 1 karma to the author of the message
.
data:image/s3,"s3://crabby-images/38d6c/38d6ce4a460e7797f0e9ab090afece4703e512f9" alt="shortcuts"
data:image/s3,"s3://crabby-images/43a49/43a495ca7f6f98cd18f6e86c3e7ea85b12a191ac" alt="shortcuts2"
Enter the Subscriptions Request URL as https://<your-karmachest-domain>/hooks/slack/event
.
For the initial setup, you'll need to respond with the appropriate challenge response. Uncomment before_action :verify_challenge_param
in https://github.com/jcraigk/karmachest/blob/master/app/controllers/hooks/slack/base_controller.rb#L6 during initial app integration.
data:image/s3,"s3://crabby-images/5151a/5151a784edc5d633762efe514851d168a13796c8" alt="event_subscriptions"
Subscribe to the following Bot Events:
- app_home_opened
- app_uninstalled
- channel_archive
- channel_created
- channel_deleted
- channel_rename
- channel_unarchive
- message.channels
- message.groups
- message.im
- reaction_added
- reaction_removed
- subteam_created
- subteam_members_changed
- subteam_updated
- team_join
- team_rename
- user_change
data:image/s3,"s3://crabby-images/1c747/1c74700b650264967905edffbfef46467af3ccb1" alt="bot_events1"
data:image/s3,"s3://crabby-images/f2f7d/f2f7dd76344b903f86391170e7c3cd80d10c4556" alt="bot_events2"
Enter the Interactivity Request URL as https://<your-karmachest-domain>/hooks/slack/action
.
data:image/s3,"s3://crabby-images/d9a4c/d9a4ca696eb1e67f272862f937638601fb3ce9e9" alt="interactivity"
Add the following redirect URLs:
https://<your-karmachest-domain>/oauth/slack_integration
https://<your-karmachest-domain>/oauth/callback/slack
data:image/s3,"s3://crabby-images/ec20a/ec20aa9a51f749758b37844a3576fd0d36e1e932" alt="redirect_urls"
Ensure the following OAuth scopes are enabled:
- channels:history
- channels:join
- channels:read
- chat:write
- commands
- emoji:read
- groups:history
- im:history
- im:read
- im:write
- mpim:history
- mpim:read
- reactions:read
- team:read
- usergroups:read
- users.profile:read
- users:read
data:image/s3,"s3://crabby-images/5a1e1/5a1e1414243342a1e9d718b58f6ce18909d3c467" alt="scopes1"
data:image/s3,"s3://crabby-images/e120f/e120fdf62bcbce19cafb114c1e946b48b24e66ad" alt="scopes2"
data:image/s3,"s3://crabby-images/742ec/742ec2710b2db29756b8320ddc6a3bf17af864c7" alt="scopes3"
Enter the following Options Load URL: https://<your-karmachest-domain>/hooks/slack/options
data:image/s3,"s3://crabby-images/b3e3b/b3e3b4b2ed762c9da34c9080ed333638f7999006" alt="select_menus"
You may provide any slash command but /karma
is recommended. Make sure config.base_command
matches this value in config/application.rb
(omit the leading slash).
data:image/s3,"s3://crabby-images/7118c/7118c8bdc438deb6bf6112759be4443c40f4e817" alt="slash_commands"
data:image/s3,"s3://crabby-images/e6141/e61417093da155e1dbb532dbd963743180a72390" alt="edit_command"
Add the following User Token Scopes to enable Slack-based logins:
- identity.basic
- identity.email
Note that logging into the KarmaChest website using Slack OAuth does not automatically associate the user profile. It is the same as logging in with any other OAuth provider in that the user must use the connect
command to associate their Slack profile with their web login after they authenticate.
data:image/s3,"s3://crabby-images/a24bd/a24bdf446ca823407237f01973f98857cc28536b" alt="user_token_scopes"