Gateway

設定 — エージェント

エージェントスコープの設定キーは agents.*multiAgent.*session.*messages.*talk.* 配下にあります。チャンネル、ツール、Gateway ランタイム、その他の トップレベルキーについては、設定リファレンスを参照してください。

エージェントのデフォルト

agents.defaults.workspace

デフォルト: ~/.openclaw/workspace

{
  agents: { defaults: { workspace: "~/.openclaw/workspace" } },
}

agents.defaults.repoRoot

システムプロンプトの Runtime 行に表示される任意のリポジトリルートです。未設定の場合、OpenClaw はワークスペースから上方向にたどって自動検出します。

{
  agents: { defaults: { repoRoot: "~/Projects/openclaw" } },
}

agents.defaults.skills

agents.list[].skills を設定していないエージェント向けの任意のデフォルト Skills 許可リストです。

{
  agents: {
    defaults: { skills: ["github", "weather"] },
    list: [
      { id: "writer" }, // inherits github, weather
      { id: "docs", skills: ["docs-search"] }, // replaces defaults
      { id: "locked-down", skills: [] }, // no skills
    ],
  },
}
  • デフォルトで Skills を制限しない場合は、agents.defaults.skills を省略します。
  • デフォルトを継承するには、agents.list[].skills を省略します。
  • Skills なしにするには、agents.list[].skills: [] を設定します。
  • 空ではない agents.list[].skills リストは、そのエージェントの最終的な集合です。デフォルトとはマージされません。

agents.defaults.skipBootstrap

ワークスペースブートストラップファイル(AGENTS.mdSOUL.mdTOOLS.mdIDENTITY.mdUSER.mdHEARTBEAT.mdBOOTSTRAP.md)の自動作成を無効にします。

{
  agents: { defaults: { skipBootstrap: true } },
}

agents.defaults.skipOptionalBootstrapFiles

必須ブートストラップファイルは書き込みつつ、選択した任意のワークスペースファイルの作成をスキップします。有効な値: SOUL.mdUSER.mdHEARTBEAT.mdIDENTITY.md

{
  agents: {
    defaults: {
      skipOptionalBootstrapFiles: ["SOUL.md", "USER.md"],
    },
  },
}

agents.defaults.contextInjection

ワークスペースブートストラップファイルをシステムプロンプトに注入するタイミングを制御します。デフォルト: "always"

  • "continuation-skip": 安全な継続ターン(完了したアシスタント応答の後)では、ワークスペースブートストラップの再注入をスキップし、プロンプトサイズを削減します。Heartbeat 実行と Compaction 後の再試行では、引き続きコンテキストを再構築します。
  • "never": すべてのターンでワークスペースブートストラップとコンテキストファイルの注入を無効にします。これは、プロンプトライフサイクルを完全に所有するエージェント(カスタムコンテキストエンジン、独自にコンテキストを構築するネイティブランタイム、またはブートストラップなしの特殊なワークフロー)にのみ使用してください。Heartbeat と Compaction 復旧ターンでも注入をスキップします。
{
  agents: { defaults: { contextInjection: "continuation-skip" } },
}

agents.defaults.bootstrapMaxChars

切り詰め前の、ワークスペースブートストラップファイルごとの最大文字数です。デフォルト: 12000

{
  agents: { defaults: { bootstrapMaxChars: 12000 } },
}

agents.defaults.bootstrapTotalMaxChars

すべてのワークスペースブートストラップファイル全体で注入される合計最大文字数です。デフォルト: 60000

{
  agents: { defaults: { bootstrapTotalMaxChars: 60000 } },
}

agents.defaults.bootstrapPromptTruncationWarning

ブートストラップコンテキストが切り詰められたときの、エージェントに見えるシステムプロンプト通知を制御します。 デフォルト: "once"

  • "off": 切り詰め通知テキストをシステムプロンプトに注入しません。
  • "once": 一意の切り詰めシグネチャごとに、簡潔な通知を 1 回注入します(推奨)。
  • "always": 切り詰めがある場合、実行ごとに簡潔な通知を注入します。

詳細な raw/注入済みカウントと設定チューニングフィールドは、コンテキスト/ステータスレポートやログなどの診断に残ります。通常の WebChat ユーザー/ランタイムコンテキストには、簡潔な復旧通知のみが渡されます。

{
  agents: { defaults: { bootstrapPromptTruncationWarning: "once" } }, // off | once | always
}

コンテキスト予算の所有権マップ

