CLI commands

頻道

openclaw channels

管理 Gateway 上的聊天頻道帳號及其執行階段狀態。

相關文件:

常用命令

openclaw channels list
openclaw channels list --all
openclaw channels status
openclaw channels capabilities
openclaw channels capabilities --channel discord --target channel:123
openclaw channels capabilities --channel discord --target channel:<voice-channel-id>
openclaw channels resolve --channel slack "#general" "@jane"
openclaw channels logs --channel all

channels list 只顯示聊天頻道:預設為已設定的帳號,並針對每個帳號附上 installedconfiguredenabled 狀態標籤。傳入 --all 也會顯示尚未設定帳號的內建頻道,以及尚未存在於磁碟上的可安裝目錄頻道。認證提供者(OAuth + API 金鑰)和模型提供者使用量/配額快照不再於此列印;請使用 openclaw models auth list 查看提供者認證設定檔,並使用 openclaw statusopenclaw models list 查看使用量。

狀態 / 功能 / 解析 / 日誌

  • channels status--probe--timeout <ms>--json
  • channels capabilities--channel <name>--account <id>(僅能與 --channel 搭配)、--target <dest>--timeout <ms>--json
  • channels resolve<entries...>--channel <name>--account <id>--kind <auto|user|group>--json
  • channels logs--channel <name|all>--lines <n>--json

channels status --probe 是即時路徑:在可連線的 Gateway 上,它會執行各帳號的 probeAccount 和選用的 auditAccount 檢查,因此輸出可能包含傳輸 狀態,以及 worksprobe failedaudit okaudit failed 等探測結果。 如果無法連上 Gateway,channels status 會退回到僅依設定產生的摘要, 而非即時探測輸出。

請勿將 openclaw sessions、Gateway sessions.list 或代理程式 sessions_list 工具用作頻道通訊端健康狀態訊號。這些介面回報的是 已儲存的對話資料列,而不是提供者執行階段狀態。Discord 提供者 重新啟動後,已連線但沒有活動的帳號可能是健康的,但在下一個傳入或傳出對話事件前, 不會出現 Discord 工作階段資料列。

新增 / 移除帳號

openclaw channels add --channel telegram --token <bot-token>
openclaw channels add --channel nostr --private-key "$NOSTR_PRIVATE_KEY"
openclaw channels remove --channel telegram --delete

channels remove 只會作用於已安裝/已設定的頻道 Plugin。若是可安裝的目錄頻道,請先使用 channels add。 對於有執行階段後端的頻道 Plugin,channels remove 也會要求執行中的 Gateway 在更新設定前停止選取的帳號,因此停用或刪除帳號後,不會讓舊的監聽器持續作用直到重新啟動。

常見的非互動式新增介面包括:

  • 機器人權杖頻道:--token--bot-token--app-token--token-file
  • Signal/iMessage 傳輸欄位:--signal-number--cli-path--http-url--http-host--http-port--db-path--service--region
  • Google Chat 欄位:--webhook-path--webhook-url--audience-type--audience
  • Matrix 欄位:--homeserver--user-id--access-token--password--device-name--initial-sync-limit
  • Nostr 欄位:--private-key--relay-urls
  • Tlon 欄位:--ship--url--code--group-channels--dm-allowlist--auto-discover-channels
  • --use-env 用於支援預設帳號環境變數後端認證的位置

如果頻道 Plugin 需要在由旗標驅動的新增命令期間安裝,OpenClaw 會使用該頻道的預設安裝來源,而不會開啟互動式 Plugin 安裝提示。

不帶旗標執行 openclaw channels add 時,互動式精靈可能會提示:

  • 每個所選頻道的帳號 ID
  • 這些帳號的選用顯示名稱
  • Bind configured channel accounts to agents now?

如果你確認立即繫結,精靈會詢問每個已設定的頻道帳號應由哪個代理程式擁有,並寫入帳號範圍的路由繫結。

你也可以稍後使用 openclaw agents bindingsopenclaw agents bindopenclaw agents unbind 管理相同的路由規則(請參閱 agents)。

