Plugins розширюють OpenClaw новими можливостями: канали, постачальники моделей, агентські harnesses, інструменти, Skills, мовлення, транскрипція в реальному часі, голос у реальному часі, розуміння медіа, генерація зображень, генерація відео, web fetch, web search та інше. Деякі plugins є основними (постачаються з OpenClaw), інші є зовнішніми. Більшість зовнішніх plugins публікуються й знаходяться через ClawHub. Npm залишається підтримуваним для прямих встановлень і для тимчасового набору пакетів plugins, що належать OpenClaw, доки ця міграція завершується.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.
Швидкий старт
Приклади встановлення копіюванням і вставлянням, перегляду списку, видалення, оновлення та публікації див. у Керування plugins.Керування з чату
У запущеному Gateway доступні лише власнику
/plugins enable і /plugins disable
запускають перезавантажувач конфігурації Gateway. Gateway перезавантажує runtime-поверхні plugin
у процесі, а нові ходи агента перебудовують свій список інструментів з
оновленого реєстру. /plugins install змінює вихідний код plugin, тому
Gateway запитує перезапуск замість того, щоб удавати, що поточний процес може
безпечно перезавантажити вже імпортовані модулі.commands.plugins: true і використовуйте:
clawhub:<pkg>, явний npm:<pkg>, явний npm-pack:<path.tgz>,
явний git:<repo> або гола специфікація пакета через npm.
Якщо конфігурація недійсна, встановлення зазвичай завершується закрито й указує на
openclaw doctor --fix. Єдиний виняток для відновлення - вузький шлях перевстановлення bundled-plugin
для plugins, які явно вмикають
openclaw.install.allowInvalidConfigRecovery.
Під час запуску Gateway недійсна конфігурація plugin завершується закрито, як і будь-яка інша недійсна
конфігурація. Запустіть openclaw doctor --fix, щоб ізолювати погану конфігурацію plugin,
вимкнувши цей запис plugin і видаливши його недійсний payload конфігурації; звичайна
резервна копія конфігурації зберігає попередні значення.
Коли конфігурація каналу посилається на plugin, який більше не можна виявити, але
той самий застарілий id plugin лишається в конфігурації plugin або записах встановлення, запуск Gateway
записує попередження й пропускає цей канал замість того, щоб блокувати всі інші канали.
Запустіть openclaw doctor --fix, щоб видалити застарілі записи channel/plugin; невідомі
ключі каналів без доказів застарілого plugin усе ще не проходять валідацію, щоб помилки друку залишалися
видимими.
Якщо встановлено plugins.enabled: false, застарілі посилання на plugin розглядаються як інертні:
запуск Gateway пропускає виявлення/завантаження plugins, а openclaw doctor зберігає
вимкнену конфігурацію plugin замість автоматичного видалення. Знову ввімкніть plugins перед
запуском очищення doctor, якщо хочете видалити застарілі id plugin.
Встановлення залежностей plugin відбувається лише під час явних потоків install/update або
repair у doctor. Запуск Gateway, перезавантаження конфігурації та runtime inspection
не запускають менеджери пакетів і не ремонтують дерева залежностей. Локальні plugins мають уже
мати встановлені свої залежності, тоді як npm, git і ClawHub plugins
встановлюються під керованими коренями plugins OpenClaw. Залежності npm можуть бути hoisted
у межах керованого npm-кореня OpenClaw; install/update сканує цей керований корінь перед
довірою, а uninstall видаляє npm-managed packages через npm. Зовнішні plugins
і custom load paths усе ще мають установлюватися через openclaw plugins install.
Використовуйте openclaw plugins list --json, щоб побачити статичний dependencyStatus для кожного
видимого plugin без імпорту runtime-коду або ремонту залежностей.
Див. розв’язання залежностей Plugin щодо
життєвого циклу під час встановлення.
Власність заблокованого шляху plugin
Якщо діагностика plugin кажеblocked plugin candidate: suspicious ownership (... uid=1000, expected uid=0 or root)
і після цього валідація конфігурації показує plugin present but blocked, OpenClaw знайшов
файли plugin, що належать іншому Unix-користувачу, ніж процес, який їх завантажує.
Залиште конфігурацію plugin на місці; виправте власність файлової системи або запускайте
OpenClaw від того самого користувача, який володіє каталогом стану.
Для встановлень Docker офіційний образ працює як node (uid 1000), тому
примонтовані з хоста каталоги конфігурації та workspace OpenClaw зазвичай мають
належати uid 1000:
openclaw doctor --fix або
openclaw plugins registry --refresh, щоб збережений реєстр plugin відповідав
виправленим файлам.
Для встановлень npm змінні селектори, як-от latest або dist-tag, розв’язуються
перед встановленням, а потім закріплюються до точної перевіреної версії в керованому
npm-корені OpenClaw. Після завершення npm OpenClaw перевіряє, що встановлений
запис package-lock.json усе ще відповідає розв’язаній версії та integrity. Якщо
npm записує інші метадані пакета, встановлення завершується помилкою, а керований пакет
відкочується замість прийняття іншого artifact plugin.
Керовані npm-корені також успадковують npm overrides рівня пакета OpenClaw, тому
security pins, які захищають packaged host, також застосовуються до hoisted зовнішніх
залежностей plugin.
Source checkouts є pnpm workspaces. Якщо ви клонуєте OpenClaw, щоб працювати з bundled
plugins, запустіть pnpm install; тоді OpenClaw завантажує bundled plugins з
extensions/<id>, щоб правки й package-local dependencies використовувалися напряму.
Звичайні npm root installs призначені для packaged OpenClaw, а не для розробки в source checkout.
Типи Plugin
OpenClaw розпізнає два формати plugin:| Формат | Як це працює | Приклади |
|---|---|---|
| Native | openclaw.plugin.json + runtime-модуль; виконується in-process | Офіційні plugins, спільнотні npm-пакети |
| Bundle | Codex/Claude/Cursor-сумісна структура; мапиться на функції OpenClaw | .codex-plugin/, .claude-plugin/, .cursor-plugin/ |
openclaw plugins list. Див. Plugin Bundles для деталей bundle.
Якщо ви пишете native plugin, почніть з Створення Plugins
і Огляд Plugin SDK.
Точки входу пакетів
Пакети npm native plugin мають оголошуватиopenclaw.extensions у package.json.
Кожен запис має залишатися всередині каталогу пакета й розв’язуватися до читабельного
runtime-файлу або до TypeScript source file з виведеним зібраним JavaScript
peer, наприклад src/index.ts до dist/index.js.
Packaged installs мають постачати цей JavaScript runtime output. TypeScript
source fallback призначений для source checkouts і локальних шляхів розробки, а не для
npm-пакетів, встановлених у керований корінь plugin OpenClaw.
Невідстежувані каталоги, скинуті в глобальний корінь extension, розглядаються як
локальні source checkouts і можуть напряму завантажувати TypeScript entries. Каталоги,
які все ще названі записом встановлення, включно з installPath або sourcePath, лишаються
керованими й зберігають вимогу compiled-output навіть тоді, коли глобальне сканування бачить
їх. Якщо ви навмисно перетворюєте кероване встановлення на невідстежуваний локальний
checkout, спершу видаліть застарілий запис встановлення через uninstall або doctor cleanup.
Якщо попередження керованого пакета каже, що він requires compiled runtime output for TypeScript entry ..., пакет було опубліковано без JavaScript-файлів,
потрібних OpenClaw під час runtime. Це проблема пакування plugin, а не локальна проблема
конфігурації. Оновіть або перевстановіть plugin після того, як видавець повторно опублікує зібраний
JavaScript, або вимкніть/видаліть цей plugin, доки не буде доступний виправлений пакет.
Використовуйте openclaw.runtimeExtensions, коли опубліковані runtime-файли не розташовані за
тими самими шляхами, що й source entries. Якщо runtimeExtensions присутній, він має містити
рівно один запис для кожного запису extensions. Невідповідні списки спричиняють помилку встановлення та
виявлення plugin замість тихого fallback до source paths. Якщо ви також
публікуєте openclaw.setupEntry, використовуйте openclaw.runtimeSetupEntry для його зібраного
JavaScript peer; цей файл є обов’язковим, якщо його оголошено.
Офіційні plugins
Npm-пакети, що належать OpenClaw, під час міграції
ClawHub є основним шляхом розповсюдження для більшості plugins. Поточні packaged релізи OpenClaw уже bundled багато офіційних plugins, тому їм не потрібні окремі npm-встановлення у звичайних налаштуваннях. Доки кожен plugin, що належить OpenClaw, не мігрує до ClawHub, OpenClaw усе ще постачає деякі пакети@openclaw/* plugin на
npm для старіших/custom installs і прямих npm workflows.
Якщо npm повідомляє, що пакет plugin @openclaw/* deprecated, ця версія пакета
походить зі старішої external package train. Використовуйте bundled plugin з
поточного OpenClaw або локальний checkout, доки не буде опубліковано новіший npm-пакет.
| Plugin | Пакет | Документація |
|---|---|---|
| Discord | @openclaw/discord | Discord |
| Feishu | @openclaw/feishu | Feishu |
| Matrix | @openclaw/matrix | Matrix |
| Mattermost | @openclaw/mattermost | Mattermost |
| Microsoft Teams | @openclaw/msteams | Microsoft Teams |
| Nextcloud Talk | @openclaw/nextcloud-talk | Nextcloud Talk |
| Nostr | @openclaw/nostr | Nostr |
| Synology Chat | @openclaw/synology-chat | Synology Chat |
| Tlon | @openclaw/tlon | Tlon |
@openclaw/whatsapp | ||
| Zalo | @openclaw/zalo | Zalo |
| Zalo Personal | @openclaw/zalouser | Zalo Personal |
Core (постачається з OpenClaw)
Постачальники моделей (увімкнено за замовчуванням)
Постачальники моделей (увімкнено за замовчуванням)
anthropic, byteplus, cloudflare-ai-gateway, github-copilot, google,
huggingface, kilocode, kimi-coding, minimax, mistral, qwen,
moonshot, nvidia, openai, opencode, opencode-go, openrouter,
qianfan, synthetic, together, venice,
vercel-ai-gateway, volcengine, xiaomi, zaiПлагіни пам’яті
Плагіни пам’яті
memory-core- вбудований пошук у пам’яті (за замовчуванням черезplugins.slots.memory)memory-lancedb- довготривала пам’ять на базі LanceDB з автоматичним пригадуванням/захопленням (задайтеplugins.slots.memory = "memory-lancedb")
Постачальники мовлення (увімкнено за замовчуванням)
Постачальники мовлення (увімкнено за замовчуванням)
elevenlabs, microsoftІнше
Інше
browser- вбудований браузерний Plugin для інструмента браузера,openclaw browserCLI, методу Gatewaybrowser.request, браузерного середовища виконання та стандартної служби керування браузером (увімкнено за замовчуванням; вимкніть перед заміною)copilot-proxy- міст VS Code Copilot Proxy (вимкнено за замовчуванням)
Конфігурація
| Поле | Опис |
|---|---|
enabled | Головний перемикач (за замовчуванням: true) |
allow | Список дозволених Plugin (необов’язково) |
bundledDiscovery | Режим виявлення вбудованих Plugin (allowlist за замовчуванням) |
deny | Список заборонених Plugin (необов’язково; заборона має пріоритет) |
load.paths | Додаткові файли/каталоги Plugin |
slots | Вибір ексклюзивних слотів (наприклад, memory, contextEngine) |
entries.\<id\> | Перемикачі й конфігурація для окремих Plugin |
plugins.allow є ексклюзивним. Коли він непорожній, лише перелічені Plugin можуть завантажуватися
або відкривати інструменти, навіть якщо tools.allow містить "*" або конкретну назву інструмента,
що належить Plugin. Якщо список дозволених інструментів посилається на інструменти Plugin, додайте id Plugin-власників
до plugins.allow або видаліть plugins.allow; openclaw doctor попереджає про таку
форму.
plugins.bundledDiscovery за замовчуванням має значення "allowlist" для нових конфігурацій, тому
обмежувальний інвентар plugins.allow також блокує пропущені вбудовані Plugin постачальників,
зокрема виявлення постачальників вебпошуку під час виконання. Doctor позначає старіші
обмежувальні конфігурації списку дозволених значенням "compat" під час міграції, щоб оновлення зберігали
застарілу поведінку вбудованих постачальників, доки оператор не ввімкне суворіший режим.
Порожній plugins.allow досі трактується як не заданий/відкритий.
Зміни конфігурації, зроблені через /plugins enable або /plugins disable, запускають
перезавантаження Plugin Gateway у поточному процесі. Нові ходи агента перебудовують свій список інструментів з
оновленого реєстру Plugin. Операції, що змінюють джерела, як-от install,
update та uninstall, досі перезапускають процес Gateway, оскільки вже імпортовані
модулі Plugin не можна безпечно замінити на місці.
openclaw plugins list — це локальний знімок реєстру/конфігурації Plugin. Позначений як
enabled Plugin там означає, що збережений реєстр і поточна конфігурація дозволяють
Plugin брати участь. Це не доводить, що вже запущений віддалений Gateway
перезавантажився або перезапустився з тим самим кодом Plugin. У налаштуваннях VPS/контейнерів
з процесами-обгортками надсилайте перезапуски або записи, що запускають перезавантаження, до фактичного
процесу openclaw gateway run, або використовуйте openclaw gateway restart для
запущеного Gateway, коли перезавантаження повідомляє про помилку.
Стани Plugin: вимкнений, відсутній, недійсний
Стани Plugin: вимкнений, відсутній, недійсний
- Вимкнений: Plugin існує, але правила ввімкнення вимкнули його. Конфігурація зберігається.
- Відсутній: конфігурація посилається на id Plugin, який виявлення не знайшло.
- Недійсний: Plugin існує, але його конфігурація не відповідає оголошеній схемі. Запуск Gateway пропускає лише цей Plugin;
openclaw doctor --fixможе помістити недійсний запис у карантин, вимкнувши його та видаливши його конфігураційне навантаження.
Виявлення та пріоритет
OpenClaw сканує Plugin у такому порядку (перший збіг перемагає):Шляхи конфігурації
plugins.load.paths - явні шляхи до файлів або каталогів. Шляхи, що вказують
назад на власні запаковані каталоги вбудованих Plugin OpenClaw, ігноруються;
запустіть openclaw doctor --fix, щоб видалити ці застарілі псевдоніми.Plugin робочого простору
\<workspace\>/.openclaw/<plugin-root>/*.ts і \<workspace\>/.openclaw/<plugin-root>/*/index.ts.dist/extensions. Якщо вихідний каталог вбудованого Plugin
прив’язано монтуванням поверх відповідного запакованого вихідного шляху, наприклад
/app/extensions/synology-chat, OpenClaw трактує цей змонтований вихідний каталог
як накладення джерела вбудованого Plugin і виявляє його перед запакованим
пакетом /app/dist/extensions/synology-chat. Це зберігає працездатність контейнерних
циклів супровідників без перемикання кожного вбудованого Plugin назад на вихідний код TypeScript.
Задайте OPENCLAW_DISABLE_BUNDLED_SOURCE_OVERLAYS=1, щоб примусово використовувати запаковані dist-пакети
навіть за наявності змонтованих вихідних накладень.
Правила ввімкнення
plugins.enabled: falseвимикає всі Plugin і пропускає роботу з виявлення/завантаження Pluginplugins.denyзавжди має пріоритет над allowplugins.entries.\<id\>.enabled: falseвимикає цей Plugin- Plugin з походженням із робочого простору вимкнені за замовчуванням (їх потрібно явно ввімкнути)
- Вбудовані Plugin дотримуються вбудованого набору увімкнених за замовчуванням, якщо не перевизначено
- Ексклюзивні слоти можуть примусово ввімкнути вибраний Plugin для цього слота
- Деякі вбудовані opt-in Plugin вмикаються автоматично, коли конфігурація називає поверхню, що належить Plugin, як-от посилання на модель постачальника, конфігурацію каналу або середовище виконання harness
- Застаріла конфігурація Plugin зберігається, доки активний
plugins.enabled: false; повторно ввімкніть Plugin перед запуском очищення doctor, якщо хочете видалити застарілі id - Маршрути Codex родини OpenAI зберігають окремі межі Plugin:
openai-codex/*належить Plugin OpenAI, тоді як вбудований Plugin app-server Codex вибирається канонічними посиланнями агентаopenai/*, явнимagentRuntime.id: "codex"постачальника/моделі або застарілими посиланнями моделейcodex/*
Усунення несправностей runtime hooks
Якщо Plugin з’являється уplugins list, але побічні ефекти або хуки register(api)
не виконуються в живому чат-трафіку, спершу перевірте таке:
- Запустіть
openclaw gateway status --deep --require-rpcі підтвердьте, що активні URL Gateway, профіль, шлях конфігурації та процес є саме тими, які ви редагуєте. - Перезапустіть живий Gateway після змін установлення/конфігурації/коду Plugin. У контейнерах-обгортках
PID 1 може бути лише супервізором; перезапустіть або надішліть сигнал дочірньому
процесу
openclaw gateway run. - Використовуйте
openclaw plugins inspect <id> --runtime --json, щоб підтвердити реєстрації хуків і діагностику. Невбудовані хуки розмови, як-отbefore_model_resolve,before_agent_reply,before_agent_run,llm_input,llm_output,before_agent_finalizeіagent_end, потребуютьplugins.entries.<id>.hooks.allowConversationAccess=true. - Для перемикання моделей надавайте перевагу
before_model_resolve. Він виконується до розв’язання моделі для ходів агента;llm_outputвиконується лише після того, як спроба моделі створить вивід асистента. - Для доказу ефективної моделі сесії використовуйте
openclaw sessionsабо поверхні сесії/статусу Gateway, а під час налагодження навантажень постачальника запускайте Gateway з--raw-stream --raw-stream-path <path>.
Повільне налаштування інструментів Plugin
Якщо здається, що ходи агента зависають під час підготовки інструментів, увімкніть трасувальне журналювання та перевірте рядки часу фабрик інструментів Plugin:Дубльоване володіння каналом або інструментом
Симптоми:channel already registered: <channel-id> (<plugin-id>)channel setup already registered: <channel-id> (<plugin-id>)plugin tool name conflict (<plugin-id>): <tool-name>
- Запустіть
openclaw plugins list --enabled --verbose, щоб побачити кожен увімкнений Plugin і його походження. - Запустіть
openclaw plugins inspect <id> --runtime --jsonдля кожного підозрюваного Plugin і порівняйтеchannels,channelConfigs,toolsі діагностику. - Запустіть
openclaw plugins registry --refreshпісля встановлення або видалення пакетів Plugin, щоб збережені метадані відображали поточне встановлення. - Перезапустіть Gateway після змін установлення, реєстру або конфігурації.
- Якщо один Plugin навмисно замінює інший для того самого id каналу, бажаний
Plugin має оголосити
channelConfigs.<channel-id>.preferOverз id Plugin нижчого пріоритету. Див. /plugins/manifest#replacing-another-channel-plugin. - Якщо дублювання випадкове, вимкніть одну зі сторін за допомогою
plugins.entries.<plugin-id>.enabled: falseабо видаліть застаріле встановлення Plugin. - Якщо ви явно ввімкнули обидва Plugin, OpenClaw зберігає цей запит і повідомляє про конфлікт. Виберіть одного власника каналу або перейменуйте інструменти, що належать Plugin, щоб поверхня runtime була однозначною.
Слоти Plugin (ексклюзивні категорії)
Деякі категорії є ексклюзивними (активна лише одна за раз):| Слот | Що він контролює | За замовчуванням |
|---|---|---|
memory | Активний Plugin пам’яті | memory-core |
contextEngine | Активний рушій контексту | legacy (вбудований) |
Довідник CLI
openclaw plugins enable <id>.
--force перезаписує наявний встановлений плагін або пакет хуків на місці. Використовуйте
openclaw plugins update <id-or-npm-spec> для звичайних оновлень відстежуваних npm
плагінів. Він не підтримується з --link, який повторно використовує шлях до джерела замість
копіювання в керовану ціль встановлення.
Коли plugins.allow уже задано, openclaw plugins install додає
ідентифікатор встановленого плагіна до цього списку дозволених перед його ввімкненням. Якщо той самий ідентифікатор плагіна
присутній у plugins.deny, встановлення видаляє цей застарілий запис заборони, щоб
явне встановлення можна було завантажити одразу після перезапуску.
OpenClaw зберігає сталий локальний реєстр плагінів як модель холодного читання для
інвентарю плагінів, належності внесків і планування запуску. Потоки встановлення, оновлення,
видалення, увімкнення та вимкнення оновлюють цей реєстр після зміни стану плагінів.
Той самий файл plugins/installs.json зберігає тривалі метадані встановлення у
верхньорівневому installRecords і відновлювані метадані маніфесту в plugins. Якщо
реєстр відсутній, застарілий або недійсний, openclaw plugins registry --refresh відновлює його подання маніфестів із записів встановлення, політики конфігурації та
метаданих маніфесту/пакета без завантаження runtime-модулів плагінів.
У режимі Nix (OPENCLAW_NIX_MODE=1) мутації життєвого циклу плагінів вимкнені.
Керуйте вибором пакетів плагінів і конфігурацією через джерело Nix для
встановлення; для nix-openclaw почніть із орієнтованого на агента
швидкого старту.
openclaw plugins update <id-or-npm-spec> застосовується до відстежуваних встановлень. Передавання
специфікації npm-пакета з dist-tag або точною версією зіставляє назву пакета
назад із записом відстежуваного плагіна та записує нову специфікацію для майбутніх оновлень.
Передавання назви пакета без версії повертає точно закріплене встановлення до
типової лінії релізів реєстру. Якщо встановлений npm-плагін уже відповідає
розв’язаній версії та записаній ідентичності артефакта, OpenClaw пропускає оновлення
без завантаження, перевстановлення або перезапису конфігурації.
Коли openclaw update запускається на beta-каналі, записи npm і ClawHub
плагінів типової лінії спочатку пробують @beta і повертаються до default/latest, якщо beta-релізу
плагіна немає. Точні версії та явні теги залишаються закріпленими.
--pin працює лише з npm. Він не підтримується з --marketplace, оскільки
встановлення з маркетплейсу зберігають метадані джерела маркетплейсу замість специфікації npm.
--dangerously-force-unsafe-install — це аварійне перевизначення для хибних
спрацювань вбудованого сканера небезпечного коду. Воно дозволяє встановлення
плагінів і оновлення плагінів продовжуватися попри вбудовані знахідки critical, але все одно
не обходить блокування політик before_install плагіна або блокування через помилку сканування.
Сканування встановлення ігнорує поширені тестові файли й каталоги, як-от tests/,
__tests__/, *.test.* і *.spec.*, щоб не блокувати упаковані тестові моки;
оголошені runtime-точки входу плагіна все одно скануються, навіть якщо вони використовують одну з
цих назв.
Цей прапорець CLI застосовується лише до потоків встановлення/оновлення плагінів. Встановлення
залежностей Skills через Gateway натомість використовують відповідне перевизначення запиту
dangerouslyForceUnsafeInstall, тоді як openclaw skills install залишається окремим потоком
завантаження/встановлення Skills з ClawHub.
Якщо плагін, який ви опублікували на ClawHub, приховано або заблоковано скануванням, відкрийте
панель ClawHub або виконайте clawhub package rescan <name>, щоб попросити ClawHub перевірити
його знову. --dangerously-force-unsafe-install впливає лише на встановлення на вашому власному
комп’ютері; він не просить ClawHub повторно сканувати плагін або робити заблокований реліз
публічним.
Сумісні набори беруть участь у тому самому потоці list/inspect/enable/disable для плагінів.
Поточна runtime-підтримка включає Skills наборів, командні Skills Claude,
типові значення Claude settings.json, типові значення Claude .lsp.json і оголошені в маніфесті
lspServers, командні Skills Cursor і сумісні каталоги хуків Codex.
openclaw plugins inspect <id> також повідомляє виявлені можливості набору, а також
підтримувані або непідтримувані записи серверів MCP і LSP для плагінів на основі наборів.
Джерелами маркетплейсу можуть бути назва відомого маркетплейсу Claude з
~/.claude/plugins/known_marketplaces.json, локальний корінь маркетплейсу або
шлях marketplace.json, скорочений запис GitHub на кшталт owner/repo, URL репозиторію
GitHub або git URL. Для віддалених маркетплейсів записи плагінів мають залишатися всередині
клонованого репозиторію маркетплейсу та використовувати лише відносні джерела шляхів.
Повні відомості див. у довіднику CLI для openclaw plugins.
Огляд API Plugin
Нативні плагіни експортують об’єкт точки входу, який надаєregister(api). Старіші
плагіни все ще можуть використовувати activate(api) як застарілий псевдонім, але нові плагіни мають
використовувати register.
register(api) під час
активації плагіна. Завантажувач усе ще повертається до activate(api) для старіших плагінів,
але вбудовані плагіни та нові зовнішні плагіни мають розглядати register як
публічний контракт.
api.registrationMode повідомляє плагіну, чому його точка входу завантажується:
| Режим | Значення |
|---|---|
full | Runtime-активація. Реєструйте інструменти, хуки, сервіси, команди, маршрути та інші активні побічні ефекти. |
discovery | Виявлення можливостей лише для читання. Реєструйте провайдерів і метадані; код точки входу довіреного плагіна може завантажуватися, але пропускайте активні побічні ефекти. |
setup-only | Завантаження метаданих налаштування каналу через легку точку входу налаштування. |
setup-runtime | Завантаження налаштування каналу, якому також потрібна runtime-точка входу. |
cli-metadata | Лише збирання метаданих команд CLI. |
api.registrationMode === "full".
Завантаження в режимі виявлення кешуються окремо від активаційних завантажень і не замінюють
поточний реєстр Gateway. Виявлення не активує плагін, але не є вільним від імпорту:
OpenClaw може виконати довірену точку входу плагіна або модуль плагіна каналу, щоб побудувати
знімок. Тримайте верхні рівні модулів легкими й без побічних ефектів, а
мережеві клієнти, підпроцеси, слухачі, читання облікових даних і запуск сервісів переносіть
за шляхи full-runtime.
Поширені методи реєстрації:
| Метод | Що він реєструє |
|---|---|
registerProvider | Провайдера моделі (LLM) |
registerChannel | Канал чату |
registerTool | Інструмент агента |
registerHook / on(...) | Хуки життєвого циклу |
registerSpeechProvider | Перетворення тексту на мовлення / STT |
registerRealtimeTranscriptionProvider | Потокове STT |
registerRealtimeVoiceProvider | Дуплексний голос у реальному часі |
registerMediaUnderstandingProvider | Аналіз зображень/аудіо |
registerImageGenerationProvider | Генерацію зображень |
registerMusicGenerationProvider | Генерацію музики |
registerVideoGenerationProvider | Генерацію відео |
registerWebFetchProvider | Провайдера веб-завантаження / скрейпінгу |
registerWebSearchProvider | Вебпошук |
registerHttpRoute | HTTP-ендпоїнт |
registerCommand / registerCli | Команди CLI |
registerContextEngine | Рушій контексту |
registerService | Фоновий сервіс |
before_tool_call:{ block: true }є кінцевим; обробники з нижчим пріоритетом пропускаються.before_tool_call:{ block: false }нічого не робить і не скидає попереднє блокування.before_install:{ block: true }є кінцевим; обробники з нижчим пріоритетом пропускаються.before_install:{ block: false }нічого не робить і не скидає попереднє блокування.message_sending:{ cancel: true }є кінцевим; обробники з нижчим пріоритетом пропускаються.message_sending:{ cancel: false }нічого не робить і не скидає попереднє скасування.
before_tool_call, спостерігати результати через after_tool_call і брати участь у схваленнях Codex PermissionRequest. Міст поки не переписує аргументи нативних для Codex інструментів. Точна межа підтримки середовища виконання Codex описана в контракті підтримки Codex harness v1.
Повну типізовану поведінку хуків див. в огляді SDK.
Пов’язане
- Створення plugins - створіть власний plugin
- Пакети Plugin - сумісність пакетів Codex/Claude/Cursor
- Маніфест Plugin - схема маніфесту
- Реєстрація інструментів - додайте інструменти агента в plugin
- Внутрішня будова Plugin - модель можливостей і конвеєр завантаження
- ClawHub - пошук сторонніх plugins