From 01coder-skills
Adds Feishu (飞书/Lark) WebSocket channel to NanoClaw bots. Applies code changes via skills engine, guides app setup, collects credentials, and handles registration.
npx claudepluginhub sugarforever/01coder-agent-skills --plugin 01coder-skillsThis skill uses the workspace's default tool permissions.
This skill adds Feishu (飞书) support to NanoClaw using the skills engine for deterministic code changes, then walks through interactive setup.
Creates isolated Git worktrees for feature branches with prioritized directory selection, gitignore safety checks, auto project setup for Node/Python/Rust/Go, and baseline verification.
Executes implementation plans in current session by dispatching fresh subagents per independent task, with two-stage reviews: spec compliance then code quality.
Dispatches parallel agents to independently tackle 2+ tasks like separate test failures or subsystems without shared state or dependencies.
This skill adds Feishu (飞书) support to NanoClaw using the skills engine for deterministic code changes, then walks through interactive setup.
Read .nanoclaw/state.yaml. If feishu is in applied_skills, skip to Phase 3 (Setup). The code changes are already in place.
Use AskUserQuestion to collect configuration:
AskUserQuestion: Do you have a Feishu app already, or do you need to create one?
If they have one, collect FEISHU_APP_ID and FEISHU_APP_SECRET now. If not, we'll create one in Phase 3.
Run the skills engine to apply this skill's code package. The package files are in this directory alongside this SKILL.md.
If .nanoclaw/ directory doesn't exist yet:
npx tsx scripts/apply-skill.ts --init
npx tsx scripts/apply-skill.ts .claude/skills/add-feishu
This deterministically:
src/channels/feishu.ts (FeishuChannel class implementing Channel interface)src/index.ts (reads credentials via readEnvFile, creates FeishuChannel if configured)@larksuiteoapi/node-sdk npm dependency.env with FEISHU_APP_ID and FEISHU_APP_SECRET.nanoclaw/state.yamlIf the apply reports merge conflicts, read the intent file:
modify/src/index.ts.intent.md — what changed and invariants for index.tsnpm run build
Build must be clean before proceeding.
If the user doesn't have a Feishu app, tell them:
I need you to create a Feishu bot:
- Go to Feishu Open Platform and create a new app
- Under Credentials, copy the App ID and App Secret
- Under Event Subscriptions, enable Long Connection (WebSocket) mode
- Add the event:
im.message.receive_v1(Receive messages)- Under Permissions, add:
im:message:send_as_bot(Send messages as bot)im:message(Read messages)- Publish the app (or create a version and approve it)
Wait for the user to provide the App ID and App Secret.
Add to .env:
FEISHU_APP_ID=<their-app-id>
FEISHU_APP_SECRET=<their-app-secret>
npm run build
launchctl kickstart -k gui/$(id -u)/com.nanoclaw # macOS
# Linux: systemctl --user restart nanoclaw
Tell the user:
- Start the bot:
npm run dev- Send any message to the bot in Feishu (DM or group)
- Check the logs — the chat_id will appear in the metadata
- The JID format is
{chat_id}@feishu
Or check the database directly:
sqlite3 store/messages.db "SELECT jid FROM chats WHERE jid LIKE '%@feishu'"
Register directly in SQLite:
INSERT INTO registered_groups (jid, name, folder, trigger_pattern, added_at, requires_trigger)
VALUES ('{chat_id}@feishu', 'feishu', 'feishu', '@{ASSISTANT_NAME}', datetime('now'), 0);
Note: requires_trigger is set to 0 (false) so the bot responds to all messages without needing @mention.
Then restart the service to pick up the new registration.
Tell the user:
Send a message to the bot in Feishu. It should respond within a few seconds.
tail -f logs/nanoclaw.log
# Or run interactively:
npm run dev
Look for:
Feishu bot info fetched — bot connected and identified itselfConnected to Feishu via WebSocket — WebSocket establishedFeishu message sent — outbound message deliveredCheck:
FEISHU_APP_ID and FEISHU_APP_SECRET are set in .envsqlite3 store/messages.db "SELECT * FROM registered_groups WHERE jid LIKE '%@feishu'"im.message.receive_v1 is enabledlaunchctl list | grep nanoclaw (macOS) or systemctl --user status nanoclaw (Linux)im:message permissionim.message.receive_v1 is subscribedim:message:send_as_bot permissionNon-critical warning. Bot message detection (filtering own messages) won't work, but message sending/receiving still functions. Usually means the bot API endpoint isn't accessible — check network connectivity.
To remove Feishu integration:
src/channels/feishu.tsFeishuChannel import and creation block from src/index.tsreadEnvFile import if no other channel uses itFEISHU_APP_ID and FEISHU_APP_SECRET from .envsqlite3 store/messages.db "DELETE FROM registered_groups WHERE jid LIKE '%@feishu'"npm uninstall @larksuiteoapi/node-sdknpm run build && launchctl kickstart -k gui/$(id -u)/com.nanoclaw (macOS) or npm run build && systemctl --user restart nanoclaw (Linux)