コンテンツにスキップ

Feishu

このコンテンツはまだ日本語訳がありません。

Feishu (Lark) is a team chat platform used by companies for messaging and collaboration. This plugin connects CoderClaw to a Feishu/Lark bot using the platform’s WebSocket event subscription so messages can be received without exposing a public webhook URL.


Install the Feishu plugin:

Terminal window
coderclaw plugins install @coderclaw/feishu

Local checkout (when running from a git repo):

Terminal window
coderclaw plugins install ./extensions/feishu

There are two ways to add the Feishu channel:

If you just installed CoderClaw, run the wizard:

Terminal window
coderclaw onboard

The wizard guides you through:

  1. Creating a Feishu app and collecting credentials
  2. Configuring app credentials in CoderClaw
  3. Starting the gateway

After configuration, check gateway status:

  • coderclaw gateway status
  • coderclaw logs --follow

If you already completed initial install, add the channel via CLI:

Terminal window
coderclaw channels add

Choose Feishu, then enter the App ID and App Secret.

After configuration, manage the gateway:

  • coderclaw gateway status
  • coderclaw gateway restart
  • coderclaw logs --follow

Visit Feishu Open Platform and sign in.

Lark (global) tenants should use https://open.larksuite.com/app and set domain: "lark" in the Feishu config.

  1. Click Create enterprise app
  2. Fill in the app name + description
  3. Choose an app icon

Create enterprise app

From Credentials & Basic Info, copy:

  • App ID (format: cli_xxx)
  • App Secret

Important: keep the App Secret private.

Get credentials

On Permissions, click Batch import and paste:

{
"scopes": {
"tenant": [
"aily:file:read",
"aily:file:write",
"application:application.app_message_stats.overview:readonly",
"application:application:self_manage",
"application:bot.menu:write",
"contact:user.employee_id:readonly",
"corehr:file:download",
"event:ip_list",
"im:chat.access_event.bot_p2p_chat:read",
"im:chat.members:bot_access",
"im:message",
"im:message.group_at_msg:readonly",
"im:message.p2p_msg:readonly",
"im:message:readonly",
"im:message:send_as_bot",
"im:resource"
],
"user": ["aily:file:read", "aily:file:write", "im:chat.access_event.bot_p2p_chat:read"]
}
}

Configure permissions

In App Capability > Bot:

  1. Enable bot capability
  2. Set the bot name

Enable bot capability

⚠️ Important: before setting event subscription, make sure:

  1. You already ran coderclaw channels add for Feishu
  2. The gateway is running (coderclaw gateway status)

In Event Subscription:

  1. Choose Use long connection to receive events (WebSocket)
  2. Add the event: im.message.receive_v1

⚠️ If the gateway is not running, the long-connection setup may fail to save.

Configure event subscription

  1. Create a version in Version Management & Release
  2. Submit for review and publish
  3. Wait for admin approval (enterprise apps usually auto-approve)

Terminal window
coderclaw channels add

Choose Feishu and paste your App ID + App Secret.

Edit ~/.coderclaw/coderclaw.json:

{
channels: {
feishu: {
enabled: true,
dmPolicy: "pairing",
accounts: {
main: {
appId: "cli_xxx",
appSecret: "xxx",
botName: "My AI assistant",
},
},
},
},
}
Terminal window
export FEISHU_APP_ID="cli_xxx"
export FEISHU_APP_SECRET="xxx"

If your tenant is on Lark (international), set the domain to lark (or a full domain string). You can set it at channels.feishu.domain or per account (channels.feishu.accounts.<id>.domain).

{
channels: {
feishu: {
domain: "lark",
accounts: {
main: {
appId: "cli_xxx",
appSecret: "xxx",
},
},
},
},
}

Terminal window
coderclaw gateway

In Feishu, find your bot and send a message.

By default, the bot replies with a pairing code. Approve it:

Terminal window
coderclaw pairing approve feishu <CODE>

After approval, you can chat normally.


  • Feishu bot channel: Feishu bot managed by the gateway
  • Deterministic routing: replies always return to Feishu
  • Session isolation: DMs share a main session; groups are isolated
  • WebSocket connection: long connection via Feishu SDK, no public URL needed

  • Default: dmPolicy: "pairing" (unknown users get a pairing code)

  • Approve pairing:

    Terminal window
    coderclaw pairing list feishu
    coderclaw pairing approve feishu <CODE>
  • Allowlist mode: set channels.feishu.allowFrom with allowed Open IDs

1. Group policy (channels.feishu.groupPolicy):

  • "open" = allow everyone in groups (default)
  • "allowlist" = only allow groupAllowFrom
  • "disabled" = disable group messages

2. Mention requirement (channels.feishu.groups.<chat_id>.requireMention):

  • true = require @mention (default)
  • false = respond without mentions

Allow all groups, require @mention (default)

Section titled “Allow all groups, require @mention (default)”
{
channels: {
feishu: {
groupPolicy: "open",
// Default requireMention: true
},
},
}
{
channels: {
feishu: {
groups: {
oc_xxx: { requireMention: false },
},
},
},
}
{
channels: {
feishu: {
groupPolicy: "allowlist",
groupAllowFrom: ["ou_xxx", "ou_yyy"],
},
},
}

