Chuyển đến nội dung chính

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

Feishu / Lark

Feishu/Lark là nền tảng cộng tác tất cả trong một, nơi các nhóm trò chuyện, chia sẻ tài liệu, quản lý lịch và cùng nhau hoàn thành công việc. Trạng thái: sẵn sàng cho môi trường production đối với tin nhắn trực tiếp với bot + cuộc trò chuyện nhóm. WebSocket là chế độ mặc định; chế độ Webhook là tùy chọn.

Bắt đầu nhanh

Yêu cầu OpenClaw 2026.4.25 trở lên. Chạy openclaw --version để kiểm tra. Nâng cấp bằng openclaw update.
1

Chạy trình hướng dẫn thiết lập kênh

openclaw channels login --channel feishu
Quét mã QR bằng ứng dụng di động Feishu/Lark để tự động tạo bot Feishu/Lark.
2

Sau khi thiết lập hoàn tất, khởi động lại Gateway để áp dụng các thay đổi

openclaw gateway restart

Kiểm soát truy cập

Tin nhắn trực tiếp

Cấu hình dmPolicy để kiểm soát ai có thể nhắn trực tiếp cho bot:
  • "pairing" — người dùng không xác định sẽ nhận mã ghép nối; phê duyệt qua CLI
  • "allowlist" — chỉ những người dùng được liệt kê trong allowFrom mới có thể trò chuyện (mặc định: chỉ chủ sở hữu bot)
  • "open" — chỉ cho phép tin nhắn trực tiếp công khai khi allowFrom bao gồm "*"; với các mục hạn chế, chỉ người dùng khớp mới có thể trò chuyện
  • "disabled" — tắt tất cả tin nhắn trực tiếp
Phê duyệt yêu cầu ghép nối:
openclaw pairing list feishu
openclaw pairing approve feishu <CODE>

Cuộc trò chuyện nhóm

Chính sách nhóm (channels.feishu.groupPolicy):
Giá trịHành vi
"open"Phản hồi tất cả tin nhắn trong nhóm
"allowlist"Chỉ phản hồi các nhóm trong groupAllowFrom hoặc được cấu hình rõ ràng trong groups.<chat_id>
"disabled"Tắt tất cả tin nhắn nhóm; các mục groups.<chat_id> rõ ràng không ghi đè điều này
Mặc định: allowlist Yêu cầu đề cập (channels.feishu.requireMention):
  • true — yêu cầu @mention (mặc định)
  • false — phản hồi mà không cần @mention
  • Ghi đè theo từng nhóm: channels.feishu.groups.<chat_id>.requireMention
  • @all@_all chỉ dùng để phát tới tất cả không được xem là đề cập đến bot. Một tin nhắn đề cập đồng thời cả @all và trực tiếp đến bot vẫn được tính là đề cập đến bot.

Ví dụ cấu hình nhóm

Cho phép tất cả nhóm, không yêu cầu @mention

{
  channels: {
    feishu: {
      groupPolicy: "open",
    },
  },
}

Cho phép tất cả nhóm, vẫn yêu cầu @mention

{
  channels: {
    feishu: {
      groupPolicy: "open",
      requireMention: true,
    },
  },
}

Chỉ cho phép các nhóm cụ thể

{
  channels: {
    feishu: {
      groupPolicy: "allowlist",
      // Group IDs look like: oc_xxx
      groupAllowFrom: ["oc_xxx", "oc_yyy"],
    },
  },
}
Ở chế độ allowlist, bạn cũng có thể cho phép một nhóm bằng cách thêm mục groups.<chat_id> rõ ràng. Các mục rõ ràng không ghi đè groupPolicy: "disabled". Mặc định ký tự đại diện trong groups.* cấu hình các nhóm khớp, nhưng tự chúng không cho phép nhóm.
{
  channels: {
    feishu: {
      groupPolicy: "allowlist",
      groups: {
        oc_xxx: {
          requireMention: false,
        },
      },
    },
  },
}

Hạn chế người gửi trong một nhóm

{
  channels: {
    feishu: {
      groupPolicy: "allowlist",
      groupAllowFrom: ["oc_xxx"],
      groups: {
        oc_xxx: {
          // User open_ids look like: ou_xxx
          allowFrom: ["ou_user1", "ou_user2"],
        },
      },
    },
  },
}

