메인 콘텐츠로 건너뛰기

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

이 페이지는 네이티브 OpenClaw Plugin 매니페스트 전용입니다. 호환되는 번들 레이아웃은 Plugin 번들을 참조하세요. 호환 번들 형식은 서로 다른 매니페스트 파일을 사용합니다.
  • Codex 번들: .codex-plugin/plugin.json
  • Claude 번들: .claude-plugin/plugin.json 또는 매니페스트가 없는 기본 Claude 컴포넌트 레이아웃
  • Cursor 번들: .cursor-plugin/plugin.json
OpenClaw는 이러한 번들 레이아웃도 자동 감지하지만, 여기에서 설명하는 openclaw.plugin.json 스키마로 검증하지는 않습니다. 호환 번들의 경우, 현재 OpenClaw는 레이아웃이 OpenClaw 런타임 기대 사항과 일치할 때 번들 메타데이터와 선언된 skill 루트, Claude 명령 루트, Claude 번들 settings.json 기본값, Claude 번들 LSP 기본값, 지원되는 훅 팩을 읽습니다. 모든 네이티브 OpenClaw Plugin은 Plugin 루트openclaw.plugin.json 파일을 반드시 포함해야 합니다. OpenClaw는 이 매니페스트를 사용해 Plugin 코드를 실행하지 않고 구성을 검증합니다. 누락되었거나 유효하지 않은 매니페스트는 Plugin 오류로 처리되며 구성 검증을 차단합니다. 전체 Plugin 시스템 가이드는 Plugins를 참조하세요. 네이티브 capability 모델과 현재 외부 호환성 지침은 다음을 참조하세요: Capability 모델.

이 파일의 역할

openclaw.plugin.json은 OpenClaw가 Plugin 코드를 로드하기 전에 읽는 메타데이터입니다. 아래의 모든 항목은 Plugin 런타임을 부팅하지 않고도 검사할 수 있을 만큼 가벼워야 합니다. 다음 용도로 사용하세요:
  • Plugin ID, 구성 검증, 구성 UI 힌트
  • 인증, 온보딩, 설정 메타데이터(별칭, 자동 활성화, provider 환경 변수, 인증 선택지)
  • control-plane 표면을 위한 활성화 힌트
  • 모델 패밀리 소유권 축약
  • 정적 capability 소유권 스냅샷(contracts)
  • 공유 openclaw qa 호스트가 검사할 수 있는 QA 실행기 메타데이터
  • 카탈로그 및 검증 표면에 병합되는 채널별 구성 메타데이터
다음 용도로는 사용하지 마세요: 런타임 동작 등록, 코드 엔트리포인트 선언, 또는 npm 설치 메타데이터. 이러한 항목은 Plugin 코드와 package.json에 속합니다.

최소 예시

{
  "id": "voice-call",
  "configSchema": {
    "type": "object",
    "additionalProperties": false,
    "properties": {}
  }
}

풍부한 예시

{
  "id": "openrouter",
  "name": "OpenRouter",
  "description": "OpenRouter provider plugin",
  "version": "1.0.0",
  "providers": ["openrouter"],
  "modelSupport": {
    "modelPrefixes": ["router-"]
  },
  "modelIdNormalization": {
    "providers": {
      "openrouter": {
        "prefixWhenBare": "openrouter"
      }
    }
  },
  "providerEndpoints": [
    {
      "endpointClass": "openrouter",
      "hostSuffixes": ["openrouter.ai"]
    }
  ],
  "providerRequest": {
    "providers": {
      "openrouter": {
        "family": "openrouter"
      }
    }
  },
  "cliBackends": ["openrouter-cli"],
  "syntheticAuthRefs": ["openrouter-cli"],
  "providerAuthEnvVars": {
    "openrouter": ["OPENROUTER_API_KEY"]
  },
  "providerAuthAliases": {
    "openrouter-coding": "openrouter"
  },
  "channelEnvVars": {
    "openrouter-chatops": ["OPENROUTER_CHATOPS_TOKEN"]
  },
  "providerAuthChoices": [
    {
      "provider": "openrouter",
      "method": "api-key",
      "choiceId": "openrouter-api-key",
      "choiceLabel": "OpenRouter API key",
      "groupId": "openrouter",
      "groupLabel": "OpenRouter",
      "optionKey": "openrouterApiKey",
      "cliFlag": "--openrouter-api-key",
      "cliOption": "--openrouter-api-key <key>",
      "cliDescription": "OpenRouter API key",
      "onboardingScopes": ["text-inference"]
    }
  ],
  "uiHints": {
    "apiKey": {
      "label": "API key",
      "placeholder": "sk-or-v1-...",
      "sensitive": true
    }
  },
  "configSchema": {
    "type": "object",
    "additionalProperties": false,
    "properties": {
      "apiKey": {
        "type": "string"
      }
    }
  }
}

최상위 필드 참조

필드필수유형의미
idstring정식 Plugin id입니다. plugins.entries.<id>에서 사용되는 id입니다.
configSchemaobject이 Plugin 구성에 대한 인라인 JSON Schema입니다.
enabledByDefault아니요true번들 Plugin을 기본적으로 활성화됨으로 표시합니다. 생략하거나 true가 아닌 값을 설정하면 Plugin은 기본적으로 비활성화된 상태로 둡니다.
enabledByDefaultOnPlatforms아니요string[]나열된 Node.js 플랫폼에서만 번들 Plugin을 기본적으로 활성화됨으로 표시합니다. 예: ["darwin"]. 명시적 구성이 여전히 우선합니다.
legacyPluginIds아니요string[]이 정식 Plugin id로 정규화되는 레거시 id입니다.
autoEnableWhenConfiguredProviders아니요string[]인증, 구성 또는 모델 참조에서 언급될 때 이 Plugin을 자동 활성화해야 하는 Provider id입니다.
kind아니요"memory" | "context-engine"plugins.slots.*에서 사용하는 배타적 Plugin 종류를 선언합니다.
channels아니요string[]이 Plugin이 소유하는 Channel id입니다. 검색 및 구성 검증에 사용됩니다.
providers아니요string[]이 Plugin이 소유하는 Provider id입니다.
providerCatalogEntry아니요string전체 Plugin 런타임을 활성화하지 않고 로드할 수 있는, 매니페스트 범위 Provider 카탈로그 메타데이터를 위한 Plugin 루트 기준 경량 Provider 카탈로그 모듈 경로입니다.
modelSupport아니요object런타임 전에 Plugin을 자동 로드하는 데 사용되는, 매니페스트 소유 축약 모델 패밀리 메타데이터입니다.
modelCatalog아니요object이 Plugin이 소유한 Provider에 대한 선언적 모델 카탈로그 메타데이터입니다. Plugin 런타임을 로드하지 않고 향후 읽기 전용 목록, 온보딩, 모델 선택기, 별칭, 숨김을 처리하기 위한 제어 평면 계약입니다.
modelPricing아니요objectProvider 소유 외부 가격 조회 정책입니다. 로컬/자체 호스팅 Provider를 원격 가격 카탈로그에서 제외하거나, core에 Provider id를 하드코딩하지 않고 Provider 참조를 OpenRouter/LiteLLM 카탈로그 id에 매핑하는 데 사용합니다.
modelIdNormalization아니요objectProvider 런타임이 로드되기 전에 실행되어야 하는 Provider 소유 모델 id 별칭/접두사 정리입니다.
providerEndpoints아니요object[]Provider 런타임이 로드되기 전에 core가 분류해야 하는 Provider 라우트용 매니페스트 소유 endpoint host/baseUrl 메타데이터입니다.
providerRequest아니요objectProvider 런타임이 로드되기 전에 일반 요청 정책에서 사용하는 저비용 Provider 패밀리 및 요청 호환성 메타데이터입니다.
cliBackends아니요string[]이 Plugin이 소유하는 CLI 추론 backend id입니다. 명시적 구성 참조에서 시작 시 자동 활성화하는 데 사용됩니다.
syntheticAuthRefs아니요string[]런타임이 로드되기 전 콜드 모델 검색 중에 Plugin 소유 합성 인증 훅을 검사해야 하는 Provider 또는 CLI backend 참조입니다.
nonSecretAuthMarkers아니요string[]비밀이 아닌 로컬, OAuth 또는 주변 자격 증명 상태를 나타내는 번들 Plugin 소유 placeholder API key 값입니다.
commandAliases아니요object[]런타임이 로드되기 전에 Plugin 인식 구성 및 CLI 진단을 생성해야 하는 이 Plugin 소유 명령 이름입니다.
providerAuthEnvVars아니요Record<string, string[]>Provider 인증/상태 조회를 위한 더 이상 권장되지 않는 호환성 env 메타데이터입니다. 새 Plugin에는 setup.providers[].envVars를 선호하세요. OpenClaw는 지원 중단 기간 동안 이를 계속 읽습니다.
providerAuthAliases아니요Record<string, string>인증 조회에 다른 Provider id를 재사용해야 하는 Provider id입니다. 예를 들어 기본 Provider API key 및 auth profile을 공유하는 coding Provider가 있습니다.
channelEnvVars아니요Record<string, string[]>OpenClaw가 Plugin 코드를 로드하지 않고 검사할 수 있는 저비용 Channel env 메타데이터입니다. 일반 시작/구성 helper가 확인해야 하는 env 기반 Channel 설정 또는 인증 표면에 사용합니다.
providerAuthChoices아니요object[]온보딩 선택기, preferred Provider 해석, 단순 CLI 플래그 연결에 사용하는 저비용 인증 선택 메타데이터입니다.
activation아니요object시작, Provider, 명령, Channel, 라우트, capability 트리거 로딩을 위한 저비용 activation planner 메타데이터입니다. 메타데이터 전용이며, 실제 동작은 여전히 Plugin 런타임이 소유합니다.
setup아니요object검색 및 설정 표면이 Plugin 런타임을 로드하지 않고 검사할 수 있는 저비용 설정/온보딩 descriptor입니다.
qaRunners아니요object[]Plugin 런타임이 로드되기 전에 공유 openclaw qa host에서 사용하는 저비용 QA runner descriptor입니다.
contracts아니요object외부 인증 훅, speech, realtime transcription, realtime voice, media-understanding, image-generation, music-generation, video-generation, web-fetch, web search, tool 소유권에 대한 정적 capability 소유권 스냅샷입니다.
mediaUnderstandingProviderMetadata아니요Record<string, object>contracts.mediaUnderstandingProviders에 선언된 Provider id에 대한 저비용 media-understanding 기본값입니다.
imageGenerationProviderMetadata아니요Record<string, object>contracts.imageGenerationProviders에 선언된 Provider id에 대한 저비용 image-generation 인증 메타데이터로, Provider 소유 인증 별칭과 base-url guard를 포함합니다.
videoGenerationProviderMetadata아니요Record<string, object>contracts.videoGenerationProviders에 선언된 Provider id에 대한 저비용 video-generation 인증 메타데이터로, Provider 소유 인증 별칭과 base-url guard를 포함합니다.
musicGenerationProviderMetadata아니요Record<string, object>contracts.musicGenerationProviders에 선언된 Provider id에 대한 저비용 music-generation 인증 메타데이터로, Provider 소유 인증 별칭과 base-url guard를 포함합니다.
toolMetadata아니요Record<string, object>contracts.tools에 선언된 Plugin 소유 tool에 대한 저비용 가용성 메타데이터입니다. 구성, env 또는 인증 증거가 있을 때만 tool이 런타임을 로드해야 하는 경우 사용합니다.
channelConfigs아니요Record<string, object>런타임이 로드되기 전에 검색 및 검증 표면에 병합되는 매니페스트 소유 Channel 구성 메타데이터입니다.
skills아니요string[]Plugin 루트 기준으로 로드할 Skills 디렉터리입니다.
name아니요string사람이 읽을 수 있는 Plugin 이름.
description아니요stringPlugin 화면에 표시되는 짧은 요약.
version아니요string정보 제공용 Plugin 버전.
uiHints아니요Record<string, object>설정 필드의 UI 레이블, 플레이스홀더, 민감도 힌트.

