The bundledDocumentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
oc-path plugin adds the openclaw path CLI for the
oc:// workspace-file addressing scheme. It ships in the OpenClaw repo under
extensions/oc-path/ but is opt-in — install/build leaves it dormant until you
enable it.
oc:// addresses point at a single leaf (or a wildcard set of leaves) inside
a workspace file. The plugin understands three kinds of files today:
- markdown (
.md,.mdx): frontmatter, sections, items, fields - jsonc (
.jsonc,.json5,.json): comments and formatting preserved - jsonl (
.jsonl,.ndjson): line-oriented records
Why enable it
Enableoc-path when you want scripts, hooks, or local agent tooling to point
at a precise piece of workspace state without inventing a parser for each file
shape. A single oc:// address can name a markdown frontmatter key, a section
item, a JSONC config leaf, or a JSONL event field.
That matters for maintainer workflows where the change should be small,
auditable, and repeatable: inspect one value, find matching records, dry-run a
write, then apply only that leaf while leaving comments, line endings, and
nearby formatting alone. Keeping this as an opt-in plugin gives power users the
addressing substrate without putting parser dependencies or CLI surface into
core for installs that never need it.
Common reasons to enable it:
- Local automation: shell scripts can resolve or update one workspace value
with
openclaw path … --jsoninstead of carrying separate markdown, JSONC, and JSONL parsing code. - Agent-visible edits: an agent can show a dry-run diff for one addressed leaf before writing, which is easier to review than a free-form file rewrite.
- Editor integrations: an editor can map
oc://AGENTS.md/tools/ghto the exact markdown node and line number without guessing from heading text. - Diagnostics:
emitround-trips a file through the parser and emitter, so you can check whether a file kind is byte-stable before relying on automated edits.
oc-path is the narrow
addressing and byte-preserving file operation layer those higher-level tools
can build around.
Where it runs
The plugin runs in-process inside theopenclaw CLI on the host where you
invoke the command. It does not need a running Gateway and does not open any
network sockets — every verb is a pure transform over a file you point it at.
The plugin metadata lives in extensions/oc-path/openclaw.plugin.json:
onStartup: false keeps the plugin out of the Gateway hot path. onCommands: ["path"] tells the CLI to load the plugin lazily the first time you run
openclaw path …, so installs that never use the verb pay no cost.
Enable
openclaw path invocations work immediately on the same host —
the CLI loads the plugin on demand.
Disable with:
Dependencies
All parser dependencies are plugin-local — enablingoc-path does not pull
new packages into the core runtime:
| Dependency | Purpose |
|---|---|
commander | Subcommand wiring for resolve, find, set, validate, emit. |
jsonc-parser | JSONC parse + leaf edits with comments and trailing commas kept. |
markdown-it | Markdown tokenization for the section / item / field model. |
jsonc-parser.
What it provides
| Surface | Provided by |
|---|---|
openclaw path CLI | extensions/oc-path/cli-registration.ts |
oc:// parser / formatter | extensions/oc-path/src/oc-path/oc-path.ts |
| Per-kind parse / emit / edit | extensions/oc-path/src/oc-path/{md,jsonc,jsonl} |
| Universal resolve / find / set | extensions/oc-path/src/oc-path/{resolve,find,edit}.ts |
| Redaction-sentinel guard | extensions/oc-path/src/oc-path/sentinel.ts |
Relationship to other plugins
memory-*: memory writes go through the memory plugins, notoc-path.oc-pathis a generic file substrate; memory plugins layer their own semantics on top.- LKG:
pathdoes not know about Last-Known-Good config restore. If a file is LKG-tracked, the nextobservecall decides whether to promote or recover;set --batchfor atomic multi-set through the LKG promote/recover lifecycle is planned alongside the LKG-recovery substrate.
Safety
set writes raw bytes through the substrate’s emit path, which applies the
redaction-sentinel guard automatically. A leaf carrying
__OPENCLAW_REDACTED__ (verbatim or as a substring) is refused at write time
with OC_EMIT_SENTINEL. The CLI also scrubs the literal sentinel from any
human or JSON output it prints, replacing it with [REDACTED] so terminal
captures and pipelines never leak the marker.