Lấy ID nhóm/người dùng

ID nhóm (chat_id, định dạng: oc_xxx)

Mở nhóm trong Feishu/Lark, nhấp vào biểu tượng menu ở góc trên bên phải và đi tới Cài đặt. ID nhóm (chat_id) được liệt kê trên trang cài đặt. Lấy ID nhóm

ID người dùng (open_id, định dạng: ou_xxx)

Khởi động Gateway, gửi tin nhắn trực tiếp cho bot, sau đó kiểm tra nhật ký:
openclaw logs --follow
Tìm open_id trong đầu ra nhật ký. Bạn cũng có thể kiểm tra các yêu cầu ghép nối đang chờ xử lý:
openclaw pairing list feishu

Lệnh phổ biến

LệnhMô tả
/statusHiển thị trạng thái bot
/resetĐặt lại phiên hiện tại
/modelHiển thị hoặc đổi mô hình AI
Feishu/Lark không hỗ trợ menu lệnh gạch chéo gốc, vì vậy hãy gửi các lệnh này dưới dạng tin nhắn văn bản thuần.

Khắc phục sự cố

Bot không phản hồi trong cuộc trò chuyện nhóm

  1. Đảm bảo bot đã được thêm vào nhóm
  2. Đảm bảo bạn @mention bot (mặc định là bắt buộc)
  3. Xác minh groupPolicy không phải là "disabled"
  4. Kiểm tra nhật ký: openclaw logs --follow

Bot không nhận được tin nhắn

  1. Đảm bảo bot đã được phát hành và phê duyệt trong Feishu Open Platform / Lark Developer
  2. Đảm bảo đăng ký sự kiện bao gồm im.message.receive_v1
  3. Đảm bảo kết nối liên tục (WebSocket) được chọn
  4. Đảm bảo tất cả phạm vi quyền bắt buộc đã được cấp
  5. Đảm bảo Gateway đang chạy: openclaw gateway status
  6. Kiểm tra nhật ký: openclaw logs --follow

App Secret bị lộ

  1. Đặt lại App Secret trong Feishu Open Platform / Lark Developer
  2. Cập nhật giá trị trong cấu hình của bạn
  3. Khởi động lại Gateway: openclaw gateway restart

Cấu hình nâng cao

Nhiều tài khoản

{
  channels: {
    feishu: {
      defaultAccount: "main",
      accounts: {
        main: {
          appId: "cli_xxx",
          appSecret: "xxx",
          name: "Primary bot",
          tts: {
            providers: {
              openai: { voice: "shimmer" },
            },
          },
        },
        backup: {
          appId: "cli_yyy",
          appSecret: "yyy",
          name: "Backup bot",
          enabled: false,
        },
      },
    },
  },
}
defaultAccount kiểm soát tài khoản nào được sử dụng khi các API gửi đi không chỉ định accountId. accounts.<id>.tts dùng cùng cấu trúc với messages.tts và hợp nhất sâu lên trên cấu hình TTS toàn cục, vì vậy các thiết lập Feishu nhiều bot có thể giữ chung thông tin xác thực nhà cung cấp ở cấp toàn cục trong khi chỉ ghi đè giọng nói, mô hình, persona hoặc chế độ tự động theo từng tài khoản.

Giới hạn tin nhắn

  • textChunkLimit — kích thước đoạn văn bản gửi đi (mặc định: 2000 ký tự)
  • mediaMaxMb — giới hạn tải lên/tải xuống phương tiện (mặc định: 30 MB)

Truyền trực tuyến

Feishu/Lark hỗ trợ phản hồi truyền trực tuyến qua thẻ tương tác. Khi được bật, bot cập nhật thẻ theo thời gian thực khi tạo văn bản.
{
  channels: {
    feishu: {
      streaming: true, // enable streaming card output (default: true)
      blockStreaming: true, // enable block-level streaming (default: true)
    },
  },
}
Đặt streaming: false để gửi phản hồi hoàn chỉnh trong một tin nhắn.

Tối ưu hóa hạn mức

