Ir al contenido

Contrato del plan de aplicación de secretos

Esta página define el contrato estricto aplicado por openclaw secrets apply.

Si un destino no coincide con estas reglas, la aplicación falla antes de mutar la configuración.

openclaw secrets apply --from <plan.json> espera una matriz targets de destinos de plan:

{
version: 1,
protocolVersion: 1,
targets: [
{
type: "models.providers.apiKey",
path: "models.providers.openai.apiKey",
pathSegments: ["models", "providers", "openai", "apiKey"],
providerId: "openai",
ref: { source: "env", provider: "default", id: "OPENAI_API_KEY" },
},
{
type: "auth-profiles.api_key.key",
path: "profiles.openai:default.key",
pathSegments: ["profiles", "openai:default", "key"],
agentId: "main",
ref: { source: "env", provider: "default", id: "OPENAI_API_KEY" },
},
],
}

Los destinos de plan se aceptan para rutas de credenciales admitidas en:

Regla general:

  • target.type debe ser reconocido y debe coincidir con la forma normalizada target.path.

Los alias de compatibilidad siguen siendo aceptados para los planes existentes:

  • models.providers.apiKey
  • skills.entries.apiKey
  • channels.googlechat.serviceAccount

Cada destino se valida con lo siguiente:

  • type debe ser un tipo de destino reconocido.
  • path debe ser una ruta de puntos no vacía.
  • pathSegments se puede omitir. Si se proporciona, debe normalizarse exactamente a la misma ruta que path.
  • Los segmentos prohibidos se rechazan: __proto__, prototype, constructor.
  • La ruta normalizada debe coincidir con la forma de ruta registrada para el tipo de destino.
  • Si se establece providerId o accountId, debe coincidir con el ID codificado en la ruta.
  • Los destinos auth-profiles.json requieren agentId.
  • Al crear una nueva asignación auth-profiles.json, incluya authProfileProvider.

Si un destino falla la validación, la aplicación sale con un error como:

Invalid plan target path for models.providers.apiKey: models.providers.openai.baseUrl

No se confirman escrituras para un plan no válido.

Comportamiento de consentimiento del proveedor exec

Sección titulada «Comportamiento de consentimiento del proveedor exec»
  • --dry-run omite las comprobaciones de exec SecretRef de forma predeterminada.
  • Los planes que contienen exec SecretRefs/proveedores se rechazan en modo de escritura a menos que se establezca --allow-exec.
  • Al validar/aplicar planes que contienen exec, pase --allow-exec tanto en comandos de ejecución en seco como de escritura.

Notas sobre el ámbito de tiempo de ejecución y auditoría

Sección titulada «Notas sobre el ámbito de tiempo de ejecución y auditoría»
  • Las entradas de solo referencia auth-profiles.json (keyRef/tokenRef) se incluyen en la resolución en tiempo de ejecución y la cobertura de auditoría.
  • secrets apply escribe objetivos openclaw.json compatibles, objetivos auth-profiles.json compatibles y objetivos de limpieza opcionales.
Ventana de terminal
# Validate plan without writes
openclaw secrets apply --from /tmp/openclaw-secrets-plan.json --dry-run
# Then apply for real
openclaw secrets apply --from /tmp/openclaw-secrets-plan.json
# For exec-containing plans, opt in explicitly in both modes
openclaw secrets apply --from /tmp/openclaw-secrets-plan.json --dry-run --allow-exec
openclaw secrets apply --from /tmp/openclaw-secrets-plan.json --allow-exec

Si la aplicación falla con un mensaje de ruta de objetivo no válida, regenere el plan con openclaw secrets configure o corrija la ruta del objetivo a una forma compatible arriba.