Skip to content

頻道

管理 Gateway 上的聊天頻道帳戶及其執行時狀態。

相關文件:

Terminal window
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: --channel <name>--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 工具用作頻道 socket 健康狀態訊號。這些介面顯示的是 儲存的對話資料列,而非提供者的執行時狀態。在 Discord 提供者 重新啟動後,已連線但靜止的帳戶可能處於健康狀態,但在下一個 傳入或傳出對話事件發生之前,不會出現任何 Discord 工作階段資料列。

Terminal window
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 僅對已安裝/已設定的頻道外掛程式進行操作。對於可安裝的目錄頻道,請先使用 channels add。 對於由執行時期支援的頻道外掛程式,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 可用於環境變數支援的預設帳戶驗證

如果在標誌驅動的 add 指令期間需要安裝通道外掛,OpenClaw 會使用通道的預設安裝來源,而不會開啟互動式外掛安裝提示。

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

  • 每個所選通道的帳戶 ID
  • 這些帳戶的可選顯示名稱
  • Route these 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 可以改為保留現有的具名/預設目標。

Terminal window
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 組態,但在目前指令路徑中無法使用,它會將該帳號回報為已組態並附上降級註記,而不是顯示為未組態。

取得提供者功能提示(可用的 intents/scopes)以及靜態功能支援:

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

備註:

  • --channel 是選用的;省略它以列出每個頻道(包括擴充功能)。
  • --account 僅在搭配 --channel 時有效。
  • --target 接受 channel:<id> 或原始數值頻道 ID,且僅適用於 Discord。對於 Discord 語音頻道,權限檢查旗標缺少 ViewChannelConnectSpeakSendMessagesReadMessageHistory
  • 探測是提供者特定的:Discord intents + 選用頻道權限;Slack bot + user scopes;Telegram bot flags + webhook;Signal daemon 版本;Microsoft Teams 應用程式權杖 + Graph roles/scopes(於已知處標註)。沒有探測的頻道會回報 Probe: unavailable

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

Terminal window
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 不會安裝頻道外掛。在為可安裝的目錄頻道解析名稱之前,請先使用 channels add --channel <name>