AgentSkillsCN

feishu-bridge

通过 WebSocket 长连接将飞书(Lark)机器人接入 ThinkFleet。无需公共服务器、域名或 ngrok。适用于将飞书/Lark 作为消息通道进行配置、排查飞书桥接问题,或管理桥接服务(启动/停止/日志查看)。涵盖飞书开放平台上的机器人创建、凭证配置、桥接服务启动、macOS launchd 自动重启,以及群聊行为的调优。

SKILL.md
--- frontmatter
name: feishu-bridge
description: Connect a Feishu (Lark) bot to ThinkFleet via WebSocket long-connection. No public server, domain, or ngrok required. Use when setting up Feishu/Lark as a messaging channel, troubleshooting the Feishu bridge, or managing the bridge service (start/stop/logs). Covers bot creation on Feishu Open Platform, credential setup, bridge startup, macOS launchd auto-restart, and group chat behavior tuning.

Feishu Bridge

Bridge Feishu bot messages to ThinkFleet Gateway over local WebSocket.

Architecture

code
Feishu user → Feishu cloud ←WS→ bridge.mjs (local) ←WS→ ThinkFleet Gateway → AI agent
  • Feishu SDK connects outbound (no inbound port / public IP needed)
  • Bridge authenticates to Gateway using the existing gateway token
  • Each Feishu chat maps to a ThinkFleet session (feishu:<chatId>)

Setup

1. Create Feishu bot

  1. Go to open.feishu.cn/app → Create self-built app → Add Bot capability
  2. Enable permissions: im:message, im:message.group_at_msg, im:message.p2p_msg
  3. Events: add im.message.receive_v1, set delivery to WebSocket long-connection
  4. Publish the app (create version → request approval)
  5. Note the App ID and App Secret

2. Store secret

bash
mkdir -p ~/.thinkfleet/secrets
echo "YOUR_APP_SECRET" > ~/.thinkfleet/secrets/feishu_app_secret
chmod 600 ~/.thinkfleet/secrets/feishu_app_secret

3. Install & run

bash
cd <skill-dir>/feishu-bridge
npm install
FEISHU_APP_ID=cli_xxx node bridge.mjs

4. Auto-start (macOS)

bash
FEISHU_APP_ID=cli_xxx node setup-service.mjs
launchctl load ~/Library/LaunchAgents/com.thinkfleet.feishu-bridge.plist

Diagnostics

bash
# Check service
launchctl list | grep feishu

# Logs
tail -f ~/.thinkfleet/logs/feishu-bridge.err.log

# Stop
launchctl unload ~/Library/LaunchAgents/com.thinkfleet.feishu-bridge.plist

Group chat behavior

Bridge replies only when: user @-mentions the bot, message ends with ?/, contains request verbs (帮/请/分析/总结…), or calls the bot by name. Customize the name list in bridge.mjsshouldRespondInGroup().

Environment variables

VariableRequiredDefault
FEISHU_APP_ID
FEISHU_APP_SECRET_PATH~/.thinkfleet/secrets/feishu_app_secret
THINKFLEET_CONFIG_PATH~/.thinkfleet/thinkfleet.json
THINKFLEET_AGENT_IDmain
FEISHU_THINKING_THRESHOLD_MS2500