Plugins
Plugin uyumluluğu
OpenClaw, SDK, manifest, kurulum, yapılandırma ve ajan çalışma zamanı sözleşmeleri gelişirken mevcut paketlenmiş ve harici Plugin'leri korumak için eski Plugin sözleşmelerini kaldırmadan önce adlandırılmış uyumluluk bağdaştırıcıları üzerinden bağlı tutar.
Uyumluluk kayıt defteri
Plugin uyumluluk sözleşmeleri çekirdek kayıt defterinde izlenir:
src/plugins/compat/registry.ts.
Her kayıtta şunlar bulunur:
- kararlı bir uyumluluk kodu
- durum:
active,deprecated,removal-pendingveyaremoved - sahip: SDK, yapılandırma, kurulum, kanal, sağlayıcı, Plugin yürütme, ajan çalışma zamanı veya çekirdek
- geçerliyse tanıtım ve kullanımdan kaldırma tarihleri
- değiştirme rehberliği
- eski ve yeni davranışı kapsayan belgeler, tanılamalar ve testler
Kayıt defteri, bakımcı planlaması ve gelecekteki Plugin denetleyici kontrolleri için kaynaktır. Plugin'e dönük bir davranış değişirse, bağdaştırıcıyı ekleyen değişiklikle aynı değişiklikte uyumluluk kaydını ekleyin veya güncelleyin.
Doctor onarımı ve taşıma uyumluluğu ayrı olarak
src/commands/doctor/shared/deprecation-compat.ts içinde izlenir. Bu kayıtlar, çalışma zamanı uyumluluk yolu kaldırıldıktan sonra da kullanılabilir kalması gerekebilecek eski yapılandırma şekillerini, kurulum defteri düzenlerini ve onarım shim'lerini kapsar.
Sürüm taramaları her iki kayıt defterini de kontrol etmelidir. Eşleşen çalışma zamanı veya yapılandırma uyumluluk kaydının süresi doldu diye bir doctor taşımasını silmeyin; önce onarıma hâlâ ihtiyaç duyan desteklenen bir yükseltme yolu olmadığını doğrulayın. Ayrıca sağlayıcılar ve kanallar çekirdekten çıktıkça Plugin sahipliği ve yapılandırma kapsamı değişebileceği için sürüm planlaması sırasında her değiştirme açıklamasını yeniden doğrulayın.
Plugin denetleyici paketi
Plugin denetleyicisi, sürümlenmiş uyumluluk ve manifest sözleşmeleriyle desteklenen ayrı bir paket/depo olarak çekirdek OpenClaw deposunun dışında yaşamalıdır.
İlk gün CLI şu olmalıdır:
openclaw-plugin-inspector ./my-plugin
Şunları üretmelidir:
- manifest/şema doğrulaması
- kontrol edilen sözleşme uyumluluk sürümü
- kurulum/kaynak meta veri kontrolleri
- soğuk yol içe aktarma kontrolleri
- kullanımdan kaldırma ve uyumluluk uyarıları
CI açıklamalarında kararlı, makine tarafından okunabilir çıktı için --json kullanın. OpenClaw çekirdeği, denetleyicinin tüketebileceği sözleşmeleri ve fixture'ları sunmalıdır, ancak denetleyici ikilisini ana openclaw paketinden yayımlamamalıdır.
Bakımcı kabul hattı
Harici denetleyiciyi OpenClaw Plugin paketlerine karşı doğrularken kurulabilir paket kabul hattı için Blacksmith Testbox kullanın. Paket oluşturulduktan sonra bunu temiz bir OpenClaw checkout'ından çalıştırın:
blacksmith testbox warmup ci-check-testbox.yml --ref main --idle-timeout 90
blacksmith testbox run --id <tbx_id> "pnpm install && pnpm build && npm exec --yes @openclaw/[email protected] -- ./extensions/telegram --json"
blacksmith testbox run --id <tbx_id> "npm exec --yes @openclaw/[email protected] -- ./extensions/discord --json"
blacksmith testbox run --id <tbx_id> "npm exec --yes @openclaw/[email protected] -- <clawhub-plugin-dir> --json"
blacksmith testbox stop <tbx_id>
Bu hattı bakımcılar için isteğe bağlı tutun; çünkü harici bir npm paketi kurar ve deponun dışında klonlanan Plugin paketlerini denetleyebilir. Yerel depo korumaları SDK dışa aktarma haritasını, uyumluluk kayıt defteri meta verilerini, kullanımdan kaldırılmış SDK içe aktarma azaltımını ve paketlenmiş extension içe aktarma sınırlarını kapsar; Testbox denetleyici kanıtı ise paketi harici Plugin yazarlarının tükettiği şekilde kapsar.
Kullanımdan kaldırma politikası
OpenClaw, belgelenmiş bir Plugin sözleşmesini, onun yerine geçen sözleşmeyi tanıttığı aynı sürümde kaldırmamalıdır.
Taşıma sırası şöyledir:
- Yeni sözleşmeyi ekleyin.
- Eski davranışı adlandırılmış bir uyumluluk bağdaştırıcısı üzerinden bağlı tutun.
- Plugin yazarları eyleme geçebildiğinde tanılama veya uyarı üretin.
- Yerine geçen çözümü ve zaman çizelgesini belgeleyin.
- Eski ve yeni yolların ikisini de test edin.
- Duyurulan taşıma penceresi boyunca bekleyin.
- Yalnızca açıkça kırıcı sürüm onayıyla kaldırın.
Kullanımdan kaldırılmış kayıtlar bir uyarı başlangıç tarihi, yerine geçen çözüm, belge bağlantısı ve uyarı başladıktan en fazla üç ay sonrasına denk gelen nihai kaldırma tarihi içermelidir. Bakımcılar bunun kalıcı uyumluluk olduğuna açıkça karar verip bunun yerine active olarak işaretlemedikçe, açık uçlu kaldırma penceresine sahip kullanımdan kaldırılmış bir uyumluluk yolu eklemeyin.
Geçerli uyumluluk alanları
Geçerli uyumluluk kayıtları şunları içerir:
openclaw/plugin-sdk/compatgibi eski geniş SDK içe aktarmaları- eski yalnızca hook içeren Plugin şekilleri ve
before_agent_start - Plugin'ler
register(api)öğesine taşınırken eskiactivate(api)Plugin giriş noktaları openclaw/extension-api,openclaw/plugin-sdk/channel-runtime,openclaw/plugin-sdk/command-authdurum oluşturucuları,openclaw/plugin-sdk/test-utils(odaklıopenclaw/plugin-sdk/*test alt yollarıyla değiştirildi) gibi eski SDK takma adları veClawdbotConfig/OpenClawSchemaTypetür takma adları- paketlenmiş Plugin izin listesi ve etkinleştirme davranışı
- eski sağlayıcı/kanal env-var manifest meta verileri
- sağlayıcılar açık katalog, kimlik doğrulama, düşünme, yeniden oynatma ve taşıma hook'larına taşınırken eski sağlayıcı Plugin hook'ları ve tür takma adları
api.runtime.taskFlow,api.runtime.subagent.getSession,api.runtime.sttve kullanımdan kaldırılmışapi.runtime.config.loadConfig()/api.runtime.config.writeConfigFile(...)gibi eski çalışma zamanı takma adları- bellek Plugin'leri
registerMemoryCapabilityöğesine taşınırken eski bellek Plugin'i bölünmüş kaydı - yerel ileti şemaları, bahsetme geçidi, gelen zarf biçimlendirmesi ve onay yeteneği iç içe yerleşimi için eski kanal SDK yardımcıları
- Plugin'ler
openclaw/plugin-sdk/channel-routeöğesine taşınırken eski kanal rota anahtarı ve karşılaştırılabilir hedef yardımcı takma adları - manifest katkı sahipliğiyle değiştirilen etkinleştirme ipuçları
- kurulum tanımlayıcıları soğuk
setup.requiresRuntime: falsemeta verilerine taşınırkensetup-apiçalışma zamanı fallback'i - sağlayıcı katalog hook'ları
catalog.run(...)öğesine taşınırken sağlayıcıdiscoveryhook'ları - kanal paketleri
openclaw.channel.exposureöğesine taşınırken kanalshowConfigured/showInSetupmeta verileri - doctor operatörleri
agentRuntimeöğesine taşırken eski runtime-policy yapılandırma anahtarları - registry-first
channelConfigsmeta verileri gelene kadar üretilmiş paketlenmiş kanal yapılandırma meta verileri fallback'i - onarım akışları operatörleri
openclaw plugins registry --refreshveopenclaw doctor --fixöğelerine taşırken kalıcı Plugin kayıt defteri devre dışı bırakma ve kurulum taşıma env bayrakları - doctor bunları
plugins.entries.<plugin>.configöğesine taşırken eski Plugin sahipli web arama, web getirme ve x_search yapılandırma yolları - kurulum meta verileri durum tarafından yönetilen Plugin defterine taşınırken eski
plugins.installsyazılmış yapılandırması ve paketlenmiş Plugin yükleme yolu takma adları
Yeni Plugin kodu, kayıt defterinde ve ilgili taşıma kılavuzunda listelenen yerine geçen çözümü tercih etmelidir. Mevcut Plugin'ler, belgeler, tanılamalar ve sürüm notları bir kaldırma penceresi duyurana kadar uyumluluk yolunu kullanmaya devam edebilir.
Sürüm notları
Sürüm notları, hedef tarihleri ve taşıma belgelerine bağlantılarıyla birlikte yaklaşan Plugin kullanımdan kaldırmalarını içermelidir. Bu uyarı, bir uyumluluk yolu removal-pending veya removed durumuna geçmeden önce yapılmalıdır.