* feat: add Slack channel skill (/add-slack) Slack Bot integration via @slack/bolt with Socket Mode. Can replace WhatsApp entirely (SLACK_ONLY=true) or run alongside it. - SlackChannel implementing Channel interface (46 unit tests) - Socket Mode connection (no public URL needed) - @mention translation (Slack <@UBOTID> → TRIGGER_PATTERN) - Message splitting at 4000-char Slack API limit - Thread flattening (threaded replies delivered as channel messages) - User name resolution with caching - Outgoing message queue with flush-on-reconnect - Channel metadata sync with pagination - Proper Bolt types (GenericMessageEvent | BotMessageEvent) - Multi-channel orchestrator changes (conditional channel creation) - Setup guide (SLACK_SETUP.md) and known limitations documented Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * local settings * adjusted when installing --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
150 lines
4.9 KiB
Markdown
150 lines
4.9 KiB
Markdown
# Slack App Setup for NanoClaw
|
|
|
|
Step-by-step guide to creating and configuring a Slack app for use with NanoClaw.
|
|
|
|
## Prerequisites
|
|
|
|
- A Slack workspace where you have admin permissions (or permission to install apps)
|
|
- Your NanoClaw instance with the `/add-slack` skill applied
|
|
|
|
## Step 1: Create the Slack App
|
|
|
|
1. Go to [api.slack.com/apps](https://api.slack.com/apps)
|
|
2. Click **Create New App**
|
|
3. Choose **From scratch**
|
|
4. Enter an app name (e.g., your `ASSISTANT_NAME` value, or any name you like)
|
|
5. Select the workspace you want to install it in
|
|
6. Click **Create App**
|
|
|
|
## Step 2: Enable Socket Mode
|
|
|
|
Socket Mode lets the bot connect to Slack without needing a public URL. This is what makes it work from your local machine.
|
|
|
|
1. In the sidebar, click **Socket Mode**
|
|
2. Toggle **Enable Socket Mode** to **On**
|
|
3. When prompted for a token name, enter something like `nanoclaw`
|
|
4. Click **Generate**
|
|
5. **Copy the App-Level Token** — it starts with `xapp-`. Save this somewhere safe; you'll need it later.
|
|
|
|
## Step 3: Subscribe to Events
|
|
|
|
This tells Slack which messages to forward to your bot.
|
|
|
|
1. In the sidebar, click **Event Subscriptions**
|
|
2. Toggle **Enable Events** to **On**
|
|
3. Under **Subscribe to bot events**, click **Add Bot User Event** and add these three events:
|
|
|
|
| Event | What it does |
|
|
|-------|-------------|
|
|
| `message.channels` | Receive messages in public channels the bot is in |
|
|
| `message.groups` | Receive messages in private channels the bot is in |
|
|
| `message.im` | Receive direct messages to the bot |
|
|
|
|
4. Click **Save Changes** at the bottom of the page
|
|
|
|
## Step 4: Set Bot Permissions (OAuth Scopes)
|
|
|
|
These scopes control what the bot is allowed to do.
|
|
|
|
1. In the sidebar, click **OAuth & Permissions**
|
|
2. Scroll down to **Scopes** > **Bot Token Scopes**
|
|
3. Click **Add an OAuth Scope** and add each of these:
|
|
|
|
| Scope | Why it's needed |
|
|
|-------|----------------|
|
|
| `chat:write` | Send messages to channels and DMs |
|
|
| `channels:history` | Read messages in public channels |
|
|
| `groups:history` | Read messages in private channels |
|
|
| `im:history` | Read direct messages |
|
|
| `channels:read` | List channels (for metadata sync) |
|
|
| `groups:read` | List private channels (for metadata sync) |
|
|
| `users:read` | Look up user display names |
|
|
|
|
## Step 5: Install to Workspace
|
|
|
|
1. In the sidebar, click **Install App**
|
|
2. Click **Install to Workspace**
|
|
3. Review the permissions and click **Allow**
|
|
4. **Copy the Bot User OAuth Token** — it starts with `xoxb-`. Save this somewhere safe.
|
|
|
|
## Step 6: Configure NanoClaw
|
|
|
|
Add both tokens to your `.env` file:
|
|
|
|
```
|
|
SLACK_BOT_TOKEN=xoxb-your-bot-token-here
|
|
SLACK_APP_TOKEN=xapp-your-app-token-here
|
|
```
|
|
|
|
If you want Slack to replace WhatsApp entirely (no WhatsApp channel), also add:
|
|
|
|
```
|
|
SLACK_ONLY=true
|
|
```
|
|
|
|
Then sync the environment to the container:
|
|
|
|
```bash
|
|
mkdir -p data/env && cp .env data/env/env
|
|
```
|
|
|
|
## Step 7: Add the Bot to Channels
|
|
|
|
The bot only receives messages from channels it has been explicitly added to.
|
|
|
|
1. Open the Slack channel you want the bot to monitor
|
|
2. Click the channel name at the top to open channel details
|
|
3. Go to **Integrations** > **Add apps**
|
|
4. Search for your bot name and add it
|
|
|
|
Repeat for each channel you want the bot in.
|
|
|
|
## Step 8: Get Channel IDs for Registration
|
|
|
|
You need the Slack channel ID to register it with NanoClaw.
|
|
|
|
**Option A — From the URL:**
|
|
Open the channel in Slack on the web. The URL looks like:
|
|
```
|
|
https://app.slack.com/client/TXXXXXXX/C0123456789
|
|
```
|
|
The `C0123456789` part is the channel ID.
|
|
|
|
**Option B — Right-click:**
|
|
Right-click the channel name in Slack > **Copy link** > the channel ID is the last path segment.
|
|
|
|
**Option C — Via API:**
|
|
```bash
|
|
curl -s -H "Authorization: Bearer $SLACK_BOT_TOKEN" \
|
|
"https://slack.com/api/conversations.list" | jq '.channels[] | {id, name}'
|
|
```
|
|
|
|
The NanoClaw JID format is `slack:` followed by the channel ID, e.g., `slack:C0123456789`.
|
|
|
|
## Token Reference
|
|
|
|
| Token | Prefix | Where to find it |
|
|
|-------|--------|-----------------|
|
|
| Bot User OAuth Token | `xoxb-` | **OAuth & Permissions** > **Bot User OAuth Token** |
|
|
| App-Level Token | `xapp-` | **Basic Information** > **App-Level Tokens** (or during Socket Mode setup) |
|
|
|
|
## Troubleshooting
|
|
|
|
**Bot not receiving messages:**
|
|
- Verify Socket Mode is enabled (Step 2)
|
|
- Verify all three events are subscribed (Step 3)
|
|
- Verify the bot has been added to the channel (Step 7)
|
|
|
|
**"missing_scope" errors:**
|
|
- Go back to **OAuth & Permissions** and add the missing scope
|
|
- After adding scopes, you must **reinstall the app** to your workspace (Slack will show a banner prompting you to do this)
|
|
|
|
**Bot can't send messages:**
|
|
- Verify the `chat:write` scope is added
|
|
- Verify the bot has been added to the target channel
|
|
|
|
**Token not working:**
|
|
- Bot tokens start with `xoxb-` — if yours doesn't, you may have copied the wrong token
|
|
- App tokens start with `xapp-` — these are generated in the Socket Mode or Basic Information pages
|
|
- If you regenerated a token, update `.env` and re-sync: `cp .env data/env/env`
|