생성 provider 메타데이터 참조

생성 provider 메타데이터 필드는 일치하는 contracts.*GenerationProviders 목록에 선언된 provider의 정적 인증 신호를 설명합니다. OpenClaw는 provider 런타임이 로드되기 전에 이 필드를 읽으므로, 핵심 도구는 모든 provider Plugin을 가져오지 않고도 생성 provider를 사용할 수 있는지 결정할 수 있습니다. 이 필드는 비용이 낮은 선언적 사실에만 사용하세요. 전송, 요청 변환, 토큰 갱신, 자격 증명 검증, 실제 생성 동작은 Plugin 런타임에 남겨둡니다.
{
  "contracts": {
    "imageGenerationProviders": ["example-image"]
  },
  "imageGenerationProviderMetadata": {
    "example-image": {
      "aliases": ["example-image-oauth"],
      "authProviders": ["example-image"],
      "configSignals": [
        {
          "rootPath": "plugins.entries.example-image.config",
          "overlayPath": "image",
          "mode": {
            "path": "mode",
            "default": "local",
            "allowed": ["local"]
          },
          "requiredAny": ["workflow", "workflowPath"],
          "required": ["promptNodeId"]
        }
      ],
      "authSignals": [
        {
          "provider": "example-image"
        },
        {
          "provider": "example-image-oauth",
          "providerBaseUrl": {
            "provider": "example-image",
            "defaultBaseUrl": "https://api.example.com/v1",
            "allowedBaseUrls": ["https://api.example.com/v1"]
          }
        }
      ]
    }
  }
}
각 메타데이터 항목은 다음을 지원합니다.
필드필수타입의미
aliases아니요string[]생성 provider의 정적 인증 별칭으로 간주해야 하는 추가 provider id입니다.
authProviders아니요string[]구성된 인증 프로필이 이 생성 provider의 인증으로 간주되어야 하는 provider id입니다.
configSignals아니요object[]인증 프로필이나 env var 없이 구성할 수 있는 로컬 또는 자체 호스팅 provider를 위한, 비용이 낮은 config 전용 가용성 신호입니다.
authSignals아니요object[]명시적 인증 신호입니다. 존재하는 경우 provider id, aliases, authProviders의 기본 신호 세트를 대체합니다.
configSignals 항목은 다음을 지원합니다.
필드필수타입의미
rootPathstring검사할 Plugin 소유 config 객체의 점 경로입니다. 예: plugins.entries.example.config.
overlayPath아니요string신호를 평가하기 전에 루트 객체 위에 겹쳐 적용해야 하는 루트 config 내부 객체의 점 경로입니다. image, video, music 같은 기능별 config에 사용하세요.
required아니요string[]값이 구성되어 있어야 하는 유효 config 내부의 점 경로입니다. 문자열은 비어 있지 않아야 하며, 객체와 배열도 비어 있으면 안 됩니다.
requiredAny아니요string[]유효 config 내부의 점 경로 중 하나 이상에 구성된 값이 있어야 합니다.
mode아니요object유효 config 내부의 선택적 문자열 모드 가드입니다. config 전용 가용성이 하나의 모드에만 적용될 때 사용하세요.
mode 가드는 다음을 지원합니다.
필드필수타입의미
path아니요string유효 config 내부의 점 경로입니다. 기본값은 mode입니다.
default아니요stringconfig에서 해당 경로를 생략했을 때 사용할 모드 값입니다.
allowed아니요string[]존재하는 경우 유효 모드가 이 값 중 하나일 때만 신호가 통과합니다.
disallowed아니요string[]존재하는 경우 유효 모드가 이 값 중 하나일 때 신호가 실패합니다.
authSignals 항목은 다음을 지원합니다.
필드필수타입의미
providerstring구성된 인증 프로필에서 확인할 provider id입니다.
providerBaseUrl아니요object참조된 구성 provider가 허용된 기본 URL을 사용할 때만 신호를 계산하게 하는 선택적 가드입니다. 인증 별칭이 특정 API에만 유효할 때 사용하세요.
providerBaseUrl 가드는 다음을 지원합니다.
필드필수타입의미
providerstringbaseUrl을 확인해야 하는 provider config id입니다.
defaultBaseUrl아니요stringprovider config에서 baseUrl을 생략했을 때 가정할 기본 URL입니다.
allowedBaseUrlsstring[]이 인증 신호에 허용되는 기본 URL입니다. 구성된 기본 URL 또는 기본값 기본 URL이 이 정규화된 값 중 하나와 일치하지 않으면 신호는 무시됩니다.

도구 메타데이터 참조

toolMetadata는 도구 이름을 키로 사용하며, 생성 provider 메타데이터와 동일한 configSignalsauthSignals 형태를 사용합니다. contracts.tools는 소유권을 선언합니다. toolMetadata는 비용이 낮은 가용성 증거를 선언하므로, OpenClaw는 도구 팩토리가 null을 반환하게 하려고 Plugin 런타임을 가져오는 일을 피할 수 있습니다.
{
  "providerAuthEnvVars": {
    "example": ["EXAMPLE_API_KEY"]
  },
  "contracts": {
    "tools": ["example_search"]
  },
  "toolMetadata": {
    "example_search": {
      "authSignals": [
        {
          "provider": "example"
        }
      ],
      "configSignals": [
        {
          "rootPath": "plugins.entries.example.config",
          "overlayPath": "search",
          "required": ["apiKey"]
        }
      ]
    }
  }
}
도구에 toolMetadata가 없으면 OpenClaw는 기존 동작을 유지하며, 도구 계약이 정책과 일치할 때 소유 Plugin을 로드합니다. 팩토리가 인증/config에 의존하는 핫 경로 도구의 경우, Plugin 작성자는 핵심이 런타임을 가져와 물어보게 하는 대신 toolMetadata를 선언해야 합니다.

providerAuthChoices 참조