當你將非預設帳號新增到仍在使用單帳號頂層設定的頻道時,OpenClaw 會先將帳號範圍的頂層值提升到該頻道的帳號對映中,再寫入新帳號。大多數頻道會將這些值放在 channels.<channel>.accounts.default,但內建頻道可以改為保留既有的相符已提升帳號。Matrix 是目前的範例:如果已存在一個具名帳號,或 defaultAccount 指向既有具名帳號,提升作業會保留該帳號,而不是建立新的 accounts.default

路由行為會保持一致:

  • 既有的僅頻道繫結(沒有 accountId)會繼續符合預設帳號。
  • channels add 不會在非互動模式中自動建立或改寫繫結。
  • 互動式設定可選擇新增帳號範圍的繫結。

如果你的設定已處於混合狀態(存在具名帳號,同時仍設定了頂層單帳號值),請執行 openclaw doctor --fix,將帳號範圍的值移入該頻道所選的已提升帳號。大多數頻道會提升到 accounts.default;Matrix 可以改為保留既有具名/預設目標。

登入和登出(互動式)

openclaw channels login --channel whatsapp
openclaw channels logout --channel whatsapp
  • channels login 支援 --verbose
  • 當只設定一個支援的登入目標時,channels loginlogout 可以推斷頻道。
  • channels logout 在可連線時會優先使用即時 Gateway 路徑,因此會先停止任何作用中的監聽器,再清除頻道認證狀態。如果無法連上本機 Gateway,則會退回到本機認證清理。
  • 請從 Gateway 主機上的終端機執行 channels login。代理程式 exec 會阻擋此互動式登入流程;如果可用,應從聊天中使用頻道原生的代理程式登入工具,例如 whatsapp_login

疑難排解

  • 執行 openclaw status --deep 進行廣泛探測。
  • 使用 openclaw doctor 取得引導式修正。
  • openclaw channels list 不再列印模型提供者使用量/配額快照。若要查看這些資訊,請使用 openclaw status(概覽)或 openclaw models list(依提供者)。
  • 當無法連上 Gateway 時,openclaw channels status 會退回到僅依設定產生的摘要。如果支援的頻道憑證透過 SecretRef 設定,但目前命令路徑無法取得該憑證,它會將該帳號回報為已設定並附上降級說明,而不是顯示為未設定。

功能探測

擷取提供者功能提示(可用時包含意圖/範圍)以及靜態功能支援:

openclaw channels capabilities
openclaw channels capabilities --channel discord --target channel:123

注意事項:

  • --channel 是選用的;省略即可列出所有頻道(包括擴充功能)。
  • --account 只有與 --channel 搭配時才有效。
  • --target 接受 channel:<id> 或原始數字頻道 ID,且僅適用於 Discord。對於 Discord 語音頻道,權限檢查會標記缺少的 ViewChannelConnectSpeakSendMessagesReadMessageHistory
  • 探測依提供者而異:Discord 意圖 + 選用頻道權限;Slack 機器人 + 使用者範圍;Telegram 機器人旗標 + Webhook;Signal daemon 版本;Microsoft Teams 應用程式權杖 + Graph 角色/範圍(在已知處加上註解)。沒有探測的頻道會回報 Probe: unavailable

將名稱解析為 ID

使用提供者目錄將頻道/使用者名稱解析為 ID:

openclaw channels resolve --channel slack "#general" "@jane"
openclaw channels resolve --channel discord "My Server/#support" "@someone"
openclaw channels resolve --channel matrix "Project Room"

注意事項:

  • 使用 --kind user|group|auto 強制指定目標類型。
  • 當多個項目共用相同名稱時,解析會優先選用作用中的符合項目。
  • channels resolve 是唯讀的。如果選取的帳號透過 SecretRef 設定,但目前命令路徑無法取得該憑證,此命令會回傳附有說明的降級未解析結果,而不是中止整個執行。
  • channels resolve 不會安裝頻道 Plugin。解析可安裝目錄頻道的名稱前,請先使用 channels add --channel <name>

相關