Group IDs look like oc_xxx.

Method 1 (recommended)

  1. Start the gateway and @mention the bot in the group
  2. Run coderclaw logs --follow and look for chat_id

Method 2

Use the Feishu API debugger to list group chats.

User IDs look like ou_xxx.

Method 1 (recommended)

  1. Start the gateway and DM the bot
  2. Run coderclaw logs --follow and look for open_id

Method 2

Check pairing requests for user Open IDs:

Terminal window
coderclaw pairing list feishu

CommandDescription
/statusShow bot status
/resetReset the session
/modelShow/switch model

Note: Feishu does not support native command menus yet, so commands must be sent as text.

CommandDescription
coderclaw gateway statusShow gateway status
coderclaw gateway installInstall/start gateway service
coderclaw gateway stopStop gateway service
coderclaw gateway restartRestart gateway service
coderclaw logs --followTail gateway logs

  1. Ensure the bot is added to the group
  2. Ensure you @mention the bot (default behavior)
  3. Check groupPolicy is not set to "disabled"
  4. Check logs: coderclaw logs --follow
  1. Ensure the app is published and approved
  2. Ensure event subscription includes im.message.receive_v1
  3. Ensure long connection is enabled
  4. Ensure app permissions are complete
  5. Ensure the gateway is running: coderclaw gateway status
  6. Check logs: coderclaw logs --follow
  1. Reset the App Secret in Feishu Open Platform
  2. Update the App Secret in your config
  3. Restart the gateway
  1. Ensure the app has im:message:send_as_bot permission
  2. Ensure the app is published
  3. Check logs for detailed errors

{
channels: {
feishu: {
accounts: {
main: {
appId: "cli_xxx",
appSecret: "xxx",
botName: "Primary bot",
},
backup: {
appId: "cli_yyy",
appSecret: "yyy",
botName: "Backup bot",
enabled: false,
},
},
},
},
}
  • textChunkLimit: outbound text chunk size (default: 2000 chars)
  • mediaMaxMb: media upload/download limit (default: 30MB)

Feishu supports streaming replies via interactive cards. When enabled, the bot updates a card as it generates text.

{
channels: {
feishu: {
streaming: true, // enable streaming card output (default true)
blockStreaming: true, // enable block-level streaming (default true)
},
},
}

Set streaming: false to wait for the full reply before sending.

Use bindings to route Feishu DMs or groups to different agents.

{
agents: {
list: [
{ id: "main" },
{
id: "coderclaw-fan",
workspace: "/home/user/coderclaw-fan",
agentDir: "/home/user/.coderclaw/agents/coderclaw-fan/agent",
},
{
id: "coderclaw-xi",
workspace: "/home/user/coderclaw-xi",
agentDir: "/home/user/.coderclaw/agents/coderclaw-xi/agent",
},
],
},
bindings: [
{
agentId: "main",
match: {
channel: "feishu",
peer: { kind: "direct", id: "ou_xxx" },
},
},
{
agentId: "coderclaw-fan",
match: {
channel: "feishu",
peer: { kind: "direct", id: "ou_yyy" },
},
},
{
agentId: "coderclaw-xi",
match: {
channel: "feishu",
peer: { kind: "group", id: "oc_zzz" },
},
},
],
}

Routing fields:

  • match.channel: "feishu"
  • match.peer.kind: "direct" or "group"
  • match.peer.id: user Open ID (ou_xxx) or group ID (oc_xxx)

See Get group/user IDs for lookup tips.


Full configuration: Gateway configuration

Key options:

SettingDescriptionDefault
channels.feishu.enabledEnable/disable channeltrue
channels.feishu.domainAPI domain (feishu or lark)feishu
channels.feishu.accounts.<id>.appIdApp ID-
channels.feishu.accounts.<id>.appSecretApp Secret-
channels.feishu.accounts.<id>.domainPer-account API domain overridefeishu
channels.feishu.dmPolicyDM policypairing
channels.feishu.allowFromDM allowlist (open_id list)-
channels.feishu.groupPolicyGroup policyopen
channels.feishu.groupAllowFromGroup allowlist-
channels.feishu.groups.<chat_id>.requireMentionRequire @mentiontrue
channels.feishu.groups.<chat_id>.enabledEnable grouptrue
channels.feishu.textChunkLimitMessage chunk size2000
channels.feishu.mediaMaxMbMedia size limit30
channels.feishu.streamingEnable streaming card outputtrue
channels.feishu.blockStreamingEnable block streamingtrue

ValueBehavior
"pairing"Default. Unknown users get a pairing code; must be approved
"allowlist"Only users in allowFrom can chat
"open"Allow all users (requires "*" in allowFrom)
"disabled"Disable DMs

  • ✅ Text
  • ✅ Rich text (post)
  • ✅ Images
  • ✅ Files
  • ✅ Audio
  • ✅ Video
  • ✅ Stickers
  • ✅ Text
  • ✅ Images
  • ✅ Files
  • ✅ Audio
  • ⚠️ Rich text (partial support)