providerAuthChoices 항목은 하나의 온보딩 또는 인증 선택지를 설명합니다. OpenClaw는 provider 런타임이 로드되기 전에 이를 읽습니다. Provider 설정 목록은 provider 런타임을 로드하지 않고 이 매니페스트 선택지, 디스크립터에서 파생된 설정 선택지, 설치 카탈로그 메타데이터를 사용합니다.
필드필수타입의미
providerstring이 선택지가 속한 provider id입니다.
methodstring디스패치할 인증 메서드 id입니다.
choiceIdstring온보딩 및 CLI 흐름에서 사용하는 안정적인 인증 선택지 id입니다.
choiceLabel아니요string사용자에게 표시되는 레이블입니다. 생략하면 OpenClaw는 choiceId로 대체합니다.
choiceHint아니요string선택기를 위한 짧은 도움말 텍스트입니다.
assistantPriority아니요number값이 낮을수록 assistant 주도 대화형 선택기에서 더 앞에 정렬됩니다.
assistantVisibility아니요"visible" | "manual-only"수동 CLI 선택은 계속 허용하면서 assistant 선택기에서는 이 선택지를 숨깁니다.
deprecatedChoiceIds아니요string[]사용자를 이 대체 선택지로 리디렉션해야 하는 레거시 선택지 id입니다.
groupId아니요string관련 선택지를 그룹화하기 위한 선택적 그룹 id입니다.
groupLabel아니요string해당 그룹에 대해 사용자에게 표시되는 레이블입니다.
groupHint아니요string그룹을 위한 짧은 도움말 텍스트입니다.
optionKey아니요string간단한 단일 플래그 인증 흐름을 위한 내부 옵션 키입니다.
cliFlag아니요string--openrouter-api-key 같은 CLI 플래그 이름입니다.
cliOption아니요string--openrouter-api-key <key> 같은 전체 CLI 옵션 형태입니다.
cliDescription아니요stringCLI 도움말에 사용되는 설명입니다.
onboardingScopes아니요Array<"text-inference" | "image-generation">이 선택지가 표시되어야 하는 온보딩 화면입니다. 생략하면 기본값은 ["text-inference"]입니다.

commandAliases 참조

commandAliases는 Plugin이 런타임 명령 이름을 소유하며, 사용자가 이를 plugins.allow에 잘못 넣거나 루트 CLI 명령으로 실행하려 할 수 있을 때 사용하세요. OpenClaw는 Plugin 런타임 코드를 가져오지 않고도 진단에 이 메타데이터를 사용합니다.
{
  "commandAliases": [
    {
      "name": "dreaming",
      "kind": "runtime-slash",
      "cliCommand": "memory"
    }
  ]
}
필드필수유형의미
namestring이 Plugin에 속한 명령 이름입니다.
kind아니요"runtime-slash"별칭을 루트 CLI 명령이 아닌 채팅 슬래시 명령으로 표시합니다.
cliCommand아니요stringCLI 작업에 제안할 관련 루트 CLI 명령입니다. 존재하는 경우에만 사용합니다.

activation 참조

Plugin이 어떤 제어 평면 이벤트에 포함되어 활성화/로드 계획에 들어가야 하는지 저렴하게 선언할 수 있을 때 activation을 사용하세요. 이 블록은 플래너 메타데이터이며, 수명 주기 API가 아닙니다. 런타임 동작을 등록하지 않고, register(...)를 대체하지 않으며, Plugin 코드가 이미 실행되었다고 보장하지도 않습니다. 활성화 플래너는 이러한 필드를 사용해 후보 Plugin을 좁힌 뒤, providers, channels, commandAliases, setup.providers, contracts.tools, 훅과 같은 기존 매니페스트 소유권 메타데이터로 대체합니다. 이미 소유권을 설명하는 가장 좁은 메타데이터를 선호하세요. 해당 필드가 관계를 표현한다면 providers, channels, commandAliases, 설정 설명자 또는 contracts를 사용하세요. 이러한 소유권 필드로 표현할 수 없는 추가 플래너 힌트에는 activation을 사용하세요. claude-cli, codex-cli, google-gemini-cli 같은 CLI 런타임 별칭에는 최상위 cliBackends를 사용하세요. activation.onAgentHarnesses는 이미 소유권 필드가 없는 내장 에이전트 하네스 ID에만 사용합니다. 이 블록은 메타데이터 전용입니다. 런타임 동작을 등록하지 않으며, register(...), setupEntry 또는 다른 런타임/Plugin 진입점을 대체하지 않습니다. 현재 소비자는 더 넓은 Plugin 로딩 전에 이를 좁히기 힌트로 사용하므로, 시작 시점이 아닌 활성화 메타데이터가 누락되어도 일반적으로 성능 비용만 발생합니다. 매니페스트 소유권 대체 경로가 여전히 존재하는 동안에는 정확성이 바뀌지 않아야 합니다. 모든 Plugin은 activation.onStartup을 의도적으로 설정해야 합니다. Plugin이 Gateway 시작 중 반드시 실행되어야 할 때만 true로 설정하세요. Plugin이 시작 시점에는 비활성이고 더 좁은 트리거에서만 로드되어야 할 때는 false로 설정하세요. onStartup을 생략해도 더 이상 Plugin이 암묵적으로 시작 로드되지 않습니다. 시작, 채널, 구성, 에이전트 하네스, 메모리 또는 기타 더 좁은 활성화 트리거에는 명시적 활성화 메타데이터를 사용하세요.
{
  "activation": {
    "onStartup": false,
    "onProviders": ["openai"],
    "onCommands": ["models"],
    "onChannels": ["web"],
    "onRoutes": ["gateway-webhook"],
    "onConfigPaths": ["browser"],
    "onCapabilities": ["provider", "tool"]
  }
}
필드필수유형의미
onStartup아니요boolean명시적 Gateway 시작 활성화입니다. 모든 Plugin은 이를 설정해야 합니다. true는 시작 중 Plugin을 가져오고, false는 다른 일치 트리거가 로드를 요구하지 않는 한 시작 지연 상태로 둡니다.
onProviders아니요string[]활성화/로드 계획에 이 Plugin을 포함해야 하는 Provider ID입니다.
onAgentHarnesses아니요string[]활성화/로드 계획에 이 Plugin을 포함해야 하는 내장 에이전트 하네스 런타임 ID입니다. CLI 백엔드 별칭에는 최상위 cliBackends를 사용하세요.
onCommands아니요string[]활성화/로드 계획에 이 Plugin을 포함해야 하는 명령 ID입니다.
onChannels아니요string[]활성화/로드 계획에 이 Plugin을 포함해야 하는 채널 ID입니다.
onRoutes아니요string[]활성화/로드 계획에 이 Plugin을 포함해야 하는 라우트 종류입니다.
onConfigPaths아니요string[]경로가 존재하고 명시적으로 비활성화되지 않은 경우 시작/로드 계획에 이 Plugin을 포함해야 하는 루트 기준 구성 경로입니다.
onCapabilities아니요Array<"provider" | "channel" | "tool" | "hook">제어 평면 활성화 계획에서 사용하는 넓은 범위의 기능 힌트입니다. 가능하면 더 좁은 필드를 선호하세요.
현재 라이브 소비자:
  • Gateway 시작 계획은 명시적 시작 가져오기에 activation.onStartup을 사용합니다
  • 명령으로 트리거되는 CLI 계획은 레거시 commandAliases[].cliCommand 또는 commandAliases[].name으로 대체됩니다
  • 에이전트 런타임 시작 계획은 내장 하네스에는 activation.onAgentHarnesses를, CLI 런타임 별칭에는 최상위 cliBackends[]를 사용합니다
  • 채널로 트리거되는 설정/채널 계획은 명시적 채널 활성화 메타데이터가 없을 때 레거시 channels[] 소유권으로 대체됩니다
  • 시작 Plugin 계획은 번들 브라우저 Plugin의 browser 블록 같은 채널이 아닌 루트 구성 표면에 activation.onConfigPaths를 사용합니다
  • Provider로 트리거되는 설정/런타임 계획은 명시적 Provider 활성화 메타데이터가 없을 때 레거시 providers[]와 최상위 cliBackends[] 소유권으로 대체됩니다
플래너 진단은 명시적 활성화 힌트와 매니페스트 소유권 대체를 구분할 수 있습니다. 예를 들어 activation-command-hintactivation.onCommands가 일치했음을 의미하고, manifest-command-alias는 플래너가 대신 commandAliases 소유권을 사용했음을 의미합니다. 이러한 이유 레이블은 호스트 진단과 테스트를 위한 것입니다. Plugin 작성자는 소유권을 가장 잘 설명하는 메타데이터를 계속 선언해야 합니다.

qaRunners 참조

Plugin이 공유 openclaw qa 루트 아래에 하나 이상의 전송 러너를 제공할 때 qaRunners를 사용하세요. 이 메타데이터는 저렴하고 정적으로 유지하세요. 실제 CLI 등록은 여전히 qaRunnerCliRegistrations를 내보내는 가벼운 runtime-api.ts 표면을 통해 Plugin 런타임이 소유합니다.
{
  "qaRunners": [
    {
      "commandName": "matrix",
      "description": "Run the Docker-backed Matrix live QA lane against a disposable homeserver"
    }
  ]
}
필드필수유형의미
commandNamestringopenclaw qa 아래에 마운트되는 하위 명령입니다. 예: matrix.
description아니요string공유 호스트가 스텁 명령을 필요로 할 때 사용하는 대체 도움말 텍스트입니다.

setup 참조

