Documentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
ステータス
共有エージェント、CLI、Plugin 機能、およびアウトバウンド配信サーフェスで実装済み:ReplyPayload.presentationはセマンティックなメッセージ UI を保持する。ReplyPayload.delivery.pinは送信済みメッセージのピン留めリクエストを保持する。- 共有メッセージアクションは、プロバイダー固有の
components、blocks、buttons、cardではなく、presentation、delivery、pinを公開する。 - コアは、Plugin が宣言したアウトバウンド機能を通じて presentation をレンダリングするか、自動的に代替表現へフォールバックする。
- Discord、Slack、Telegram、Mattermost、MS Teams、Feishu のレンダラーは汎用契約を使用する。
- Discord チャネルの制御プレーンコードは、Carbon ベースの UI コンテナーをインポートしなくなった。
問題
チャネル UI は現在、互換性のない複数のサーフェスに分割されている:- コアは
buildCrossContextComponentsを通じて、Discord 形状のクロスコンテキストレンダラーフックを所有している。 - Discord の
channel.tsはDiscordUiContainerを通じてネイティブ Carbon UI をインポートできるため、実行時 UI 依存関係がチャネル Plugin の制御プレーンに入り込む。 - エージェントと CLI は、Discord の
components、Slack のblocks、Telegram または Mattermost のbuttons、Teams または Feishu のcardなどのネイティブペイロード回避口を公開している。 ReplyPayload.channelDataは、トランスポートヒントとネイティブ UI エンベロープの両方を保持している。- 汎用の
interactiveモデルは存在するが、Discord、Slack、Teams、Feishu、LINE、Telegram、Mattermost ですでに使われているよりリッチなレイアウトより狭い。
目標
- コアは、宣言された機能からメッセージに最適なセマンティック presentation を決定する。
- 拡張は機能を宣言し、セマンティック presentation をネイティブトランスポートペイロードにレンダリングする。
- Web Control UI はチャットネイティブ UI から分離したままにする。
- ネイティブチャネルペイロードは、共有エージェントまたは CLI メッセージサーフェスを通じて公開しない。
- サポートされていない presentation 機能は、最適なテキスト表現へ自動的にフォールバックする。
- 送信済みメッセージのピン留めなどの配信動作は、presentation ではなく汎用配信メタデータである。
非目標
buildCrossContextComponentsの後方互換 shim は作らない。components、blocks、buttons、cardの公開ネイティブ回避口は作らない。- コアはチャネルネイティブ UI ライブラリをインポートしない。
- バンドル済みチャネル向けのプロバイダー固有 SDK シームは作らない。
目標モデル
コア所有のpresentation フィールドを ReplyPayload に追加する。
interactive は presentation のサブセットになる:
interactiveテキストブロックはpresentation.blocks[].type = "text"にマップされる。interactiveボタンブロックはpresentation.blocks[].type = "buttons"にマップされる。interactiveセレクトブロックはpresentation.blocks[].type = "select"にマップされる。
presentation を使用する。interactive は既存の返信生成側のための内部レガシーパーサー/レンダリングヘルパーとして残る。
配信メタデータ
UI ではない送信動作用に、コア所有のdelivery フィールドを追加する。
delivery.pin = trueは、最初に正常配信されたメッセージをピン留めすることを意味する。notifyのデフォルトはfalse。requiredのデフォルトはfalse。サポートされていないチャネルやピン留め失敗は、配信を継続することで自動的に代替動作へフォールバックする。- 手動の
pin、unpin、list-pinsメッセージアクションは既存メッセージ用に残る。
channelData.telegram.pin = true から delivery.pin = true に移す必要がある。
実行時機能契約
制御プレーンのチャネル Plugin ではなく、実行時アウトバウンドアダプターに presentation と delivery のレンダーフックを追加する。- 対象チャネルと実行時アダプターを解決する。
- presentation 機能を問い合わせる。
- レンダリング前にサポートされていないブロックを劣化させる。
renderPresentationを呼び出す。- レンダラーが存在しない場合、presentation をテキストフォールバックに変換する。
- 送信成功後、
delivery.pinがリクエストされサポートされている場合はpinDeliveredMessageを呼び出す。
チャネルマッピング
Discord:presentationをコンポーネント v2 と Carbon コンテナーへ、実行時専用モジュールでレンダリングする。- アクセントカラーヘルパーは軽量モジュールに保持する。
- チャネル Plugin 制御プレーンコードから
DiscordUiContainerのインポートを削除する。
presentationを Block Kit にレンダリングする。- エージェントと CLI の
blocks入力を削除する。
- テキスト、コンテキスト、区切り線をテキストとしてレンダリングする。
- ターゲットサーフェスで設定され許可されている場合、アクションとセレクトをインラインキーボードとしてレンダリングする。
- インラインボタンが無効な場合はテキストフォールバックを使用する。
- ACP トピックのピン留めを
delivery.pinに移す。
- 設定されている場合、アクションをインタラクティブボタンとしてレンダリングする。
- その他のブロックはテキストフォールバックとしてレンダリングする。
presentationを Adaptive Cards にレンダリングする。- 手動の pin/unpin/list-pins アクションを保持する。
- 対象会話で Graph サポートが信頼できる場合は、任意で
pinDeliveredMessageを実装する。
presentationをインタラクティブカードにレンダリングする。- 手動の pin/unpin/list-pins アクションを保持する。
- API 動作が信頼できる場合は、送信済みメッセージのピン留め向けに任意で
pinDeliveredMessageを実装する。
- 可能な場合、
presentationを Flex またはテンプレートメッセージにレンダリングする。 - サポートされていないブロックはテキストにフォールバックする。
- LINE UI ペイロードを
channelDataから削除する。
- presentation を保守的な書式のテキストに変換する。
リファクタリング手順
ui-colors.tsを Carbon ベース UI から分離し、extensions/discord/src/channel.tsからDiscordUiContainerを削除する Discord リリース修正を再適用する。ReplyPayload、アウトバウンドペイロード正規化、配信サマリー、フックペイロードにpresentationとdeliveryを追加する。- 狭い SDK/実行時サブパスに
MessagePresentationスキーマとパーサーヘルパーを追加する。 - メッセージ機能の
buttons、cards、components、blocksをセマンティック presentation 機能に置き換える。 - presentation レンダリングと delivery ピン留め用の実行時アウトバウンドアダプターフックを追加する。
- クロスコンテキストコンポーネント構築を
buildCrossContextPresentationに置き換える。 src/infra/outbound/channel-adapters.tsを削除し、チャネル Plugin 型からbuildCrossContextComponentsを削除する。maybeApplyCrossContextMarkerを変更し、ネイティブパラメーターではなくpresentationをアタッチする。- Plugin ディスパッチ送信パスを更新し、セマンティック presentation と delivery メタデータのみを使用する。
- エージェントと CLI のネイティブペイロードパラメーター
components、blocks、buttons、cardを削除する。 - ネイティブメッセージツールスキーマを作成する SDK ヘルパーを削除し、presentation スキーマヘルパーに置き換える。
- UI/ネイティブエンベロープを
channelDataから削除する。残る各フィールドがレビューされるまでは、トランスポートメタデータのみを保持する。 - Discord、Slack、Telegram、Mattermost、MS Teams、Feishu、LINE のレンダラーを移行する。
- メッセージ CLI、チャネルページ、Plugin SDK、機能クックブックのドキュメントを更新する。
- Discord と影響を受けるチャネルエントリーポイントのインポートファンアウトプロファイリングを実行する。
channelData トランスポートエンベロープに対する、より深い内部クリーンアップパスとして残っている。手順 15 は、型/テストゲートを超えた定量的なインポートファンアウト数値が必要な場合のフォローアップ検証として残っている。
テスト
追加または更新するもの:- presentation 正規化テスト。
- サポートされていないブロック向けの presentation 自動劣化テスト。
- Plugin ディスパッチとコア配信パスのクロスコンテキストマーカーテスト。
- Discord、Slack、Telegram、Mattermost、MS Teams、Feishu、LINE、テキストフォールバックのチャネルレンダリングマトリクステスト。
- ネイティブフィールドがなくなったことを証明するメッセージツールスキーマテスト。
- ネイティブフラグがなくなったことを証明する CLI テスト。
- Carbon を対象にした Discord エントリーポイントのインポート遅延性回帰テスト。
- Telegram と汎用フォールバックを対象にした delivery ピン留めテスト。
未解決の質問
delivery.pinは初回パスで Discord、Slack、MS Teams、Feishu にも実装すべきか、それともまず Telegram のみにすべきか。deliveryは最終的にreplyToId、replyToCurrent、silent、audioAsVoiceなどの既存フィールドも吸収すべきか、それとも送信後の動作に集中したままにすべきか。- presentation は画像やファイル参照を直接サポートすべきか、それとも当面はメディアを UI レイアウトから分離したままにすべきか。