Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

351 documentation update #354

Merged
merged 7 commits into from
Nov 28, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
42 changes: 39 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,14 @@ A Phoenix app that supports the following slash commands from Slack:
```
git clone https://github.com/revelrylabs/slax
./bin/setup
./bin/server
```

## Configuration

The [/bin/setup](https://github.com/revelrylabs/slax/blob/master/bin/setup) script should add a `config/dev.secret.exs` file. Use this to put secrets into.
[/config/runtime.exs](https://github.com/revelrylabs/slax/blob/master/config/runtime.exs) is a good example of what secrets are needed as that file is used to setup secrets in produciton.
[/config/runtime.exs](https://github.com/revelrylabs/slax/blob/master/config/runtime.exs) is a good example of what secrets are needed as that file is used to setup secrets in produciton. (only the configs listed in the following sections are needed for the currently used functionality)

You will need to create a GitHub OAuth app in order to use the GitHub functionality, including authentication.
You will need to create a GitHub OAuth app in order to use the GitHub functionality, including authentication, and a Slack workspace and app.

### Create Github OAuth App

Expand All @@ -42,9 +41,46 @@ config :slax, Slax.Github,
org_teams: ["<my_org_team>"]
```

### Create Slack App
- Go to https://slack.com/get-started#/createnew and create a workspace for testing
- Go to https://api.slack.com/apps
- Click "Create New App" and select "From an app manifest"
- Select your new Slack workspace
- Copy slack-manifest.yml into the field and create the App
- Click "Install to Workspace" and allow it in your workspace
- Generate an app-level token with the "connections:write" scope and copy the generated token into `config/dev.secret.exs`
- Go to the `Install App` menu and copy the Bot User OAuth Token into `config/dev.secret.exs`

```elixir
config :slax, Slax.Slack,
api_url: "https://slack.com/api",
api_token: "<bot_user_oauth_token>",
channel_name: "<default_post_channel>",
app_token: "<app_level_token>"
```

## Usage / Commands

```./bin/server```
All commands provide usage details when executing them without any parameters.
> **_NOTE:_** Issue / PR lookup and pokerbot require a fine grained access token be setup for the specified repos with the `/token` command

### /token
This is a slack shortcut that is an interactive series of modals to setup project repo connections in the database as well as store fine grained access tokens to enable issue lookup and poker functionality. **This is necessary** for proper functionality of Issue/PR lookup and Poker.

The first modal you see lets you select a Repo and attach an access token and expiration date to it.
The second modal is accessed by clicking Create Repo and lets you either select or create a new Project and attach a Repo to the Project

To generate a fine grained access token go to https://github.com/settings/tokens?type=beta and fill out the form. Check `Only Select Repositories` and select the desired repo(s). Under Repository Permissions, give at least Read and write to `Issues` and Read only to `Pull Requests`. Extra setup video for Github Access tokens with different permissions: https://www.loom.com/share/43993db839d14fbd86a9ce344e17b7fb
> **_NOTE:_** For third party organizations, fine grained access tokens must be enabled.

### Issue & PR lookup
With the websocket connection slax parses every message for the specified patterns corresponding to an issue `org/repo#1` `repo#1` or a PR `org/repo$1` `repo$1`.

### /poker
This command is the interaction point for the poker feature and when just typing `/poker` it will respond with a help message on how to use it.

### _The following commands have not been tested or used in a while_

### /auth

Expand Down
33 changes: 33 additions & 0 deletions slack-manifest.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
display_information:
name: Slax
features:
bot_user:
display_name: Slax
always_online: false
shortcuts:
- name: Token
type: global
callback_id: access_token
description: Register access token
slash_commands:
- command: /poker
description: poker
should_escape: false
oauth_config:
scopes:
user:
- channels:history
bot:
- channels:history
- chat:write
- chat:write.public
- commands
settings:
event_subscriptions:
user_events:
- message.channels
interactivity:
is_enabled: true
org_deploy_enabled: false
socket_mode_enabled: true
token_rotation_enabled: false