설정 및 온보딩 표면이 런타임 로드 전에 저렴한 Plugin 소유 메타데이터를 필요로 할 때 setup을 사용하세요.
{
  "setup": {
    "providers": [
      {
        "id": "openai",
        "authMethods": ["api-key"],
        "envVars": ["OPENAI_API_KEY"],
        "authEvidence": [
          {
            "type": "local-file-with-env",
            "fileEnvVar": "OPENAI_CREDENTIALS_FILE",
            "requiresAllEnv": ["OPENAI_PROJECT"],
            "credentialMarker": "openai-local-credentials",
            "source": "openai local credentials"
          }
        ]
      }
    ],
    "cliBackends": ["openai-cli"],
    "configMigrations": ["legacy-openai-auth"],
    "requiresRuntime": false
  }
}
최상위 cliBackends는 계속 유효하며 CLI 추론 백엔드를 계속 설명합니다. setup.cliBackends는 메타데이터 전용으로 유지되어야 하는 제어 평면/설정 흐름을 위한 설정 전용 설명자 표면입니다. setup.providerssetup.cliBackends가 있으면 설정 발견을 위한 설명자 우선 조회 표면으로 선호됩니다. 설명자가 후보 Plugin만 좁히고 설정에 더 풍부한 설정 시점 런타임 훅이 여전히 필요하다면 requiresRuntime: true를 설정하고 대체 실행 경로로 setup-api를 유지하세요. OpenClaw는 일반 Provider 인증 및 환경 변수 조회에도 setup.providers[].envVars를 포함합니다. providerAuthEnvVars는 지원 중단 기간 동안 호환성 어댑터를 통해 계속 지원되지만, 이를 여전히 사용하는 비번들 Plugin은 매니페스트 진단을 받습니다. 새 Plugin은 설정/상태 환경 메타데이터를 setup.providers[].envVars에 넣어야 합니다. OpenClaw는 설정 항목이 없거나 setup.requiresRuntime: false가 설정 런타임이 불필요하다고 선언할 때 setup.providers[].authMethods에서 간단한 설정 선택지를 도출할 수도 있습니다. 명시적 providerAuthChoices 항목은 사용자 지정 레이블, CLI 플래그, 온보딩 범위, 어시스턴트 메타데이터에 계속 선호됩니다. requiresRuntime: false는 해당 설명자가 설정 표면에 충분할 때만 설정하세요. OpenClaw는 명시적 false를 설명자 전용 계약으로 취급하며 설정 조회를 위해 setup-api 또는 openclaw.setupEntry를 실행하지 않습니다. 설명자 전용 Plugin이 그러한 설정 런타임 항목 중 하나를 여전히 포함하는 경우, OpenClaw는 추가 진단을 보고하고 이를 계속 무시합니다. requiresRuntime을 생략하면 레거시 대체 동작이 유지되므로 플래그 없이 설명자를 추가한 기존 Plugin이 깨지지 않습니다. 설정 조회는 Plugin 소유 setup-api 코드를 실행할 수 있으므로, 정규화된 setup.providers[].idsetup.cliBackends[] 값은 발견된 Plugin 전체에서 고유해야 합니다. 소유권이 모호하면 발견 순서에서 승자를 고르는 대신 닫힌 방식으로 실패합니다. 설정 런타임이 실행될 때, setup-api가 매니페스트 설명자에 선언되지 않은 Provider나 CLI 백엔드를 등록하거나, 설명자에 일치하는 런타임 등록이 없으면 설정 레지스트리 진단이 설명자 드리프트를 보고합니다. 이러한 진단은 추가적이며 레거시 Plugin을 거부하지 않습니다.

setup.providers 참조

필드필수유형의미
idstring설정 또는 온보딩 중 노출되는 Provider ID입니다. 정규화된 ID는 전역적으로 고유하게 유지하세요.
authMethods아니요string[]이 Provider가 전체 런타임을 로드하지 않고 지원하는 설정/인증 방법 ID입니다.
envVars아니요string[]일반 설정/상태 표면이 Plugin 런타임 로드 전에 확인할 수 있는 환경 변수입니다.
authEvidence아니요object[]비밀이 아닌 마커를 통해 인증할 수 있는 Provider를 위한 저렴한 로컬 인증 증거 확인입니다.
authEvidence는 런타임 코드를 로드하지 않고도 확인할 수 있는, 제공자가 소유한 로컬 자격 증명 마커에 사용됩니다. 이러한 검사는 저렴하고 로컬에 머물러야 합니다: 네트워크 호출, 키체인 또는 시크릿 관리자 읽기, 셸 명령, 제공자 API 프로브는 없어야 합니다. 지원되는 증거 항목:
필드필수유형의미
typestring현재는 local-file-with-env입니다.
fileEnvVar아니요string명시적인 자격 증명 파일 경로가 들어 있는 env var입니다.
fallbackPaths아니요string[]fileEnvVar가 없거나 비어 있을 때 확인하는 로컬 자격 증명 파일 경로입니다. ${HOME}${APPDATA}를 지원합니다.
requiresAnyEnv아니요string[]증거가 유효해지려면 나열된 env var 중 하나 이상이 비어 있지 않아야 합니다.
requiresAllEnv아니요string[]증거가 유효해지려면 나열된 모든 env var가 비어 있지 않아야 합니다.
credentialMarkerstring증거가 있을 때 반환되는 비밀이 아닌 마커입니다.
source아니요string인증/상태 출력에 사용할 사용자 표시 소스 레이블입니다.

설정 필드

필드필수유형의미
providers아니요object[]설정 및 온보딩 중에 노출되는 제공자 설정 설명자입니다.
cliBackends아니요string[]설명자 우선 설정 조회에 사용되는 설정 시점 백엔드 ID입니다. 정규화된 ID는 전역적으로 고유하게 유지하세요.
configMigrations아니요string[]이 Plugin의 설정 표면이 소유한 구성 마이그레이션 ID입니다.
requiresRuntime아니요boolean설명자 조회 후에도 설정에 setup-api 실행이 필요한지 여부입니다.

uiHints 참조

uiHints는 구성 필드 이름에서 작은 렌더링 힌트로 매핑되는 맵입니다.
{
  "uiHints": {
    "apiKey": {
      "label": "API key",
      "help": "Used for OpenRouter requests",
      "placeholder": "sk-or-v1-...",
      "sensitive": true
    }
  }
}
각 필드 힌트에는 다음이 포함될 수 있습니다:
필드유형의미
labelstring사용자 표시 필드 레이블입니다.
helpstring짧은 도움말 텍스트입니다.
tagsstring[]선택적 UI 태그입니다.
advancedboolean필드를 고급으로 표시합니다.
sensitiveboolean필드를 비밀 또는 민감 정보로 표시합니다.
placeholderstring양식 입력의 자리표시자 텍스트입니다.

contracts 참조

OpenClaw가 Plugin 런타임을 가져오지 않고 읽을 수 있는 정적 기능 소유권 메타데이터에만 contracts를 사용하세요.
{
  "contracts": {
    "agentToolResultMiddleware": ["pi", "codex"],
    "externalAuthProviders": ["acme-ai"],
    "speechProviders": ["openai"],
    "realtimeTranscriptionProviders": ["openai"],
    "realtimeVoiceProviders": ["openai"],
    "memoryEmbeddingProviders": ["local"],
    "mediaUnderstandingProviders": ["openai", "openai-codex"],
    "imageGenerationProviders": ["openai"],
    "videoGenerationProviders": ["qwen"],
    "webFetchProviders": ["firecrawl"],
    "webSearchProviders": ["gemini"],
    "migrationProviders": ["hermes"],
    "tools": ["firecrawl_search", "firecrawl_scrape"]
  }
}
각 목록은 선택 사항입니다:
필드유형의미
embeddedExtensionFactoriesstring[]Codex 앱 서버 확장 팩터리 ID이며, 현재는 codex-app-server입니다.
agentToolResultMiddlewarestring[]번들 Plugin이 도구 결과 미들웨어를 등록할 수 있는 런타임 ID입니다.
externalAuthProvidersstring[]이 Plugin이 외부 인증 프로필 훅을 소유한 제공자 ID입니다.
speechProvidersstring[]이 Plugin이 소유한 음성 제공자 ID입니다.
realtimeTranscriptionProvidersstring[]이 Plugin이 소유한 실시간 전사 제공자 ID입니다.
realtimeVoiceProvidersstring[]이 Plugin이 소유한 실시간 음성 제공자 ID입니다.
memoryEmbeddingProvidersstring[]이 Plugin이 소유한 메모리 임베딩 제공자 ID입니다.
mediaUnderstandingProvidersstring[]이 Plugin이 소유한 미디어 이해 제공자 ID입니다.
imageGenerationProvidersstring[]이 Plugin이 소유한 이미지 생성 제공자 ID입니다.
videoGenerationProvidersstring[]이 Plugin이 소유한 비디오 생성 제공자 ID입니다.
webFetchProvidersstring[]이 Plugin이 소유한 웹 가져오기 제공자 ID입니다.
webSearchProvidersstring[]이 Plugin이 소유한 웹 검색 제공자 ID입니다.
migrationProvidersstring[]openclaw migrate에 대해 이 Plugin이 소유한 가져오기 제공자 ID입니다.
toolsstring[]이 Plugin이 소유한 에이전트 도구 이름입니다.
contracts.embeddedExtensionFactories는 번들 Codex 앱 서버 전용 확장 팩터리를 위해 유지됩니다. 번들 도구 결과 변환은 대신 contracts.agentToolResultMiddleware를 선언하고 api.registerAgentToolResultMiddleware(...)로 등록해야 합니다. 외부 Plugin은 모델이 보기 전에 높은 신뢰도의 도구 출력을 이 이음새가 다시 쓸 수 있으므로 도구 결과 미들웨어를 등록할 수 없습니다. 런타임 api.registerTool(...) 등록은 contracts.tools와 일치해야 합니다. 도구 검색은 이 목록을 사용해 요청된 도구를 소유할 수 있는 Plugin 런타임만 로드합니다. resolveExternalAuthProfiles를 구현하는 제공자 Plugin은 contracts.externalAuthProviders를 선언해야 합니다. 선언이 없는 Plugin은 여전히 더 이상 사용되지 않는 호환성 폴백을 통해 실행되지만, 해당 폴백은 더 느리며 마이그레이션 기간 후 제거될 예정입니다. 번들 메모리 임베딩 제공자는 local 같은 기본 제공 어댑터를 포함해 노출하는 모든 어댑터 ID에 대해 contracts.memoryEmbeddingProviders를 선언해야 합니다. 독립 실행형 CLI 경로는 전체 Gateway 런타임이 제공자를 등록하기 전에 이 매니페스트 계약을 사용해 소유 Plugin만 로드합니다.