Giảm số lượng lệnh gọi API Feishu/Lark bằng hai cờ tùy chọn:
  • typingIndicator (mặc định true): đặt false để bỏ qua các lệnh gọi phản ứng đang nhập
  • resolveSenderNames (mặc định true): đặt false để bỏ qua tra cứu hồ sơ người gửi
{
  channels: {
    feishu: {
      typingIndicator: false,
      resolveSenderNames: false,
    },
  },
}

Phiên ACP

Feishu/Lark hỗ trợ ACP cho tin nhắn trực tiếp và tin nhắn luồng nhóm. ACP của Feishu/Lark được điều khiển bằng lệnh văn bản — không có menu lệnh gạch chéo gốc, vì vậy hãy dùng trực tiếp các tin nhắn /acp ... trong cuộc trò chuyện.

Liên kết ACP liên tục

{
  agents: {
    list: [
      {
        id: "codex",
        runtime: {
          type: "acp",
          acp: {
            agent: "codex",
            backend: "acpx",
            mode: "persistent",
            cwd: "/workspace/openclaw",
          },
        },
      },
    ],
  },
  bindings: [
    {
      type: "acp",
      agentId: "codex",
      match: {
        channel: "feishu",
        accountId: "default",
        peer: { kind: "direct", id: "ou_1234567890" },
      },
    },
    {
      type: "acp",
      agentId: "codex",
      match: {
        channel: "feishu",
        accountId: "default",
        peer: { kind: "group", id: "oc_group_chat:topic:om_topic_root" },
      },
      acp: { label: "codex-feishu-topic" },
    },
  ],
}

Tạo ACP từ cuộc trò chuyện

Trong tin nhắn trực tiếp hoặc luồng Feishu/Lark:
/acp spawn codex --thread here
--thread here hoạt động với tin nhắn trực tiếp và tin nhắn luồng Feishu/Lark. Các tin nhắn tiếp theo trong cuộc trò chuyện đã liên kết sẽ được định tuyến trực tiếp đến phiên ACP đó.

Định tuyến nhiều agent

Dùng bindings để định tuyến tin nhắn trực tiếp hoặc nhóm Feishu/Lark đến các agent khác nhau.
{
  agents: {
    list: [
      { id: "main" },
      { id: "agent-a", workspace: "/home/user/agent-a" },
      { id: "agent-b", workspace: "/home/user/agent-b" },
    ],
  },
  bindings: [
    {
      agentId: "agent-a",
      match: {
        channel: "feishu",
        peer: { kind: "direct", id: "ou_xxx" },
      },
    },
    {
      agentId: "agent-b",
      match: {
        channel: "feishu",
        peer: { kind: "group", id: "oc_zzz" },
      },
    },
  ],
}
Trường định tuyến:
  • match.channel: "feishu"
  • match.peer.kind: "direct" (tin nhắn trực tiếp) hoặc "group" (cuộc trò chuyện nhóm)
  • match.peer.id: Open ID người dùng (ou_xxx) hoặc ID nhóm (oc_xxx)
Xem Lấy ID nhóm/người dùng để biết mẹo tra cứu.

Tham chiếu cấu hình

Cấu hình đầy đủ: Cấu hình Gateway
Thiết lậpMô tảMặc định
channels.feishu.enabledBật/tắt kênhtrue
channels.feishu.domainMiền API (feishu hoặc lark)feishu
channels.feishu.connectionModeTruyền tải sự kiện (websocket hoặc webhook)websocket
channels.feishu.defaultAccountTài khoản mặc định cho định tuyến gửi đidefault
channels.feishu.verificationTokenBắt buộc đối với chế độ Webhook
channels.feishu.encryptKeyBắt buộc đối với chế độ Webhook
channels.feishu.webhookPathĐường dẫn tuyến Webhook/feishu/events
channels.feishu.webhookHostMáy chủ liên kết Webhook127.0.0.1
channels.feishu.webhookPortCổng liên kết Webhook3000
channels.feishu.accounts.<id>.appIdID ứng dụng
channels.feishu.accounts.<id>.appSecretKhóa bí mật ứng dụng
channels.feishu.accounts.<id>.domainGhi đè miền theo tài khoảnfeishu
channels.feishu.accounts.<id>.ttsGhi đè TTS theo tài khoảnmessages.tts
channels.feishu.dmPolicyChính sách DMallowlist
channels.feishu.allowFromDanh sách cho phép DM (danh sách open_id)[BotOwnerId]
channels.feishu.groupPolicyChính sách nhómallowlist
channels.feishu.groupAllowFromDanh sách cho phép nhóm
channels.feishu.requireMentionYêu cầu @mention trong nhómtrue
channels.feishu.groups.<chat_id>.requireMentionGhi đè @mention theo nhóm; ID rõ ràng cũng cho phép nhóm trong chế độ danh sách cho phépinherited
channels.feishu.groups.<chat_id>.enabledBật/tắt một nhóm cụ thểtrue
channels.feishu.textChunkLimitKích thước đoạn tin nhắn2000
channels.feishu.mediaMaxMbGiới hạn kích thước phương tiện30
channels.feishu.streamingĐầu ra thẻ truyền pháttrue
channels.feishu.blockStreamingTruyền phát cấp khốitrue
channels.feishu.typingIndicatorGửi phản ứng đang nhậptrue
channels.feishu.resolveSenderNamesPhân giải tên hiển thị của người gửitrue

