CLI commands
エージェント
openclaw agent
Gateway 経由でエージェントターンを実行します(埋め込みには --local を使用)。
構成済みエージェントを直接対象にするには --agent <id> を使用します。
少なくとも 1 つのセッションセレクターを渡します。
--to <dest>--session-key <key>--session-id <id>--agent <id>
関連:
- エージェント送信ツール: エージェント送信
オプション
-m, --message <text>: メッセージ本文--message-file <path>: UTF-8 ファイルからメッセージ本文を読み取る-t, --to <dest>: セッションキーの導出に使用する受信者--session-key <key>: ルーティングに使用する明示的なセッションキー--session-id <id>: 明示的なセッション ID--agent <id>: エージェント ID。ルーティングバインディングを上書きします--model <id>: この実行のモデル上書き(provider/modelまたはモデル ID)--thinking <level>: エージェントの思考レベル(off、minimal、low、medium、highに加え、xhigh、adaptive、maxなどプロバイダーが対応するカスタムレベル)--verbose <on|off>: セッションの詳細出力レベルを永続化する--channel <channel>: 配信チャネル。メインセッションチャネルを使用する場合は省略します--reply-to <target>: 配信先の上書き--reply-channel <channel>: 配信チャネルの上書き--reply-account <id>: 配信アカウントの上書き--local: 埋め込みエージェントを直接実行する(Plugin レジストリのプリロード後)--deliver: 選択したチャネル/対象へ返信を送り返す--timeout <seconds>: エージェントのタイムアウトを上書きする(デフォルトは 600 または構成値)--json: JSON を出力する
例
openclaw agent --to +15555550123 --message "status update" --deliveropenclaw agent --agent ops --message "Summarize logs"openclaw agent --agent ops --message-file ./task.mdopenclaw agent --agent ops --model openai/gpt-5.4 --message "Summarize logs"openclaw agent --session-key agent:ops:incident-42 --message "Summarize status"openclaw agent --agent ops --session-key incident-42 --message "Summarize status"openclaw agent --session-id 1234 --message "Summarize inbox" --thinking mediumopenclaw agent --to +15555550123 --message "Trace logs" --verbose on --jsonopenclaw agent --agent ops --message "Generate report" --deliver --reply-channel slack --reply-to "#reports"openclaw agent --agent ops --message "Run locally" --local注記
--messageまたは--message-fileのどちらか一方だけを渡します。--message-fileは、任意の UTF-8 BOM を削除した後も複数行のファイル内容を保持し、有効な UTF-8 ではないファイルを拒否します。- Gateway モードでは、Gateway リクエストが失敗すると埋め込みエージェントにフォールバックします。最初から埋め込み実行を強制するには
--localを使用します。 --localでも先に Plugin レジストリをプリロードするため、Plugin が提供するプロバイダー、ツール、チャネルは埋め込み実行中も利用できます。--localと埋め込みフォールバック実行は、ワンショット実行として扱われます。そのローカルプロセス用に開かれたバンドル済み MCP loopback リソースとウォームな Claude stdio セッションは返信後に破棄されるため、スクリプト呼び出しがローカル子プロセスを生存させ続けることはありません。- Gateway ベースの実行では、Gateway 所有の MCP loopback リソースは実行中の Gateway プロセスの下に残ります。古いクライアントは履歴上のクリーンアップフラグをまだ送信する場合がありますが、Gateway は互換性のための no-op として受け入れます。
--channel、--reply-channel、--reply-accountは返信の配信に影響し、セッションルーティングには影響しません。--session-keyは明示的なセッションキーを選択します。エージェント接頭辞付きキーはagent:<agent-id>:<session-key>を使用する必要があり、--agentとキーのエージェント ID は、両方が指定された場合に一致している必要があります。裸の非センチネルキーは、指定されている場合は--agentに、そうでない場合は構成済みのデフォルトエージェントにスコープされます。たとえば、--agent ops --session-key incident-42はagent:ops:incident-42にルーティングされます。リテラルのglobalとunknownは、--agentが指定されていない場合にのみスコープなしのままです。その場合、埋め込みフォールバックとストア所有権は構成済みのデフォルトエージェントを使用します。--jsonは stdout を JSON レスポンス専用に保ちます。Gateway、Plugin、埋め込みフォールバックの診断は stderr にルーティングされるため、スクリプトは stdout を直接解析できます。- 埋め込みフォールバック JSON には
meta.transport: "embedded"とmeta.fallbackFrom: "gateway"が含まれるため、スクリプトはフォールバック実行と Gateway 実行を区別できます。 - Gateway がエージェント実行を受け付けたものの、CLI が最終返信を待機中にタイムアウトした場合、埋め込みフォールバックは新しい明示的な
gateway-fallback-*セッション/実行 ID を使用し、フォールバックセッションフィールドに加えてmeta.fallbackReason: "gateway_timeout"を報告します。これにより、Gateway 所有のトランスクリプトロックとの競合や、元のルーティング済み会話セッションの暗黙の置き換えを避けます。 - Gateway ベースの実行では、
SIGTERMとSIGINTは待機中の CLI リクエストを中断します。Gateway がすでに実行を受け付けている場合、CLI は終了前に、その受け付け済み実行 ID に対してchat.abortも送信します。ローカルの--local実行と埋め込みフォールバック実行は同じ中止シグナルを受け取りますが、chat.abortは送信しません。元のエージェント実行がまだアクティブな間に重複した--run-idが Gateway に到達した場合、重複レスポンスはstatus: "in_flight"を報告し、非 JSON CLI は空の返信ではなく stderr 診断を出力します。外部の cron/systemd ラッパーでは、シャットダウンを正常に完了できない場合でもスーパーバイザーがプロセスを回収できるように、timeout -k 60 600 openclaw agent ...のような外側のハードキルのバックストップを保持してください。 - このコマンドが
models.jsonの再生成をトリガーする場合、SecretRef 管理のプロバイダー認証情報は、解決済みシークレット平文ではなく、非シークレットマーカー(たとえば環境変数名、secretref-env:ENV_VAR_NAME、またはsecretref-managed)として永続化されます。 - マーカー書き込みはソースを権威とします。OpenClaw は、解決済みランタイムシークレット値ではなく、アクティブなソース構成スナップショットからマーカーを永続化します。
JSON 配信ステータス
--json --deliver を使用すると、CLI の JSON レスポンスにはトップレベルの deliveryStatus が含まれる場合があり、スクリプトは配信済み、抑制、部分的、失敗した送信を区別できます。
{ "payloads": [{ "text": "Report ready", "mediaUrl": null }], "meta": { "durationMs": 1200 }, "deliveryStatus": { "requested": true, "attempted": true, "status": "sent", "succeeded": true, "resultCount": 1 }}deliveryStatus.status は sent、suppressed、partial_failed、failed のいずれかです。suppressed は、たとえばメッセージ送信フックがキャンセルした、または可視の結果がなかったなどの理由で、配信が意図的に送信されなかったことを意味します。それでもこれは再試行しない終端結果です。partial_failed は、後続のペイロードが失敗する前に少なくとも 1 つのペイロードが送信されたことを意味します。failed は、永続的な送信が完了しなかったか、配信の事前確認が失敗したことを意味します。
Gateway ベースの CLI レスポンスは、生の Gateway 結果形状も保持します。同じオブジェクトは result.deliveryStatus で利用できます。
共通フィールド:
requested: オブジェクトが存在する場合は常にtrue。attempted: 永続的な送信パスが実行された後はtrue。事前確認失敗または可視ペイロードなしの場合はfalse。succeeded:true、false、または"partial"。"partial"はstatus: "partial_failed"と組み合わせられます。reason: 永続的な配信または事前確認バリデーションからの小文字のスネークケース理由。既知の理由にはcancelled_by_message_sending_hook、no_visible_payload、no_visible_result、channel_resolved_to_internal、unknown_channel、invalid_delivery_target、no_delivery_targetが含まれます。永続的な送信の失敗では、失敗したステージも報告される場合があります。集合は拡張される可能性があるため、不明な値は不透明なものとして扱ってください。resultCount: 利用可能な場合のチャネル送信結果数。sentBeforeError: 部分的な失敗で、エラー前に少なくとも 1 つのペイロードが送信された場合はtrue。error: 失敗または部分的失敗の送信では booleantrue。errorMessage: 基礎となる配信エラーメッセージが捕捉された場合にのみ含まれます。事前確認失敗ではerrorとreasonは含まれますが、errorMessageは含まれません。payloadOutcomes: 利用可能な場合、index、status、reason、resultCount、error、stage、sentBeforeError、またはフックメタデータを含む、ペイロードごとの任意の結果。
関連
Was this useful?