mediaUnderstandingProviderMetadata 참조

미디어 이해 제공자에 런타임 로드 전에 일반 코어 헬퍼가 필요로 하는 기본 모델, 자동 인증 폴백 우선순위, 또는 네이티브 문서 지원이 있을 때 mediaUnderstandingProviderMetadata를 사용하세요. 키는 contracts.mediaUnderstandingProviders에도 선언되어야 합니다.
{
  "contracts": {
    "mediaUnderstandingProviders": ["example"]
  },
  "mediaUnderstandingProviderMetadata": {
    "example": {
      "capabilities": ["image", "audio"],
      "defaultModels": {
        "image": "example-vision-latest",
        "audio": "example-transcribe-latest"
      },
      "autoPriority": {
        "image": 40
      },
      "nativeDocumentInputs": ["pdf"]
    }
  }
}
각 제공자 항목에는 다음이 포함될 수 있습니다:
필드유형의미
capabilities("image" | "audio" | "video")[]이 제공자가 노출하는 미디어 기능입니다.
defaultModelsRecord<string, string>구성에서 모델을 지정하지 않을 때 사용하는 기능-모델 기본값입니다.
autoPriorityRecord<string, number>자동 자격 증명 기반 제공자 폴백에서 숫자가 낮을수록 더 먼저 정렬됩니다.
nativeDocumentInputs"pdf"[]제공자가 지원하는 네이티브 문서 입력입니다.

channelConfigs 참조

채널 Plugin이 런타임 로드 전에 저렴한 구성 메타데이터가 필요할 때 channelConfigs를 사용하세요. 읽기 전용 채널 설정/상태 검색은 설정 항목이 없거나 setup.requiresRuntime: false가 설정 런타임이 불필요하다고 선언할 때, 구성된 외부 채널에 대해 이 메타데이터를 직접 사용할 수 있습니다. channelConfigs는 Plugin 매니페스트 메타데이터이지, 새로운 최상위 사용자 구성 섹션이 아닙니다. 사용자는 여전히 channels.<channel-id> 아래에서 채널 인스턴스를 구성합니다. OpenClaw는 Plugin 런타임 코드가 실행되기 전에 구성된 채널을 어느 Plugin이 소유하는지 결정하기 위해 매니페스트 메타데이터를 읽습니다. 채널 Plugin의 경우 configSchemachannelConfigs는 서로 다른 경로를 설명합니다:
  • configSchemaplugins.entries.<plugin-id>.config를 검증합니다.
  • channelConfigs.<channel-id>.schemachannels.<channel-id>를 검증합니다.
channels[]를 선언하는 비번들 Plugin은 일치하는 channelConfigs 항목도 선언해야 합니다. 그렇지 않으면 OpenClaw가 여전히 Plugin을 로드할 수는 있지만, 콜드 경로 구성 스키마, 설정, Control UI 표면은 Plugin 런타임이 실행될 때까지 채널 소유 옵션의 형태를 알 수 없습니다. channelConfigs.<channel-id>.commands.nativeCommandsAutoEnablednativeSkillsAutoEnabled는 채널 런타임이 로드되기 전에 실행되는 명령 구성 검사에 대한 정적 auto 기본값을 선언할 수 있습니다. 번들 채널은 다른 패키지 소유 채널 카탈로그 메타데이터와 함께 package.json#openclaw.channel.commands를 통해 동일한 기본값을 게시할 수도 있습니다.
{
  "channelConfigs": {
    "matrix": {
      "schema": {
        "type": "object",
        "additionalProperties": false,
        "properties": {
          "homeserverUrl": { "type": "string" }
        }
      },
      "uiHints": {
        "homeserverUrl": {
          "label": "Homeserver URL",
          "placeholder": "https://matrix.example.com"
        }
      },
      "label": "Matrix",
      "description": "Matrix homeserver connection",
      "commands": {
        "nativeCommandsAutoEnabled": true,
        "nativeSkillsAutoEnabled": true
      },
      "preferOver": ["matrix-legacy"]
    }
  }
}
각 채널 항목에는 다음이 포함될 수 있습니다:
필드유형의미
schemaobjectchannels.<id>의 JSON Schema입니다. 선언된 각 채널 구성 항목에 필요합니다.
uiHintsRecord<string, object>해당 채널 구성 섹션에 대한 선택적 UI 레이블/플레이스홀더/민감 정보 힌트입니다.
labelstring런타임 메타데이터가 준비되지 않았을 때 선택기와 검사 화면에 병합되는 채널 레이블입니다.
descriptionstring검사 및 카탈로그 화면에 표시되는 짧은 채널 설명입니다.
commandsobject런타임 전 구성 검사를 위한 정적 네이티브 명령 및 네이티브 skill 자동 기본값입니다.
preferOverstring[]선택 화면에서 이 채널이 우선해야 하는 레거시 또는 낮은 우선순위의 Plugin ID입니다.

다른 채널 Plugin 대체하기

다른 Plugin도 제공할 수 있는 채널 ID에 대해 내 Plugin이 선호되는 소유자라면 preferOver를 사용하세요. 일반적인 경우는 이름이 바뀐 Plugin ID, 번들 Plugin을 대체하는 독립형 Plugin, 또는 구성 호환성을 위해 같은 채널 ID를 유지하는 유지 관리되는 포크입니다.
{
  "id": "acme-chat",
  "channels": ["chat"],
  "channelConfigs": {
    "chat": {
      "schema": {
        "type": "object",
        "additionalProperties": false,
        "properties": {
          "webhookUrl": { "type": "string" }
        }
      },
      "preferOver": ["chat"]
    }
  }
}
channels.chat가 구성되면 OpenClaw는 채널 ID와 선호 Plugin ID를 모두 고려합니다. 낮은 우선순위 Plugin이 번들되어 있거나 기본적으로 활성화되어 있다는 이유만으로 선택된 경우, OpenClaw는 유효 런타임 구성에서 이를 비활성화하여 하나의 Plugin이 채널과 해당 도구를 소유하게 합니다. 명시적인 사용자 선택은 여전히 우선합니다. 사용자가 두 Plugin을 명시적으로 활성화하면, OpenClaw는 요청된 Plugin 집합을 조용히 변경하는 대신 그 선택을 보존하고 중복 채널/도구 진단을 보고합니다. preferOver는 실제로 같은 채널을 제공할 수 있는 Plugin ID로 범위를 제한하세요. 이는 일반적인 우선순위 필드가 아니며 사용자 구성 키의 이름을 바꾸지도 않습니다.

modelSupport 참조

Plugin 런타임이 로드되기 전에 OpenClaw가 gpt-5.5 또는 claude-sonnet-4.6 같은 축약 모델 ID에서 제공자 Plugin을 추론해야 할 때 modelSupport를 사용하세요.
{
  "modelSupport": {
    "modelPrefixes": ["gpt-", "o1", "o3", "o4"],
    "modelPatterns": ["^computer-use-preview"]
  }
}
OpenClaw는 다음 우선순위를 적용합니다.
  • 명시적 provider/model 참조는 소유 providers 매니페스트 메타데이터를 사용합니다
  • modelPatternsmodelPrefixes보다 우선합니다
  • 번들되지 않은 Plugin 하나와 번들 Plugin 하나가 모두 일치하면, 번들되지 않은 Plugin이 우선합니다
  • 남은 모호성은 사용자 또는 구성이 제공자를 지정할 때까지 무시됩니다
필드:
필드유형의미
modelPrefixesstring[]축약 모델 ID에 대해 startsWith로 일치시키는 접두사입니다.
modelPatternsstring[]프로필 접미사 제거 후 축약 모델 ID에 대해 일치시키는 정규식 소스입니다.

modelCatalog 참조