Loại tin nhắn được hỗ trợ

Nhận

  • ✅ Văn bản
  • ✅ Văn bản có định dạng (post)
  • ✅ Hình ảnh
  • ✅ Tệp
  • ✅ Âm thanh
  • ✅ Video/phương tiện
  • ✅ Nhãn dán
Tin nhắn âm thanh Feishu/Lark đến được chuẩn hóa thành phần giữ chỗ phương tiện thay vì JSON file_key thô. Khi tools.media.audio được cấu hình, OpenClaw tải tài nguyên ghi chú thoại xuống và chạy bản chép lời âm thanh dùng chung trước lượt của agent, để agent nhận được bản chép lời lời nói. Nếu Feishu đưa trực tiếp văn bản chép lời vào payload âm thanh, văn bản đó được dùng mà không cần lệnh gọi ASR khác. Khi không có nhà cung cấp bản chép lời âm thanh, agent vẫn nhận được phần giữ chỗ <media:audio> cùng tệp đính kèm đã lưu, không phải payload tài nguyên Feishu thô.

Gửi

  • ✅ Văn bản
  • ✅ Hình ảnh
  • ✅ Tệp
  • ✅ Âm thanh
  • ✅ Video/phương tiện
  • ✅ Thẻ tương tác (bao gồm cập nhật truyền phát)
  • ⚠️ Văn bản có định dạng (định dạng kiểu post; không hỗ trợ đầy đủ khả năng biên soạn của Feishu/Lark)
Bong bóng âm thanh Feishu/Lark gốc dùng loại tin nhắn audio của Feishu và yêu cầu phương tiện tải lên Ogg/Opus (file_type: "opus"). Phương tiện .opus.ogg hiện có được gửi trực tiếp dưới dạng âm thanh gốc. MP3/WAV/M4A và các định dạng có khả năng là âm thanh khác được chuyển mã sang Ogg/Opus 48kHz bằng ffmpeg chỉ khi phản hồi yêu cầu gửi bằng giọng nói (audioAsVoice / công cụ tin nhắn asVoice, bao gồm phản hồi ghi chú thoại TTS). Tệp đính kèm MP3 thông thường vẫn là tệp bình thường. Nếu thiếu ffmpeg hoặc chuyển đổi thất bại, OpenClaw chuyển về tệp đính kèm và ghi nhật ký lý do.

Luồng và phản hồi

  • ✅ Phản hồi nội tuyến
  • ✅ Phản hồi trong luồng
  • ✅ Phản hồi phương tiện vẫn nhận biết luồng khi phản hồi một tin nhắn trong luồng
Đối với groupSessionScope: "group_topic""group_topic_sender", các nhóm chủ đề Feishu/Lark gốc dùng thread_id (omt_*) của sự kiện làm khóa phiên chủ đề chuẩn. Các phản hồi nhóm bình thường mà OpenClaw chuyển thành luồng tiếp tục dùng ID tin nhắn gốc của phản hồi (om_*) để lượt đầu tiên và lượt tiếp theo vẫn ở trong cùng một phiên.

Liên quan