# Agent Runtime Configuration Notes

> For ckm-hypogen plugin development context

## Config File

`~/.agent-runtime/agent-runtime.json` — central configuration.

---

## Model Providers

### Provider API Types

Valid values for `models.providers.<name>.api`:

| API Type | Protocol | Schema Cleaning |
|---|---|---|
| `openai-completions` | OpenAI Chat Completions | None |
| `openai-responses` | OpenAI Messages | None |
| `anthropic-messages` | Anthropic Messages | None |
| `google-generative-ai` | Google Gemini | `sanitizeToolsForGoogle()` strips `patternProperties` etc. |
| `github-copilot` | GitHub Copilot | None |
| `bedrock-converse-stream` | AWS Bedrock | None |
| `ollama` | Ollama local | None |

### Gemini Schema Cleaning

`sanitizeToolsForGoogle()` only triggers when runtime provider is `google-gemini-cli` or `google-antigravity` (mapped from config `google-generative-ai`). It strips:
- `patternProperties`
- `additionalProperties`
- `minimum` / `maximum`
- Other Gemini-unsupported JSON Schema keywords

**Key insight**: Using an OpenAI-compatible proxy (like openai-compatible-proxy) with `openai-completions` API to access Gemini will NOT trigger schema cleaning. The proxy forwards tool schemas as-is, and Gemini rejects `patternProperties` even on the first message (tools are declared with every request, not just when called).

### Current Config (2026-02-23)

```json
{
  "models": {
    "providers": {
      "google": {
        "baseUrl": "https://newapi.anonymous.com/v1",
        "api": "openai-completions",
        "models": [{ "id": "gemini-3-flash-preview" }]
      },
      "anthropic": {
        "baseUrl": "https://newapi.anonymous.com/v1",
        "api": "openai-completions",
        "models": [{ "id": "claude-opus-4-6" }]
      },
      "openai-compatible-proxy": {
        "baseUrl": "https://newapi.anonymous.com/v1",
        "api": "openai-completions",
        "models": [
          { "id": "gpt-5.2" },
          { "id": "gpt-5.3-codex" }
        ]
      }
    }
  }
}
```

**Why `anthropic` provider exists**: Agent Runtime's internal `slug-generator` (generates session titles) hardcodes fallback to `anthropic/claude-opus-4-6`. Without an `anthropic` provider config, it fails with "No API key found for provider anthropic", causing "An unknown error occurred" on session creation. The workaround maps `anthropic` to the openai-compatible-proxy proxy.

---

## Workspace

### Default Location
- `~/.agent-runtime/workspace`
- With profiles: `~/.agent-runtime/workspace-<profile>` (via `AGENT_RUNTIME_PROFILE` env)
- Override: `agents.defaults.workspace` in config

### Multi-Workspace (Multi-Agent)

```json
{
  "agents": {
    "list": [
      { "id": "home", "workspace": "~/.agent-runtime/workspace-home" },
      { "id": "work", "workspace": "~/.agent-runtime/workspace-work" }
    ]
  }
}
```

Each agent gets isolated workspace, persona, memory, sessions.

### Bootstrap File Limits
- Per-file: 20,000 chars (`agents.defaults.bootstrapMaxChars`)
- Total: 150,000 chars (`agents.defaults.bootstrapTotalMaxChars`)

---

## Plugin Config

```json
{
  "plugins": {
    "load": {
      "paths": ["/path/to/plugin"]
    },
    "entries": {
      "ckm-hypogen": { "enabled": true }
    },
    "installs": {
      "ckm-hypogen": {
        "source": "path",
        "sourcePath": "/path/to/plugin",
        "installPath": "/path/to/plugin",
        "version": "1.7.2"
      }
    }
  }
}
```

### Enable/Disable Plugin via jq

```bash
# Enable
jq '.plugins.load.paths += ["/path"]' ~/.agent-runtime/agent-runtime.json > tmp && mv tmp ~/.agent-runtime/agent-runtime.json

# Disable
jq '.plugins.load.paths |= map(select(. != "/path"))' ~/.agent-runtime/agent-runtime.json > tmp && mv tmp ~/.agent-runtime/agent-runtime.json
jq 'del(.plugins.entries.ckm-hypogen) | del(.plugins.installs.ckm-hypogen)' ~/.agent-runtime/agent-runtime.json > tmp && mv tmp ~/.agent-runtime/agent-runtime.json
```

---

## Gateway

```json
{
  "gateway": {
    "port": 18789,
    "mode": "local",
    "bind": "loopback",
    "auth": {
      "mode": "token",
      "token": "<auto-generated>"
    }
  }
}
```

- Web UI: `http://127.0.0.1:18789/`
- Requires `--noproxy 127.0.0.1` if HTTP proxy is configured
- Restart required after config changes

---

## Skills Config

```json
{
  "skills": {
    "load": {
      "watch": true,
      "extraDirs": ["/path/to/skills"]
    },
    "install": {
      "nodeManager": "pnpm"
    },
    "entries": {
      "skill-name": {
        "enabled": true,
        "env": { "API_KEY": "..." }
      }
    }
  }
}
```

- `watch: true` enables hot reload of SKILL.md changes
- `extraDirs` for shared skill directories (lowest precedence)
- Per-skill `env` injected only during agent runs (scoped, not global)
