استخدم IRC عندما تريد 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.
#room) والرسائل المباشرة.
يأتي IRC كـ Plugin مضمن، لكنه يُكوَّن في الإعدادات الرئيسية ضمن channels.irc.
البدء السريع
- فعّل إعدادات IRC في
~/.openclaw/openclaw.json. - اضبط على الأقل:
- ابدأ/أعد تشغيل Gateway:
افتراضيات الأمان
- يستخدم IRC مقابس TCP/TLS خامًا خارج توجيه وكيل التمرير الأمامي المُدار من مشغّل OpenClaw. في عمليات النشر التي تتطلب مرور كل الخروج عبر وكيل التمرير الأمامي هذا، اضبط
channels.irc.enabled=falseما لم تتم الموافقة صراحةً على خروج IRC المباشر. - القيمة الافتراضية لـ
channels.irc.dmPolicyهي"pairing". - القيمة الافتراضية لـ
channels.irc.groupPolicyهي"allowlist". - مع
groupPolicy="allowlist"، اضبطchannels.irc.groupsلتعريف القنوات المسموح بها. - استخدم TLS (
channels.irc.tls=true) ما لم تكن تقبل النقل بالنص الصريح عن قصد.
التحكم في الوصول
توجد “بوابتان” منفصلتان لقنوات IRC:- وصول القناة (
groupPolicy+groups): ما إذا كان البوت يقبل الرسائل من قناة أصلًا. - وصول المرسل (
groupAllowFrom/ لكل قناةgroups["#channel"].allowFrom): من يُسمح له بتشغيل البوت داخل تلك القناة.
- قائمة السماح للرسائل المباشرة (وصول مرسل الرسائل المباشرة):
channels.irc.allowFrom - قائمة سماح مرسلي المجموعة (وصول مرسل القناة):
channels.irc.groupAllowFrom - عناصر التحكم لكل قناة (قواعد القناة + المرسل + الإشارة):
channels.irc.groups["#channel"] - يتيح
channels.irc.groupPolicy="open"القنوات غير المكوّنة (مع بقائها مقيّدة بالإشارة افتراضيًا)
nick!user@host).
مطابقة الاسم المستعار وحده قابلة للتغيير ولا تُفعّل إلا عند channels.irc.dangerouslyAllowNameMatching: true.
مشكلة شائعة: allowFrom مخصص للرسائل المباشرة، وليس للقنوات
إذا رأيت سجلات مثل:
irc: drop group sender alice!ident@host (policy=allowlist)
- ضبط
channels.irc.groupAllowFrom(عام لكل القنوات)، أو - ضبط قوائم سماح المرسلين لكل قناة:
channels.irc.groups["#channel"].allowFrom
#tuirc-dev بالتحدث إلى البوت):
تشغيل الرد (الإشارات)
حتى إذا كانت القناة مسموحًا بها (عبرgroupPolicy + groups) وكان المرسل مسموحًا به، فإن OpenClaw يستخدم افتراضيًا تقييد الإشارة في سياقات المجموعات.
وهذا يعني أنك قد ترى سجلات مثل drop channel … (missing-mention) ما لم تتضمن الرسالة نمط إشارة يطابق البوت.
لجعل البوت يرد في قناة IRC من دون الحاجة إلى إشارة، عطّل تقييد الإشارة لتلك القناة:
ملاحظة أمنية (موصى بها للقنوات العامة)
إذا سمحت بـallowFrom: ["*"] في قناة عامة، فيمكن لأي شخص إرسال مطالبات إلى البوت.
لتقليل المخاطر، قيّد الأدوات لتلك القناة.
الأدوات نفسها لكل شخص في القناة
أدوات مختلفة لكل مرسل (يحصل المالك على صلاحيات أكثر)
استخدمtoolsBySender لتطبيق سياسة أكثر صرامة على "*" وسياسة أخف على اسمك المستعار:
- يجب أن تستخدم مفاتيح
toolsBySenderالبادئةid:لقيم هوية مرسل IRC:id:eigenأوid:eigen!~eigen@174.127.248.171لمطابقة أقوى. - لا تزال المفاتيح القديمة غير المسبوقة مقبولة وتُطابق كـ
id:فقط. - تفوز أول سياسة مرسل مطابقة؛ أما
"*"فهي خيار الرجوع العام.
NickServ
للتعريف مع NickServ بعد الاتصال:register بعد تسجيل الاسم المستعار لتجنب محاولات REGISTER المتكررة.
متغيرات البيئة
يدعم الحساب الافتراضي:IRC_HOSTIRC_PORTIRC_TLSIRC_NICKIRC_USERNAMEIRC_REALNAMEIRC_PASSWORDIRC_CHANNELS(مفصولة بفواصل)IRC_NICKSERV_PASSWORDIRC_NICKSERV_REGISTER_EMAIL
IRC_HOST من ملف .env في مساحة العمل؛ راجع ملفات .env لمساحة العمل.
استكشاف الأخطاء وإصلاحها
- إذا كان البوت يتصل لكنه لا يرد أبدًا في القنوات، فتحقق من
channels.irc.groupsومن ما إذا كان تقييد الإشارة يسقط الرسائل (missing-mention). إذا كنت تريده أن يرد من دون تنبيهات، فاضبطrequireMention:falseللقناة. - إذا فشل تسجيل الدخول، فتحقق من توفر الاسم المستعار وكلمة مرور الخادم.
- إذا فشل TLS على شبكة مخصصة، فتحقق من المضيف/المنفذ وإعداد الشهادة.
ذات صلة
- نظرة عامة على القنوات — كل القنوات المدعومة
- الاقتران — مصادقة الرسائل المباشرة وتدفق الاقتران
- المجموعات — سلوك دردشة المجموعة وتقييد الإشارة
- توجيه القنوات — توجيه الجلسات للرسائل
- الأمان — نموذج الوصول والتقوية