package.json को रनटाइम लोडिंग को बने हुए
JavaScript की ओर इंगित करना चाहिए:
extensions और setupEntry workspace और git
checkout विकास के लिए वैध स्रोत एंट्री बने रहते हैं। जब OpenClaw कोई इंस्टॉल किया गया पैकेज लोड करता है, तब runtimeExtensions और runtimeSetupEntry को प्राथमिकता दी जाती है
और npm पैकेजों को रनटाइम
TypeScript compilation से बचने देते हैं। स्पष्ट रनटाइम एंट्री आवश्यक हैं: runtimeSetupEntry
के लिए setupEntry आवश्यक है, और गायब runtimeExtensions या runtimeSetupEntry
artifacts स्रोत पर चुपचाप वापस जाने के बजाय install/discovery में विफल होते हैं। यदि
कोई इंस्टॉल किया गया पैकेज केवल TypeScript स्रोत एंट्री घोषित करता है, तो OpenClaw
मिलान करने वाले बने हुए dist/*.js peer का उपयोग करेगा, जब वह मौजूद हो, फिर TypeScript
स्रोत पर वापस जाएगा।
सभी एंट्री paths को plugin पैकेज directory के अंदर ही रहना चाहिए। रनटाइम एंट्री
और अनुमानित बने हुए JavaScript peers किसी बाहर निकलने वाले extensions या
setupEntry स्रोत path को वैध नहीं बनाते।
defineToolPlugin
Import: openclaw/plugin-sdk/tool-plugin
सरल plugins के लिए जो केवल agent tools जोड़ते हैं। defineToolPlugin
authoring source को छोटा रखता है, TypeBox schemas से config और tool parameter types का अनुमान लगाता है, साधारण return values को OpenClaw tool-result format में wrap करता है, और
static metadata expose करता है जिसे openclaw plugins build plugin
manifest में लिखता है।
configSchemaवैकल्पिक है। छोड़े जाने पर, OpenClaw strict empty object schema का उपयोग करता है और generated manifest में फिर भीconfigSchemaशामिल होता है।executeसाधारण string या JSON-serializable value लौटाता है। helper इसेdetailsके साथ text tool result के रूप में wrap करता है।- Tool names static होते हैं।
openclaw plugins buildघोषित tools सेcontracts.toolsनिकालता है, इसलिए authors को names हाथ से duplicate नहीं करने पड़ते। - Runtime loading strict रहती है। इंस्टॉल किए गए plugins को अभी भी
openclaw.plugin.jsonऔरpackage.jsonopenclaw.extensionsचाहिए; OpenClaw गायब manifest data का अनुमान लगाने के लिए plugin code execute नहीं करता।
definePluginEntry
Import: openclaw/plugin-sdk/plugin-entry
Provider plugins, advanced tool plugins, hook plugins, और ऐसी किसी भी चीज़ के लिए जो
messaging channel नहीं है।
| फ़ील्ड | प्रकार | आवश्यक | डिफ़ॉल्ट |
|---|---|---|---|
id | string | हाँ | - |
name | string | हाँ | - |
description | string | हाँ | - |
kind | string | नहीं | - |
configSchema | OpenClawPluginConfigSchema | () => OpenClawPluginConfigSchema | नहीं | Empty object schema |
register | (api: OpenClawPluginApi) => void | हाँ | - |
idको आपकेopenclaw.plugin.jsonmanifest से मेल खाना चाहिए।kindexclusive slots के लिए है:"memory"या"context-engine"।configSchemalazy evaluation के लिए function हो सकता है।- OpenClaw पहली access पर उस schema को resolve और memoize करता है, इसलिए महंगे schema builders केवल एक बार चलते हैं।
defineChannelPluginEntry
Import: openclaw/plugin-sdk/channel-core
definePluginEntry को channel-specific wiring के साथ wrap करता है। अपने-आप
api.registerChannel({ plugin }) call करता है, वैकल्पिक root-help CLI metadata
seam expose करता है, और registerFull को registration mode पर gate करता है।
| फ़ील्ड | प्रकार | आवश्यक | डिफ़ॉल्ट |
|---|---|---|---|
id | string | हाँ | - |
name | string | हाँ | - |
description | string | हाँ | - |
plugin | ChannelPlugin | हाँ | - |
configSchema | OpenClawPluginConfigSchema | () => OpenClawPluginConfigSchema | नहीं | Empty object schema |
setRuntime | (runtime: PluginRuntime) => void | नहीं | - |
registerCliMetadata | (api: OpenClawPluginApi) => void | नहीं | - |
registerFull | (api: OpenClawPluginApi) => void | नहीं | - |
setRuntimeregistration के दौरान call किया जाता है ताकि आप runtime reference store कर सकें (आमतौर परcreatePluginRuntimeStoreके जरिए)। CLI metadata capture के दौरान इसे skip किया जाता है।registerCliMetadataapi.registrationMode === "cli-metadata",api.registrationMode === "discovery", औरapi.registrationMode === "full"के दौरान चलता है। इसे channel-owned CLI descriptors के canonical स्थान के रूप में उपयोग करें, ताकि root help non-activating रहे, discovery snapshots में static command metadata शामिल हो, और normal CLI command registration full plugin loads के साथ compatible रहे।- Discovery registration non-activating है, import-free नहीं। OpenClaw
snapshot बनाने के लिए trusted plugin entry और channel plugin module evaluate कर सकता है,
इसलिए top-level imports को side-effect-free रखें और sockets,
clients, workers, और services को
"full"-only paths के पीछे रखें। registerFullकेवल तब चलता है जबapi.registrationMode === "full"। setup-only loading के दौरान इसे skip किया जाता है।definePluginEntryकी तरह,configSchemalazy factory हो सकता है और OpenClaw पहली access पर resolved schema को memoize करता है।- Plugin-owned root CLI commands के लिए, जब आप चाहते हैं कि command root CLI parse tree से गायब हुए बिना lazy-loaded रहे, तो
api.registerCli(..., { descriptors: [...] })को प्राथमिकता दें। paired-node feature commands के लिए,api.registerNodeCliFeature(...)को प्राथमिकता दें ताकि commandopenclaw nodesके नीचे आए। अन्य nested plugin commands के लिए,parentPathजोड़ें और registrar को दिए गएprogramobject पर commands register करें; OpenClaw plugin को call करने से पहले इसे parent command में resolve करता है। channel plugins के लिए, उन descriptors कोregisterCliMetadata(...)से register करना पसंद करें औरregisterFull(...)को runtime-only work पर केंद्रित रखें। - यदि
registerFull(...)gateway RPC methods भी register करता है, तो उन्हें plugin-specific prefix पर रखें। Reserved core admin namespaces (config.*,exec.approvals.*,wizard.*,update.*) हमेशाoperator.adminमें coerced किए जाते हैं।
defineSetupPluginEntry
Import: openclaw/plugin-sdk/channel-core
हल्की setup-entry.ts file के लिए। बिना runtime या CLI wiring के केवल { plugin }
लौटाता है।
defineSetupPluginEntry(...) को संकीर्ण setup helper
families के साथ pair करें:
- runtime-safe setup helpers जैसे
createSetupTranslator, import-safe setup patch adapters, lookup-note output,promptResolvedAllowFrom,splitSetupEntries, और delegated setup proxies के लिएopenclaw/plugin-sdk/setup-runtime - optional-install setup surfaces के लिए
openclaw/plugin-sdk/channel-setup - setup/install CLI/archive/docs helpers के लिए
openclaw/plugin-sdk/setup-tools
openclaw/plugin-sdk/channel-entry-contract से
defineBundledChannelSetupEntry(...) का उपयोग कर सकते हैं। वह contract
setup entry को setup-safe plugin/secrets exports रखने देता है, जबकि फिर भी
runtime setter expose करता है:
registerSetupRuntime केवल "setup-runtime" loads के लिए चलता है; इसे
config-only routes या उन methods तक सीमित रखें जिन्हें deferred full activation से पहले मौजूद होना चाहिए।
Registration mode
api.registrationMode आपके plugin को बताता है कि उसे कैसे load किया गया था:
| मोड | कब | क्या रजिस्टर करना है |
|---|---|---|
"full" | सामान्य Gateway स्टार्टअप | सब कुछ |
"discovery" | रीड-ओनली क्षमता खोज | चैनल रजिस्ट्रेशन और स्थिर CLI डिस्क्रिप्टर; एंट्री कोड लोड हो सकता है, लेकिन सॉकेट, वर्कर, क्लाइंट और सेवाएं छोड़ें |
"setup-only" | अक्षम/अकॉन्फ़िगर किया गया चैनल | केवल चैनल रजिस्ट्रेशन |
"setup-runtime" | रनटाइम उपलब्ध होने वाला सेटअप फ़्लो | चैनल रजिस्ट्रेशन और पूर्ण एंट्री लोड होने से पहले आवश्यक केवल हल्का रनटाइम |
"cli-metadata" | रूट सहायता / CLI मेटाडेटा कैप्चर | केवल CLI डिस्क्रिप्टर |
defineChannelPluginEntry इस विभाजन को अपने-आप संभालता है। यदि आप किसी चैनल के लिए
सीधे definePluginEntry का उपयोग करते हैं, तो मोड खुद जांचें:
"setup-runtime" को वह विंडो मानें जहां सेटअप-ओनली स्टार्टअप सरफ़ेस
पूर्ण बंडल किए गए चैनल रनटाइम में दोबारा प्रवेश किए बिना मौजूद होने चाहिए। अच्छे विकल्प हैं
चैनल रजिस्ट्रेशन, सेटअप-सुरक्षित HTTP रूट, सेटअप-सुरक्षित Gateway मेथड और
डेलीगेट किए गए सेटअप हेल्पर। भारी बैकग्राउंड सेवाएं, CLI रजिस्ट्रार और
प्रोवाइडर/क्लाइंट SDK बूटस्ट्रैप अब भी "full" में ही आते हैं।
CLI रजिस्ट्रार के लिए विशेष रूप से:
- जब रजिस्ट्रार एक या अधिक रूट कमांड का स्वामी हो और आप चाहते हों कि
OpenClaw पहली बार चलाने पर असली CLI मॉड्यूल को लेज़ी-लोड करे, तब
descriptorsका उपयोग करें - सुनिश्चित करें कि वे डिस्क्रिप्टर रजिस्ट्रार द्वारा उजागर किए गए हर टॉप-लेवल कमांड रूट को कवर करते हों
- डिस्क्रिप्टर कमांड नामों को अक्षरों, संख्याओं, हाइफ़न और अंडरस्कोर तक सीमित रखें, और उन्हें किसी अक्षर या संख्या से शुरू करें; OpenClaw इस आकार से बाहर के डिस्क्रिप्टर नामों को अस्वीकार करता है और सहायता रेंडर करने से पहले विवरणों से टर्मिनल कंट्रोल सीक्वेंस हटा देता है
- केवल उत्सुक संगतता पाथ के लिए ही
commandsअकेले उपयोग करें
Plugin आकार
OpenClaw लोड किए गए plugins को उनके रजिस्ट्रेशन व्यवहार के आधार पर वर्गीकृत करता है:| आकार | विवरण |
|---|---|
| plain-capability | एक क्षमता प्रकार (जैसे केवल-प्रोवाइडर) |
| hybrid-capability | कई क्षमता प्रकार (जैसे प्रोवाइडर + स्पीच) |
| hook-only | केवल हुक, कोई क्षमताएं नहीं |
| non-capability | टूल/कमांड/सेवाएं, लेकिन कोई क्षमताएं नहीं |
openclaw plugins inspect <id> का उपयोग करें।
संबंधित
- SDK अवलोकन - रजिस्ट्रेशन API और सबपाथ संदर्भ
- रनटाइम हेल्पर -
api.runtimeऔरcreatePluginRuntimeStore - सेटअप और कॉन्फ़िग - मैनिफ़ेस्ट, सेटअप एंट्री, स्थगित लोडिंग
- चैनल Plugins -
ChannelPluginऑब्जेक्ट बनाना - प्रोवाइडर Plugins - प्रोवाइडर रजिस्ट्रेशन और हुक