Plugin 런타임을 로드하기 전에 OpenClaw가 제공자 모델 메타데이터를 알아야 할 때 modelCatalog를 사용하세요. 이는 고정 카탈로그 행, 제공자 별칭, 억제 규칙, 발견 모드를 위한 매니페스트 소유 소스입니다. 런타임 새로 고침은 여전히 제공자 런타임 코드에 속하지만, 매니페스트는 런타임이 언제 필요한지를 코어에 알려줍니다.
{
  "providers": ["openai"],
  "modelCatalog": {
    "providers": {
      "openai": {
        "baseUrl": "https://api.openai.com/v1",
        "api": "openai-responses",
        "models": [
          {
            "id": "gpt-5.4",
            "name": "GPT-5.4",
            "input": ["text", "image"],
            "reasoning": true,
            "contextWindow": 256000,
            "maxTokens": 128000,
            "cost": {
              "input": 1.25,
              "output": 10,
              "cacheRead": 0.125
            },
            "status": "available",
            "tags": ["default"]
          }
        ]
      }
    },
    "aliases": {
      "azure-openai-responses": {
        "provider": "openai",
        "api": "azure-openai-responses"
      }
    },
    "suppressions": [
      {
        "provider": "azure-openai-responses",
        "model": "gpt-5.3-codex-spark",
        "reason": "not available on Azure OpenAI Responses"
      }
    ],
    "discovery": {
      "openai": "static"
    }
  }
}
최상위 필드:
필드유형의미
providersRecord<string, object>이 Plugin이 소유한 제공자 ID의 카탈로그 행입니다. 키는 최상위 providers에도 나타나야 합니다.
aliasesRecord<string, object>카탈로그 또는 억제 계획을 위해 소유 제공자로 해석되어야 하는 제공자 별칭입니다.
suppressionsobject[]이 Plugin이 제공자별 사유로 억제하는 다른 소스의 모델 행입니다.
discoveryRecord<string, "static" | "refreshable" | "runtime">제공자 카탈로그를 매니페스트 메타데이터에서 읽을 수 있는지, 캐시에 새로 고칠 수 있는지, 런타임이 필요한지입니다.
aliases는 모델 카탈로그 계획을 위한 제공자 소유권 조회에 참여합니다. 별칭 대상은 같은 Plugin이 소유한 최상위 제공자여야 합니다. 제공자로 필터링된 목록이 별칭을 사용하면, OpenClaw는 제공자 런타임을 로드하지 않고도 소유 매니페스트를 읽고 별칭 API/기본 URL 재정의를 적용할 수 있습니다. 별칭은 필터링되지 않은 카탈로그 목록을 확장하지 않습니다. 광범위한 목록은 소유 정식 제공자 행만 내보냅니다. suppressions는 이전 제공자 런타임 suppressBuiltInModel 훅을 대체합니다. 억제 항목은 제공자가 Plugin이 소유한 제공자이거나 소유 제공자를 대상으로 하는 modelCatalog.aliases 키로 선언된 경우에만 적용됩니다. 런타임 억제 훅은 더 이상 모델 해석 중에 호출되지 않습니다. 제공자 필드:
필드유형의미
baseUrlstring이 제공자 카탈로그의 모델에 대한 선택적 기본 base URL입니다.
apiModelApi이 제공자 카탈로그의 모델에 대한 선택적 기본 API 어댑터입니다.
headersRecord<string, string>이 제공자 카탈로그에 적용되는 선택적 정적 헤더입니다.
modelsobject[]필수 모델 행입니다. id가 없는 행은 무시됩니다.
모델 필드:
필드유형의미
idstringprovider/ 접두사가 없는 제공자 로컬 모델 ID입니다.
namestring선택적 표시 이름입니다.
apiModelApi선택적 모델별 API 재정의입니다.
baseUrlstring선택적 모델별 base URL 재정의입니다.
headersRecord<string, string>선택적 모델별 정적 헤더입니다.
inputArray<"text" | "image" | "document" | "audio" | "video">모델이 허용하는 모달리티입니다.
reasoningboolean모델이 추론 동작을 노출하는지 여부입니다.
contextWindownumber네이티브 제공자 컨텍스트 창입니다.
contextTokensnumbercontextWindow와 다를 때의 선택적 유효 런타임 컨텍스트 상한입니다.
maxTokensnumber알려진 경우 최대 출력 토큰 수입니다.
costobject선택적 tieredPricing을 포함한 토큰 백만 개당 선택적 USD 가격입니다.
compatobjectOpenClaw 모델 구성 호환성과 일치하는 선택적 호환성 플래그입니다.
status"available" | "preview" | "deprecated" | "disabled"목록 표시 상태입니다. 행이 전혀 나타나면 안 되는 경우에만 억제하세요.
statusReasonstring사용할 수 없는 상태와 함께 표시되는 선택적 사유입니다.
replacesstring[]이 모델이 대체하는 이전 제공자 로컬 모델 ID입니다.
replacedBystring지원 중단된 행의 대체 제공자 로컬 모델 ID입니다.
tagsstring[]선택기와 필터에서 사용하는 안정적인 태그입니다.
억제 필드:
필드유형의미
providerstring억제할 업스트림 행의 제공자 ID입니다. 이 Plugin이 소유하거나 소유 별칭으로 선언되어야 합니다.
modelstring억제할 제공자 로컬 모델 ID입니다.
reasonstring억제된 행이 직접 요청될 때 표시되는 선택적 메시지입니다.
when.baseUrlHostsstring[]억제가 적용되기 전에 필요한 유효 제공자 base URL 호스트의 선택적 목록입니다.
when.providerConfigApiInstring[]억제가 적용되기 전에 필요한 정확한 제공자 구성 api 값의 선택적 목록입니다.
런타임 전용 데이터를 modelCatalog에 넣지 마세요. 매니페스트 행이 provider 기준 필터링 목록과 선택기 화면에서 레지스트리/런타임 탐색을 건너뛸 수 있을 만큼 충분히 완전할 때만 static을 사용하세요. 매니페스트 행이 나열 가능한 유용한 시드 또는 보충 정보이지만, 나중에 새로 고침/캐시로 더 많은 행을 추가할 수 있을 때는 refreshable을 사용하세요. refreshable 행은 그 자체만으로 권위 있는 기준이 아닙니다. 목록을 알기 위해 OpenClaw가 provider 런타임을 로드해야 할 때는 runtime을 사용하세요.

modelIdNormalization 참조

provider 런타임이 로드되기 전에 반드시 수행되어야 하는, 비용이 낮은 provider 소유 모델 ID 정리에 modelIdNormalization을 사용하세요. 이렇게 하면 짧은 모델 이름, provider 로컬 레거시 ID, 프록시 접두사 규칙 같은 별칭이 코어 모델 선택 테이블이 아니라 소유 Plugin 매니페스트에 유지됩니다.
{
  "providers": ["anthropic", "openrouter"],
  "modelIdNormalization": {
    "providers": {
      "anthropic": {
        "aliases": {
          "sonnet-4.6": "claude-sonnet-4-6"
        }
      },
      "openrouter": {
        "prefixWhenBare": "openrouter"
      }
    }
  }
}
Provider 필드:
필드타입의미
aliasesRecord<string,string>대소문자를 구분하지 않는 정확한 모델 ID 별칭입니다. 값은 작성된 그대로 반환됩니다.
stripPrefixesstring[]별칭 조회 전에 제거할 접두사입니다. 레거시 provider/model 중복에 유용합니다.
prefixWhenBarestring정규화된 모델 ID에 아직 /가 없을 때 추가할 접두사입니다.
prefixWhenBareAfterAliasStartsWithobject[]별칭 조회 후의 조건부 bare ID 접두사 규칙이며, modelPrefixprefix를 키로 사용합니다.

providerEndpoints 참조

provider 런타임이 로드되기 전에 일반 요청 정책이 알아야 하는 엔드포인트 분류에 providerEndpoints를 사용하세요. 각 endpointClass의 의미는 여전히 코어가 소유하며, Plugin 매니페스트는 호스트와 기본 URL 메타데이터를 소유합니다. 엔드포인트 필드:
필드타입의미
endpointClassstringopenrouter, moonshot-native, google-vertex 같은 알려진 코어 엔드포인트 클래스입니다.
hostsstring[]엔드포인트 클래스에 매핑되는 정확한 호스트 이름입니다.
hostSuffixesstring[]엔드포인트 클래스에 매핑되는 호스트 접미사입니다. 도메인 접미사 전용 매칭에는 .를 붙이세요.
baseUrlsstring[]엔드포인트 클래스에 매핑되는 정확히 정규화된 HTTP(S) 기본 URL입니다.
googleVertexRegionstring정확한 전역 호스트에 대한 정적 Google Vertex 리전입니다.
googleVertexRegionHostSuffixstring매칭되는 호스트에서 제거해 Google Vertex 리전 접두사를 노출할 접미사입니다.

providerRequest 참조

provider 런타임을 로드하지 않고도 일반 요청 정책에 필요한, 비용이 낮은 요청 호환성 메타데이터에 providerRequest를 사용하세요. 동작별 페이로드 재작성은 provider 런타임 훅이나 공유 provider 패밀리 헬퍼에 유지하세요.
{
  "providers": ["vllm"],
  "providerRequest": {
    "providers": {
      "vllm": {
        "family": "vllm",
        "openAICompletions": {
          "supportsStreamingUsage": true
        }
      }
    }
  }
}
Provider 필드:
필드타입의미
familystring일반 요청 호환성 결정과 진단에 사용되는 provider 패밀리 레이블입니다.
compatibilityFamily"moonshot"공유 요청 헬퍼를 위한 선택적 provider 패밀리 호환성 버킷입니다.
openAICompletionsobjectOpenAI 호환 completions 요청 플래그이며, 현재는 supportsStreamingUsage입니다.

modelPricing 참조