OpenClaw には複数の大容量プロンプト/コンテキスト予算があり、それらは 1 つの汎用ノブを通すのではなく、意図的にサブシステムごとに分割されています。

  • agents.defaults.bootstrapMaxChars / agents.defaults.bootstrapTotalMaxChars: 通常のワークスペースブートストラップ注入。
  • agents.defaults.startupContext.*: 最近の日次 memory/*.md ファイルを含む、リセット/起動時モデル実行の 1 回限りの前置き。素のチャット /new/reset コマンドは、モデルを呼び出さずに確認応答されます。
  • skills.limits.*: システムプロンプトに注入されるコンパクトな Skills リスト。
  • agents.defaults.contextLimits.*: 境界付きのランタイム抜粋と、ランタイム所有の注入ブロック。
  • memory.qmd.limits.*: インデックス済みメモリ検索スニペットと注入サイズ。

あるエージェントだけに異なる予算が必要な場合にのみ、対応するエージェント単位のオーバーライドを使用します。

  • agents.list[].skillsLimits.maxSkillsPromptChars
  • agents.list[].contextLimits.*

agents.defaults.startupContext

リセット/起動時モデル実行で注入される、初回ターンの起動前置きを制御します。素のチャット /new/reset コマンドは、モデルを呼び出さずにリセットを確認応答するため、この前置きを読み込みません。

{
  agents: {
    defaults: {
      startupContext: {
        enabled: true,
        applyOn: ["new", "reset"],
        dailyMemoryDays: 2,
        maxFileBytes: 16384,
        maxFileChars: 1200,
        maxTotalChars: 2800,
      },
    },
  },
}

agents.defaults.contextLimits

境界付きランタイムコンテキストサーフェスの共有デフォルトです。

{
  agents: {
    defaults: {
      contextLimits: {
        memoryGetMaxChars: 12000,
        memoryGetDefaultLines: 120,
        toolResultMaxChars: 16000,
        postCompactionMaxChars: 1800,
      },
    },
  },
}
  • memoryGetMaxChars: 切り詰めメタデータと継続通知が追加される前の、デフォルトの memory_get 抜粋上限です。
  • memoryGetDefaultLines: lines が省略されたときの、デフォルトの memory_get 行ウィンドウです。
  • toolResultMaxChars: 永続化された結果とオーバーフロー復旧に使われる、ライブツール結果の上限です。
  • postCompactionMaxChars: Compaction 後の更新注入中に使われる、AGENTS.md 抜粋の上限です。

agents.list[].contextLimits

共有 contextLimits ノブのエージェント単位オーバーライドです。省略されたフィールドは agents.defaults.contextLimits から継承されます。

{
  agents: {
    defaults: {
      contextLimits: {
        memoryGetMaxChars: 12000,
        toolResultMaxChars: 16000,
      },
    },
    list: [
      {
        id: "tiny-local",
        contextLimits: {
          memoryGetMaxChars: 6000,
          toolResultMaxChars: 8000,
        },
      },
    ],
  },
}

skills.limits.maxSkillsPromptChars

システムプロンプトに注入されるコンパクトな Skills リストのグローバル上限です。これは、必要に応じて SKILL.md ファイルを読むことには影響しません。

{
  skills: {
    limits: {
      maxSkillsPromptChars: 18000,
    },
  },
}

agents.list[].skillsLimits.maxSkillsPromptChars

Skills プロンプト予算のエージェント単位オーバーライドです。

{
  agents: {
    list: [
      {
        id: "tiny-local",
        skillsLimits: {
          maxSkillsPromptChars: 6000,
        },
      },
    ],
  },
}

agents.defaults.imageMaxDimensionPx

プロバイダー呼び出し前に、トランスクリプト/ツール画像ブロック内の画像の最長辺に適用される最大ピクセルサイズです。 デフォルト: 1200

値を低くすると、通常はスクリーンショットが多い実行で vision-token 使用量とリクエストペイロードサイズを削減できます。 値を高くすると、より多くの視覚的詳細を保持できます。

{
  agents: { defaults: { imageMaxDimensionPx: 1200 } },
}

agents.defaults.userTimezone

システムプロンプトコンテキスト用のタイムゾーンです(メッセージのタイムスタンプではありません)。ホストのタイムゾーンにフォールバックします。

{
  agents: { defaults: { userTimezone: "America/Chicago" } },
}

agents.defaults.timeFormat

システムプロンプト内の時刻形式です。デフォルト: auto(OS 設定)。

{
  agents: { defaults: { timeFormat: "auto" } }, // auto | 12 | 24
}

agents.defaults.model

{
  agents: {
    defaults: {
      models: {
        "anthropic/claude-opus-4-6": { alias: "opus" },
        "minimax/MiniMax-M2.7": { alias: "minimax" },
      },
      model: {
        primary: "anthropic/claude-opus-4-6",
        fallbacks: ["minimax/MiniMax-M2.7"],
      },
      imageModel: {
        primary: "openrouter/qwen/qwen-2.5-vl-72b-instruct:free",
        fallbacks: ["openrouter/google/gemini-2.0-flash-vision:free"],
      },
      imageGenerationModel: {
        primary: "openai/gpt-image-2",
        fallbacks: ["google/gemini-3.1-flash-image-preview"],
      },
      videoGenerationModel: {
        primary: "qwen/wan2.6-t2v",
        fallbacks: ["qwen/wan2.6-i2v"],
      },
      pdfModel: {
        primary: "anthropic/claude-opus-4-6",
        fallbacks: ["openai/gpt-5.4-mini"],
      },
      params: { cacheRetention: "long" }, // global default provider params
      agentRuntime: {
        id: "pi", // pi | auto | registered harness id, e.g. codex
      },
      pdfMaxBytesMb: 10,
      pdfMaxPages: 20,
      thinkingDefault: "low",
      verboseDefault: "off",
      toolProgressDetail: "explain",
      reasoningDefault: "off",
      elevatedDefault: "on",
      timeoutSeconds: 600,
      mediaMaxMb: 5,
      contextTokens: 200000,
      maxConcurrent: 3,
    },
  },
}
  • model: 文字列 ("provider/model") またはオブジェクト ({ primary, fallbacks }) を受け付けます。
    • 文字列形式ではプライマリモデルのみを設定します。
    • オブジェクト形式では、プライマリと順序付きフェイルオーバーモデルを設定します。
  • imageModel: 文字列 ("provider/model") またはオブジェクト ({ primary, fallbacks }) を受け付けます。
    • image ツールパスで、そのビジョンモデル設定として使用されます。
    • 選択済みまたはデフォルトのモデルが画像入力を受け付けられない場合のフォールバックルーティングにも使用されます。
    • 明示的な provider/model 参照を推奨します。互換性のために裸の ID も受け付けます。裸の ID が models.providers.*.models 内の設定済みで画像対応のエントリに一意に一致する場合、OpenClaw はそれをそのプロバイダーに修飾します。設定済みの一致が曖昧な場合は、明示的なプロバイダープレフィックスが必要です。
  • imageGenerationModel: 文字列 ("provider/model") またはオブジェクト ({ primary, fallbacks }) を受け付けます。
    • 共有の画像生成機能と、画像を生成する将来のツール/Plugin サーフェスで使用されます。
    • 典型的な値: ネイティブ Gemini 画像生成では google/gemini-3.1-flash-image-preview、fal では fal/fal-ai/flux/dev、OpenAI Images では openai/gpt-image-2、透明背景の OpenAI PNG/WebP 出力では openai/gpt-image-1.5
    • プロバイダー/モデルを直接選択する場合は、一致するプロバイダー認証も設定してください (例: google/* には GEMINI_API_KEY または GOOGLE_API_KEYopenai/gpt-image-2 / openai/gpt-image-1.5 には OPENAI_API_KEY または OpenAI Codex OAuth、fal/* には FAL_KEY)。
    • 省略した場合でも、image_generate は認証に裏付けられたプロバイダーのデフォルトを推論できます。まず現在のデフォルトプロバイダーを試し、その後、残りの登録済み画像生成プロバイダーをプロバイダー ID 順に試します。
  • musicGenerationModel: 文字列 ("provider/model") またはオブジェクト ({ primary, fallbacks }) を受け付けます。
    • 共有の音楽生成機能と組み込みの music_generate ツールで使用されます。
    • 典型的な値: google/lyria-3-clip-previewgoogle/lyria-3-pro-preview、または minimax/music-2.6
    • 省略した場合でも、music_generate は認証に裏付けられたプロバイダーのデフォルトを推論できます。まず現在のデフォルトプロバイダーを試し、その後、残りの登録済み音楽生成プロバイダーをプロバイダー ID 順に試します。
    • プロバイダー/モデルを直接選択する場合は、一致するプロバイダー認証/API キーも設定してください。
  • videoGenerationModel: 文字列 ("provider/model") またはオブジェクト ({ primary, fallbacks }) を受け付けます。
    • 共有の動画生成機能と組み込みの video_generate ツールで使用されます。
    • 典型的な値: qwen/wan2.6-t2vqwen/wan2.6-i2vqwen/wan2.6-r2vqwen/wan2.6-r2v-flash、または qwen/wan2.7-r2v
    • 省略した場合でも、video_generate は認証に裏付けられたプロバイダーのデフォルトを推論できます。まず現在のデフォルトプロバイダーを試し、その後、残りの登録済み動画生成プロバイダーをプロバイダー ID 順に試します。
    • プロバイダー/モデルを直接選択する場合は、一致するプロバイダー認証/API キーも設定してください。
    • バンドルされている Qwen 動画生成プロバイダーは、最大 1 個の出力動画、1 個の入力画像、4 個の入力動画、10 秒の長さ、およびプロバイダーレベルの sizeaspectRatioresolutionaudiowatermark オプションをサポートします。
  • pdfModel: 文字列 ("provider/model") またはオブジェクト ({ primary, fallbacks }) を受け付けます。
    • モデルルーティングのために pdf ツールで使用されます。
    • 省略した場合、PDF ツールは imageModel にフォールバックし、その後、解決済みのセッション/デフォルトモデルにフォールバックします。
  • pdfMaxBytesMb: 呼び出し時に maxBytesMb が渡されない場合の、pdf ツールのデフォルト PDF サイズ上限。
  • pdfMaxPages: pdf ツールの抽出フォールバックモードで考慮されるデフォルトの最大ページ数。
  • verboseDefault: エージェントのデフォルト詳細レベル。値: "off""on""full"。デフォルト: "off"
  • toolProgressDetail: /verbose ツール要約と進行状況ドラフトのツール行の詳細モード。値: "explain" (デフォルト、簡潔な人間向けラベル) または "raw" (利用可能な場合は生のコマンド/詳細を追加)。エージェントごとの agents.list[].toolProgressDetail はこのデフォルトを上書きします。
  • reasoningDefault: エージェントのデフォルト推論表示。値: "off""on""stream"。エージェントごとの agents.list[].reasoningDefault はこのデフォルトを上書きします。設定済みの推論デフォルトは、メッセージごとまたはセッションの推論上書きが設定されていない場合に、所有者、許可済み送信者、またはオペレーター管理者 Gateway コンテキストに対してのみ適用されます。
  • elevatedDefault: エージェントのデフォルト昇格出力レベル。値: "off""on""ask""full"。デフォルト: "on"
  • model.primary: 形式は provider/model です (例: OpenAI API キーまたは Codex OAuth アクセスでは openai/gpt-5.5)。プロバイダーを省略した場合、OpenClaw はまずエイリアスを試し、次にその正確なモデル ID に対する一意の設定済みプロバイダー一致を試し、その後で設定済みのデフォルトプロバイダーにフォールバックします (非推奨の互換動作のため、明示的な provider/model を推奨します)。そのプロバイダーが設定済みのデフォルトモデルを公開しなくなった場合、OpenClaw は古くなった削除済みプロバイダーのデフォルトを表示する代わりに、最初に設定されたプロバイダー/モデルにフォールバックします。
  • models: /model 用に設定されたモデルカタログと許可リスト。各エントリには alias (ショートカット) と params (プロバイダー固有。例: temperaturemaxTokenscacheRetentioncontext1mresponsesServerCompactionresponsesCompactThresholdchat_template_kwargsextra_body/extraBody) を含められます。
    • 安全な編集: エントリを追加するには openclaw config set agents.defaults.models '<json>' --strict-json --merge を使用します。config set は、--replace を渡さない限り、既存の許可リストエントリを削除する置換を拒否します。
    • プロバイダー範囲の設定/オンボーディングフローは、選択されたプロバイダーモデルをこのマップにマージし、すでに設定済みの無関係なプロバイダーを保持します。
    • 直接 OpenAI Responses モデルでは、サーバー側 Compaction が自動的に有効になります。context_management の注入を停止するには params.responsesServerCompaction: false を使用し、しきい値を上書きするには params.responsesCompactThreshold を使用します。OpenAI サーバー側 Compaction を参照してください。
  • params: すべてのモデルに適用されるグローバルなデフォルトプロバイダーパラメーター。agents.defaults.params で設定します (例: { cacheRetention: "long" })。
  • params のマージ優先順位 (設定): agents.defaults.params (グローバルベース) は agents.defaults.models["provider/model"].params (モデルごと) によって上書きされ、その後 agents.list[].params (一致するエージェント ID) がキー単位で上書きします。詳細は Prompt Caching を参照してください。
  • params.extra_body/params.extraBody: OpenAI 互換プロキシ向けに api: "openai-completions" リクエストボディへマージされる高度なパススルー JSON。生成されたリクエストキーと衝突した場合は追加ボディが優先されます。非ネイティブの completions ルートでは、その後も OpenAI 専用の store が削除されます。
  • params.chat_template_kwargs: トップレベルの api: "openai-completions" リクエストボディへマージされる vLLM/OpenAI 互換のチャットテンプレート引数。思考をオフにした vllm/nemotron-3-* では、バンドルされている vLLM Plugin が自動的に enable_thinking: falseforce_nonempty_content: true を送信します。明示的な chat_template_kwargs は生成されたデフォルトを上書きし、extra_body.chat_template_kwargs が引き続き最終的な優先権を持ちます。vLLM Qwen の思考制御では、そのモデルエントリで params.qwenThinkingFormat"chat-template" または "top-level" に設定します。
  • compat.supportedReasoningEfforts: モデルごとの OpenAI 互換推論努力レベル一覧。実際に受け付けるカスタムエンドポイントには "xhigh" を含めてください。すると OpenClaw は、設定されたそのプロバイダー/モデルに対して、コマンドメニュー、Gateway セッション行、セッションパッチ検証、エージェント CLI 検証、llm-task 検証で /think xhigh を公開します。バックエンドが標準レベルに対してプロバイダー固有の値を必要とする場合は compat.reasoningEffortMap を使用します。
  • params.preserveThinking: 保存された思考に対する Z.AI 専用のオプトイン。有効で思考がオンの場合、OpenClaw は thinking.clear_thinking: false を送信し、以前の reasoning_content を再生します。Z.AI の思考と保存された思考 を参照してください。
  • agentRuntime: デフォルトの低レベルエージェント実行時ポリシー。ID を省略すると OpenClaw Pi がデフォルトになります。組み込みの PI ハーネスを強制するには id: "pi"、登録済み Plugin ハーネスにサポート対象モデルを要求させ、一致しない場合に PI を使用するには id: "auto"、そのハーネスを必須にするには id: "codex" のような登録済みハーネス ID、サポート対象 CLI バックエンドエイリアスには id: "claude-cli" のような値を使用します。明示的な Plugin ランタイムは、ハーネスが利用できない場合または失敗した場合にクローズドに失敗します。モデル参照は provider/model として正規形に保ってください。Codex、Claude CLI、Gemini CLI、およびその他の実行バックエンドは、レガシーなランタイムプロバイダープレフィックスではなくランタイム設定で選択します。これがプロバイダー/モデル選択とどう異なるかは エージェントランタイム を参照してください。
  • これらのフィールドを変更する設定書き込み機能 (例: /models set/models set-image、フォールバック追加/削除コマンド) は、正規のオブジェクト形式で保存し、可能な場合は既存のフォールバック一覧を保持します。
  • maxConcurrent: セッション全体での最大並列エージェント実行数 (各セッション自体は引き続き直列化されます)。デフォルト: 4。

agents.defaults.agentRuntime

agentRuntime は、どの低レベル実行器がエージェントターンを実行するかを制御します。ほとんどの デプロイでは、デフォルトの OpenClaw Pi ランタイムを維持するべきです。バンドルされている Codex app-server ハーネスのように、信頼済みの Plugin がネイティブハーネスを提供する場合、または Claude CLI のようなサポート対象 CLI バックエンドを使いたい場合に使用します。メンタルモデルについては、 エージェントランタイム を参照してください。

{
  agents: {
    defaults: {
      model: "openai/gpt-5.5",
      agentRuntime: {
        id: "codex",
      },
    },
  },
}
  • id: "auto""pi"、登録済み Plugin ハーネス ID、またはサポート対象 CLI バックエンドエイリアス。バンドルされている Codex Plugin は codex を登録します。バンドルされている Anthropic Plugin は claude-cli CLI バックエンドを提供します。
  • id: "auto" は、登録済み Plugin ハーネスにサポート対象ターンを要求させ、一致するハーネスがない場合は PI を使用します。id: "codex" のような明示的な Plugin ランタイムは、そのハーネスを必須にし、利用できない場合または失敗した場合にクローズドに失敗します。
  • 環境上書き: OPENCLAW_AGENT_RUNTIME=<id|auto|pi> は、そのプロセスの id を上書きします。
  • OpenAI エージェントモデルはデフォルトで Codex ハーネスを使用します。明示したい場合、agentRuntime.id: "codex" は引き続き有効です。
  • Claude CLI デプロイでは、model: "anthropic/claude-opus-4-7"agentRuntime.id: "claude-cli" の組み合わせを推奨します。レガシーな claude-cli/claude-opus-4-7 モデル参照は互換性のために引き続き動作しますが、新しい設定ではプロバイダー/モデル選択を正規形に保ち、実行バックエンドを agentRuntime.id に置くべきです。
  • 古いランタイムポリシーキーは openclaw doctor --fix によって agentRuntime に書き換えられます。
  • ハーネス選択は、最初の埋め込み実行後にセッション ID ごとに固定されます。設定/環境の変更は、新規またはリセットされたセッションに影響し、既存のトランスクリプトには影響しません。トランスクリプト履歴はあるが記録済みピンがないレガシー OpenAI セッションは Codex を使用します。古くなった OpenAI PI ピンは openclaw doctor --fix で修復できます。/status は有効なランタイムを報告します。例: Runtime: OpenClaw Pi Default または Runtime: OpenAI Codex
  • これはテキストのエージェントターン実行のみを制御します。メディア生成、ビジョン、PDF、音楽、動画、TTS は引き続きそれぞれのプロバイダー/モデル設定を使用します。

組み込みエイリアス短縮形 (agents.defaults.models 内にモデルがある場合にのみ適用されます):

エイリアス モデル
opus anthropic/claude-opus-4-6
sonnet anthropic/claude-sonnet-4-6
gpt openai/gpt-5.5
gpt-mini openai/gpt-5.4-mini
gpt-nano openai/gpt-5.4-nano
gemini google/gemini-3.1-pro-preview
gemini-flash google/gemini-3-flash-preview
gemini-flash-lite google/gemini-3.1-flash-lite-preview

設定したエイリアスは常にデフォルトより優先されます。

Z.AI GLM-4.x モデルは、--thinking off を設定するか agents.defaults.models["zai/<model>"].params.thinking を自分で定義しない限り、思考モードを自動的に有効にします。 Z.AI モデルは、ツール呼び出しストリーミングのためにデフォルトで tool_stream を有効にします。無効にするには、agents.defaults.models["zai/<model>"].params.tool_streamfalse に設定します。 Anthropic Claude 4.6 モデルは、明示的な思考レベルが設定されていない場合、デフォルトで adaptive 思考になります。

agents.defaults.cliBackends

テキストのみのフォールバック実行用の任意の CLI バックエンドです(ツール呼び出しなし)。API プロバイダーが失敗した場合のバックアップとして便利です。

{
  agents: {
    defaults: {
      cliBackends: {
        "codex-cli": {
          command: "/opt/homebrew/bin/codex",
        },
        "my-cli": {
          command: "my-cli",
          args: ["--json"],
          output: "json",
          modelArg: "--model",
          sessionArg: "--session",
          sessionMode: "existing",
          systemPromptArg: "--system",
          // Or use systemPromptFileArg when the CLI accepts a prompt file flag.
          systemPromptWhen: "first",
          imageArg: "--image",
          imageMode: "repeat",
        },
      },
    },
  },
}
  • CLI バックエンドはテキスト優先です。ツールは常に無効です。
  • sessionArg が設定されている場合、セッションがサポートされます。
  • imageArg がファイルパスを受け付ける場合、画像のパススルーがサポートされます。

agents.defaults.systemPromptOverride

OpenClaw が組み立てたシステムプロンプト全体を固定文字列で置き換えます。デフォルトレベル(agents.defaults.systemPromptOverride)またはエージェントごと(agents.list[].systemPromptOverride)に設定します。エージェントごとの値が優先されます。空または空白のみの値は無視されます。制御されたプロンプト実験に便利です。

{
  agents: {
    defaults: {
      systemPromptOverride: "You are a helpful assistant.",
    },
  },
}

agents.defaults.promptOverlays

モデルファミリー別に適用される、プロバイダー非依存のプロンプトオーバーレイです。GPT-5 ファミリーのモデル ID は、プロバイダーをまたいで共有の振る舞い契約を受け取ります。personality はフレンドリーな対話スタイルレイヤーのみを制御します。

{
  agents: {
    defaults: {
      promptOverlays: {
        gpt5: {
          personality: "friendly", // friendly | on | off
        },
      },
    },
  },
}
  • "friendly"(デフォルト)と "on" は、フレンドリーな対話スタイルレイヤーを有効にします。
  • "off" はフレンドリーレイヤーのみを無効にします。タグ付けされた GPT-5 の振る舞い契約は有効なままです。
  • この共有設定が未設定の場合、従来の plugins.entries.openai.config.personality が引き続き読み取られます。

agents.defaults.heartbeat

定期的な Heartbeat 実行です。

{
  agents: {
    defaults: {
      heartbeat: {
        every: "30m", // 0m disables
        model: "openai/gpt-5.4-mini",
        includeReasoning: false,
        includeSystemPromptSection: true, // default: true; false omits the Heartbeat section from the system prompt
        lightContext: false, // default: false; true keeps only HEARTBEAT.md from workspace bootstrap files
        isolatedSession: false, // default: false; true runs each heartbeat in a fresh session (no conversation history)
        skipWhenBusy: false, // default: false; true also waits for subagent/nested lanes
        session: "main",
        to: "+15555550123",
        directPolicy: "allow", // allow (default) | block
        target: "none", // default: none | options: last | whatsapp | telegram | discord | ...
        prompt: "Read HEARTBEAT.md if it exists...",
        ackMaxChars: 300,
        suppressToolErrorWarnings: false,
        timeoutSeconds: 45,
      },
    },
  },
}
  • every: 期間文字列(ms/s/m/h)。デフォルト: 30m(API キー認証)または 1h(OAuth 認証)。無効にするには 0m に設定します。
  • includeSystemPromptSection: false の場合、システムプロンプトから Heartbeat セクションを省略し、ブートストラップコンテキストへの HEARTBEAT.md 注入をスキップします。デフォルト: true
  • suppressToolErrorWarnings: true の場合、Heartbeat 実行中のツールエラー警告ペイロードを抑制します。
  • timeoutSeconds: Heartbeat エージェントターンが中止される前に許可される最大秒数です。未設定のままにすると agents.defaults.timeoutSeconds を使用します。
  • directPolicy: ダイレクト/DM 配信ポリシーです。allow(デフォルト)はダイレクトターゲット配信を許可します。block はダイレクトターゲット配信を抑制し、reason=dm-blocked を出力します。
  • lightContext: true の場合、Heartbeat 実行は軽量なブートストラップコンテキストを使用し、ワークスペースのブートストラップファイルから HEARTBEAT.md のみを保持します。
  • isolatedSession: true の場合、各 Heartbeat は以前の会話履歴なしの新しいセッションで実行されます。cron sessionTarget: "isolated" と同じ分離パターンです。Heartbeat ごとのトークンコストを約 100K から約 2-5K トークンに削減します。
  • skipWhenBusy: true の場合、Heartbeat 実行は追加のビジーなレーン(サブエージェントまたはネストされたコマンド作業)で延期されます。このフラグがなくても、Cron レーンは常に Heartbeat を延期します。
  • エージェントごと: agents.list[].heartbeat を設定します。いずれかのエージェントが heartbeat を定義している場合、それらのエージェントのみが Heartbeat を実行します。
  • Heartbeat は完全なエージェントターンを実行します。間隔が短いほど消費するトークンは増えます。

agents.defaults.compaction

{
  agents: {
    defaults: {
      compaction: {
        mode: "safeguard", // default | safeguard
        provider: "my-provider", // id of a registered compaction provider plugin (optional)
        timeoutSeconds: 900,
        reserveTokensFloor: 24000,
        keepRecentTokens: 50000,
        identifierPolicy: "strict", // strict | off | custom
        identifierInstructions: "Preserve deployment IDs, ticket IDs, and host:port pairs exactly.", // used when identifierPolicy=custom
        qualityGuard: { enabled: true, maxRetries: 1 },
        midTurnPrecheck: { enabled: false }, // optional Pi tool-loop pressure check
        postCompactionSections: ["Session Startup", "Red Lines"], // [] disables reinjection
        model: "openrouter/anthropic/claude-sonnet-4-6", // optional compaction-only model override
        truncateAfterCompaction: true, // rotate to a smaller successor JSONL after compaction
        maxActiveTranscriptBytes: "20mb", // optional preflight local compaction trigger
        notifyUser: true, // send brief notices when compaction starts and completes (default: false)
        memoryFlush: {
          enabled: true,
          model: "ollama/qwen3:8b", // optional memory-flush-only model override
          softThresholdTokens: 6000,
          systemPrompt: "Session nearing compaction. Store durable memories now.",
          prompt: "Write any lasting notes to memory/YYYY-MM-DD.md; reply with the exact silent token NO_REPLY if nothing to store.",
        },
      },
    },
  },
}
  • mode: default または safeguard(長い履歴向けのチャンク化要約)。Compaction を参照してください。
  • provider: 登録済み Compaction プロバイダー Plugin の ID です。設定すると、組み込み LLM 要約の代わりにプロバイダーの summarize() が呼び出されます。失敗時は組み込みにフォールバックします。プロバイダーを設定すると mode: "safeguard" が強制されます。Compaction を参照してください。
  • timeoutSeconds: OpenClaw が単一の Compaction 操作を中止するまでに許可する最大秒数です。デフォルト: 900
  • keepRecentTokens: 最新のトランスクリプト末尾をそのまま保持するための Pi カットポイント予算です。明示的に設定されている場合、手動 /compact はこれを尊重します。それ以外の場合、手動 Compaction はハードチェックポイントになります。
  • identifierPolicy: strict(デフォルト)、off、または customstrict は、Compaction 要約中に組み込みの不透明識別子保持ガイダンスを先頭に追加します。
  • identifierInstructions: identifierPolicy=custom の場合に使用される、識別子保持用の任意のカスタムテキストです。
  • qualityGuard: safeguard 要約の不正形式出力に対する再試行チェックです。safeguard モードではデフォルトで有効です。監査をスキップするには enabled: false を設定します。
  • midTurnPrecheck: 任意の Pi ツールループ圧力チェックです。enabled: true の場合、OpenClaw はツール結果が追加された後、次のモデル呼び出しの前にコンテキスト圧力をチェックします。コンテキストが収まらなくなっている場合、プロンプトを送信する前に現在の試行を中止し、既存の事前チェック復旧パスを再利用してツール結果を切り詰めるか、Compaction して再試行します。defaultsafeguard の両方の Compaction モードで動作します。デフォルト: 無効。
  • postCompactionSections: Compaction 後に再注入する任意の AGENTS.md H2/H3 セクション名です。デフォルトは ["Session Startup", "Red Lines"] です。再注入を無効にするには [] を設定します。未設定、または明示的にそのデフォルトペアに設定されている場合、古い Every Session/Safety 見出しもレガシーフォールバックとして受け付けられます。
  • model: Compaction 要約専用の任意の provider/model-id オーバーライドです。メインセッションは 1 つのモデルを維持しつつ、Compaction 要約は別のモデルで実行したい場合に使用します。未設定の場合、Compaction はセッションのプライマリモデルを使用します。
  • maxActiveTranscriptBytes: アクティブな JSONL がしきい値を超えて増加した場合に、実行前に通常のローカル Compaction をトリガーする任意のバイトしきい値(number または "20mb" のような文字列)です。Compaction 成功後により小さな後続トランスクリプトへローテーションできるよう、truncateAfterCompaction が必要です。未設定または 0 の場合は無効です。
  • notifyUser: true の場合、Compaction の開始時と完了時に短い通知をユーザーへ送信します(例: 「コンテキストを Compaction 中...」と「Compaction が完了しました」)。Compaction を静かに保つため、デフォルトでは無効です。
  • memoryFlush: 自動 Compaction の前に永続メモリを保存するためのサイレントなエージェントターンです。このハウスキーピングターンをローカルモデルに留めたい場合は、modelollama/qwen3:8b のような正確な provider/model に設定します。このオーバーライドはアクティブセッションのフォールバックチェーンを継承しません。ワークスペースが読み取り専用の場合はスキップされます。

agents.defaults.contextPruning

LLM に送信する前に、メモリ内コンテキストから古いツール結果を枝刈りします。ディスク上のセッション履歴は変更しません

{
  agents: {
    defaults: {
      contextPruning: {
        mode: "cache-ttl", // off | cache-ttl
        ttl: "1h", // duration (ms/s/m/h), default unit: minutes
        keepLastAssistants: 3,
        softTrimRatio: 0.3,
        hardClearRatio: 0.5,
        minPrunableToolChars: 50000,
        softTrim: { maxChars: 4000, headChars: 1500, tailChars: 1500 },
        hardClear: { enabled: true, placeholder: "[Old tool result content cleared]" },
        tools: { deny: ["browser", "canvas"] },
      },
    },
  },
}
cache-ttl mode behavior
  • mode: "cache-ttl" は枝刈りパスを有効にします。
  • ttl は、(最後のキャッシュタッチ後に)枝刈りを再度実行できる頻度を制御します。
  • 枝刈りはまず大きすぎるツール結果をソフトトリムし、その後必要に応じて古いツール結果をハードクリアします。

ソフトトリムは先頭と末尾を保持し、中央に ... を挿入します。

ハードクリアはツール結果全体をプレースホルダーで置き換えます。

注記:

  • 画像ブロックはトリム/クリアされません。
  • 比率は文字ベース(概算)であり、正確なトークン数ではありません。
  • keepLastAssistants より少ない assistant メッセージしか存在しない場合、枝刈りはスキップされます。

振る舞いの詳細は セッション枝刈り を参照してください。

ブロックストリーミング

{
  agents: {
    defaults: {
      blockStreamingDefault: "off", // on | off
      blockStreamingBreak: "text_end", // text_end | message_end
      blockStreamingChunk: { minChars: 800, maxChars: 1200 },
      blockStreamingCoalesce: { idleMs: 1000 },
      humanDelay: { mode: "natural" }, // off | natural | custom (use minMs/maxMs)
    },
  },
}
  • Telegram 以外のチャネルでは、ブロック返信を有効にするために明示的な *.blockStreaming: true が必要です。
  • チャネルオーバーライド: channels.<channel>.blockStreamingCoalesce(およびアカウントごとのバリアント)。Signal/Slack/Discord/Google Chat のデフォルトは minChars: 1500 です。
  • humanDelay: ブロック返信間のランダム化された一時停止です。natural = 800–2500ms。エージェントごとのオーバーライド: agents.list[].humanDelay

振る舞いとチャンク化の詳細は ストリーミング を参照してください。

入力中インジケーター

{
  agents: {
    defaults: {
      typingMode: "instant", // never | instant | thinking | message
      typingIntervalSeconds: 6,
    },
  },
}
  • 既定値: 直接チャット/メンションでは instant、メンションされていないグループチャットでは message
  • セッションごとの上書き: session.typingModesession.typingIntervalSeconds

入力インジケーターを参照してください。

agents.defaults.sandbox

埋め込みエージェント向けの任意のサンドボックス化。完全なガイドはサンドボックス化を参照してください。

{
  agents: {
    defaults: {
      sandbox: {
        mode: "non-main", // off | non-main | all
        backend: "docker", // docker | ssh | openshell
        scope: "agent", // session | agent | shared
        workspaceAccess: "none", // none | ro | rw
        workspaceRoot: "~/.openclaw/sandboxes",
        docker: {
          image: "openclaw-sandbox:bookworm-slim",
          containerPrefix: "openclaw-sbx-",
          workdir: "/workspace",
          readOnlyRoot: true,
          tmpfs: ["/tmp", "/var/tmp", "/run"],
          network: "none",
          user: "1000:1000",
          capDrop: ["ALL"],
          env: { LANG: "C.UTF-8" },
          setupCommand: "apt-get update && apt-get install -y git curl jq",
          pidsLimit: 256,
          memory: "1g",
          memorySwap: "2g",
          cpus: 1,
          ulimits: {
            nofile: { soft: 1024, hard: 2048 },
            nproc: 256,
          },
          seccompProfile: "/path/to/seccomp.json",
          apparmorProfile: "openclaw-sandbox",
          dns: ["1.1.1.1", "8.8.8.8"],
          extraHosts: ["internal.service:10.0.0.5"],
          binds: ["/home/user/source:/source:rw"],
        },
        ssh: {
          target: "user@gateway-host:22",
          command: "ssh",
          workspaceRoot: "/tmp/openclaw-sandboxes",
          strictHostKeyChecking: true,
          updateHostKeys: true,
          identityFile: "~/.ssh/id_ed25519",
          certificateFile: "~/.ssh/id_ed25519-cert.pub",
          knownHostsFile: "~/.ssh/known_hosts",
          // SecretRefs / inline contents also supported:
          // identityData: { source: "env", provider: "default", id: "SSH_IDENTITY" },
          // certificateData: { source: "env", provider: "default", id: "SSH_CERTIFICATE" },
          // knownHostsData: { source: "env", provider: "default", id: "SSH_KNOWN_HOSTS" },
        },
        browser: {
          enabled: false,
          image: "openclaw-sandbox-browser:bookworm-slim",
          network: "openclaw-sandbox-browser",
          cdpPort: 9222,
          cdpSourceRange: "172.21.0.1/32",
          vncPort: 5900,
          noVncPort: 6080,
          headless: false,
          enableNoVnc: true,
          allowHostControl: false,
          autoStart: true,
          autoStartTimeoutMs: 12000,
        },
        prune: {
          idleHours: 24,
          maxAgeDays: 7,
        },
      },
    },
  },
  tools: {
    sandbox: {
      tools: {
        allow: [
          "exec",
          "process",
          "read",
          "write",
          "edit",
          "apply_patch",
          "sessions_list",
          "sessions_history",
          "sessions_send",
          "sessions_spawn",
          "session_status",
        ],
        deny: ["browser", "canvas", "nodes", "cron", "discord", "gateway"],
      },
    },
  },
}
Sandbox details

バックエンド:

  • docker: ローカル Docker ランタイム(既定)
  • ssh: 汎用 SSH ベースのリモートランタイム
  • openshell: OpenShell ランタイム

backend: "openshell" が選択されている場合、ランタイム固有の設定は plugins.entries.openshell.config に移動します。

SSH バックエンド設定:

  • target: user@host[:port] 形式の SSH ターゲット
  • command: SSH クライアントコマンド(既定: ssh
  • workspaceRoot: スコープごとのワークスペースに使用される絶対リモートルート
  • identityFile / certificateFile / knownHostsFile: OpenSSH に渡される既存のローカルファイル
  • identityData / certificateData / knownHostsData: OpenClaw が実行時に一時ファイルへ実体化するインライン内容または SecretRefs
  • strictHostKeyChecking / updateHostKeys: OpenSSH ホストキー方針の調整項目

SSH 認証の優先順位:

  • identityDataidentityFile より優先されます
  • certificateDatacertificateFile より優先されます
  • knownHostsDataknownHostsFile より優先されます
  • SecretRef ベースの *Data 値は、サンドボックスセッション開始前にアクティブなシークレットランタイムスナップショットから解決されます

SSH バックエンドの動作:

  • 作成または再作成後にリモートワークスペースを一度シードします
  • その後はリモート SSH ワークスペースを正とします
  • exec、ファイルツール、メディアパスを SSH 経由でルーティングします
  • リモート変更をホストへ自動同期しません
  • サンドボックスブラウザーコンテナには対応していません

ワークスペースアクセス:

  • none: ~/.openclaw/sandboxes 配下のスコープごとのサンドボックスワークスペース
  • ro: /workspace のサンドボックスワークスペース、/agent に読み取り専用でマウントされたエージェントワークスペース
  • rw: /workspace に読み書き可能でマウントされたエージェントワークスペース

スコープ:

  • session: セッションごとのコンテナ + ワークスペース
  • agent: エージェントごとに 1 つのコンテナ + ワークスペース(既定)
  • shared: 共有コンテナおよびワークスペース(セッション間の分離なし)

OpenShell Plugin 設定:

{
plugins: {
  entries: {
    openshell: {
      enabled: true,
      config: {
        mode: "mirror", // mirror | remote
        from: "openclaw",
        remoteWorkspaceDir: "/sandbox",
        remoteAgentWorkspaceDir: "/agent",
        gateway: "lab", // optional
        gatewayEndpoint: "https://lab.example", // optional
        policy: "strict", // optional OpenShell policy id
        providers: ["openai"], // optional
        autoProviders: true,
        timeoutSeconds: 120,
      },
    },
  },
},
}

OpenShell モード:

  • mirror: 実行前にローカルからリモートへシードし、実行後に同期して戻します。ローカルワークスペースが正のままです
  • remote: サンドボックス作成時にリモートへ一度シードし、その後はリモートワークスペースを正とします

remote モードでは、OpenClaw の外部で行われたホストローカル編集は、シード手順後にサンドボックスへ自動同期されません。 トランスポートは OpenShell サンドボックスへの SSH ですが、Plugin がサンドボックスのライフサイクルと任意のミラー同期を所有します。

setupCommand はコンテナ作成後に一度実行されます(sh -lc 経由)。ネットワーク外向き通信、書き込み可能なルート、root ユーザーが必要です。

コンテナの既定は network: "none" です。エージェントに外向きアクセスが必要な場合は "bridge"(またはカスタムブリッジネットワーク)に設定してください。 "host" はブロックされます。"container:<id>" は、 sandbox.docker.dangerouslyAllowContainerNamespaceJoin: true(緊急回避)を明示的に設定しない限り、既定でブロックされます。

受信添付ファイル は、アクティブなワークスペース内の media/inbound/* にステージングされます。

docker.binds は追加のホストディレクトリをマウントします。グローバルおよびエージェントごとのバインドはマージされます。

サンドボックス化されたブラウザーsandbox.browser.enabled): コンテナ内の Chromium + CDP。noVNC URL がシステムプロンプトに注入されます。openclaw.jsonbrowser.enabled は不要です。 noVNC オブザーバーアクセスは既定で VNC 認証を使用し、OpenClaw は共有 URL でパスワードを公開する代わりに短命のトークン URL を発行します。

  • allowHostControl: false(既定)は、サンドボックス化されたセッションがホストブラウザーを対象にすることをブロックします。
  • network の既定は openclaw-sandbox-browser(専用ブリッジネットワーク)です。グローバルブリッジ接続を明示的に必要とする場合のみ bridge に設定してください。
  • cdpSourceRange は、必要に応じてコンテナ境界での CDP 受信を CIDR 範囲(例: 172.21.0.1/32)に制限します。
  • sandbox.browser.binds は、追加のホストディレクトリをサンドボックスブラウザーコンテナのみにマウントします。設定されている場合([] を含む)、ブラウザーコンテナでは docker.binds を置き換えます。
  • 起動時の既定値は scripts/sandbox-browser-entrypoint.sh で定義され、コンテナホスト向けに調整されています:
  • --remote-debugging-address=127.0.0.1
  • --remote-debugging-port=<derived from OPENCLAW_BROWSER_CDP_PORT>
  • --user-data-dir=${HOME}/.chrome
  • --no-first-run
  • --no-default-browser-check
  • --disable-3d-apis
  • --disable-gpu
  • --disable-software-rasterizer
  • --disable-dev-shm-usage
  • --disable-background-networking
  • --disable-features=TranslateUI
  • --disable-breakpad
  • --disable-crash-reporter
  • --renderer-process-limit=2
  • --no-zygote
  • --metrics-recording-only
  • --disable-extensions(既定で有効)
  • --disable-3d-apis--disable-software-rasterizer、および --disable-gpu は 既定で有効であり、WebGL/3D の使用で必要な場合は OPENCLAW_BROWSER_DISABLE_GRAPHICS_FLAGS=0 で無効にできます。
  • ワークフローが拡張機能に依存する場合、OPENCLAW_BROWSER_DISABLE_EXTENSIONS=0 で拡張機能を再度有効にします。
  • --renderer-process-limit=2OPENCLAW_BROWSER_RENDERER_PROCESS_LIMIT=&lt;N&gt; で変更できます。Chromium の 既定のプロセス制限を使用するには 0 を設定してください。
  • さらに、noSandbox が有効な場合は --no-sandbox
  • 既定値はコンテナイメージのベースラインです。コンテナの既定値を変更するには、カスタム エントリーポイントを持つカスタムブラウザーイメージを使用してください。

ブラウザーのサンドボックス化と sandbox.docker.binds は Docker のみです。

イメージをビルドします(ソースチェックアウトから):

scripts/sandbox-setup.sh           # main sandbox image
scripts/sandbox-browser-setup.sh   # optional browser image

ソースチェックアウトなしの npm インストールでは、インラインの docker build コマンドについてサンドボックス化 § イメージとセットアップを参照してください。

agents.list(エージェントごとの上書き)

agents.list[].tts を使用して、エージェントに独自の TTS プロバイダー、音声、モデル、 スタイル、または自動 TTS モードを指定できます。エージェントブロックはグローバルの messages.tts にディープマージされるため、共有認証情報を 1 か所に保ちながら、個々の エージェントは必要な音声またはプロバイダーフィールドだけを上書きできます。アクティブなエージェントの 上書きは、自動音声返信、/tts audio/tts status、および tts エージェントツールに適用されます。プロバイダー例と優先順位については、テキスト読み上げ を参照してください。

{
  agents: {
    list: [
      {
        id: "main",
        default: true,
        name: "Main Agent",
        workspace: "~/.openclaw/workspace",
        agentDir: "~/.openclaw/agents/main/agent",
        model: "anthropic/claude-opus-4-6", // or { primary, fallbacks }
        thinkingDefault: "high", // per-agent thinking level override
        reasoningDefault: "on", // per-agent reasoning visibility override
        fastModeDefault: false, // per-agent fast mode override
        agentRuntime: { id: "auto" },
        params: { cacheRetention: "none" }, // overrides matching defaults.models params by key
        tts: {
          providers: {
            elevenlabs: { voiceId: "EXAVITQu4vr4xnSDxMaL" },
          },
        },
        skills: ["docs-search"], // replaces agents.defaults.skills when set
        identity: {
          name: "Samantha",
          theme: "helpful sloth",
          emoji: "🦥",
          avatar: "avatars/samantha.png",
        },
        groupChat: { mentionPatterns: ["@openclaw"] },
        sandbox: { mode: "off" },
        runtime: {
          type: "acp",
          acp: {
            agent: "codex",
            backend: "acpx",
            mode: "persistent",
            cwd: "/workspace/openclaw",
          },
        },
        subagents: { allowAgents: ["*"] },
        tools: {
          profile: "coding",
          allow: ["browser"],
          deny: ["canvas"],
          elevated: { enabled: true },
        },
      },
    ],
  },
}
  • id: 安定したエージェント ID (必須)。
  • default: 複数設定されている場合は、最初のものが優先されます (警告が記録されます)。何も設定されていない場合は、リストの最初のエントリがデフォルトです。
  • model: 文字列形式は、モデルフォールバックなしの厳密なエージェントごとのプライマリを設定します。オブジェクト形式 { primary } も、fallbacks を追加しない限り厳密です。{ primary, fallbacks: [...] } を使うと、そのエージェントをフォールバック対象にできます。または { primary, fallbacks: [] } を使うと、厳密な挙動を明示できます。primary のみを上書きする Cron ジョブは、fallbacks: [] を設定しない限り、デフォルトのフォールバックを引き継ぎます。
  • params: agents.defaults.models で選択されたモデルエントリにマージされる、エージェントごとのストリームパラメータです。モデルカタログ全体を重複させずに、cacheRetentiontemperaturemaxTokens などのエージェント固有の上書きに使用します。
  • tts: 任意のエージェントごとのテキスト読み上げ上書きです。このブロックは messages.tts にディープマージされるため、共有プロバイダー認証情報とフォールバックポリシーは messages.tts に保持し、プロバイダー、音声、モデル、スタイル、自動モードなど、ペルソナ固有の値だけをここに設定します。
  • skills: 任意のエージェントごとのスキル許可リストです。省略すると、設定されている場合はエージェントが agents.defaults.skills を継承します。明示的なリストはデフォルトとマージされず置き換えられ、[] はスキルなしを意味します。
  • thinkingDefault: 任意のエージェントごとのデフォルト思考レベル (off | minimal | low | medium | high | xhigh | adaptive | max) です。メッセージごとまたはセッションの上書きが設定されていない場合、このエージェントの agents.defaults.thinkingDefault を上書きします。選択されたプロバイダー/モデルプロファイルが有効な値を制御します。Google Gemini の場合、adaptive はプロバイダー所有の動的思考を維持します (Gemini 3/3.1 では thinkingLevel を省略し、Gemini 2.5 では thinkingBudget: -1)。
  • reasoningDefault: 任意のエージェントごとのデフォルト推論可視性 (on | off | stream) です。メッセージごとまたはセッションの推論上書きが設定されていない場合、このエージェントの agents.defaults.reasoningDefault を上書きします。
  • fastModeDefault: 任意のエージェントごとの高速モードデフォルト (true | false) です。メッセージごとまたはセッションの高速モード上書きが設定されていない場合に適用されます。
  • agentRuntime: 任意のエージェントごとの低レベルランタイムポリシー上書きです。{ id: "codex" } を使うと、他のエージェントが auto モードのデフォルト PI フォールバックを維持する一方で、1 つのエージェントを Codex 専用にできます。
  • runtime: 任意のエージェントごとのランタイム記述子です。エージェントがデフォルトで ACP ハーネスセッションを使うべき場合は、runtime.acp のデフォルト (agentbackendmodecwd) とともに type: "acp" を使います。
  • identity.avatar: ワークスペース相対パス、http(s) URL、または data: URI です。
  • identity はデフォルトを派生します。emoji から ackReactionname/emoji から mentionPatterns を派生します。
  • subagents.allowAgents: 明示的な sessions_spawn.agentId ターゲット用のエージェント ID の許可リストです (["*"] = 任意、デフォルト: 同じエージェントのみ)。自己ターゲットの agentId 呼び出しを許可する必要がある場合は、リクエスター ID を含めます。
  • サンドボックス継承ガード: リクエスターセッションがサンドボックス化されている場合、sessions_spawn はサンドボックス外で実行されるターゲットを拒否します。
  • subagents.requireAgentId: true の場合、agentId を省略した sessions_spawn 呼び出しをブロックします (明示的なプロファイル選択を強制します。デフォルト: false)。

マルチエージェントルーティング

1 つの Gateway 内で複数の分離されたエージェントを実行します。マルチエージェントを参照してください。

{
  agents: {
    list: [
      { id: "home", default: true, workspace: "~/.openclaw/workspace-home" },
      { id: "work", workspace: "~/.openclaw/workspace-work" },
    ],
  },
  bindings: [
    { agentId: "home", match: { channel: "whatsapp", accountId: "personal" } },
    { agentId: "work", match: { channel: "whatsapp", accountId: "biz" } },
  ],
}

バインディング一致フィールド

  • type (任意): 通常のルーティングには route (type がない場合のデフォルトは route)、永続的な ACP 会話バインディングには acp
  • match.channel (必須)
  • match.accountId (任意。* = 任意のアカウント、省略 = デフォルトアカウント)
  • match.peer (任意。{ kind: direct|group|channel, id })
  • match.guildId / match.teamId (任意。チャネル固有)
  • acp (任意。type: "acp" の場合のみ): { mode, label, cwd, backend }

決定的な一致順序:

  1. match.peer
  2. match.guildId
  3. match.teamId
  4. match.accountId (完全一致、peer/guild/team なし)
  5. match.accountId: "*" (チャネル全体)
  6. デフォルトエージェント

各階層内では、最初に一致した bindings エントリが優先されます。

type: "acp" エントリの場合、OpenClaw は正確な会話 ID (match.channel + account + match.peer.id) によって解決し、上記のルートバインディング階層順序は使用しません。

エージェントごとのアクセスプロファイル

Full access (no sandbox)
{
agents: {
  list: [
    {
      id: "personal",
      workspace: "~/.openclaw/workspace-personal",
      sandbox: { mode: "off" },
    },
  ],
},
}
Read-only tools + workspace
{
agents: {
  list: [
    {
      id: "family",
      workspace: "~/.openclaw/workspace-family",
      sandbox: { mode: "all", scope: "agent", workspaceAccess: "ro" },
      tools: {
        allow: [
          "read",
          "sessions_list",
          "sessions_history",
          "sessions_send",
          "sessions_spawn",
          "session_status",
        ],
        deny: ["write", "edit", "apply_patch", "exec", "process", "browser"],
      },
    },
  ],
},
}
ファイルシステムアクセスなし(メッセージングのみ)
{
agents: {
  list: [
    {
      id: "public",
      workspace: "~/.openclaw/workspace-public",
      sandbox: { mode: "all", scope: "agent", workspaceAccess: "none" },
      tools: {
        allow: [
          "sessions_list",
          "sessions_history",
          "sessions_send",
          "sessions_spawn",
          "session_status",
          "whatsapp",
          "telegram",
          "slack",
          "discord",
          "gateway",
        ],
        deny: [
          "read",
          "write",
          "edit",
          "apply_patch",
          "exec",
          "process",
          "browser",
          "canvas",
          "nodes",
          "cron",
          "gateway",
          "image",
        ],
      },
    },
  ],
},
}

優先順位の詳細については、Multi-Agent Sandbox & Toolsを参照してください。


セッション

{
  session: {
    scope: "per-sender",
    dmScope: "main", // main | per-peer | per-channel-peer | per-account-channel-peer
    identityLinks: {
      alice: ["telegram:123456789", "discord:987654321012345678"],
    },
    reset: {
      mode: "daily", // daily | idle
      atHour: 4,
      idleMinutes: 60,
    },
    resetByType: {
      thread: { mode: "daily", atHour: 4 },
      direct: { mode: "idle", idleMinutes: 240 },
      group: { mode: "idle", idleMinutes: 120 },
    },
    resetTriggers: ["/new", "/reset"],
    store: "~/.openclaw/agents/{agentId}/sessions/sessions.json",
    maintenance: {
      mode: "warn", // warn | enforce
      pruneAfter: "30d",
      maxEntries: 500,
      resetArchiveRetention: "30d", // duration or false
      maxDiskBytes: "500mb", // optional hard budget
      highWaterBytes: "400mb", // optional cleanup target
    },
    threadBindings: {
      enabled: true,
      idleHours: 24, // default inactivity auto-unfocus in hours (`0` disables)
      maxAgeHours: 0, // default hard max age in hours (`0` disables)
    },
    mainKey: "main", // legacy (runtime always uses "main")
    agentToAgent: { maxPingPongTurns: 5 },
    sendPolicy: {
      rules: [{ action: "deny", match: { channel: "discord", chatType: "group" } }],
      default: "allow",
    },
  },
}
セッションフィールドの詳細
  • scope: グループチャットコンテキストにおける基本のセッショングループ化戦略。
  • per-sender(デフォルト): 各送信者は、チャネルコンテキスト内で分離されたセッションを取得します。
  • global: チャネルコンテキスト内のすべての参加者が単一のセッションを共有します(共有コンテキストが意図されている場合にのみ使用)。
  • dmScope: DM のグループ化方法。
  • main: すべての DM がメインセッションを共有します。
  • per-peer: チャネルをまたいで送信者 ID ごとに分離します。
  • per-channel-peer: チャネル + 送信者ごとに分離します(複数ユーザーの受信箱に推奨)。
  • per-account-channel-peer: アカウント + チャネル + 送信者ごとに分離します(複数アカウントに推奨)。
  • identityLinks: チャネル横断のセッション共有のために、正規 ID をプロバイダー接頭辞付きピアへマップします。/dock_discord などのドックコマンドは同じマップを使用して、アクティブセッションの返信経路を別のリンク済みチャネルピアに切り替えます。チャネルドッキングを参照してください。
  • reset: 主なリセットポリシー。daily はローカル時刻の atHour にリセットします。idleidleMinutes 後にリセットします。両方を設定した場合は、先に期限切れになった方が優先されます。日次リセットの鮮度にはセッション行の sessionStartedAt を使用します。アイドルリセットの鮮度には lastInteractionAt を使用します。heartbeat、cron ウェイクアップ、exec 通知、gateway の管理処理などのバックグラウンド/システムイベントの書き込みは updatedAt を更新できますが、日次/アイドルセッションの鮮度は維持しません。
  • resetByType: タイプ別の上書き(directgroupthread)。従来の dmdirect のエイリアスとして受け付けられます。
  • mainKey: 従来のフィールド。ランタイムはメインの直接チャットバケットに常に "main" を使用します。
  • agentToAgent.maxPingPongTurns: エージェント間のやり取り中にエージェント間で返信を返し合う最大ターン数(整数、範囲: 05)。0 はピンポン連鎖を無効にします。
  • sendPolicy: channelchatTypedirect|group|channel、従来の dm エイリアスあり)、keyPrefix、または rawKeyPrefix で照合します。最初の拒否が優先されます。
  • maintenance: セッションストアのクリーンアップ + 保持制御。
  • mode: warn は警告のみを出力します。enforce はクリーンアップを適用します。
  • pruneAfter: 古いエントリの経過時間カットオフ(デフォルトは 30d)。
  • maxEntries: sessions.json 内の最大エントリ数(デフォルトは 500)。ランタイムは本番サイズの上限向けに小さな高水位バッファ付きでバッチクリーンアップを書き込みます。openclaw sessions cleanup --enforce は上限を即座に適用します。
  • rotateBytes: 非推奨で無視されます。openclaw doctor --fix は古い設定からこれを削除します。
  • resetArchiveRetention: *.reset.<timestamp> トランスクリプトアーカイブの保持期間。デフォルトは pruneAfter です。無効化するには false を設定します。
  • maxDiskBytes: 任意のセッションディレクトリのディスク予算。warn モードでは警告をログに出力します。enforce モードでは最も古いアーティファクト/セッションから削除します。
  • highWaterBytes: 予算クリーンアップ後の任意の目標値。デフォルトは maxDiskBytes80% です。
  • threadBindings: スレッド紐付けセッション機能のグローバルデフォルト。
  • enabled: マスターのデフォルトスイッチ(プロバイダーは上書き可能。Discord は channels.discord.threadBindings.enabled を使用)
  • idleHours: 非アクティブ時の自動フォーカス解除のデフォルト時間(0 で無効化。プロバイダーは上書き可能)
  • maxAgeHours: 強制最大経過時間のデフォルト時間(0 で無効化。プロバイダーは上書き可能)
  • spawnSessions: sessions_spawn と ACP スレッドスポーンからスレッド紐付け作業セッションを作成するためのデフォルトゲート。スレッド紐付けが有効な場合はデフォルトで true です。プロバイダー/アカウントは上書き可能です。
  • defaultSpawnContext: スレッド紐付けスポーンのデフォルトのネイティブサブエージェントコンテキスト("fork" または "isolated")。デフォルトは "fork" です。

メッセージ

{
  messages: {
    responsePrefix: "🦞", // or "auto"
    ackReaction: "👀",
    ackReactionScope: "group-mentions", // group-mentions | group-all | direct | all
    removeAckAfterReply: false,
    queue: {
      mode: "steer", // steer | queue (legacy one-at-a-time) | followup | collect | steer-backlog | steer+backlog | interrupt
      debounceMs: 500,
      cap: 20,
      drop: "summarize", // old | new | summarize
      byChannel: {
        whatsapp: "steer",
        telegram: "steer",
      },
    },
    inbound: {
      debounceMs: 2000, // 0 disables
      byChannel: {
        whatsapp: 5000,
        slack: 1500,
      },
    },
  },
}

応答プレフィックス

チャネル/アカウント単位の上書き: channels.<channel>.responsePrefix, channels.<channel>.accounts.<id>.responsePrefix.

解決方法(最も具体的なものが優先): アカウント → チャネル → グローバル。"" は無効化してカスケードを停止します。"auto"[{identity.name}] から派生します。

テンプレート変数:

変数 説明
{model} 短いモデル名 claude-opus-4-6
{modelFull} 完全なモデル識別子 anthropic/claude-opus-4-6
{provider} プロバイダー名 anthropic
{thinkingLevel} 現在の思考レベル high, low, off
{identity.name} エージェントのアイデンティティ名 ("auto" と同じ)

変数では大文字と小文字は区別されません。{think}{thinkingLevel} のエイリアスです。

Ack リアクション

  • 既定ではアクティブなエージェントの identity.emoji、それ以外は "👀" です。無効にするには "" を設定します。
  • チャネル単位の上書き: channels.<channel>.ackReaction, channels.<channel>.accounts.<id>.ackReaction
  • 解決順序: アカウント → チャネル → messages.ackReaction → アイデンティティのフォールバック。
  • スコープ: group-mentions(既定)、group-alldirectall
  • removeAckAfterReply: Slack、Discord、Telegram、WhatsApp、BlueBubbles など、リアクション対応チャネルで返信後に ack を削除します。
  • messages.statusReactions.enabled: Slack、Discord、Telegram でライフサイクルステータスリアクションを有効にします。 Slack と Discord では、未設定の場合、ack リアクションがアクティブなときにステータスリアクションが有効のままになります。 Telegram では、ライフサイクルステータスリアクションを有効にするには明示的に true に設定します。

受信デバウンス

同じ送信者からの短時間のテキストのみのメッセージを、1 回のエージェントターンにまとめます。メディア/添付ファイルは即座にフラッシュされます。制御コマンドはデバウンスを迂回します。

TTS(テキスト読み上げ)

{
  messages: {
    tts: {
      auto: "always", // off | always | inbound | tagged
      mode: "final", // final | all
      provider: "elevenlabs",
      summaryModel: "openai/gpt-4.1-mini",
      modelOverrides: { enabled: true },
      maxTextLength: 4000,
      timeoutMs: 30000,
      prefsPath: "~/.openclaw/settings/tts.json",
      providers: {
        elevenlabs: {
          apiKey: "elevenlabs_api_key",
          baseUrl: "https://api.elevenlabs.io",
          voiceId: "voice_id",
          modelId: "eleven_multilingual_v2",
          seed: 42,
          applyTextNormalization: "auto",
          languageCode: "en",
          voiceSettings: {
            stability: 0.5,
            similarityBoost: 0.75,
            style: 0.0,
            useSpeakerBoost: true,
            speed: 1.0,
          },
        },
        microsoft: {
          voice: "en-US-AvaMultilingualNeural",
          lang: "en-US",
          outputFormat: "audio-24khz-48kbitrate-mono-mp3",
        },
        openai: {
          apiKey: "openai_api_key",
          baseUrl: "https://api.openai.com/v1",
          model: "gpt-4o-mini-tts",
          voice: "alloy",
        },
      },
    },
  },
}
  • auto は既定の自動 TTS モードを制御します: offalwaysinboundtagged/tts on|off はローカル設定を上書きでき、/tts status は有効な状態を表示します。
  • summaryModel は自動要約用の agents.defaults.model.primary を上書きします。
  • modelOverrides は既定で有効です。modelOverrides.allowProvider の既定値は false(オプトイン)です。
  • API キーは ELEVENLABS_API_KEY/XI_API_KEYOPENAI_API_KEY にフォールバックします。
  • バンドルされた音声プロバイダーは Plugin 所有です。plugins.allow が設定されている場合は、使用する各 TTS プロバイダー Plugin を含めます。たとえば Edge TTS には microsoft を含めます。従来の edge プロバイダー ID は microsoft のエイリアスとして受け入れられます。
  • providers.openai.baseUrl は OpenAI TTS エンドポイントを上書きします。解決順序は、config、次に OPENAI_TTS_BASE_URL、次に https://api.openai.com/v1 です。
  • providers.openai.baseUrl が OpenAI 以外のエンドポイントを指している場合、OpenClaw はそれを OpenAI 互換 TTS サーバーとして扱い、モデル/音声の検証を緩和します。

Talk

Talk モード(macOS/iOS/Android)の既定値。

{
  talk: {
    provider: "elevenlabs",
    providers: {
      elevenlabs: {
        voiceId: "elevenlabs_voice_id",
        voiceAliases: {
          Clawd: "EXAVITQu4vr4xnSDxMaL",
          Roger: "CwhRBWXzGAHq8TQ4Fs17",
        },
        modelId: "eleven_v3",
        outputFormat: "mp3_44100_128",
        apiKey: "elevenlabs_api_key",
      },
      mlx: {
        modelId: "mlx-community/Soprano-80M-bf16",
      },
      system: {},
    },
    speechLocale: "ru-RU",
    silenceTimeoutMs: 1500,
    interruptOnSpeech: true,
    realtime: {
      provider: "openai",
      providers: {
        openai: {
          model: "gpt-realtime",
          voice: "alloy",
        },
      },
      mode: "realtime",
      transport: "webrtc",
      brain: "agent-consult",
    },
  },
}
  • 複数の Talk プロバイダーが設定されている場合、talk.providertalk.providers 内のキーと一致している必要があります。
  • 従来のフラットな Talk キー(talk.voiceIdtalk.voiceAliasestalk.modelIdtalk.outputFormattalk.apiKey)は互換性専用です。永続化された config を talk.providers.<provider> に書き換えるには openclaw doctor --fix を実行してください。
  • 音声 ID は ELEVENLABS_VOICE_ID または SAG_VOICE_ID にフォールバックします。
  • providers.*.apiKey はプレーンテキスト文字列または SecretRef オブジェクトを受け入れます。
  • ELEVENLABS_API_KEY フォールバックは、Talk API キーが設定されていない場合にのみ適用されます。
  • providers.*.voiceAliases により、Talk ディレクティブでわかりやすい名前を使用できます。
  • providers.mlx.modelId は macOS local MLX ヘルパーで使用する Hugging Face リポジトリを選択します。省略した場合、macOS は mlx-community/Soprano-80M-bf16 を使用します。
  • macOS MLX 再生は、存在する場合はバンドルされた openclaw-mlx-tts ヘルパーを通じて実行され、そうでなければ PATH 上の実行可能ファイルを通じて実行されます。OPENCLAW_MLX_TTS_BIN は開発用にヘルパーパスを上書きします。
  • speechLocale は、iOS/macOS Talk 音声認識で使用する BCP 47 ロケール ID を設定します。デバイスの既定値を使用するには未設定のままにします。
  • silenceTimeoutMs は、Talk モードがユーザーの無音後にトランスクリプトを送信するまで待機する時間を制御します。未設定の場合、プラットフォーム既定の一時停止時間(macOS と Android では 700 ms、iOS では 900 ms)を維持します。

関連