Plugins
Pakiety Plugin
OpenClaw może instalować pluginy z trzech zewnętrznych ekosystemów: Codex, Claude i Cursor. Są one nazywane pakietami — pakietami treści i metadanych, które OpenClaw mapuje na natywne funkcje, takie jak Skills, hooki i narzędzia MCP.
Dlaczego istnieją pakiety
Wiele przydatnych pluginów jest publikowanych w formacie Codex, Claude lub Cursor. Zamiast wymagać od autorów przepisywania ich jako natywnych pluginów OpenClaw, OpenClaw wykrywa te formaty i mapuje ich obsługiwaną treść na natywny zestaw funkcji. Oznacza to, że możesz zainstalować pakiet poleceń Claude lub pakiet Skills Codex i od razu go używać.
Zainstaluj pakiet
Zainstaluj z katalogu, archiwum lub marketplace
# Local directory
openclaw plugins install ./my-bundle
# Archive
openclaw plugins install ./my-bundle.tgz
# Claude marketplace
openclaw plugins marketplace list <marketplace-name>
openclaw plugins install <plugin-name>@<marketplace-name>
Zweryfikuj wykrywanie
openclaw plugins list
openclaw plugins inspect <id>
Pakiety są wyświetlane jako Format: bundle z podtypem codex, claude lub cursor.
Uruchom ponownie i użyj
openclaw gateway restart
Zmapowane funkcje (Skills, hooki, narzędzia MCP, domyślne ustawienia LSP) są dostępne w następnej sesji.
Co OpenClaw mapuje z pakietów
Nie każda funkcja pakietu działa dziś w OpenClaw. Oto, co działa i co jest wykrywane, ale nie jest jeszcze podłączone.
Obsługiwane obecnie
| Funkcja | Jak jest mapowana | Dotyczy |
|---|---|---|
| Treść Skills | Katalogi główne Skills pakietu są ładowane jak zwykłe Skills OpenClaw | Wszystkie formaty |
| Polecenia | commands/ i .cursor/commands/ są traktowane jako katalogi główne Skills |
Claude, Cursor |
| Pakiety hooków | Układy w stylu OpenClaw: HOOK.md + handler.ts |
Codex |
| Narzędzia MCP | Konfiguracja MCP pakietu scalona z osadzonymi ustawieniami Pi; obsługiwane serwery stdio i HTTP są ładowane | Wszystkie formaty |
| Serwery LSP | Claude .lsp.json i zadeklarowane w manifeście lspServers scalone z domyślnymi ustawieniami LSP osadzonego Pi |
Claude |
| Ustawienia | Claude settings.json zaimportowane jako domyślne ustawienia osadzonego Pi |
Claude |
Treść Skills
- katalogi główne Skills pakietu są ładowane jak zwykłe katalogi główne Skills OpenClaw
- katalogi główne Claude
commandssą traktowane jako dodatkowe katalogi główne Skills - katalogi główne Cursor
.cursor/commandssą traktowane jako dodatkowe katalogi główne Skills
Oznacza to, że pliki poleceń markdown Claude działają przez standardowy loader Skills OpenClaw. Markdown poleceń Cursor działa tą samą ścieżką.
Pakiety hooków
- katalogi główne hooków pakietu działają tylko wtedy, gdy używają standardowego układu
pakietu hooków OpenClaw. Dziś jest to przede wszystkim przypadek zgodny z Codex:
HOOK.mdhandler.tslubhandler.js
MCP dla Pi
- włączone pakiety mogą dostarczać konfigurację serwera MCP
- OpenClaw scala konfigurację MCP pakietu z efektywnymi ustawieniami osadzonego Pi jako
mcpServers - OpenClaw udostępnia obsługiwane narzędzia MCP pakietu podczas tur agenta osadzonego Pi przez uruchamianie serwerów stdio lub łączenie się z serwerami HTTP
- profile narzędzi
codingimessagingdomyślnie zawierają narzędzia MCP pakietów; użyjtools.deny: ["bundle-mcp"], aby zrezygnować z nich dla agenta lub gateway - lokalne ustawienia projektu Pi nadal mają zastosowanie po domyślnych ustawieniach pakietu, więc ustawienia obszaru roboczego mogą w razie potrzeby nadpisywać wpisy MCP pakietu
- katalogi narzędzi MCP pakietów są sortowane deterministycznie przed rejestracją, więc
zmiany kolejności upstream
listTools()nie destabilizują bloków narzędzi prompt-cache
Transporty
Serwery MCP mogą używać transportu stdio lub HTTP:
Stdio uruchamia proces potomny:
{
"mcp": {
"servers": {
"my-server": {
"command": "node",
"args": ["server.js"],
"env": { "PORT": "3000" }
}
}
}
}
HTTP łączy się z działającym serwerem MCP przez sse domyślnie albo streamable-http, gdy zostanie to zażądane:
{
"mcp": {
"servers": {
"my-server": {
"url": "http://localhost:3100/mcp",
"transport": "streamable-http",
"headers": {
"Authorization": "Bearer ${MY_SECRET_TOKEN}"
},
"connectionTimeoutMs": 30000
}
}
}
}
transportmoże być ustawiony na"streamable-http"lub"sse"; gdy zostanie pominięty, OpenClaw używassetype: "http"to natywny dla CLI kształt downstream; w konfiguracji OpenClaw użyjtransport: "streamable-http".openclaw mcp setiopenclaw doctor --fixnormalizują typowy alias.- dozwolone są tylko schematy URL
http:ihttps: - wartości
headersobsługują interpolację${ENV_VAR} - wpis serwera zawierający jednocześnie
commandiurljest odrzucany - dane uwierzytelniające URL (userinfo i parametry zapytania) są redagowane z opisów narzędzi i logów
connectionTimeoutMsnadpisuje domyślny 30-sekundowy limit czasu połączenia dla transportów stdio i HTTP
Nazewnictwo narzędzi
OpenClaw rejestruje narzędzia MCP pakietu z nazwami bezpiecznymi dla dostawców w formie
serverName__toolName. Na przykład serwer o kluczu "vigil-harbor" udostępniający
narzędzie memory_search jest rejestrowany jako vigil-harbor__memory_search.
- znaki spoza
A-Za-z0-9_-są zastępowane przez- - prefiksy serwerów są ograniczone do 30 znaków
- pełne nazwy narzędzi są ograniczone do 64 znaków
- puste nazwy serwerów używają wartości zapasowej
mcp - kolidujące oczyszczone nazwy są rozróżniane za pomocą sufiksów numerycznych
- końcowa kolejność udostępnianych narzędzi jest deterministyczna według bezpiecznej nazwy, aby powtarzane tury Pi pozostawały stabilne dla cache
- filtrowanie profili traktuje wszystkie narzędzia z jednego serwera MCP pakietu jako należące do pluginu
bundle-mcp, więc listy dozwolone i listy blokowane profilu mogą zawierać albo pojedyncze udostępnione nazwy narzędzi, albo klucz pluginubundle-mcp
Ustawienia osadzonego Pi
- Claude
settings.jsonjest importowany jako domyślne ustawienia osadzonego Pi, gdy pakiet jest włączony - OpenClaw oczyszcza klucze nadpisywania powłoki przed ich zastosowaniem
Oczyszczone klucze:
shellPathshellCommandPrefix
LSP osadzonego Pi
- włączone pakiety Claude mogą dostarczać konfigurację serwera LSP
- OpenClaw ładuje
.lsp.jsonoraz wszelkie ścieżkilspServerszadeklarowane w manifeście - konfiguracja LSP pakietu jest scalana z efektywnymi domyślnymi ustawieniami LSP osadzonego Pi
- dziś uruchamialne są tylko obsługiwane serwery LSP oparte na stdio; nieobsługiwane
transporty nadal pojawiają się w
openclaw plugins inspect <id>
Wykrywane, ale niewykonywane
Te elementy są rozpoznawane i pokazywane w diagnostyce, ale OpenClaw ich nie uruchamia:
- Claude
agents, automatyzacjahooks.json,outputStyles - Cursor
.cursor/agents,.cursor/hooks.json,.cursor/rules - Metadane inline/aplikacji Codex poza raportowaniem możliwości
Formaty pakietów
Pakiety Codex
Markery: .codex-plugin/plugin.json
Opcjonalna treść: skills/, hooks/, .mcp.json, .app.json
Pakiety Codex najlepiej pasują do OpenClaw, gdy używają katalogów głównych Skills oraz katalogów
pakietów hooków w stylu OpenClaw (HOOK.md + handler.ts).
Pakiety Claude
Dwa tryby wykrywania:
- Oparte na manifeście:
.claude-plugin/plugin.json - Bez manifestu: domyślny układ Claude (
skills/,commands/,agents/,hooks/,.mcp.json,.lsp.json,settings.json)
Zachowanie specyficzne dla Claude:
commands/jest traktowany jako treść Skillssettings.jsonjest importowany do ustawień osadzonego Pi (klucze nadpisywania powłoki są oczyszczane).mcp.jsonudostępnia obsługiwane narzędzia stdio osadzonemu Pi.lsp.jsonoraz ścieżkilspServerszadeklarowane w manifeście są ładowane do domyślnych ustawień LSP osadzonego Pihooks/hooks.jsonjest wykrywany, ale niewykonywany- Niestandardowe ścieżki komponentów w manifeście są addytywne (rozszerzają domyślne, nie zastępują ich)
Pakiety Cursor
Markery: .cursor-plugin/plugin.json
Opcjonalna treść: skills/, .cursor/commands/, .cursor/agents/, .cursor/rules/, .cursor/hooks.json, .mcp.json
.cursor/commands/jest traktowany jako treść Skills.cursor/rules/,.cursor/agents/i.cursor/hooks.jsonsą tylko wykrywane
Pierwszeństwo wykrywania
OpenClaw najpierw sprawdza natywny format pluginu:
openclaw.plugin.jsonlub prawidłowypackage.jsonzopenclaw.extensions— traktowane jako natywny plugin- Markery pakietów (
.codex-plugin/,.claude-plugin/lub domyślny układ Claude/Cursor) — traktowane jako pakiet
Jeśli katalog zawiera oba, OpenClaw używa ścieżki natywnej. Zapobiega to częściowej instalacji pakietów w dwóch formatach jako pakietów.
Zależności środowiska uruchomieniowego i czyszczenie
- Zgodne pakiety firm trzecich nie otrzymują naprawy startowej
npm install. Powinny być instalowane przezopenclaw plugins installi dostarczać wszystko, czego potrzebują, w zainstalowanym katalogu pluginu. - Pluginy pakietowe należące do OpenClaw są albo dostarczane w lekkiej postaci w core, albo pobierane przez instalator pluginów. Uruchomienie Gateway nigdy nie uruchamia dla nich menedżera pakietów.
openclaw doctor --fixusuwa starsze katalogi etapowanych zależności i może odzyskać pobieralne pluginy, których brakuje w lokalnym indeksie pluginów, gdy konfiguracja się do nich odwołuje.
Bezpieczeństwo
Pakiety mają węższą granicę zaufania niż natywne pluginy:
- OpenClaw nie ładuje dowolnych modułów uruchomieniowych pakietu w procesie
- Ścieżki Skills i pakietów hooków muszą pozostać wewnątrz katalogu głównego pluginu (sprawdzane względem granic)
- Pliki ustawień są odczytywane z tymi samymi kontrolami granic
- Obsługiwane serwery MCP stdio mogą być uruchamiane jako podprocesy
Dzięki temu pakiety są domyślnie bezpieczniejsze, ale nadal należy traktować pakiety firm trzecich jako zaufaną treść dla funkcji, które faktycznie udostępniają.
Rozwiązywanie problemów
Pakiet jest wykrywany, ale możliwości nie działają
Uruchom openclaw plugins inspect <id>. Jeśli możliwość jest wymieniona, ale oznaczona jako
niepodłączona, jest to ograniczenie produktu — nie uszkodzona instalacja.
Pliki poleceń Claude się nie pojawiają
Upewnij się, że pakiet jest włączony, a pliki markdown znajdują się w wykrytym
katalogu głównym commands/ lub skills/.
Ustawienia Claude nie są stosowane
Obsługiwane są tylko ustawienia osadzonego Pi z settings.json. OpenClaw nie
traktuje ustawień pakietu jako surowych łatek konfiguracji.
Hooki Claude się nie wykonują
hooks/hooks.json jest tylko wykrywany. Jeśli potrzebujesz uruchamialnych hooków, użyj
układu pakietu hooków OpenClaw albo dostarcz natywny plugin.
Powiązane
- Instalowanie i konfigurowanie pluginów
- Tworzenie pluginów — utwórz natywny plugin
- Manifest pluginu — natywny schemat manifestu