provider가 런타임 로드 전에 제어 플레인 가격 동작을 제어해야 할 때 modelPricing을 사용하세요. Gateway 가격 캐시는 provider 런타임 코드를 가져오지 않고 이 메타데이터를 읽습니다.
{
  "providers": ["ollama", "openrouter"],
  "modelPricing": {
    "providers": {
      "ollama": {
        "external": false
      },
      "openrouter": {
        "openRouter": {
          "passthroughProviderModel": true
        },
        "liteLLM": false
      }
    }
  }
}
Provider 필드:
필드타입의미
externalbooleanOpenRouter 또는 LiteLLM 가격을 절대 가져오지 않아야 하는 로컬/셀프 호스팅 provider에는 false로 설정합니다.
openRouterfalse | objectOpenRouter 가격 조회 매핑입니다. false는 이 provider에 대한 OpenRouter 조회를 비활성화합니다.
liteLLMfalse | objectLiteLLM 가격 조회 매핑입니다. false는 이 provider에 대한 LiteLLM 조회를 비활성화합니다.
소스 필드:
필드타입의미
providerstringOpenClaw provider ID와 다를 때의 외부 카탈로그 provider ID입니다. 예를 들어 zai provider에는 z-ai를 사용합니다.
passthroughProviderModelboolean슬래시가 포함된 모델 ID를 중첩 provider/model 참조로 취급합니다. OpenRouter 같은 프록시 provider에 유용합니다.
modelIdTransforms"version-dots"[]추가 외부 카탈로그 모델 ID 변형입니다. version-dotsclaude-opus-4.6 같은 점 표기 버전 ID를 시도합니다.

OpenClaw Provider Index

OpenClaw Provider Index는 아직 Plugin이 설치되지 않았을 수 있는 provider를 위한 OpenClaw 소유 미리 보기 메타데이터입니다. 이는 Plugin 매니페스트의 일부가 아닙니다. Plugin 매니페스트는 설치된 Plugin에 대한 권위 있는 기준으로 남습니다. Provider Index는 provider Plugin이 설치되지 않았을 때 향후 설치 가능한 provider 및 설치 전 모델 선택기 화면이 사용할 내부 폴백 계약입니다. 카탈로그 권위 순서:
  1. 사용자 설정.
  2. 설치된 Plugin 매니페스트 modelCatalog.
  3. 명시적 새로 고침의 모델 카탈로그 캐시.
  4. OpenClaw Provider Index 미리 보기 행.
Provider Index에는 비밀, 활성화 상태, 런타임 훅, 실시간 계정별 모델 데이터가 포함되어서는 안 됩니다. 미리 보기 카탈로그는 Plugin 매니페스트와 동일한 modelCatalog provider 행 형태를 사용하지만, api, baseUrl, 가격, 호환성 플래그 같은 런타임 어댑터 필드가 설치된 Plugin 매니페스트와 의도적으로 동기화되어 유지되는 경우가 아니라면 안정적인 표시 메타데이터로 제한해야 합니다. 실시간 /models 탐색이 있는 provider는 일반 목록 조회나 온보딩이 provider API를 호출하게 하는 대신, 명시적 모델 카탈로그 캐시 경로를 통해 새로 고친 행을 작성해야 합니다. Provider Index 항목은 Plugin이 코어 밖으로 이동했거나 아직 설치되지 않은 provider에 대해 설치 가능한 Plugin 메타데이터도 포함할 수 있습니다. 이 메타데이터는 채널 카탈로그 패턴을 반영합니다. 설치 가능한 설정 옵션을 보여 주기에는 패키지 이름, npm 설치 사양, 예상 무결성, 비용이 낮은 인증 선택 레이블이면 충분합니다. Plugin이 설치되면 해당 매니페스트가 우선하며, 그 provider에 대한 Provider Index 항목은 무시됩니다. 레거시 최상위 기능 키는 더 이상 권장되지 않습니다. openclaw doctor --fix를 사용해 speechProviders, realtimeTranscriptionProviders, realtimeVoiceProviders, mediaUnderstandingProviders, imageGenerationProviders, videoGenerationProviders, webFetchProviders, webSearchProviderscontracts 아래로 이동하세요. 일반 매니페스트 로딩은 더 이상 이러한 최상위 필드를 기능 소유권으로 취급하지 않습니다.

매니페스트와 package.json 비교

두 파일은 서로 다른 역할을 합니다.
파일사용 용도
openclaw.plugin.jsonPlugin 코드가 실행되기 전에 존재해야 하는 탐색, 설정 검증, 인증 선택 메타데이터, UI 힌트
package.jsonnpm 메타데이터, 의존성 설치, 엔트리포인트, 설치 게이팅, 설정 또는 카탈로그 메타데이터에 사용되는 openclaw 블록
메타데이터 조각이 어디에 속하는지 확실하지 않다면 다음 규칙을 사용하세요.
  • OpenClaw가 Plugin 코드를 로드하기 전에 알아야 하는 정보라면 openclaw.plugin.json에 넣으세요
  • 패키징, 엔트리 파일 또는 npm 설치 동작에 관한 정보라면 package.json에 넣으세요

탐색에 영향을 주는 package.json 필드

일부 사전 런타임 Plugin 메타데이터는 의도적으로 openclaw.plugin.json 대신 package.jsonopenclaw 블록 아래에 둡니다. openclaw.bundleopenclaw.bundle.json은 OpenClaw Plugin 계약이 아닙니다. 네이티브 Plugin은 openclaw.plugin.json과 아래에서 지원되는 package.json#openclaw 필드를 사용해야 합니다. 중요한 예:
필드의미
openclaw.extensions네이티브 Plugin 엔트리포인트를 선언합니다. Plugin 패키지 디렉터리 안에 있어야 합니다.
openclaw.runtimeExtensions설치된 패키지의 빌드된 JavaScript 런타임 엔트리포인트를 선언합니다. Plugin 패키지 디렉터리 안에 있어야 합니다.
openclaw.setupEntry온보딩, 지연된 채널 시작, 읽기 전용 채널 상태/SecretRef 발견 중에 사용되는 가벼운 설정 전용 엔트리포인트입니다. Plugin 패키지 디렉터리 안에 있어야 합니다.
openclaw.runtimeSetupEntry설치된 패키지의 빌드된 JavaScript 설정 엔트리포인트를 선언합니다. setupEntry가 필요하고, 존재해야 하며, Plugin 패키지 디렉터리 안에 있어야 합니다.
openclaw.channel레이블, 문서 경로, 별칭, 선택 문구 같은 저비용 채널 카탈로그 메타데이터입니다.
openclaw.channel.commands채널 런타임이 로드되기 전에 구성, 감사, 명령 목록 화면에서 사용하는 정적 네이티브 명령 및 네이티브 skill 자동 기본값 메타데이터입니다.
openclaw.channel.configuredState전체 채널 런타임을 로드하지 않고도 “환경 변수 전용 설정이 이미 존재하는가?”에 답할 수 있는 가벼운 구성 상태 검사기 메타데이터입니다.
openclaw.channel.persistedAuthState전체 채널 런타임을 로드하지 않고도 “이미 로그인된 항목이 있는가?”에 답할 수 있는 가벼운 영구 인증 검사기 메타데이터입니다.
openclaw.install.clawhubSpec / openclaw.install.npmSpec / openclaw.install.localPath번들 및 외부 게시 Plugin에 대한 설치/업데이트 힌트입니다.
openclaw.install.defaultChoice여러 설치 소스를 사용할 수 있을 때 선호되는 설치 경로입니다.
openclaw.install.minHostVersion>=2026.3.22 또는 >=2026.5.1-beta.1 같은 semver 하한을 사용하는 최소 지원 OpenClaw 호스트 버전입니다.
openclaw.install.expectedIntegritysha512-... 같은 예상 npm 배포 무결성 문자열입니다. 설치 및 업데이트 흐름은 가져온 아티팩트를 이 값으로 검증합니다.
openclaw.install.allowInvalidConfigRecovery구성이 유효하지 않을 때 좁은 범위의 번들 Plugin 재설치 복구 경로를 허용합니다.
openclaw.startup.deferConfiguredChannelFullLoadUntilAfterListen시작 중 전체 채널 Plugin보다 먼저 설정 전용 채널 화면을 로드할 수 있게 합니다.
매니페스트 메타데이터는 런타임이 로드되기 전에 온보딩에 어떤 제공자/채널/설정 선택지가 나타나는지 결정합니다. package.json#openclaw.install은 사용자가 해당 선택지 중 하나를 고를 때 온보딩이 그 Plugin을 가져오거나 활성화하는 방법을 알려줍니다. 설치 힌트를 openclaw.plugin.json으로 옮기지 마세요. openclaw.install.minHostVersion은 비번들 Plugin 소스의 설치 및 매니페스트 레지스트리 로딩 중에 적용됩니다. 유효하지 않은 값은 거부됩니다. 더 최신이지만 유효한 값은 오래된 호스트에서 외부 Plugin을 건너뜁니다. 번들 소스 Plugin은 호스트 체크아웃과 같은 버전으로 맞춰져 있다고 가정합니다. 공식 온디맨드 설치 메타데이터는 Plugin이 ClawHub에 게시되어 있으면 clawhubSpec을 사용해야 합니다. 온보딩은 이를 선호되는 원격 소스로 취급하고 설치 후 ClawHub 아티팩트 정보를 기록합니다. npmSpec은 아직 ClawHub로 이동하지 않은 패키지를 위한 호환성 폴백으로 남아 있습니다. 정확한 npm 버전 고정은 이미 npmSpec에 있습니다. 예를 들어 "npmSpec": "@wecom/wecom-openclaw-plugin@1.2.3"입니다. 공식 외부 카탈로그 항목은 정확한 사양을 expectedIntegrity와 함께 사용해야 하며, 그래야 가져온 npm 아티팩트가 고정된 릴리스와 더 이상 일치하지 않을 경우 업데이트 흐름이 안전하게 실패합니다. 대화형 온보딩은 호환성을 위해 단순 패키지 이름과 dist-tag를 포함한 신뢰된 레지스트리 npm 사양을 계속 제공합니다. 카탈로그 진단은 정확한 소스, 부동 소스, 무결성 고정 소스, 무결성 누락 소스, 패키지 이름 불일치 소스, 유효하지 않은 기본 선택 소스를 구분할 수 있습니다. 또한 expectedIntegrity가 있지만 이를 고정할 수 있는 유효한 npm 소스가 없을 때 경고합니다. expectedIntegrity가 있으면 설치/업데이트 흐름이 이를 강제합니다. 생략되면 레지스트리 해석 결과가 무결성 고정 없이 기록됩니다. 채널 Plugin은 상태, 채널 목록 또는 SecretRef 스캔이 전체 런타임을 로드하지 않고 구성된 계정을 식별해야 할 때 openclaw.setupEntry를 제공해야 합니다. 설정 엔트리는 채널 메타데이터와 설정에 안전한 구성, 상태, secrets 어댑터를 노출해야 합니다. 네트워크 클라이언트, Gateway 리스너, 전송 런타임은 기본 확장 엔트리포인트에 유지하세요. 런타임 엔트리포인트 필드는 소스 엔트리포인트 필드의 패키지 경계 검사를 재정의하지 않습니다. 예를 들어 openclaw.runtimeExtensions가 경계를 벗어난 openclaw.extensions 경로를 로드 가능하게 만들 수는 없습니다. openclaw.install.allowInvalidConfigRecovery는 의도적으로 범위가 좁습니다. 임의의 손상된 구성을 설치 가능하게 만들지 않습니다. 현재는 누락된 번들 Plugin 경로나 같은 번들 Plugin에 대한 오래된 channels.<id> 항목처럼 특정한 오래된 번들 Plugin 업그레이드 실패에서 설치 흐름이 복구되는 것만 허용합니다. 관련 없는 구성 오류는 여전히 설치를 차단하고 운영자에게 openclaw doctor --fix를 안내합니다. openclaw.channel.persistedAuthState는 작은 검사기 모듈을 위한 패키지 메타데이터입니다.
{
  "openclaw": {
    "channel": {
      "id": "whatsapp",
      "persistedAuthState": {
        "specifier": "./auth-presence",
        "exportName": "hasAnyWhatsAppAuth"
      }
    }
  }
}
설정, doctor, 상태 또는 읽기 전용 존재 확인 흐름이 전체 채널 Plugin을 로드하기 전에 저비용 예/아니요 인증 탐지가 필요할 때 사용하세요. 영구 인증 상태는 구성된 채널 상태가 아닙니다. 이 메타데이터를 Plugin 자동 활성화, 런타임 의존성 복구 또는 채널 런타임 로드 여부 결정에 사용하지 마세요. 대상 export는 영구 상태만 읽는 작은 함수여야 합니다. 전체 채널 런타임 barrel을 거치도록 라우팅하지 마세요. openclaw.channel.configuredState는 저비용 환경 변수 전용 구성 검사를 위해 같은 형태를 따릅니다.
{
  "openclaw": {
    "channel": {
      "id": "telegram",
      "configuredState": {
        "specifier": "./configured-state",
        "exportName": "hasTelegramConfiguredState"
      }
    }
  }
}
채널이 환경 변수나 다른 작은 비런타임 입력만으로 구성 상태에 답할 수 있을 때 사용하세요. 검사가 전체 구성 해석이나 실제 채널 런타임을 필요로 한다면 해당 로직은 대신 Plugin config.hasConfiguredState hook에 유지하세요.

