Plugin SDK reference
Plugin kurulumu ve yapılandırması
Plugin paketleme (package.json meta verileri), manifestler (openclaw.plugin.json), kurulum girişleri ve yapılandırma şemaları için başvuru.
Paket meta verileri
package.json dosyanızda, Plugin sistemine Plugin'inizin ne sağladığını bildiren bir openclaw alanı gerekir:
Kanal Plugin'i
{ "name": "@myorg/openclaw-my-channel", "version": "1.0.0", "type": "module", "openclaw": { "extensions": ["./index.ts"], "setupEntry": "./setup-entry.ts", "channel": { "id": "my-channel", "label": "My Channel", "blurb": "Short description of the channel." } }}Sağlayıcı Plugin'i / ClawHub taban çizgisi
{ "name": "@myorg/openclaw-my-plugin", "version": "1.0.0", "type": "module", "openclaw": { "extensions": ["./index.ts"], "compat": { "pluginApi": ">=2026.3.24-beta.2", "minGatewayVersion": "2026.3.24-beta.2" }, "build": { "openclawVersion": "2026.3.24-beta.2", "pluginSdkVersion": "2026.3.24-beta.2" } }}openclaw alanları
extensionsstring[]Giriş noktası dosyaları (paket köküne göreli).
setupEntrystringHafif, yalnızca kurulum amaçlı giriş (isteğe bağlı).
channelobjectKurulum, seçici, hızlı başlangıç ve durum yüzeyleri için kanal katalog meta verileri.
providersstring[]Bu Plugin tarafından kaydedilen sağlayıcı kimlikleri.
installobjectKurulum ipuçları: npmSpec, localPath, defaultChoice, minHostVersion, expectedIntegrity, allowInvalidConfigRecovery.
startupobjectBaşlatma davranışı bayrakları.
openclaw.channel
openclaw.channel, çalışma zamanı yüklenmeden önce kanal keşfi ve kurulum yüzeyleri için düşük maliyetli paket meta verisidir.
| Alan | Tür | Anlamı |
|---|---|---|
id |
string |
Standart kanal kimliği. |
label |
string |
Birincil kanal etiketi. |
selectionLabel |
string |
label değerinden farklı olması gerektiğinde seçici/kurulum etiketi. |
detailLabel |
string |
Daha zengin kanal katalogları ve durum yüzeyleri için ikincil ayrıntı etiketi. |
docsPath |
string |
Kurulum ve seçim bağlantıları için dokümantasyon yolu. |
docsLabel |
string |
Kanal kimliğinden farklı olması gerektiğinde dokümantasyon bağlantıları için kullanılan geçersiz kılma etiketi. |
blurb |
string |
Kısa ilk kullanım/katalog açıklaması. |
order |
number |
Kanal kataloglarındaki sıralama düzeni. |
aliases |
string[] |
Kanal seçimi için ek arama takma adları. |
preferOver |
string[] |
Bu kanalın önüne geçmesi gereken daha düşük öncelikli Plugin/kanal kimlikleri. |
systemImage |
string |
Kanal UI katalogları için isteğe bağlı simge/sistem görseli adı. |
selectionDocsPrefix |
string |
Seçim yüzeylerinde dokümantasyon bağlantılarından önceki önek metni. |
selectionDocsOmitLabel |
boolean |
Seçim metninde etiketli dokümantasyon bağlantısı yerine dokümantasyon yolunu doğrudan gösterir. |
selectionExtras |
string[] |
Seçim metnine eklenen ek kısa dizeler. |
markdownCapable |
boolean |
Giden biçimlendirme kararları için kanalı Markdown uyumlu olarak işaretler. |
exposure |
object |
Kurulum, yapılandırılmış listeler ve dokümantasyon yüzeyleri için kanal görünürlük kontrolleri. |
quickstartAllowFrom |
boolean |
Bu kanalı standart hızlı başlangıç allowFrom kurulum akışına dahil eder. |
forceAccountBinding |
boolean |
Yalnızca bir hesap olsa bile açık hesap bağlamayı zorunlu kılar. |
preferSessionLookupForAnnounceTarget |
boolean |
Bu kanal için duyuru hedeflerini çözerken oturum aramasını tercih eder. |
Örnek:
{ "openclaw": { "channel": { "id": "my-channel", "label": "My Channel", "selectionLabel": "My Channel (self-hosted)", "detailLabel": "My Channel Bot", "docsPath": "/channels/my-channel", "docsLabel": "my-channel", "blurb": "Webhook-based self-hosted chat integration.", "order": 80, "aliases": ["mc"], "preferOver": ["my-channel-legacy"], "selectionDocsPrefix": "Guide:", "selectionExtras": ["Markdown"], "markdownCapable": true, "exposure": { "configured": true, "setup": true, "docs": true }, "quickstartAllowFrom": true } }}exposure şunları destekler:
configured: kanalı yapılandırılmış/durum tarzı listeleme yüzeylerine dahil etsetup: kanalı etkileşimli kurulum/yapılandırma seçicilerine dahil etdocs: kanalı dokümantasyon/gezinme yüzeylerinde herkese açık olarak işaretle
openclaw.install
openclaw.install paket meta verisidir, manifest meta verisi değildir.
| Alan | Tür | Anlamı |
|---|---|---|
clawhubSpec |
string |
Kurulum/güncelleme ve ilk kullanımda isteğe bağlı kurulum akışları için standart ClawHub belirtimi. |
npmSpec |
string |
Kurulum/güncelleme yedek akışları için standart npm belirtimi. |
localPath |
string |
Yerel geliştirme veya paketlenmiş kurulum yolu. |
defaultChoice |
"clawhub" | "npm" | "local" |
Birden fazla kaynak mevcut olduğunda tercih edilen kurulum kaynağı. |
minHostVersion |
string |
>=x.y.z veya >=x.y.z-prerelease biçimindeki desteklenen minimum OpenClaw sürümü. |
expectedIntegrity |
string |
Sabitlenmiş kurulumlar için beklenen npm dağıtım bütünlük dizesi; genellikle sha512-.... |
allowInvalidConfigRecovery |
boolean |
Paketlenmiş Plugin yeniden kurulum akışlarının belirli eski yapılandırma hatalarından kurtulmasına izin verir. |
İlk kullanım davranışı
Etkileşimli ilk kullanım da isteğe bağlı kurulum yüzeyleri için openclaw.install kullanır. Plugin'iniz çalışma zamanı yüklenmeden önce sağlayıcı kimlik doğrulama seçenekleri veya kanal kurulum/katalog meta verileri sunuyorsa, ilk kullanım bu seçeneği gösterebilir, ClawHub, npm veya yerel kurulum için istemde bulunabilir, Plugin'i kurabilir veya etkinleştirebilir ve ardından seçilen akışa devam edebilir. ClawHub ilk kullanım seçenekleri clawhubSpec kullanır ve mevcut olduğunda tercih edilir; npm seçenekleri, kayıt defteri npmSpec içeren güvenilir katalog meta verileri gerektirir; kesin sürümler ve expectedIntegrity isteğe bağlı npm sabitlemeleridir. expectedIntegrity mevcutsa, kurulum/güncelleme akışları bunu npm için zorunlu kılar. "Ne gösterilecek" meta verilerini openclaw.plugin.json içinde, "nasıl kurulacak" meta verilerini ise package.json içinde tutun.
minHostVersion zorunlu kılma
minHostVersion ayarlanmışsa, hem kurulum hem de paketlenmemiş manifest kayıt defteri yükleme bunu zorunlu kılar. Eski ana makineler harici Plugin'leri atlar; geçersiz sürüm dizeleri reddedilir. Paketlenmiş kaynak Plugin'lerin ana makine çalışma kopyasıyla aynı sürümde olduğu varsayılır.
Sabitlenmiş npm kurulumları
Sabitlenmiş npm kurulumları için kesin sürümü npmSpec içinde tutun ve beklenen yapıt bütünlüğünü ekleyin:
{ "openclaw": { "install": { "npmSpec": "@wecom/[email protected]", "expectedIntegrity": "sha512-REPLACE_WITH_NPM_DIST_INTEGRITY", "defaultChoice": "npm" } }}allowInvalidConfigRecovery kapsamı
allowInvalidConfigRecovery, bozuk yapılandırmalar için genel bir baypas değildir. Yalnızca dar kapsamlı paketlenmiş Plugin kurtarması içindir; böylece yeniden kurulum/kurulum, eksik paketlenmiş Plugin yolu veya aynı Plugin için eski channels.<id> girdisi gibi bilinen yükseltme artıklarını onarabilir. Yapılandırma ilgisiz nedenlerle bozuksa, kurulum yine kapalı başarısız olur ve operatöre openclaw doctor --fix çalıştırmasını söyler.
Ertelenmiş tam yükleme
Kanal Plugin'leri şu şekilde ertelenmiş yüklemeye dahil olabilir:
{ "openclaw": { "extensions": ["./index.ts"], "setupEntry": "./setup-entry.ts", "startup": { "deferConfiguredChannelFullLoadUntilAfterListen": true } }}Etkinleştirildiğinde OpenClaw, ön dinleme başlatma aşamasında, zaten yapılandırılmış kanallar için bile yalnızca setupEntry yükler. Tam giriş, gateway dinlemeye başladıktan sonra yüklenir.
Kurulum/tam girişiniz gateway RPC yöntemleri kaydediyorsa, bunları Plugin'e özgü bir önekte tutun. Ayrılmış çekirdek yönetici ad alanları (config.*, exec.approvals.*, wizard.*, update.*) çekirdeğe ait kalır ve her zaman operator.admin olarak çözümlenir.
Plugin manifesti
Her yerel Plugin, paket kökünde bir openclaw.plugin.json ile gelmelidir. OpenClaw bunu, Plugin kodunu çalıştırmadan yapılandırmayı doğrulamak için kullanır.
{ "id": "my-plugin", "name": "My Plugin", "description": "Adds My Plugin capabilities to OpenClaw", "configSchema": { "type": "object", "additionalProperties": false, "properties": { "webhookSecret": { "type": "string", "description": "Webhook verification secret" } } }}Kanal Plugin'leri için kind ve channels ekleyin:
{ "id": "my-channel", "kind": "channel", "channels": ["my-channel"], "configSchema": { "type": "object", "additionalProperties": false, "properties": {} }}Yapılandırması olmayan Plugin'ler bile bir şema ile gelmelidir. Boş bir şema geçerlidir:
{ "id": "my-plugin", "configSchema": { "type": "object", "additionalProperties": false }}Tam şema başvurusu için Plugin manifesti bölümüne bakın.
ClawHub yayımlama
Plugin paketleri için pakete özgü ClawHub komutunu kullanın:
clawhub package publish your-org/your-plugin --dry-runclawhub package publish your-org/your-pluginKurulum girişi
setup-entry.ts dosyası, OpenClaw yalnızca kurulum yüzeylerine ihtiyaç duyduğunda (ilk katılım, yapılandırma onarımı, devre dışı kanal incelemesi) yüklediği index.ts dosyasına hafif bir alternatiftir.
// setup-entry.ts export default defineSetupPluginEntry(myChannelPlugin);Bu, kurulum akışları sırasında ağır çalışma zamanı kodunun (kripto kitaplıkları, CLI kayıtları, arka plan servisleri) yüklenmesini önler.
Kurulum için güvenli dışa aktarımları yan modüllerde tutan paketlenmiş çalışma alanı kanalları, defineSetupPluginEntry(...) yerine openclaw/plugin-sdk/channel-entry-contract içindeki defineBundledChannelSetupEntry(...) işlevini kullanabilir. Bu paketlenmiş sözleşme, kurulum zamanı çalışma zamanı bağlantısının hafif ve açık kalabilmesi için isteğe bağlı bir runtime dışa aktarımını da destekler.
OpenClaw setupEntry'yi tam giriş yerine ne zaman kullanır
- Kanal devre dışıdır ama kurulum/ilk katılım yüzeylerine ihtiyaç duyar.
- Kanal etkindir ama yapılandırılmamıştır.
- Ertelenmiş yükleme etkindir (
deferConfiguredChannelFullLoadUntilAfterListen).
setupEntry ne kaydetmelidir
- Kanal Plugin nesnesi (
defineSetupPluginEntryaracılığıyla). - Gateway dinlemeden önce gereken tüm HTTP rotaları.
- Başlangıç sırasında gereken tüm Gateway yöntemleri.
Bu başlangıç Gateway yöntemleri yine de config.* veya update.* gibi ayrılmış çekirdek yönetim ad alanlarından kaçınmalıdır.
setupEntry neleri içermemelidir
- CLI kayıtları.
- Arka plan servisleri.
- Ağır çalışma zamanı içe aktarımları (kripto, SDK'ler).
- Yalnızca başlangıçtan sonra gereken Gateway yöntemleri.
Dar kurulum yardımcısı içe aktarımları
Sıcak yalnızca kurulum yollarında, kurulum yüzeyinin yalnızca bir bölümüne ihtiyaç duyduğunuzda daha geniş plugin-sdk/setup şemsiyesi yerine dar kurulum yardımcısı bağlantılarını tercih edin:
| İçe aktarma yolu | Bunun için kullanın | Ana dışa aktarımlar |
|---|---|---|
plugin-sdk/setup-runtime |
setupEntry / ertelenmiş kanal başlangıcında kullanılabilir kalan kurulum zamanı çalışma zamanı yardımcıları |
createPatchedAccountSetupAdapter, createEnvPatchedAccountSetupAdapter, createSetupInputPresenceValidator, noteChannelLookupFailure, noteChannelLookupSummary, promptResolvedAllowFrom, splitSetupEntries, createAllowlistSetupWizardProxy, createDelegatedSetupWizardProxy |
plugin-sdk/setup-adapter-runtime |
kullanımdan kaldırılmış uyumluluk takma adı; plugin-sdk/setup-runtime kullanın |
createEnvPatchedAccountSetupAdapter |
plugin-sdk/setup-tools |
kurulum/yükleme CLI/arşiv/dokümantasyon yardımcıları | formatCliCommand, detectBinary, extractArchive, resolveBrewExecutable, formatDocsLink, CONFIG_DIR |
moveSingleAccountChannelSectionToDefaultAccount(...) gibi yapılandırma yaması yardımcıları dahil, tam paylaşılan kurulum araç kutusunu istediğinizde daha geniş plugin-sdk/setup bağlantısını kullanın.
Kurulum yama adaptörleri içe aktarımda sıcak yol için güvenli kalır. Paketlenmiş tek hesap yükseltme sözleşme yüzeyi araması tembeldir; bu yüzden plugin-sdk/setup-runtime içe aktarımı, adaptör gerçekten kullanılmadan önce paketlenmiş sözleşme yüzeyi keşfini istekli biçimde yüklemez.
Kanalın sahip olduğu tek hesap yükseltmesi
Bir kanal, tek hesaplı üst düzey yapılandırmadan channels.<id>.accounts.* yapısına yükselttiğinde, varsayılan paylaşılan davranış yükseltilen hesap kapsamlı değerleri accounts.default içine taşımaktır.
Paketlenmiş kanallar, kurulum sözleşme yüzeyleri aracılığıyla bu yükseltmeyi daraltabilir veya geçersiz kılabilir:
singleAccountKeysToMove: yükseltilen hesaba taşınması gereken ek üst düzey anahtarlarnamedAccountPromotionKeys: adlandırılmış hesaplar zaten mevcut olduğunda, yalnızca bu anahtarlar yükseltilen hesaba taşınır; paylaşılan ilke/teslimat anahtarları kanal kökünde kalırresolveSingleAccountPromotionTarget(...): yükseltilen değerleri hangi mevcut hesabın alacağını seçin
Yapılandırma şeması
Plugin yapılandırması, manifestinizdeki JSON Schema'ya göre doğrulanır. Kullanıcılar Plugin'leri şu şekilde yapılandırır:
{ plugins: { entries: { "my-plugin": { config: { webhookSecret: "abc123", }, }, }, },}Plugin'iniz bu yapılandırmayı kayıt sırasında api.pluginConfig olarak alır.
Kanala özgü yapılandırma için bunun yerine kanal yapılandırma bölümünü kullanın:
{ channels: { "my-channel": { token: "bot-token", allowFrom: ["user1", "user2"], }, },}Kanal yapılandırma şemaları oluşturma
Bir Zod şemasını Plugin'e ait yapılandırma yapıları tarafından kullanılan ChannelConfigSchema sarmalayıcısına dönüştürmek için buildChannelConfigSchema kullanın:
const accountSchema = z.object({ token: z.string().optional(), allowFrom: z.array(z.string()).optional(), accounts: z.object({}).catchall(z.any()).optional(), defaultAccount: z.string().optional(),}); const configSchema = buildChannelConfigSchema(accountSchema);Sözleşmeyi zaten JSON Schema veya TypeBox olarak yazıyorsanız, OpenClaw'ın meta veri yollarında Zod'dan JSON Schema'ya dönüştürmeyi atlayabilmesi için doğrudan yardımcıyı kullanın:
const configSchema = buildJsonChannelConfigSchema( Type.Object({ token: Type.Optional(Type.String()), allowFrom: Type.Optional(Type.Array(Type.String())), }),);Üçüncü taraf Plugin'ler için soğuk yol sözleşmesi hâlâ Plugin manifestidir: oluşturulan JSON Schema'yı openclaw.plugin.json#channelConfigs içine yansıtın; böylece yapılandırma şeması, kurulum ve UI yüzeyleri çalışma zamanı kodunu yüklemeden channels.<id> öğesini inceleyebilir.
Kurulum sihirbazları
Kanal Plugin'leri openclaw onboard için etkileşimli kurulum sihirbazları sağlayabilir. Sihirbaz, ChannelPlugin üzerinde bir ChannelSetupWizard nesnesidir:
const setupWizard: ChannelSetupWizard = { channel: "my-channel", status: { configuredLabel: "Connected", unconfiguredLabel: "Not configured", resolveConfigured: ({ cfg }) => Boolean((cfg.channels as any)?.["my-channel"]?.token), }, credentials: [ { inputKey: "token", providerHint: "my-channel", credentialLabel: "Bot token", preferredEnvVar: "MY_CHANNEL_BOT_TOKEN", envPrompt: "Use MY_CHANNEL_BOT_TOKEN from environment?", keepPrompt: "Keep current token?", inputPrompt: "Enter your bot token:", inspect: ({ cfg, accountId }) => { const token = (cfg.channels as any)?.["my-channel"]?.token; return { accountConfigured: Boolean(token), hasConfiguredValue: Boolean(token), }; }, }, ],};ChannelSetupWizard türü credentials, textInputs, dmPolicy, allowFrom, groupAccess, prepare, finalize ve daha fazlasını destekler. Tam örnekler için paketlenmiş Plugin paketlerine bakın (örneğin Discord Plugin'i src/channel.setup.ts).
Paylaşılan allowFrom istemleri
Yalnızca standart note -> prompt -> parse -> merge -> patch akışına ihtiyaç duyan DM izin listesi istemleri için, openclaw/plugin-sdk/setup içindeki paylaşılan kurulum yardımcılarını tercih edin: createPromptParsedAllowFromForAccount(...), createTopLevelChannelParsedAllowFromPrompt(...) ve createNestedChannelParsedAllowFromPrompt(...).
Standart kanal kurulum durumu
Yalnızca etiketlere, puanlara ve isteğe bağlı ek satırlara göre değişen kanal kurulum durumu blokları için, her Plugin'de aynı status nesnesini elle oluşturmak yerine openclaw/plugin-sdk/setup içindeki createStandardChannelSetupStatus(...) işlevini tercih edin.
İsteğe bağlı kanal kurulum yüzeyi
Yalnızca belirli bağlamlarda görünmesi gereken isteğe bağlı kurulum yüzeyleri için openclaw/plugin-sdk/channel-setup içindeki createOptionalChannelSetupSurface kullanın:
import { createOptionalChannelSetupSurface } from "openclaw/plugin-sdk/channel-setup"; const setupSurface = createOptionalChannelSetupSurface({ channel: "my-channel", label: "My Channel", npmSpec: "@myorg/openclaw-my-channel", docsPath: "/channels/my-channel",});// Returns { setupAdapter, setupWizard }plugin-sdk/channel-setup, bu isteğe bağlı yükleme yüzeyinin yalnızca bir yarısına ihtiyaç duyduğunuzda daha düşük düzeyli createOptionalChannelSetupAdapter(...) ve createOptionalChannelSetupWizard(...) oluşturucularını da sunar.
Oluşturulan isteğe bağlı adaptör/sihirbaz, gerçek yapılandırma yazımlarında kapalı başarısız olur. validateInput, applyAccountConfig ve finalize boyunca tek bir yükleme gerekli mesajını yeniden kullanırlar ve docsPath ayarlandığında bir dokümantasyon bağlantısı eklerler.
İkili dosya destekli kurulum yardımcıları
İkili dosya destekli kurulum UI'ları için, aynı ikili dosya/durum bağlantısını her kanala kopyalamak yerine paylaşılan yetkilendirilmiş yardımcıları tercih edin:
- Yalnızca etiketlere, ipuçlarına, puanlara ve ikili dosya algılamasına göre değişen durum blokları için
createDetectedBinaryStatus(...) - Yol destekli metin girdileri için
createCliPathTextInput(...) setupEntrydaha ağır bir tam sihirbaza tembel olarak iletmek zorunda olduğundacreateDelegatedSetupWizardStatusResolvers(...),createDelegatedPrepare(...),createDelegatedFinalize(...)vecreateDelegatedResolveConfigured(...)setupEntryyalnızca birtextInputs[*].shouldPromptkararını yetkilendirmek zorunda olduğundacreateDelegatedTextInputShouldPrompt(...)
Yayımlama ve yükleme
Harici Plugin'ler: ClawHub üzerinde yayımlayın, ardından yükleyin:
npm
openclaw plugins install @myorg/openclaw-my-pluginYalın paket belirtimleri, başlatma geçişi sırasında npm üzerinden yüklenir.
Yalnızca ClawHub
openclaw plugins install clawhub:@myorg/openclaw-my-pluginnpm paket belirtimi
Bir paket henüz ClawHub'a taşınmadığında veya geçiş sırasında doğrudan npm yükleme yoluna ihtiyaç duyduğunuzda npm kullanın:
openclaw plugins install npm:@myorg/openclaw-my-pluginRepo içi Plugin'ler: birlikte paketlenen Plugin çalışma alanı ağacının altına yerleştirin; derleme sırasında otomatik olarak keşfedilirler.
Kullanıcılar şunu kurabilir:
openclaw plugins install <package-name>Birlikte paketlenen paket meta verileri açıktır; Gateway başlangıcında derlenmiş JavaScript'ten çıkarımsanmaz. Çalışma zamanı bağımlılıkları, onlara sahip olan Plugin paketinde bulunmalıdır; paketlenmiş OpenClaw başlangıcı Plugin bağımlılıklarını asla onarmaz veya yansıtmaz.
İlgili
- Plugin oluşturma — adım adım başlangıç kılavuzu
- Plugin manifesti — tam manifest şeması başvurusu
- SDK giriş noktaları —
definePluginEntryvedefineChannelPluginEntry