vtcode 0.99.1

A Rust-based terminal coding agent with modular architecture supporting multiple LLM providers
{
  "$schema": "http://json-schema.org/draft-07/schema#",
  "title": "CommandExecParams",
  "description": "Run a standalone command (argv vector) in the server sandbox without creating a thread or turn.\n\nThe final `command/exec` response is deferred until the process exits and is sent only after all `command/exec/outputDelta` notifications for that connection have been emitted.",
  "type": "object",
  "required": [
    "command"
  ],
  "properties": {
    "command": {
      "description": "Command argv vector. Empty arrays are rejected.",
      "type": "array",
      "items": {
        "type": "string"
      }
    },
    "cwd": {
      "description": "Optional working directory. Defaults to the server cwd.",
      "type": [
        "string",
        "null"
      ]
    },
    "disableOutputCap": {
      "description": "Disable stdout/stderr capture truncation for this request.\n\nCannot be combined with `outputBytesCap`.",
      "type": "boolean"
    },
    "disableTimeout": {
      "description": "Disable the timeout entirely for this request.\n\nCannot be combined with `timeoutMs`.",
      "type": "boolean"
    },
    "env": {
      "description": "Optional environment overrides merged into the server-computed environment.\n\nMatching names override inherited values. Set a key to `null` to unset an inherited variable.",
      "type": [
        "object",
        "null"
      ],
      "additionalProperties": {
        "type": [
          "string",
          "null"
        ]
      }
    },
    "outputBytesCap": {
      "description": "Optional per-stream stdout/stderr capture cap in bytes.\n\nWhen omitted, the server default applies. Cannot be combined with `disableOutputCap`.",
      "type": [
        "integer",
        "null"
      ],
      "format": "uint",
      "minimum": 0.0
    },
    "processId": {
      "description": "Optional client-supplied, connection-scoped process id.\n\nRequired for `tty`, `streamStdin`, `streamStdoutStderr`, and follow-up `command/exec/write`, `command/exec/resize`, and `command/exec/terminate` calls. When omitted, buffered execution gets an internal id that is not exposed to the client.",
      "type": [
        "string",
        "null"
      ]
    },
    "sandboxPolicy": {
      "description": "Optional sandbox policy for this command.\n\nUses the same shape as thread/turn execution sandbox configuration and defaults to the user's configured policy when omitted.",
      "anyOf": [
        {
          "$ref": "#/definitions/SandboxPolicy"
        },
        {
          "type": "null"
        }
      ]
    },
    "size": {
      "description": "Optional initial PTY size in character cells. Only valid when `tty` is true.",
      "anyOf": [
        {
          "$ref": "#/definitions/CommandExecTerminalSize"
        },
        {
          "type": "null"
        }
      ]
    },
    "streamStdin": {
      "description": "Allow follow-up `command/exec/write` requests to write stdin bytes.\n\nRequires a client-supplied `processId`.",
      "type": "boolean"
    },
    "streamStdoutStderr": {
      "description": "Stream stdout/stderr via `command/exec/outputDelta` notifications.\n\nStreamed bytes are not duplicated into the final response and require a client-supplied `processId`.",
      "type": "boolean"
    },
    "timeoutMs": {
      "description": "Optional timeout in milliseconds.\n\nWhen omitted, the server default applies. Cannot be combined with `disableTimeout`.",
      "type": [
        "integer",
        "null"
      ],
      "format": "int64"
    },
    "tty": {
      "description": "Enable PTY mode.\n\nThis implies `streamStdin` and `streamStdoutStderr`.",
      "type": "boolean"
    }
  },
  "definitions": {
    "AbsolutePathBuf": {
      "description": "A path that is guaranteed to be absolute and normalized (though it is not guaranteed to be canonicalized or exist on the filesystem).\n\nIMPORTANT: When deserializing an `AbsolutePathBuf`, a base path must be set using [AbsolutePathBufGuard::new]. If no base path is set, the deserialization will fail unless the path being deserialized is already absolute.",
      "type": "string"
    },
    "CommandExecTerminalSize": {
      "description": "PTY size in character cells for `command/exec` PTY sessions.",
      "type": "object",
      "required": [
        "cols",
        "rows"
      ],
      "properties": {
        "cols": {
          "description": "Terminal width in character cells.",
          "type": "integer",
          "format": "uint16",
          "minimum": 0.0
        },
        "rows": {
          "description": "Terminal height in character cells.",
          "type": "integer",
          "format": "uint16",
          "minimum": 0.0
        }
      }
    },
    "NetworkAccess": {
      "type": "string",
      "enum": [
        "restricted",
        "enabled"
      ]
    },
    "ReadOnlyAccess": {
      "oneOf": [
        {
          "type": "object",
          "required": [
            "type"
          ],
          "properties": {
            "includePlatformDefaults": {
              "default": true,
              "type": "boolean"
            },
            "readableRoots": {
              "default": [],
              "type": "array",
              "items": {
                "$ref": "#/definitions/AbsolutePathBuf"
              }
            },
            "type": {
              "type": "string",
              "enum": [
                "restricted"
              ],
              "title": "RestrictedReadOnlyAccessType"
            }
          },
          "title": "RestrictedReadOnlyAccess"
        },
        {
          "type": "object",
          "required": [
            "type"
          ],
          "properties": {
            "type": {
              "type": "string",
              "enum": [
                "fullAccess"
              ],
              "title": "FullAccessReadOnlyAccessType"
            }
          },
          "title": "FullAccessReadOnlyAccess"
        }
      ]
    },
    "SandboxPolicy": {
      "oneOf": [
        {
          "type": "object",
          "required": [
            "type"
          ],
          "properties": {
            "type": {
              "type": "string",
              "enum": [
                "dangerFullAccess"
              ],
              "title": "DangerFullAccessSandboxPolicyType"
            }
          },
          "title": "DangerFullAccessSandboxPolicy"
        },
        {
          "type": "object",
          "required": [
            "type"
          ],
          "properties": {
            "access": {
              "default": {
                "type": "fullAccess"
              },
              "allOf": [
                {
                  "$ref": "#/definitions/ReadOnlyAccess"
                }
              ]
            },
            "networkAccess": {
              "default": false,
              "type": "boolean"
            },
            "type": {
              "type": "string",
              "enum": [
                "readOnly"
              ],
              "title": "ReadOnlySandboxPolicyType"
            }
          },
          "title": "ReadOnlySandboxPolicy"
        },
        {
          "type": "object",
          "required": [
            "type"
          ],
          "properties": {
            "networkAccess": {
              "default": "restricted",
              "allOf": [
                {
                  "$ref": "#/definitions/NetworkAccess"
                }
              ]
            },
            "type": {
              "type": "string",
              "enum": [
                "externalSandbox"
              ],
              "title": "ExternalSandboxSandboxPolicyType"
            }
          },
          "title": "ExternalSandboxSandboxPolicy"
        },
        {
          "type": "object",
          "required": [
            "type"
          ],
          "properties": {
            "excludeSlashTmp": {
              "default": false,
              "type": "boolean"
            },
            "excludeTmpdirEnvVar": {
              "default": false,
              "type": "boolean"
            },
            "networkAccess": {
              "default": false,
              "type": "boolean"
            },
            "readOnlyAccess": {
              "default": {
                "type": "fullAccess"
              },
              "allOf": [
                {
                  "$ref": "#/definitions/ReadOnlyAccess"
                }
              ]
            },
            "type": {
              "type": "string",
              "enum": [
                "workspaceWrite"
              ],
              "title": "WorkspaceWriteSandboxPolicyType"
            },
            "writableRoots": {
              "default": [],
              "type": "array",
              "items": {
                "$ref": "#/definitions/AbsolutePathBuf"
              }
            }
          },
          "title": "WorkspaceWriteSandboxPolicy"
        }
      ]
    }
  }
}