Plugins
افزودن قابلیتها (راهنمای مشارکتکننده)
از این راهنما زمانی استفاده کنید که OpenClaw به یک دامنه مشترک جدید مانند تولید تصویر، تولید ویدئو، یا یک حوزه ویژگی آینده با پشتیبانی فروشنده نیاز دارد.
قاعده:
- Plugin = مرز مالکیت
- قابلیت = قرارداد مشترک هسته
کار را با متصل کردن مستقیم یک فروشنده به یک کانال یا ابزار شروع نکنید. با تعریف قابلیت شروع کنید.
چه زمانی یک قابلیت بسازیم
زمانی یک قابلیت جدید بسازید که همه موارد زیر درست باشند:
- بیش از یک فروشنده بتواند بهطور معقول آن را پیادهسازی کند.
- کانالها، ابزارها، یا Pluginهای ویژگی باید بدون اهمیت دادن به فروشنده از آن استفاده کنند.
- هسته باید مالک رفتارهای جایگزین، سیاست، پیکربندی، یا تحویل باشد.
اگر کار فقط مخصوص فروشنده است و هنوز قرارداد مشترکی وجود ندارد، متوقف شوید و ابتدا قرارداد را تعریف کنید.
توالی استاندارد
- قرارداد تایپشده هسته را تعریف کنید.
- ثبت Plugin را برای آن قرارداد اضافه کنید.
- یک راهنمای زمان اجرای مشترک اضافه کنید.
- یک Plugin فروشنده واقعی را بهعنوان اثبات متصل کنید.
- مصرفکنندگان ویژگی/کانال را به راهنمای زمان اجرا منتقل کنید.
- آزمونهای قرارداد را اضافه کنید.
- پیکربندی و مدل مالکیت روبهروی اپراتور را مستند کنید.
چه چیزی کجا قرار میگیرد
هسته:
- نوعهای درخواست/پاسخ.
- رجیستری ارائهدهنده + تفکیک.
- رفتار جایگزین.
- شِمای پیکربندی با فراداده مستندات
title/descriptionمنتشرشده روی گرههای شیء تودرتو، wildcard، آیتم آرایه، و ترکیب. - سطح راهنمای زمان اجرا.
Plugin فروشنده:
- فراخوانیهای API فروشنده.
- مدیریت احراز هویت فروشنده.
- عادیسازی درخواست مخصوص فروشنده.
- ثبت پیادهسازی قابلیت.
Plugin ویژگی/کانال:
api.runtime.*یا راهنمای متناظرplugin-sdk/*-runtimeرا فراخوانی میکند.- هرگز پیادهسازی فروشنده را مستقیم فراخوانی نمیکند.
مرزهای ارائهدهنده و هارنس
از قلابهای ارائهدهنده زمانی استفاده کنید که رفتار به قرارداد ارائهدهنده مدل تعلق دارد، نه حلقه عمومی عامل. نمونهها شامل پارامترهای درخواست مخصوص ارائهدهنده پس از انتخاب انتقال، ترجیح پروفایل احراز هویت، پوششهای پرامپت، و مسیریابی جایگزین پیگیری پس از failover مدل/پروفایل هستند.
از قلابهای هارنس عامل زمانی استفاده کنید که رفتار به زمان اجرایی تعلق دارد که یک نوبت را اجرا میکند. هارنسها میتوانند نتایج تلاش موفق اما غیرقابلاستفاده، مانند پاسخهای خالی، فقط استدلالی، یا فقط برنامهریزی را دستهبندی کنند تا سیاست جایگزین مدل بیرونی بتواند درباره تلاش دوباره تصمیم بگیرد.
هر دو مرز را محدود نگه دارید:
- هسته مالک سیاست تلاش دوباره/جایگزین است.
- Pluginهای ارائهدهنده مالک اشارههای درخواست/احراز هویت/مسیریابی مخصوص ارائهدهنده هستند.
- Pluginهای هارنس مالک دستهبندی تلاش مخصوص زمان اجرا هستند.
- Pluginهای شخص ثالث اشاره برمیگردانند، نه تغییر مستقیم وضعیت هسته.
چکلیست فایل
برای یک قابلیت جدید، انتظار داشته باشید این بخشها را تغییر دهید:
src/<capability>/types.tssrc/<capability>/...registry/runtime.tssrc/plugins/types.tssrc/plugins/registry.tssrc/plugins/captured-registration.tssrc/plugins/contracts/registry.tssrc/plugins/runtime/types-core.tssrc/plugins/runtime/index.tssrc/plugin-sdk/<capability>.tssrc/plugin-sdk/<capability>-runtime.ts- یک یا چند بسته Plugin همراه.
- پیکربندی، مستندات، آزمونها.
مثال کارشده: تولید تصویر
تولید تصویر از شکل استاندارد پیروی میکند:
- هسته
ImageGenerationProviderرا تعریف میکند. - هسته
registerImageGenerationProvider(...)را در دسترس میگذارد. - هسته
runtime.imageGeneration.generate(...)را در دسترس میگذارد. - Pluginهای
openai،google،fal، وminimaxپیادهسازیهای دارای پشتیبانی فروشنده را ثبت میکنند. - فروشندگان آینده همان قرارداد را بدون تغییر دادن کانالها/ابزارها ثبت میکنند.
کلید پیکربندی عمداً از مسیریابی تحلیل بینایی جداست:
agents.defaults.imageModelتصویرها را تحلیل میکند.agents.defaults.imageGenerationModelتصویرها را تولید میکند.
این دو را جدا نگه دارید تا جایگزین و سیاست صریح باقی بمانند.
چکلیست بازبینی
پیش از ارسال یک قابلیت جدید، بررسی کنید:
- هیچ کانال/ابزاری کد فروشنده را مستقیم وارد نمیکند.
- راهنمای زمان اجرا مسیر مشترک است.
- حداقل یک آزمون قرارداد، مالکیت همراه را بررسی میکند.
- مستندات پیکربندی نام کلید مدل/پیکربندی جدید را ذکر میکنند.
- مستندات Plugin مرز مالکیت را توضیح میدهند.
اگر یک PR لایه قابلیت را دور میزند و رفتار فروشنده را در یک کانال/ابزار hardcode میکند، آن را برگردانید و ابتدا قرارداد را تعریف کنید.
مرتبط
- درونیات Plugin — مدل قابلیت، مالکیت، خط لوله بارگذاری، راهنماهای زمان اجرا.
- ساخت Pluginها — آموزش اولین Plugin.
- نمای کلی SDK — نقشه import و مرجع API ثبت.
- ساخت Skills — سطح همراه مشارکتکننده.