Files
nanoclaw/.claude/skills/add-slack-v2/SKILL.md
Gabi Simons a9f9eda9f8 docs(slack-v2): update skill with DM setup, webhook URL, and reinstall step
Corrects webhook URL to /api/webhooks/slack, adds Enable DMs step
(App Home > Messages Tab), documents reinstall requirement after
adding event subscriptions, and adds webhook server section.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-12 12:33:56 +00:00

3.2 KiB

name, description
name description
add-slack-v2 Add Slack channel integration to NanoClaw v2 via Chat SDK.

Add Slack Channel

Adds Slack support to NanoClaw v2 using the Chat SDK bridge.

Pre-flight

Check if src/channels/slack.ts exists and the import is uncommented in src/channels/index.ts. If both are in place, skip to Credentials.

Install

Install the adapter package

npm install @chat-adapter/slack

Enable the channel

Uncomment the Slack import in src/channels/index.ts:

import './slack.js';

Build

npm run build

Credentials

Create Slack App

  1. Go to api.slack.com/apps and click Create New App > From scratch
  2. Name it (e.g., "NanoClaw") and select your workspace
  3. Go to OAuth & Permissions and add Bot Token Scopes:
    • chat:write, channels:history, groups:history, im:history, channels:read, groups:read, users:read, reactions:write
  4. Click Install to Workspace and copy the Bot User OAuth Token (xoxb-...)
  5. Go to Basic Information and copy the Signing Secret

Enable DMs

  1. Go to App Home and enable the Messages Tab
  2. Check "Allow users to send Slash commands and messages from the messages tab"

Event Subscriptions

  1. Go to Event Subscriptions and toggle Enable Events
  2. Set the Request URL to https://your-domain/api/webhooks/slack — Slack will send a verification challenge; it must pass before you can save
  3. Under Subscribe to bot events, add:
    • message.channels, message.groups, message.im, app_mention
  4. Click Save Changes
  5. Slack will show a banner asking you to reinstall the app — click it to apply the new event subscriptions

Configure environment

Add to .env:

SLACK_BOT_TOKEN=xoxb-your-bot-token
SLACK_SIGNING_SECRET=your-signing-secret

Sync to container: mkdir -p data/env && cp .env data/env/env

Webhook server

The Chat SDK bridge automatically starts a shared webhook server on port 3000 (configurable via WEBHOOK_PORT env var). The server handles /api/webhooks/slack for Slack and other webhook-based adapters. This port must be publicly reachable from the internet for Slack to deliver events.

Next Steps

If you're in the middle of /setup, return to the setup flow now.

Otherwise, run /manage-channels to wire this channel to an agent group.

Channel Info

  • type: slack
  • terminology: Slack has "workspaces" containing "channels." Channels can be public (#general) or private. The bot can also receive direct messages.
  • platform-id-format: slack:{channelId} for channels (e.g., slack:C0123ABC), slack:{dmId} for DMs (e.g., slack:D0ARWEBLV63)
  • how-to-find-id: Right-click a channel name > "View channel details" — the Channel ID is at the bottom (starts with C). For DMs, the ID starts with D. Or copy the channel link — the ID is the last segment of the URL.
  • supports-threads: yes
  • typical-use: Interactive chat — team channels or direct messages
  • default-isolation: Same agent group for channels where you're the primary user. Separate agent group for channels with different teams or sensitive contexts.