mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-06 12:30:44 +00:00
docs: consolidate moved docs pages
Consolidate moved docs pages, add redirects, and update glossary labels.
This commit is contained in:
committed by
GitHub
parent
c37871e77b
commit
b31774749c
133
docs/plugins/adding-capabilities.md
Normal file
133
docs/plugins/adding-capabilities.md
Normal file
@@ -0,0 +1,133 @@
|
||||
---
|
||||
summary: "Contributor guide for adding a new shared capability to the OpenClaw plugin system"
|
||||
read_when:
|
||||
- Adding a new core capability and plugin registration surface
|
||||
- Deciding whether code belongs in core, a vendor plugin, or a feature plugin
|
||||
- Wiring a new runtime helper for channels or tools
|
||||
title: "Adding capabilities (contributor guide)"
|
||||
sidebarTitle: "Adding capabilities"
|
||||
---
|
||||
|
||||
<Info>
|
||||
This is a **contributor guide** for OpenClaw core developers. If you are
|
||||
building an external plugin, see [Building plugins](/plugins/building-plugins)
|
||||
instead. For the deep architecture reference (capability model, ownership,
|
||||
load pipeline, runtime helpers), see [Plugin internals](/plugins/architecture).
|
||||
</Info>
|
||||
|
||||
Use this when OpenClaw needs a new shared domain such as image generation, video generation, or some future vendor-backed feature area.
|
||||
|
||||
The rule:
|
||||
|
||||
- **plugin** = ownership boundary
|
||||
- **capability** = shared core contract
|
||||
|
||||
Do not start by wiring a vendor directly into a channel or a tool. Start by defining the capability.
|
||||
|
||||
## When to create a capability
|
||||
|
||||
Create a new capability when **all** of these are true:
|
||||
|
||||
1. More than one vendor could plausibly implement it.
|
||||
2. Channels, tools, or feature plugins should consume it without caring about the vendor.
|
||||
3. Core needs to own fallback, policy, config, or delivery behavior.
|
||||
|
||||
If the work is vendor-only and no shared contract exists yet, stop and define the contract first.
|
||||
|
||||
## The standard sequence
|
||||
|
||||
1. Define the typed core contract.
|
||||
2. Add plugin registration for that contract.
|
||||
3. Add a shared runtime helper.
|
||||
4. Wire one real vendor plugin as proof.
|
||||
5. Move feature/channel consumers onto the runtime helper.
|
||||
6. Add contract tests.
|
||||
7. Document the operator-facing config and ownership model.
|
||||
|
||||
## What goes where
|
||||
|
||||
**Core:**
|
||||
|
||||
- Request/response types.
|
||||
- Provider registry + resolution.
|
||||
- Fallback behavior.
|
||||
- Config schema with propagated `title` / `description` docs metadata on nested object, wildcard, array-item, and composition nodes.
|
||||
- Runtime helper surface.
|
||||
|
||||
**Vendor plugin:**
|
||||
|
||||
- Vendor API calls.
|
||||
- Vendor auth handling.
|
||||
- Vendor-specific request normalization.
|
||||
- Registration of the capability implementation.
|
||||
|
||||
**Feature/channel plugin:**
|
||||
|
||||
- Calls `api.runtime.*` or the matching `plugin-sdk/*-runtime` helper.
|
||||
- Never calls a vendor implementation directly.
|
||||
|
||||
## Provider and harness seams
|
||||
|
||||
Use **provider hooks** when the behavior belongs to the model provider contract rather than the generic agent loop. Examples include provider-specific request params after transport selection, auth-profile preference, prompt overlays, and follow-up fallback routing after model/profile failover.
|
||||
|
||||
Use **agent harness hooks** when the behavior belongs to the runtime that is executing a turn. Harnesses can classify successful-but-unusable attempt results such as empty, reasoning-only, or planning-only responses so the outer model fallback policy can make the retry decision.
|
||||
|
||||
Keep both seams narrow:
|
||||
|
||||
- Core owns the retry/fallback policy.
|
||||
- Provider plugins own provider-specific request/auth/routing hints.
|
||||
- Harness plugins own runtime-specific attempt classification.
|
||||
- Third-party plugins return hints, not direct mutations of core state.
|
||||
|
||||
## File checklist
|
||||
|
||||
For a new capability, expect to touch these areas:
|
||||
|
||||
- `src/<capability>/types.ts`
|
||||
- `src/<capability>/...registry/runtime.ts`
|
||||
- `src/plugins/types.ts`
|
||||
- `src/plugins/registry.ts`
|
||||
- `src/plugins/captured-registration.ts`
|
||||
- `src/plugins/contracts/registry.ts`
|
||||
- `src/plugins/runtime/types-core.ts`
|
||||
- `src/plugins/runtime/index.ts`
|
||||
- `src/plugin-sdk/<capability>.ts`
|
||||
- `src/plugin-sdk/<capability>-runtime.ts`
|
||||
- One or more bundled plugin packages.
|
||||
- Config, docs, tests.
|
||||
|
||||
## Worked example: image generation
|
||||
|
||||
Image generation follows the standard shape:
|
||||
|
||||
1. Core defines `ImageGenerationProvider`.
|
||||
2. Core exposes `registerImageGenerationProvider(...)`.
|
||||
3. Core exposes `runtime.imageGeneration.generate(...)`.
|
||||
4. The `openai`, `google`, `fal`, and `minimax` plugins register vendor-backed implementations.
|
||||
5. Future vendors register the same contract without changing channels/tools.
|
||||
|
||||
The config key is intentionally separate from vision-analysis routing:
|
||||
|
||||
- `agents.defaults.imageModel` analyzes images.
|
||||
- `agents.defaults.imageGenerationModel` generates images.
|
||||
|
||||
Keep those separate so fallback and policy remain explicit.
|
||||
|
||||
## Review checklist
|
||||
|
||||
Before shipping a new capability, verify:
|
||||
|
||||
- No channel/tool imports vendor code directly.
|
||||
- The runtime helper is the shared path.
|
||||
- At least one contract test asserts bundled ownership.
|
||||
- Config docs name the new model/config key.
|
||||
- Plugin docs explain the ownership boundary.
|
||||
|
||||
If a PR skips the capability layer and hardcodes vendor behavior into a channel/tool, send it back and define the contract first.
|
||||
|
||||
## Related
|
||||
|
||||
- [Plugin internals](/plugins/architecture) — capability model, ownership, load pipeline, runtime helpers.
|
||||
- [Building plugins](/plugins/building-plugins) — first-plugin tutorial.
|
||||
- [SDK overview](/plugins/sdk-overview) — import map and registration API reference.
|
||||
- [Creating skills](/tools/creating-skills) — companion contributor surface.
|
||||
Reference in New Issue
Block a user