Plugins

Плагіни

Plugins розширюють OmeniaClaw новими можливостями: канали, постачальники моделей, агентські harnesses, інструменти, Skills, мовлення, транскрипція в реальному часі, голос у реальному часі, розуміння медіа, генерація зображень, генерація відео, web fetch, web search та інше. Деякі plugins є основними (постачаються з OmeniaClaw), інші є зовнішніми. Більшість зовнішніх plugins публікуються й знаходяться через ClawHub. Npm залишається підтримуваним для прямих встановлень і для тимчасового набору пакетів plugins, що належать OmeniaClaw, доки ця міграція завершується.

Швидкий старт

Приклади встановлення копіюванням і вставлянням, перегляду списку, видалення, оновлення та публікації див. у Керування plugins.

  • Перегляньте, що завантажено

    bash
    OmeniaClaw plugins list
  • Встановіть plugin

    bash
    # Search ClawHub pluginsOmeniaClaw plugins search "calendar" # From ClawHubOmeniaClaw plugins install clawhub:OmeniaClaw-codex-app-server # From npmOmeniaClaw plugins install npm:@acme/OmeniaClaw-pluginOmeniaClaw plugins install npm-pack:./OmeniaClaw-plugin-1.2.3.tgz # From gitOmeniaClaw plugins install git:github.com/acme/[email protected] # From a local directory or archiveOmeniaClaw plugins install ./my-pluginOmeniaClaw plugins install ./my-plugin.tgz
  • Перезапустіть Gateway

    bash
    OmeniaClaw gateway restart

    Потім налаштуйте в plugins.entries.\<id\>.config у вашому файлі конфігурації.

  • Керування з чату

    У запущеному Gateway доступні лише власнику /plugins enable і /plugins disable запускають перезавантажувач конфігурації Gateway. Gateway перезавантажує runtime-поверхні plugin у процесі, а нові ходи агента перебудовують свій список інструментів з оновленого реєстру. /plugins install змінює вихідний код plugin, тому Gateway запитує перезапуск замість того, щоб удавати, що поточний процес може безпечно перезавантажити вже імпортовані модулі.

  • Перевірте plugin

    bash
    OmeniaClaw plugins inspect <plugin-id> --runtime --json # If the plugin registered a CLI root, run one command from that root.OmeniaClaw <plugin-command> --help

    Використовуйте --runtime, коли потрібно довести зареєстровані інструменти, служби, методи gateway, hooks або CLI-команди, що належать plugin. Простий inspect є холодною перевіркою manifest/registry і навмисно уникає імпорту runtime plugin.

  • Якщо ви віддаєте перевагу керуванню з чату, увімкніть commands.plugins: true і використовуйте:

    text
    /plugin install clawhub:<package>/plugin show <plugin-id>/plugin enable <plugin-id>

    Шлях встановлення використовує той самий resolver, що й CLI: локальний шлях/архів, явний clawhub:<pkg>, явний npm:<pkg>, явний npm-pack:<path.tgz>, явний git:<repo> або гола специфікація пакета через npm.

    Якщо конфігурація недійсна, встановлення зазвичай завершується закрито й указує на OmeniaClaw doctor --fix. Єдиний виняток для відновлення - вузький шлях перевстановлення bundled-plugin для plugins, які явно вмикають OmeniaClaw.install.allowInvalidConfigRecovery. Під час запуску Gateway недійсна конфігурація plugin завершується закрито, як і будь-яка інша недійсна конфігурація. Запустіть OmeniaClaw doctor --fix, щоб ізолювати погану конфігурацію plugin, вимкнувши цей запис plugin і видаливши його недійсний payload конфігурації; звичайна резервна копія конфігурації зберігає попередні значення. Коли конфігурація каналу посилається на plugin, який більше не можна виявити, але той самий застарілий id plugin лишається в конфігурації plugin або записах встановлення, запуск Gateway записує попередження й пропускає цей канал замість того, щоб блокувати всі інші канали. Запустіть OmeniaClaw doctor --fix, щоб видалити застарілі записи channel/plugin; невідомі ключі каналів без доказів застарілого plugin усе ще не проходять валідацію, щоб помилки друку залишалися видимими. Якщо встановлено plugins.enabled: false, застарілі посилання на plugin розглядаються як інертні: запуск Gateway пропускає виявлення/завантаження plugins, а OmeniaClaw doctor зберігає вимкнену конфігурацію plugin замість автоматичного видалення. Знову ввімкніть plugins перед запуском очищення doctor, якщо хочете видалити застарілі id plugin.

    Встановлення залежностей plugin відбувається лише під час явних потоків install/update або repair у doctor. Запуск Gateway, перезавантаження конфігурації та runtime inspection не запускають менеджери пакетів і не ремонтують дерева залежностей. Локальні plugins мають уже мати встановлені свої залежності, тоді як npm, git і ClawHub plugins встановлюються під керованими коренями plugins OmeniaClaw. Залежності npm можуть бути hoisted у межах керованого npm-кореня OmeniaClaw; install/update сканує цей керований корінь перед довірою, а uninstall видаляє npm-managed packages через npm. Зовнішні plugins і custom load paths усе ще мають установлюватися через OmeniaClaw plugins install. Використовуйте OmeniaClaw 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, OmeniaClaw знайшов файли plugin, що належать іншому Unix-користувачу, ніж процес, який їх завантажує. Залиште конфігурацію plugin на місці; виправте власність файлової системи або запускайте OmeniaClaw від того самого користувача, який володіє каталогом стану.

    Для встановлень Docker офіційний образ працює як node (uid 1000), тому примонтовані з хоста каталоги конфігурації та workspace OmeniaClaw зазвичай мають належати uid 1000:

    bash
    sudo chown -R 1000:1000 /path/to/OmeniaClaw-config /path/to/OmeniaClaw-workspace

    Якщо ви навмисно запускаєте OmeniaClaw як root, натомість виправте керований корінь plugin до власності root:

    bash
    sudo chown -R root:root /path/to/OmeniaClaw-config/npm

    Після виправлення власності повторно запустіть OmeniaClaw doctor --fix або OmeniaClaw plugins registry --refresh, щоб збережений реєстр plugin відповідав виправленим файлам.

    Для встановлень npm змінні селектори, як-от latest або dist-tag, розв'язуються перед встановленням, а потім закріплюються до точної перевіреної версії в керованому npm-корені OmeniaClaw. Після завершення npm OmeniaClaw перевіряє, що встановлений запис package-lock.json усе ще відповідає розв'язаній версії та integrity. Якщо npm записує інші метадані пакета, встановлення завершується помилкою, а керований пакет відкочується замість прийняття іншого artifact plugin. Керовані npm-корені також успадковують npm overrides рівня пакета OmeniaClaw, тому security pins, які захищають packaged host, також застосовуються до hoisted зовнішніх залежностей plugin.

    Source checkouts є pnpm workspaces. Якщо ви клонуєте OmeniaClaw, щоб працювати з bundled plugins, запустіть pnpm install; тоді OmeniaClaw завантажує bundled plugins з extensions/<id>, щоб правки й package-local dependencies використовувалися напряму. Звичайні npm root installs призначені для packaged OmeniaClaw, а не для розробки в source checkout.

    Типи Plugin

    OmeniaClaw розпізнає два формати plugin:

    Формат Як це працює Приклади
    Native OmeniaClaw.plugin.json + runtime-модуль; виконується in-process Офіційні plugins, спільнотні npm-пакети
    Bundle Codex/Claude/Cursor-сумісна структура; мапиться на функції OmeniaClaw .codex-plugin/, .claude-plugin/, .cursor-plugin/

    Обидва з'являються в OmeniaClaw plugins list. Див. Plugin Bundles для деталей bundle.

    Якщо ви пишете native plugin, почніть з Створення Plugins і Огляд Plugin SDK.

    Точки входу пакетів

    Пакети npm native plugin мають оголошувати OmeniaClaw.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 OmeniaClaw.

    Невідстежувані каталоги, скинуті в глобальний корінь extension, розглядаються як локальні source checkouts і можуть напряму завантажувати TypeScript entries. Каталоги, які все ще названі записом встановлення, включно з installPath або sourcePath, лишаються керованими й зберігають вимогу compiled-output навіть тоді, коли глобальне сканування бачить їх. Якщо ви навмисно перетворюєте кероване встановлення на невідстежуваний локальний checkout, спершу видаліть застарілий запис встановлення через uninstall або doctor cleanup.

    Якщо попередження керованого пакета каже, що він requires compiled runtime output for TypeScript entry ..., пакет було опубліковано без JavaScript-файлів, потрібних OmeniaClaw під час runtime. Це проблема пакування plugin, а не локальна проблема конфігурації. Оновіть або перевстановіть plugin після того, як видавець повторно опублікує зібраний JavaScript, або вимкніть/видаліть цей plugin, доки не буде доступний виправлений пакет.

    Використовуйте OmeniaClaw.runtimeExtensions, коли опубліковані runtime-файли не розташовані за тими самими шляхами, що й source entries. Якщо runtimeExtensions присутній, він має містити рівно один запис для кожного запису extensions. Невідповідні списки спричиняють помилку встановлення та виявлення plugin замість тихого fallback до source paths. Якщо ви також публікуєте OmeniaClaw.setupEntry, використовуйте OmeniaClaw.runtimeSetupEntry для його зібраного JavaScript peer; цей файл є обов'язковим, якщо його оголошено.

    json
    {  "name": "@acme/OmeniaClaw-plugin",  "OmeniaClaw": {    "extensions": ["./src/index.ts"],    "runtimeExtensions": ["./dist/index.js"]  }}

    Офіційні plugins

    Npm-пакети, що належать OmeniaClaw, під час міграції

    ClawHub є основним шляхом розповсюдження для більшості plugins. Поточні packaged релізи OmeniaClaw уже bundled багато офіційних plugins, тому їм не потрібні окремі npm-встановлення у звичайних налаштуваннях. Доки кожен plugin, що належить OmeniaClaw, не мігрує до ClawHub, OmeniaClaw усе ще постачає деякі пакети @OmeniaClaw/* plugin на npm для старіших/custom installs і прямих npm workflows.

    Якщо npm повідомляє, що пакет plugin @OmeniaClaw/* deprecated, ця версія пакета походить зі старішої external package train. Використовуйте bundled plugin з поточного OmeniaClaw або локальний checkout, доки не буде опубліковано новіший npm-пакет.

    Plugin Пакет Документація
    Discord @OmeniaClaw/discord Discord
    Feishu @OmeniaClaw/feishu Feishu
    Matrix @OmeniaClaw/matrix Matrix
    Mattermost @OmeniaClaw/mattermost Mattermost
    Microsoft Teams @OmeniaClaw/msteams Microsoft Teams
    Nextcloud Talk @OmeniaClaw/nextcloud-talk Nextcloud Talk
    Nostr @OmeniaClaw/nostr Nostr
    Synology Chat @OmeniaClaw/synology-chat Synology Chat
    Tlon @OmeniaClaw/tlon Tlon
    WhatsApp @OmeniaClaw/whatsapp WhatsApp
    Zalo @OmeniaClaw/zalo Zalo
    Zalo Personal @OmeniaClaw/zalouser Zalo Personal

    Core (постачається з OmeniaClaw)

    Постачальники моделей (увімкнено за замовчуванням)

    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")

    Див. Memory LanceDB щодо налаштування сумісних з OpenAI ембедингів, прикладів Ollama, лімітів пригадування та усунення несправностей.

    Постачальники мовлення (увімкнено за замовчуванням)

    elevenlabs, microsoft

    Інше
    • browser - вбудований браузерний Plugin для інструмента браузера, OmeniaClaw browser CLI, методу Gateway browser.request, браузерного середовища виконання та стандартної служби керування браузером (увімкнено за замовчуванням; вимкніть перед заміною)
    • copilot-proxy - міст VS Code Copilot Proxy (вимкнено за замовчуванням)

    Шукаєте сторонні плагіни? Див. ClawHub.

    Конфігурація

    json5
    {  plugins: {    enabled: true,    allow: ["voice-call"],    deny: ["untrusted-plugin"],    load: { paths: ["~/Projects/oss/voice-call-plugin"] },    entries: {      "voice-call": { enabled: true, config: { provider: "twilio" } },    },  },}
    Поле Опис
    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; OmeniaClaw doctor попереджає про таку форму.

    plugins.bundledDiscovery за замовчуванням має значення "allowlist" для нових конфігурацій, тому обмежувальний інвентар plugins.allow також блокує пропущені вбудовані Plugin постачальників, зокрема виявлення постачальників вебпошуку під час виконання. Doctor позначає старіші обмежувальні конфігурації списку дозволених значенням "compat" під час міграції, щоб оновлення зберігали застарілу поведінку вбудованих постачальників, доки оператор не ввімкне суворіший режим. Порожній plugins.allow досі трактується як не заданий/відкритий.

    Зміни конфігурації, зроблені через /plugins enable або /plugins disable, запускають перезавантаження Plugin Gateway у поточному процесі. Нові ходи агента перебудовують свій список інструментів з оновленого реєстру Plugin. Операції, що змінюють джерела, як-от install, update та uninstall, досі перезапускають процес Gateway, оскільки вже імпортовані модулі Plugin не можна безпечно замінити на місці.

    OmeniaClaw plugins list — це локальний знімок реєстру/конфігурації Plugin. Позначений як enabled Plugin там означає, що збережений реєстр і поточна конфігурація дозволяють Plugin брати участь. Це не доводить, що вже запущений віддалений Gateway перезавантажився або перезапустився з тим самим кодом Plugin. У налаштуваннях VPS/контейнерів з процесами-обгортками надсилайте перезапуски або записи, що запускають перезавантаження, до фактичного процесу OmeniaClaw gateway run, або використовуйте OmeniaClaw gateway restart для запущеного Gateway, коли перезавантаження повідомляє про помилку.

    Стани Plugin: вимкнений, відсутній, недійсний
    • Вимкнений: Plugin існує, але правила ввімкнення вимкнули його. Конфігурація зберігається.
    • Відсутній: конфігурація посилається на id Plugin, який виявлення не знайшло.
    • Недійсний: Plugin існує, але його конфігурація не відповідає оголошеній схемі. Запуск Gateway пропускає лише цей Plugin; OmeniaClaw doctor --fix може помістити недійсний запис у карантин, вимкнувши його та видаливши його конфігураційне навантаження.

    Виявлення та пріоритет

    OmeniaClaw сканує Plugin у такому порядку (перший збіг перемагає):

  • Шляхи конфігурації

    plugins.load.paths - явні шляхи до файлів або каталогів. Шляхи, що вказують назад на власні запаковані каталоги вбудованих Plugin OmeniaClaw, ігноруються; запустіть OmeniaClaw doctor --fix, щоб видалити ці застарілі псевдоніми.

  • Plugin робочого простору

    \<workspace\>/.OmeniaClaw/<plugin-root>/*.ts і \<workspace\>/.OmeniaClaw/<plugin-root>/*/index.ts.

  • Глобальні Plugin

    ~/.OmeniaClaw/<plugin-root>/*.ts і ~/.OmeniaClaw/<plugin-root>/*/index.ts.

  • Вбудовані Plugin

    Постачаються з OmeniaClaw. Багато з них увімкнені за замовчуванням (постачальники моделей, мовлення). Інші потребують явного ввімкнення.

  • Запаковані встановлення та Docker-образи зазвичай розв’язують вбудовані Plugin з скомпільованого дерева dist/extensions. Якщо вихідний каталог вбудованого Plugin прив’язано монтуванням поверх відповідного запакованого вихідного шляху, наприклад /app/extensions/synology-chat, OmeniaClaw трактує цей змонтований вихідний каталог як накладення джерела вбудованого Plugin і виявляє його перед запакованим пакетом /app/dist/extensions/synology-chat. Це зберігає працездатність контейнерних циклів супровідників без перемикання кожного вбудованого Plugin назад на вихідний код TypeScript. Задайте OmeniaClaw_DISABLE_BUNDLED_SOURCE_OVERLAYS=1, щоб примусово використовувати запаковані dist-пакети навіть за наявності змонтованих вихідних накладень.

    Правила ввімкнення

    • plugins.enabled: false вимикає всі Plugin і пропускає роботу з виявлення/завантаження Plugin
    • plugins.deny завжди має пріоритет над allow
    • plugins.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) не виконуються в живому чат-трафіку, спершу перевірте таке:

    • Запустіть OmeniaClaw gateway status --deep --require-rpc і підтвердьте, що активні URL Gateway, профіль, шлях конфігурації та процес є саме тими, які ви редагуєте.
    • Перезапустіть живий Gateway після змін установлення/конфігурації/коду Plugin. У контейнерах-обгортках PID 1 може бути лише супервізором; перезапустіть або надішліть сигнал дочірньому процесу OmeniaClaw gateway run.
    • Використовуйте OmeniaClaw 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 виконується лише після того, як спроба моделі створить вивід асистента.
    • Для доказу ефективної моделі сесії використовуйте OmeniaClaw sessions або поверхні сесії/статусу Gateway, а під час налагодження навантажень постачальника запускайте Gateway з --raw-stream --raw-stream-path <path>.

    Повільне налаштування інструментів Plugin

    Якщо здається, що ходи агента зависають під час підготовки інструментів, увімкніть трасувальне журналювання та перевірте рядки часу фабрик інструментів Plugin:

    bash
    OmeniaClaw config set logging.level traceOmeniaClaw logs --follow

    Шукайте:

    text
    [trace:plugin-tools] factory timings ...

    Підсумок перелічує загальний час фабрик і найповільніші фабрики інструментів Plugin, зокрема id Plugin, оголошені назви інструментів, форму результату та чи є інструмент необов’язковим. Повільні рядки підвищуються до попереджень, коли одна фабрика займає щонайменше 1с або загальна підготовка фабрик інструментів Plugin займає щонайменше 5с.

    OmeniaClaw кешує успішні результати фабрик інструментів Plugin для повторних розв’язань з тим самим ефективним контекстом запиту. Ключ кешу містить ефективну конфігурацію середовища виконання, робочий простір, id агента/сесії, політику sandbox, налаштування браузера, контекст доставки, ідентичність запитувача та стан володіння, тому фабрики, що залежать від цих довірених полів, повторно виконуються, коли контекст змінюється.

    Якщо один Plugin домінує за часом, перевірте його runtime-реєстрації:

    bash
    OmeniaClaw plugins inspect <plugin-id> --runtime --json

    Потім оновіть, перевстановіть або вимкніть цей 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>

    Це означає, що більш ніж один увімкнений Plugin намагається володіти тим самим каналом, потоком налаштування або назвою інструмента. Найпоширеніша причина — зовнішній Plugin каналу, встановлений поруч із вбудованим Plugin, який тепер надає той самий id каналу.

    Кроки налагодження:

    • Запустіть OmeniaClaw plugins list --enabled --verbose, щоб побачити кожен увімкнений Plugin і його походження.
    • Запустіть OmeniaClaw plugins inspect <id> --runtime --json для кожного підозрюваного Plugin і порівняйте channels, channelConfigs, tools і діагностику.
    • Запустіть OmeniaClaw 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, OmeniaClaw зберігає цей запит і повідомляє про конфлікт. Виберіть одного власника каналу або перейменуйте інструменти, що належать Plugin, щоб поверхня runtime була однозначною.

    Слоти Plugin (ексклюзивні категорії)

    Деякі категорії є ексклюзивними (активна лише одна за раз):

    json5
    {  plugins: {    slots: {      memory: "memory-core", // or "none" to disable      contextEngine: "legacy", // or a plugin id    },  },}
    Слот Що він контролює За замовчуванням
    memory Активний Plugin пам’яті memory-core
    contextEngine Активний рушій контексту legacy (вбудований)

    Довідник CLI

    bash
    OmeniaClaw plugins list                       # compact inventoryOmeniaClaw plugins list --enabled            # only enabled pluginsOmeniaClaw plugins list --verbose            # per-plugin detail linesOmeniaClaw plugins list --json               # machine-readable inventoryOmeniaClaw plugins search <query>            # search ClawHub plugin catalogOmeniaClaw plugins inspect <id>              # static detailOmeniaClaw plugins inspect <id> --runtime    # registered hooks/tools/CLI/gateway methodsOmeniaClaw plugins inspect <id> --json       # machine-readableOmeniaClaw plugins inspect --all             # fleet-wide tableOmeniaClaw plugins info <id>                 # inspect aliasOmeniaClaw plugins doctor                    # diagnosticsOmeniaClaw plugins registry                  # inspect persisted registry stateOmeniaClaw plugins registry --refresh        # rebuild persisted registryOmeniaClaw doctor --fix                      # repair plugin registry state OmeniaClaw plugins install <package>         # install from npm by defaultOmeniaClaw plugins install clawhub:<pkg>     # install from ClawHub onlyOmeniaClaw plugins install npm:<pkg>         # install from npm onlyOmeniaClaw plugins install git:<repo>        # install from gitOmeniaClaw plugins install git:<repo>@<ref>  # install from git refOmeniaClaw plugins install <spec> --force    # overwrite existing installOmeniaClaw plugins install <path>            # install from local pathOmeniaClaw plugins install -l <path>         # link (no copy) for devOmeniaClaw plugins install <plugin> --marketplace <source>OmeniaClaw plugins install <plugin> --marketplace https://github.com/<owner>/<repo>OmeniaClaw plugins install <spec> --pin      # record exact resolved npm specOmeniaClaw plugins install <spec> --dangerously-force-unsafe-installOmeniaClaw plugins update <id-or-npm-spec> # update one pluginOmeniaClaw plugins update <id-or-npm-spec> --dangerously-force-unsafe-installOmeniaClaw plugins update --all            # update allOmeniaClaw plugins uninstall <id>          # remove config and plugin index recordsOmeniaClaw plugins uninstall <id> --keep-filesOmeniaClaw plugins marketplace list <source>OmeniaClaw plugins marketplace list <source> --json # Verify runtime registrations after install.OmeniaClaw plugins inspect <id> --runtime --json # Run plugin-owned CLI commands directly from the OmeniaClaw root CLI.OmeniaClaw <plugin-command> --help OmeniaClaw plugins enable <id>OmeniaClaw plugins disable <id>

    Вбудовані плагіни постачаються разом з OmeniaClaw. Багато з них увімкнені за замовчуванням (наприклад, вбудовані провайдери моделей, вбудовані провайдери мовлення та вбудований браузерний плагін). Інші вбудовані плагіни все ще потребують OmeniaClaw plugins enable <id>.

    --force перезаписує наявний встановлений плагін або пакет хуків на місці. Використовуйте OmeniaClaw plugins update <id-or-npm-spec> для звичайних оновлень відстежуваних npm плагінів. Він не підтримується з --link, який повторно використовує шлях до джерела замість копіювання в керовану ціль встановлення.

    Коли plugins.allow уже задано, OmeniaClaw plugins install додає ідентифікатор встановленого плагіна до цього списку дозволених перед його ввімкненням. Якщо той самий ідентифікатор плагіна присутній у plugins.deny, встановлення видаляє цей застарілий запис заборони, щоб явне встановлення можна було завантажити одразу після перезапуску.

    OmeniaClaw зберігає сталий локальний реєстр плагінів як модель холодного читання для інвентарю плагінів, належності внесків і планування запуску. Потоки встановлення, оновлення, видалення, увімкнення та вимкнення оновлюють цей реєстр після зміни стану плагінів. Той самий файл plugins/installs.json зберігає тривалі метадані встановлення у верхньорівневому installRecords і відновлювані метадані маніфесту в plugins. Якщо реєстр відсутній, застарілий або недійсний, OmeniaClaw plugins registry --refresh відновлює його подання маніфестів із записів встановлення, політики конфігурації та метаданих маніфесту/пакета без завантаження runtime-модулів плагінів.

    У режимі Nix (OmeniaClaw_NIX_MODE=1) мутації життєвого циклу плагінів вимкнені. Керуйте вибором пакетів плагінів і конфігурацією через джерело Nix для встановлення; для nix-OmeniaClaw почніть із орієнтованого на агента швидкого старту. OmeniaClaw plugins update <id-or-npm-spec> застосовується до відстежуваних встановлень. Передавання специфікації npm-пакета з dist-tag або точною версією зіставляє назву пакета назад із записом відстежуваного плагіна та записує нову специфікацію для майбутніх оновлень. Передавання назви пакета без версії повертає точно закріплене встановлення до типової лінії релізів реєстру. Якщо встановлений npm-плагін уже відповідає розв’язаній версії та записаній ідентичності артефакта, OmeniaClaw пропускає оновлення без завантаження, перевстановлення або перезапису конфігурації. Коли OmeniaClaw 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, тоді як OmeniaClaw 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.

    OmeniaClaw plugins inspect <id> також повідомляє виявлені можливості набору, а також підтримувані або непідтримувані записи серверів MCP і LSP для плагінів на основі наборів.

    Джерелами маркетплейсу можуть бути назва відомого маркетплейсу Claude з ~/.claude/plugins/known_marketplaces.json, локальний корінь маркетплейсу або шлях marketplace.json, скорочений запис GitHub на кшталт owner/repo, URL репозиторію GitHub або git URL. Для віддалених маркетплейсів записи плагінів мають залишатися всередині клонованого репозиторію маркетплейсу та використовувати лише відносні джерела шляхів.

    Повні відомості див. у довіднику CLI для OmeniaClaw plugins.

    Огляд API Plugin

    Нативні плагіни експортують об’єкт точки входу, який надає register(api). Старіші плагіни все ще можуть використовувати activate(api) як застарілий псевдонім, але нові плагіни мають використовувати register.

    typescript
    export default definePluginEntry({  id: "my-plugin",  name: "My Plugin",  register(api) {    api.registerProvider({      /* ... */    });    api.registerTool({      /* ... */    });    api.registerChannel({      /* ... */    });  },});

    OmeniaClaw завантажує об’єкт точки входу та викликає register(api) під час активації плагіна. Завантажувач усе ще повертається до activate(api) для старіших плагінів, але вбудовані плагіни та нові зовнішні плагіни мають розглядати register як публічний контракт.

    api.registrationMode повідомляє плагіну, чому його точка входу завантажується:

    Режим Значення
    full Runtime-активація. Реєструйте інструменти, хуки, сервіси, команди, маршрути та інші активні побічні ефекти.
    discovery Виявлення можливостей лише для читання. Реєструйте провайдерів і метадані; код точки входу довіреного плагіна може завантажуватися, але пропускайте активні побічні ефекти.
    setup-only Завантаження метаданих налаштування каналу через легку точку входу налаштування.
    setup-runtime Завантаження налаштування каналу, якому також потрібна runtime-точка входу.
    cli-metadata Лише збирання метаданих команд CLI.

    Точки входу плагінів, які відкривають сокети, бази даних, фонові воркери або довготривалі клієнти, мають захищати ці побічні ефекти умовою api.registrationMode === "full". Завантаження в режимі виявлення кешуються окремо від активаційних завантажень і не замінюють поточний реєстр Gateway. Виявлення не активує плагін, але не є вільним від імпорту: OmeniaClaw може виконати довірену точку входу плагіна або модуль плагіна каналу, щоб побудувати знімок. Тримайте верхні рівні модулів легкими й без побічних ефектів, а мережеві клієнти, підпроцеси, слухачі, читання облікових даних і запуск сервісів переносіть за шляхи 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 } нічого не робить і не скидає попереднє скасування.

    Нативний сервер застосунку Codex запускає міст, який повертає нативні для Codex події інструментів до цієї поверхні хуків. Plugins можуть блокувати нативні інструменти Codex через before_tool_call, спостерігати результати через after_tool_call і брати участь у схваленнях Codex PermissionRequest. Міст поки не переписує аргументи нативних для Codex інструментів. Точна межа підтримки середовища виконання Codex описана в контракті підтримки Codex harness v1.

    Повну типізовану поведінку хуків див. в огляді SDK.

    Пов’язане

    Was this useful?
    On this page

    On this page