Plugins
حزم Plugin
يمكن لـ OpenClaw تثبيت الإضافات من ثلاثة أنظمة بيئية خارجية: Codex وClaude وCursor. تُسمّى هذه حزمًا، وهي حزم محتوى وبيانات وصفية يحوّلها OpenClaw إلى ميزات أصلية مثل Skills والخطافات وأدوات MCP.
لماذا توجد الحزم
تُنشر كثير من الإضافات المفيدة بتنسيق Codex أو Claude أو Cursor. وبدلًا من مطالبة المؤلفين بإعادة كتابتها كإضافات OpenClaw أصلية، يكتشف OpenClaw هذه التنسيقات ويحوّل محتواها المدعوم إلى مجموعة الميزات الأصلية. يعني هذا أنه يمكنك تثبيت حزمة أوامر Claude أو حزمة Skills لـ Codex واستخدامها فورًا.
تثبيت حزمة
التثبيت من دليل أو أرشيف أو سوق
# Local directoryopenclaw plugins install ./my-bundle # Archiveopenclaw plugins install ./my-bundle.tgz # Claude marketplaceopenclaw plugins marketplace list <marketplace-name>openclaw plugins install <plugin-name>@<marketplace-name>التحقق من الاكتشاف
openclaw plugins listopenclaw plugins inspect <id>تظهر الحزم على أنها Format: bundle مع نوع فرعي هو codex أو claude أو cursor.
إعادة التشغيل والاستخدام
openclaw gateway restartتتوفر الميزات المحوّلة (Skills، والخطافات، وأدوات MCP، وافتراضيات LSP) في الجلسة التالية.
ما الذي يحوّله OpenClaw من الحزم
لا تعمل كل ميزة في الحزم داخل OpenClaw اليوم. إليك ما يعمل وما يُكتشف لكنه غير موصول بعد.
مدعوم الآن
| الميزة | كيفية تحويلها | ينطبق على |
|---|---|---|
| محتوى Skills | تُحمّل جذور Skills في الحزمة كـ Skills عادية في OpenClaw | كل التنسيقات |
| الأوامر | تُعامل commands/ و.cursor/commands/ كجذور Skills |
Claude، Cursor |
| حزم الخطافات | تخطيطات HOOK.md + handler.ts بأسلوب OpenClaw |
Codex |
| أدوات MCP | تُدمج إعدادات MCP الخاصة بالحزمة في إعدادات OpenClaw المضمّنة؛ وتُحمّل خوادم stdio وHTTP المدعومة | كل التنسيقات |
| خوادم LSP | تُدمج ملفات Claude .lsp.json وlspServers المعلنة في البيان في افتراضيات LSP المضمّنة في OpenClaw |
Claude |
| الإعدادات | يُستورد settings.json الخاص بـ Claude كافتراضيات OpenClaw مضمّنة |
Claude |
محتوى Skills
- تُحمّل جذور Skills في الحزمة كجذور Skills عادية في OpenClaw
- تُعامل جذور
commandsفي Claude كجذور Skills إضافية - تُعامل جذور
.cursor/commandsفي Cursor كجذور Skills إضافية
يعني هذا أن ملفات أوامر Markdown الخاصة بـ Claude تعمل عبر مُحمّل Skills العادي في OpenClaw. وتعمل أوامر Markdown الخاصة بـ Cursor عبر المسار نفسه.
حزم الخطافات
- تعمل جذور الخطافات في الحزم فقط عندما تستخدم تخطيط حزمة الخطافات
العادي في OpenClaw. حاليًا، هذه هي غالبًا الحالة المتوافقة مع Codex:
HOOK.mdhandler.tsأوhandler.js
MCP لـ OpenClaw المضمّن
- يمكن للحزم المفعّلة الإسهام بإعدادات خادم MCP
- يدمج OpenClaw إعدادات MCP الخاصة بالحزمة في إعدادات OpenClaw المضمّنة الفعالة باسم
mcpServers - يعرّض OpenClaw أدوات MCP المدعومة من الحزم أثناء دورات وكيل OpenClaw المضمّن عبر تشغيل خوادم stdio أو الاتصال بخوادم HTTP
- تتضمن ملفات تعريف الأدوات
codingوmessagingأدوات MCP الخاصة بالحزم افتراضيًا؛ استخدمtools.deny: ["bundle-mcp"]لإلغاء ذلك لوكيل أو Gateway - تظل إعدادات الوكيل المضمّن المحلية للمشروع مطبقة بعد افتراضيات الحزمة، لذلك يمكن لإعدادات مساحة العمل تجاوز إدخالات MCP الخاصة بالحزمة عند الحاجة
- تُرتب كتالوجات أدوات MCP الخاصة بالحزم ترتيبًا حتميًا قبل التسجيل، بحيث لا
تؤدي تغييرات ترتيب
listTools()في المصدر إلى إرباك كتل أدوات ذاكرة التخزين المؤقت للمطالبات
وسائل النقل
يمكن لخوادم MCP استخدام نقل stdio أو HTTP:
Stdio يشغّل عملية فرعية:
{ "mcp": { "servers": { "my-server": { "command": "node", "args": ["server.js"], "env": { "PORT": "3000" } } } }}HTTP يتصل بخادم MCP قيد التشغيل عبر sse افتراضيًا، أو streamable-http عند طلب ذلك:
{ "mcp": { "servers": { "my-server": { "url": "http://localhost:3100/mcp", "transport": "streamable-http", "headers": { "Authorization": "Bearer ${MY_SECRET_TOKEN}" }, "connectionTimeoutMs": 30000 } } }}- يمكن تعيين
transportإلى"streamable-http"أو"sse"؛ وعند إغفاله يستخدم OpenClawsse type: "http"شكل لاحق أصلي للـ CLI؛ استخدمtransport: "streamable-http"في إعدادات OpenClaw. يقومopenclaw mcp setوopenclaw doctor --fixبتطبيع الاسم البديل الشائع.- لا يُسمح إلا بمخططات URL من نوع
http:وhttps: - تدعم قيم
headersاستيفاء${ENV_VAR} - يُرفض إدخال الخادم الذي يحتوي على كل من
commandوurl - تُحجب بيانات اعتماد URL (معلومات المستخدم ومعاملات الاستعلام) من أوصاف الأدوات والسجلات
- يتجاوز
connectionTimeoutMsمهلة الاتصال الافتراضية البالغة 30 ثانية لكل من وسائل نقل stdio وHTTP
تسمية الأدوات
يسجل OpenClaw أدوات MCP الخاصة بالحزم بأسماء آمنة للمزوّدين بالشكل
serverName__toolName. على سبيل المثال، خادم مفتاحه "vigil-harbor" ويعرّض أداة
memory_search يُسجل باسم vigil-harbor__memory_search.
- تُستبدل الأحرف خارج
A-Za-z0-9_-بـ- - تُضاف بادئة حرفية إلى الأجزاء التي قد تبدأ بغير حرف، لذلك تتحول
مفاتيح الخوادم الرقمية مثل
12306إلى بادئات أدوات آمنة للمزوّدين - تُحد بادئات الخوادم عند 30 حرفًا
- تُحد أسماء الأدوات الكاملة عند 64 حرفًا
- تعود أسماء الخوادم الفارغة إلى
mcp - تُميّز الأسماء المنقّاة المتصادمة بلاحقات رقمية
- يكون ترتيب الأدوات النهائي المعروض حتميًا حسب الاسم الآمن للحفاظ على استقرار ذاكرة التخزين المؤقت في دورات الوكيل المضمّن المتكررة
- يعامل ترشيح ملف التعريف كل الأدوات من خادم MCP واحد في الحزمة على أنها مملوكة لإضافة
باسم
bundle-mcp، لذلك يمكن أن تتضمن قوائم السماح والمنع في ملفات التعريف إما أسماء الأدوات المعروضة الفردية أو مفتاح الإضافةbundle-mcp
إعدادات OpenClaw المضمّنة
- يُستورد
settings.jsonالخاص بـ Claude كإعدادات OpenClaw مضمّنة افتراضية عندما تكون الحزمة مفعّلة - ينقّي OpenClaw مفاتيح تجاوز الصدفة قبل تطبيقها
المفاتيح المنقّاة:
shellPathshellCommandPrefix
LSP المضمّن في OpenClaw
- يمكن لحزم Claude المفعّلة الإسهام بإعدادات خادم LSP
- يحمّل OpenClaw ملف
.lsp.jsonإضافة إلى أي مساراتlspServersمعلنة في البيان - تُدمج إعدادات LSP الخاصة بالحزمة في افتراضيات LSP الفعالة المضمّنة في OpenClaw
- لا يمكن تشغيل سوى خوادم LSP المدعومة والمعتمدة على stdio اليوم؛ أما وسائل النقل
غير المدعومة فتظل ظاهرة في
openclaw plugins inspect <id>
مكتشف لكنه غير منفّذ
تُتعرف هذه العناصر وتظهر في التشخيصات، لكن OpenClaw لا يشغّلها:
agentsوhooks.jsonautomation وoutputStylesفي Claude.cursor/agentsو.cursor/hooks.jsonو.cursor/rulesفي Cursor- البيانات الوصفية المضمّنة/الخاصة بالتطبيق في Codex بما يتجاوز الإبلاغ عن القدرات
تنسيقات الحزم
حزم Codex
العلامات: .codex-plugin/plugin.json
محتوى اختياري: skills/ وhooks/ و.mcp.json و.app.json
تناسب حزم Codex OpenClaw على أفضل وجه عندما تستخدم جذور Skills وأدلة
حزم خطافات بأسلوب OpenClaw (HOOK.md + handler.ts).
حزم Claude
وضعا اكتشاف:
- معتمدة على البيان:
.claude-plugin/plugin.json - بلا بيان: تخطيط Claude الافتراضي (
skills/،commands/،agents/،hooks/،.mcp.json،.lsp.json،settings.json)
سلوك خاص بـ Claude:
- يُعامل
commands/كمحتوى Skills - يُستورد
settings.jsonإلى إعدادات OpenClaw المضمّنة (تُنقّى مفاتيح تجاوز الصدفة) - يعرّض
.mcp.jsonأدوات stdio المدعومة إلى OpenClaw المضمّن - تُحمّل
.lsp.jsonإضافة إلى مساراتlspServersالمعلنة في البيان إلى افتراضيات LSP المضمّنة في OpenClaw - يُكتشف
hooks/hooks.jsonلكنه لا يُنفّذ - مسارات المكونات المخصصة في البيان إضافية (توسّع الافتراضيات ولا تستبدلها)
حزم Cursor
العلامات: .cursor-plugin/plugin.json
محتوى اختياري: skills/ و.cursor/commands/ و.cursor/agents/ و.cursor/rules/ و.cursor/hooks.json و.mcp.json
- يُعامل
.cursor/commands/كمحتوى Skills .cursor/rules/و.cursor/agents/و.cursor/hooks.jsonمخصصة للاكتشاف فقط
أسبقية الاكتشاف
يتحقق OpenClaw من تنسيق الإضافة الأصلية أولًا:
openclaw.plugin.jsonأوpackage.jsonصالح معopenclaw.extensions— يُعامل كـ إضافة أصلية- علامات الحزمة (
.codex-plugin/أو.claude-plugin/أو تخطيط Claude/Cursor الافتراضي) — تُعامل كـ حزمة
إذا احتوى دليل على الاثنين معًا، يستخدم OpenClaw المسار الأصلي. يمنع هذا تثبيت الحزم ثنائية التنسيق جزئيًا كحزم.
تبعيات وقت التشغيل والتنظيف
- لا تحصل الحزم المتوافقة من جهات خارجية على إصلاح
npm installعند بدء التشغيل. يجب تثبيتها عبرopenclaw plugins installوأن تشحن كل ما تحتاج إليه داخل دليل الإضافة المثبّتة. - تكون الإضافات المجمّعة المملوكة لـ OpenClaw إما مشحونة بشكل خفيف داخل النواة أو قابلة للتنزيل عبر مثبت الإضافات. لا يشغّل بدء تشغيل Gateway أبدًا مدير حزم لها.
- يزيل
openclaw doctor --fixأدلة التبعيات المرحلية القديمة ويمكنه استرداد الإضافات القابلة للتنزيل المفقودة من فهرس الإضافات المحلي عندما تشير إليها الإعدادات.
الأمان
للحزم حد ثقة أضيق من الإضافات الأصلية:
- لا يحمّل OpenClaw وحدات وقت تشغيل عشوائية من الحزم داخل العملية
- يجب أن تبقى مسارات Skills وحزم الخطافات داخل جذر الإضافة (مع فحص الحدود)
- تُقرأ ملفات الإعدادات بفحوصات الحدود نفسها
- قد تُشغّل خوادم MCP المدعومة عبر stdio كعمليات فرعية
يجعل هذا الحزم أكثر أمانًا افتراضيًا، لكن يجب عليك مع ذلك التعامل مع حزم الجهات الخارجية كمحتوى موثوق للميزات التي تعرّضها.
استكشاف الأخطاء وإصلاحها
الحزمة مكتشفة لكن القدرات لا تعمل
شغّل openclaw plugins inspect <id>. إذا كانت قدرة مدرجة لكنها مميزة على أنها
غير موصولة، فهذا حد في المنتج، وليس تثبيتًا معطّلًا.
ملفات أوامر Claude لا تظهر
تأكد من أن الحزمة مفعّلة وأن ملفات Markdown موجودة داخل جذر
commands/ أو skills/ مكتشف.
إعدادات Claude لا تُطبّق
لا يُدعم إلا إعدادات OpenClaw المضمّنة من settings.json. لا يتعامل OpenClaw
مع إعدادات الحزمة كتصحيحات إعدادات خام.
خطافات Claude لا تُنفّذ
hooks/hooks.json مخصص للاكتشاف فقط. إذا كنت تحتاج إلى خطافات قابلة للتشغيل، فاستخدم
تخطيط حزم الخطافات في OpenClaw أو اشحن إضافة أصلية.
ذات صلة
- تثبيت الإضافات وتهيئتها
- بناء الإضافات — أنشئ إضافة أصلية
- بيان الإضافة — مخطط البيان الأصلي