Each skill now: - Pre-flight: checks for file present + import line + dep listed (idempotent) - git fetch origin channels - git show origin/channels:<paths> > <paths> to copy adapter (and helpers/tests/setup-step where applicable) - Append `import './<chan>.js';` to src/channels/index.ts - pnpm install <pkg>@<pinned-version> - pnpm run build Telegram additionally copies 4 helper/test files + setup/pair-telegram.ts and registers `'pair-telegram':` in setup/index.ts STEPS. WhatsApp (native) additionally copies setup/whatsapp-auth.ts and registers `'whatsapp-auth':` in setup/index.ts STEPS, installs @whiskeysockets/baileys + qrcode + @types/qrcode pinned. All credential / next-steps / channel-info / troubleshooting sections preserved verbatim. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2.6 KiB
2.6 KiB
name, description
| name | description |
|---|---|
| add-linear-v2 | Add Linear channel integration to NanoClaw v2 via Chat SDK. Issue comment threads as conversations. |
Add Linear Channel
Adds Linear support to NanoClaw v2 using the Chat SDK bridge. The agent participates in issue comment threads.
Install
v2 trunk doesn't ship channels. This skill copies the Linear adapter in from the channels branch.
Pre-flight (idempotent)
Skip to Credentials if all of these are already in place:
src/channels/linear.tsexistssrc/channels/index.tscontainsimport './linear.js';@chat-adapter/linearis listed inpackage.jsondependencies
Otherwise continue. Every step below is safe to re-run.
1. Fetch the channels branch
git fetch origin channels
2. Copy the adapter
git show origin/channels:src/channels/linear.ts > src/channels/linear.ts
3. Append the self-registration import
Append to src/channels/index.ts (skip if the line is already present):
import './linear.js';
4. Install the adapter package (pinned)
pnpm install @chat-adapter/linear@4.26.0
5. Build
pnpm run build
Credentials
- Go to Linear Settings > API Keys
- Create a Personal API Key (or use an OAuth application for team-wide access)
- Copy the API key
- Set up a webhook:
- Go to Settings > API > Webhooks > New webhook
- URL:
https://your-domain/webhook/linear- Select events: Comment (created, updated)
- Copy the signing secret
Configure environment
Add to .env:
LINEAR_API_KEY=lin_api_...
LINEAR_WEBHOOK_SECRET=your-webhook-secret
Sync to container: mkdir -p data/env && cp .env data/env/env
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:
linear - terminology: Linear has "teams" containing "issues." Each issue's comment thread is a separate conversation.
- how-to-find-id: The platform ID is your team key (e.g.
ENG). Find it in Linear under Settings > Teams. Each issue becomes its own thread automatically. - supports-threads: yes (issue comment threads are native conversations)
- typical-use: Webhook/notification — the agent receives issue comment events and responds in threads
- default-isolation: Typically shares a session with a chat channel (e.g. Slack) so the agent can discuss issues in the same context as team chat. Use a separate agent group if the Linear team tracks sensitive work.