Developer and self-hosted
IRC
استخدم IRC عندما تريد OpenClaw في القنوات الكلاسيكية (#room) والرسائل المباشرة.
يأتي IRC كـ Plugin مضمن، لكنه يُكوَّن في الإعدادات الرئيسية ضمن channels.irc.
البدء السريع
- فعّل إعدادات IRC في
~/.openclaw/openclaw.json. - اضبط على الأقل:
{
channels: {
irc: {
enabled: true,
host: "irc.example.com",
port: 6697,
tls: true,
nick: "openclaw-bot",
channels: ["#openclaw"],
},
},
}
فضّل خادم IRC خاصًا لتنسيق البوتات. إذا كنت تستخدم شبكة IRC عامة عن قصد، فمن الخيارات الشائعة Libera.Chat وOFTC وSnoonet. تجنّب القنوات العامة المتوقعة لحركة مرور القناة الخلفية للبوتات أو السرب.
- ابدأ/أعد تشغيل Gateway:
openclaw gateway run
افتراضيات الأمان
- يستخدم 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 بالتحدث إلى البوت):
{
channels: {
irc: {
groupPolicy: "allowlist",
groups: {
"#tuirc-dev": { allowFrom: ["*"] },
},
},
},
}
تشغيل الرد (الإشارات)
حتى إذا كانت القناة مسموحًا بها (عبر groupPolicy + groups) وكان المرسل مسموحًا به، فإن OpenClaw يستخدم افتراضيًا تقييد الإشارة في سياقات المجموعات.
وهذا يعني أنك قد ترى سجلات مثل drop channel … (missing-mention) ما لم تتضمن الرسالة نمط إشارة يطابق البوت.
لجعل البوت يرد في قناة IRC من دون الحاجة إلى إشارة، عطّل تقييد الإشارة لتلك القناة:
{
channels: {
irc: {
groupPolicy: "allowlist",
groups: {
"#tuirc-dev": {
requireMention: false,
allowFrom: ["*"],
},
},
},
},
}
أو للسماح بكل قنوات IRC (من دون قائمة سماح لكل قناة) مع الاستمرار في الرد من دون إشارات:
{
channels: {
irc: {
groupPolicy: "open",
groups: {
"*": { requireMention: false, allowFrom: ["*"] },
},
},
},
}
ملاحظة أمنية (موصى بها للقنوات العامة)
إذا سمحت بـ allowFrom: ["*"] في قناة عامة، فيمكن لأي شخص إرسال مطالبات إلى البوت.
لتقليل المخاطر، قيّد الأدوات لتلك القناة.
الأدوات نفسها لكل شخص في القناة
{
channels: {
irc: {
groups: {
"#tuirc-dev": {
allowFrom: ["*"],
tools: {
deny: ["group:runtime", "group:fs", "gateway", "nodes", "cron", "browser"],
},
},
},
},
},
}
أدوات مختلفة لكل مرسل (يحصل المالك على صلاحيات أكثر)
استخدم toolsBySender لتطبيق سياسة أكثر صرامة على "*" وسياسة أخف على اسمك المستعار:
{
channels: {
irc: {
groups: {
"#tuirc-dev": {
allowFrom: ["*"],
toolsBySender: {
"*": {
deny: ["group:runtime", "group:fs", "gateway", "nodes", "cron", "browser"],
},
"id:eigen": {
deny: ["gateway", "nodes", "cron"],
},
},
},
},
},
},
}
ملاحظات:
- يجب أن تستخدم مفاتيح
toolsBySenderالبادئةid:لقيم هوية مرسل IRC:id:eigenأوid:[email protected]لمطابقة أقوى. - لا تزال المفاتيح القديمة غير المسبوقة مقبولة وتُطابق كـ
id:فقط. - تفوز أول سياسة مرسل مطابقة؛ أما
"*"فهي خيار الرجوع العام.
لمزيد من المعلومات حول وصول المجموعة مقابل تقييد الإشارة (وكيفية تفاعلهما)، راجع: /channels/groups.
NickServ
للتعريف مع NickServ بعد الاتصال:
{
channels: {
irc: {
nickserv: {
enabled: true,
service: "NickServ",
password: "your-nickserv-password",
},
},
},
}
تسجيل اختياري لمرة واحدة عند الاتصال:
{
channels: {
irc: {
nickserv: {
register: true,
registerEmail: "[email protected]",
},
},
},
}
عطّل 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 على شبكة مخصصة، فتحقق من المضيف/المنفذ وإعداد الشهادة.
ذات صلة
- نظرة عامة على القنوات — كل القنوات المدعومة
- الاقتران — مصادقة الرسائل المباشرة وتدفق الاقتران
- المجموعات — سلوك دردشة المجموعة وتقييد الإشارة
- توجيه القنوات — توجيه الجلسات للرسائل
- الأمان — نموذج الوصول والتقوية