발견 우선순위(중복 Plugin id)

OpenClaw는 여러 루트(번들, 전역 설치, 워크스페이스, 명시적 구성 선택 경로)에서 Plugin을 발견합니다. 두 발견 결과가 같은 id를 공유하면 가장 높은 우선순위의 매니페스트만 유지됩니다. 낮은 우선순위의 중복 항목은 함께 로드되지 않고 삭제됩니다. 우선순위는 높은 순서에서 낮은 순서로 다음과 같습니다.
  1. 구성 선택plugins.entries.<id>에 명시적으로 고정된 경로
  2. 번들 — OpenClaw와 함께 제공되는 Plugin
  3. 전역 설치 — 전역 OpenClaw Plugin 루트에 설치된 Plugin
  4. 워크스페이스 — 현재 워크스페이스를 기준으로 발견된 Plugin
영향:
  • 워크스페이스에 있는 번들 Plugin의 포크 또는 오래된 복사본은 번들 빌드를 가리지 않습니다.
  • 로컬 Plugin으로 번들 Plugin을 실제로 재정의하려면 워크스페이스 발견에 의존하지 말고 plugins.entries.<id>로 고정해 우선순위에서 이기게 하세요.
  • 중복 삭제는 로그에 기록되므로 Doctor와 시작 진단이 버려진 복사본을 가리킬 수 있습니다.
  • 구성 선택 중복 재정의는 진단에서 명시적 재정의로 표현되지만, 오래된 포크와 의도치 않은 가림이 계속 보이도록 여전히 경고합니다.

JSON Schema 요구 사항

  • 모든 Plugin은 JSON Schema를 포함해야 합니다. 구성을 받지 않는 경우에도 마찬가지입니다.
  • 빈 schema도 허용됩니다. 예: { "type": "object", "additionalProperties": false }
  • Schema는 런타임이 아니라 구성 읽기/쓰기 시점에 검증됩니다.
  • 새 구성 키로 번들 Plugin을 확장하거나 포크할 때는 해당 Plugin의 openclaw.plugin.json configSchema도 동시에 업데이트하세요. 번들 Plugin schema는 엄격하므로, configSchema.propertiesmyNewKey를 추가하지 않고 사용자 구성에 plugins.entries.<id>.config.myNewKey를 추가하면 Plugin 런타임이 로드되기 전에 거부됩니다.
Schema 확장 예:
{
  "configSchema": {
    "type": "object",
    "additionalProperties": false,
    "properties": {
      "myNewKey": {
        "type": "string"
      }
    }
  }
}

검증 동작

  • 알 수 없는 channels.* 키는 채널 id가 Plugin 매니페스트에 선언되어 있지 않는 한 오류입니다.
  • plugins.entries.<id>, plugins.allow, plugins.deny, plugins.slots.*발견 가능한 Plugin id를 참조해야 합니다. 알 수 없는 id는 오류입니다.
  • Plugin이 설치되어 있지만 매니페스트나 schema가 손상되었거나 누락된 경우 검증이 실패하고 Doctor가 Plugin 오류를 보고합니다.
  • Plugin 구성이 존재하지만 Plugin이 비활성화되어 있으면 구성은 유지되고 Doctor와 로그에 경고가 표시됩니다.
전체 plugins.* schema는 구성 참조를 참조하세요.

참고

  • 매니페스트는 로컬 파일시스템 로드를 포함한 네이티브 OpenClaw Plugin에 필수입니다. 런타임은 여전히 Plugin 모듈을 별도로 로드하며, 매니페스트는 검색 + 검증에만 사용됩니다.
  • 네이티브 매니페스트는 JSON5로 파싱되므로 최종 값이 여전히 객체인 한 주석, 후행 쉼표, 따옴표 없는 키를 사용할 수 있습니다.
  • 매니페스트 로더는 문서화된 매니페스트 필드만 읽습니다. 사용자 지정 최상위 키는 피하세요.
  • Plugin에 필요하지 않은 경우 channels, providers, cliBackends, skills는 모두 생략할 수 있습니다.
  • providerCatalogEntry는 가볍게 유지해야 하며 광범위한 런타임 코드를 가져오면 안 됩니다. 요청 시점 실행이 아니라 정적 공급자 카탈로그 메타데이터나 좁은 검색 설명자에 사용하세요. providerDiscoveryEntry는 레거시 표기이며 기존 Plugin에서는 계속 작동합니다.
  • 배타적 Plugin 종류는 plugins.slots.*를 통해 선택됩니다. plugins.slots.memory를 통한 kind: "memory", plugins.slots.contextEngine을 통한 kind: "context-engine"(기본값 legacy)입니다.
  • 이 매니페스트에서 배타적 Plugin 종류를 선언하세요. 런타임 진입점 OpenClawPluginDefinition.kind는 더 이상 권장되지 않으며 이전 Plugin과의 호환성 대체 수단으로만 남아 있습니다.
  • 환경 변수 메타데이터(setup.providers[].envVars, 더 이상 권장되지 않는 providerAuthEnvVars, channelEnvVars)는 선언용일 뿐입니다. 상태, 감사, Cron 전달 검증 및 기타 읽기 전용 표면은 환경 변수를 구성된 것으로 취급하기 전에 여전히 Plugin 신뢰와 유효 활성화 정책을 적용합니다.
  • 공급자 코드가 필요한 런타임 마법사 메타데이터는 공급자 런타임 훅을 참조하세요.
  • Plugin이 네이티브 모듈에 의존하는 경우 빌드 단계와 패키지 관리자 허용 목록 요구 사항(예: pnpm allow-build-scripts + pnpm rebuild <package>)을 문서화하세요.

관련 항목

Plugin 빌드하기

Plugin 시작하기.

Plugin 아키텍처

내부 아키텍처 및 기능 모델.

SDK 개요

Plugin SDK 참조 및 하위 경로 가져오기.