مفاتيح إعدادات كل قناة ضمنDocumentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
channels.*. تغطي الوصول إلى الرسائل المباشرة والمجموعات،
وإعدادات الحسابات المتعددة، وبوابة الإشارات، ومفاتيح كل قناة لـ Slack وDiscord
وTelegram وWhatsApp وMatrix وiMessage وغيرها من Plugins القنوات المضمّنة.
بالنسبة إلى الوكلاء والأدوات وبيئة تشغيل Gateway والمفاتيح العليا الأخرى، راجع
مرجع الإعدادات.
القنوات
تبدأ كل قناة تلقائياً عند وجود قسم إعداداتها (ما لم يكنenabled: false).
الوصول إلى الرسائل المباشرة والمجموعات
تدعم كل القنوات سياسات الرسائل المباشرة وسياسات المجموعات:| سياسة الرسائل المباشرة | السلوك |
|---|---|
pairing (الافتراضي) | يحصل المرسلون غير المعروفين على رمز إقران لمرة واحدة؛ يجب أن يوافق المالك |
allowlist | المرسلون الموجودون في allowFrom فقط (أو مخزن السماح المقترن) |
open | السماح بكل الرسائل المباشرة الواردة (يتطلب allowFrom: ["*"]) |
disabled | تجاهل كل الرسائل المباشرة الواردة |
| سياسة المجموعة | السلوك |
|---|---|
allowlist (الافتراضي) | المجموعات المطابقة لقائمة السماح المضبوطة فقط |
open | تجاوز قوائم السماح للمجموعات (تظل بوابة الإشارات مطبقة) |
disabled | حظر كل رسائل المجموعات/الغرف |
يضبط
channels.defaults.groupPolicy القيمة الافتراضية عندما لا تكون groupPolicy لدى مزود معيّن مضبوطة.
تنتهي صلاحية رموز الإقران بعد ساعة واحدة. طلبات إقران الرسائل المباشرة المعلّقة محدودة بـ 3 لكل قناة.
إذا كانت كتلة المزود مفقودة بالكامل (غياب channels.<provider>)، فستعود سياسة مجموعات وقت التشغيل إلى allowlist (إغلاق عند الفشل) مع تحذير عند بدء التشغيل.تجاوزات نموذج القناة
استخدمchannels.modelByChannel لتثبيت معرّفات قنوات محددة على نموذج. تقبل القيم provider/model أو أسماء النماذج المستعارة المضبوطة. يُطبّق تعيين القناة عندما لا تحتوي الجلسة مسبقاً على تجاوز للنموذج (على سبيل المثال، مضبوط عبر /model).
افتراضيات القناة وHeartbeat
استخدمchannels.defaults لسلوك سياسة المجموعات وHeartbeat المشتركين عبر المزودين:
channels.defaults.groupPolicy: سياسة المجموعة الاحتياطية عندما لا تكونgroupPolicyعلى مستوى المزود مضبوطة.channels.defaults.contextVisibility: وضع الرؤية الافتراضي للسياق التكميلي لكل القنوات. القيم:all(افتراضي، تضمين كل سياق الاقتباسات/السلاسل/السجل)، وallowlist(تضمين السياق من المرسلين المدرجين في قائمة السماح فقط)، وallowlist_quote(مثل قائمة السماح لكن مع إبقاء سياق الاقتباس/الرد الصريح). تجاوز لكل قناة:channels.<channel>.contextVisibility.channels.defaults.heartbeat.showOk: تضمين حالات القنوات السليمة في مخرجات Heartbeat.channels.defaults.heartbeat.showAlerts: تضمين الحالات المتدهورة/حالات الخطأ في مخرجات Heartbeat.channels.defaults.heartbeat.useIndicator: عرض مخرجات Heartbeat بنمط مؤشرات مضغوط.
WhatsApp متعدد الحسابات
WhatsApp متعدد الحسابات
- تستخدم الأوامر الصادرة الحساب
defaultافتراضياً إذا كان موجوداً؛ وإلا تستخدم أول معرّف حساب مضبوط (بعد الفرز). - يتجاوز
channels.whatsapp.defaultAccountالاختياري اختيار الحساب الافتراضي الاحتياطي عندما يطابق معرّف حساب مضبوطاً. - يُرحَّل دليل مصادقة Baileys القديم للحساب الواحد بواسطة
openclaw doctorإلىwhatsapp/default. - تجاوزات لكل حساب:
channels.whatsapp.accounts.<id>.sendReadReceipts، وchannels.whatsapp.accounts.<id>.dmPolicy، وchannels.whatsapp.accounts.<id>.allowFrom.
Telegram
- رمز البوت:
channels.telegram.botTokenأوchannels.telegram.tokenFile(ملف عادي فقط؛ تُرفض الروابط الرمزية)، معTELEGRAM_BOT_TOKENكاحتياطي للحساب الافتراضي. apiRootهو جذر Telegram Bot API فقط. استخدمhttps://api.telegram.orgأو جذر الاستضافة الذاتية/الوكيل لديك، وليسhttps://api.telegram.org/bot<TOKEN>؛ يزيلopenclaw doctor --fixلاحقة/bot<TOKEN>الزائدة عن طريق الخطأ.- يتجاوز
channels.telegram.defaultAccountالاختياري اختيار الحساب الافتراضي عندما يطابق معرّف حساب مضبوطاً. - في إعدادات الحسابات المتعددة (معرّفا حساب أو أكثر)، اضبط قيمة افتراضية صريحة (
channels.telegram.defaultAccountأوchannels.telegram.accounts.default) لتجنب التوجيه الاحتياطي؛ يحذرopenclaw doctorعندما تكون مفقودة أو غير صالحة. - يمنع
configWrites: falseعمليات كتابة الإعدادات التي يبدأها Telegram (ترحيلات معرّفات المجموعات الفائقة، و/config set|unset). - تضبط إدخالات
bindings[]العليا ذاتtype: "acp"ارتباطات ACP مستمرة لمواضيع المنتدى (استخدمchatId:topic:topicIdالقانوني فيmatch.peer.id). دلالات الحقول مشتركة في وكلاء ACP. - تستخدم معاينات بث Telegram
sendMessage+editMessageText(تعمل في المحادثات المباشرة والجماعية). - سياسة إعادة المحاولة: راجع سياسة إعادة المحاولة.
Discord
- الرمز المميّز:
channels.discord.token، معDISCORD_BOT_TOKENكخيار احتياطي للحساب الافتراضي. - تستخدم المكالمات الصادرة المباشرة التي توفّر Discord
tokenصريحا ذلك الرمز المميّز للمكالمة؛ وتظل إعدادات إعادة المحاولة/السياسة الخاصة بالحساب مأخوذة من الحساب المحدد في لقطة وقت التشغيل النشطة. - يتجاوز
channels.discord.defaultAccountالاختياري اختيار الحساب الافتراضي عندما يطابق معرف حساب مكوّنا. - استخدم
user:<id>(رسالة مباشرة) أوchannel:<id>(قناة guild) لأهداف التسليم؛ تُرفض المعرفات الرقمية المجرّدة. - تكون مختصرات guild بأحرف صغيرة مع استبدال المسافات بـ
-؛ وتستخدم مفاتيح القنوات الاسم المختصر (من دون#). فضّل معرفات guild. - تُتجاهل الرسائل التي كتبها البوت افتراضيا. يفعّلها
allowBots: true؛ استخدمallowBots: "mentions"لقبول رسائل البوت التي تذكر البوت فقط (تظل الرسائل الذاتية مرشّحة). - يُسقط
channels.discord.guilds.<id>.ignoreOtherMentions(وتجاوزات القناة) الرسائل التي تذكر مستخدما آخر أو دورا آخر ولكن لا تذكر البوت (باستثناء @everyone/@here). - يربط
channels.discord.mentionAliasesنص@handleالصادر الثابت بمعرفات مستخدمي Discord قبل الإرسال، بحيث يمكن ذكر الزملاء المعروفين بصورة حتمية حتى عندما تكون ذاكرة التخزين المؤقتة العابرة للدليل فارغة. توجد التجاوزات لكل حساب ضمنchannels.discord.accounts.<accountId>.mentionAliases. - يقسم
maxLinesPerMessage(الافتراضي 17) الرسائل الطويلة حتى عندما تكون أقل من 2000 حرف. - يتحكم
channels.discord.threadBindingsفي التوجيه المرتبط بسلاسل Discord:enabled: تجاوز Discord لميزات الجلسات المرتبطة بالسلاسل (/focusو/unfocusو/agentsو/session idleو/session max-ageوالتسليم/التوجيه المرتبطين)idleHours: تجاوز Discord لإلغاء التركيز التلقائي عند عدم النشاط بالساعات (0يعطّل)maxAgeHours: تجاوز Discord للحد الأقصى الصارم للعمر بالساعات (0يعطّل)spawnSessions: مفتاح تشغيل لـsessions_spawn({ thread: true })وإنشاء/ربط السلاسل تلقائيا عند إنشاء سلاسل ACP (الافتراضي:true)defaultSpawnContext: سياق الوكيل الفرعي الأصلي للعمليات المنشأة المرتبطة بالسلاسل ("fork"افتراضيا)
- تضبط إدخالات
bindings[]على المستوى الأعلى ذاتtype: "acp"روابط ACP دائمة للقنوات والسلاسل (استخدم معرف القناة/السلسلة فيmatch.peer.id). دلالات الحقول مشتركة في وكلاء ACP. - يضبط
channels.discord.ui.components.accentColorلون التمييز لحاويات مكونات Discord v2. - يفعّل
channels.discord.voiceمحادثات قنوات الصوت في Discord، مع تجاوزات اختيارية للانضمام التلقائي وLLM وTTS. تترك إعدادات Discord النصية فقط الصوت معطّلا افتراضيا؛ عيّنchannels.discord.voice.enabled=trueللاشتراك. - يتجاوز
channels.discord.voice.modelاختياريا نموذج LLM المستخدم لاستجابات قنوات الصوت في Discord. - يمرّر
channels.discord.voice.daveEncryptionوchannels.discord.voice.decryptionFailureToleranceإلى خيارات DAVE في@discordjs/voice(trueو24افتراضيا). - يتحكم
channels.discord.voice.connectTimeoutMsفي انتظار Ready الأولي في@discordjs/voiceلمحاولات/vc joinوالانضمام التلقائي (30000افتراضيا). - يتحكم
channels.discord.voice.reconnectGraceMsفي المدة التي يمكن أن تستغرقها جلسة صوت منفصلة للدخول في إشارة إعادة الاتصال قبل أن يدمّرها OpenClaw (15000افتراضيا). - لا يُقاطع تشغيل صوت Discord عند حدث بدء التحدث لمستخدم آخر. لتجنب حلقات التغذية الراجعة، يتجاهل OpenClaw التقاط الصوت الجديد أثناء تشغيل TTS.
- يحاول OpenClaw أيضا استعادة استقبال الصوت عبر مغادرة/إعادة الانضمام إلى جلسة صوت بعد إخفاقات فك تشفير متكررة.
channels.discord.streamingهو مفتاح وضع البث الأساسي. تستخدم Discord افتراضياstreaming.mode: "progress"بحيث يظهر تقدم الأدوات/العمل في رسالة معاينة واحدة محررة؛ عيّنstreaming.mode: "off"لتعطيله. تظل قيمstreamModeالقديمة وقيمstreamingالمنطقية أسماء مستعارة وقت التشغيل؛ شغّلopenclaw doctor --fixلإعادة كتابة الإعدادات المحفوظة.- يربط
channels.discord.autoPresenceإتاحة وقت التشغيل بحضور البوت (healthy => online وdegraded => idle وexhausted => dnd) ويسمح بتجاوزات اختيارية لنص الحالة. - يعيد
channels.discord.dangerouslyAllowNameMatchingتفعيل مطابقة الاسم/الوسم القابلة للتغيير (وضع توافق للطوارئ). channels.discord.execApprovals: تسليم موافقات التنفيذ الأصلي في Discord وتفويض المعتمدين.enabled:trueأوfalseأو"auto"(افتراضي). في الوضع التلقائي، تنشط موافقات التنفيذ عندما يمكن حل المعتمدين منapproversأوcommands.ownerAllowFrom.approvers: معرفات مستخدمي Discord المسموح لهم بالموافقة على طلبات التنفيذ. يعود إلىcommands.ownerAllowFromعند حذفه.agentFilter: قائمة سماح اختيارية لمعرفات الوكلاء. احذفها لتمرير الموافقات لكل الوكلاء.sessionFilter: أنماط اختيارية لمفاتيح الجلسات (سلسلة فرعية أو تعبير نمطي).target: مكان إرسال مطالبات الموافقة. يرسل"dm"(الافتراضي) إلى الرسائل المباشرة للمعتمدين، ويرسل"channel"إلى القناة الأصلية، ويرسل"both"إلى كليهما. عندما يتضمن الهدف"channel"، لا يمكن استخدام الأزرار إلا بواسطة المعتمدين المحلولين.cleanupAfterResolve: عندما تكونtrue، يحذف رسائل الموافقة المباشرة بعد الموافقة أو الرفض أو انتهاء المهلة.
off (لا شيء)، own (رسائل البوت، الافتراضي)، all (كل الرسائل)، allowlist (من guilds.<id>.users على كل الرسائل).
Google Chat
- حساب الخدمة JSON: مضمّن (
serviceAccount) أو مستند إلى ملف (serviceAccountFile). - SecretRef لحساب الخدمة مدعوم أيضا (
serviceAccountRef). - خيارات env الاحتياطية:
GOOGLE_CHAT_SERVICE_ACCOUNTأوGOOGLE_CHAT_SERVICE_ACCOUNT_FILE. - استخدم
spaces/<spaceId>أوusers/<userId>لأهداف التسليم. - يعيد
channels.googlechat.dangerouslyAllowNameMatchingتفعيل مطابقة أصل البريد الإلكتروني القابلة للتغيير (وضع توافق للطوارئ).
Slack
- يتطلب وضع Socket كلا من
botTokenوappToken(SLACK_BOT_TOKEN+SLACK_APP_TOKENكخيار env احتياطي للحساب الافتراضي). - يتطلب وضع HTTP
botTokenبالإضافة إلىsigningSecret(على الجذر أو لكل حساب). - يمرّر
socketModeضبط نقل وضع Socket في Slack SDK إلى واجهة Bolt receiver API العامة. استخدمه فقط عند التحقيق في مهلة ping/pong أو سلوك websocket القديم. - تقبل
botTokenوappTokenوsigningSecretوuserTokenسلاسل نصية صريحة أو كائنات SecretRef. - تعرض لقطات حساب Slack حقول المصدر/الحالة لكل اعتماد مثل
botTokenSourceوbotTokenStatusوappTokenStatus، وفي وضع HTTP،signingSecretStatus. تعنيconfigured_unavailableأن الحساب مكوّن عبر SecretRef ولكن مسار الأمر/وقت التشغيل الحالي لم يستطع حل قيمة السر. - يمنع
configWrites: falseعمليات كتابة الإعدادات التي يبدأها Slack. - يتجاوز
channels.slack.defaultAccountالاختياري اختيار الحساب الافتراضي عندما يطابق معرف حساب مكوّنا. channels.slack.streaming.modeهو مفتاح وضع بث Slack الأساسي. يتحكمchannels.slack.streaming.nativeTransportفي نقل البث الأصلي في Slack. تظل قيمstreamModeالقديمة وقيمstreamingالمنطقية وnativeStreamingأسماء مستعارة وقت التشغيل؛ شغّلopenclaw doctor --fixلإعادة كتابة الإعدادات المحفوظة.- يمرّر
unfurlLinksوunfurlMediaقيم Slack المنطقية لفرد روابط ووسائطchat.postMessageلردود البوت. احذفهما للإبقاء على سلوك Slack الافتراضي؛ عيّنهما فيchannels.slack.accounts.<accountId>لتجاوز الافتراضي على المستوى الأعلى لحساب واحد. - استخدم
user:<id>(رسالة مباشرة) أوchannel:<id>لأهداف التسليم.
off، own (افتراضي)، all، allowlist (من reactionAllowlist).
عزل جلسات السلاسل: يكون thread.historyScope لكل سلسلة (افتراضيا) أو مشتركا عبر القناة. ينسخ thread.inheritParent نص قناة الأصل إلى سلاسل جديدة.
- يتطلب بث Slack الأصلي مع حالة سلسلة نمط مساعد Slack “is typing…” هدف سلسلة رد. تظل الرسائل المباشرة على المستوى الأعلى خارج السلاسل افتراضيا، لذلك لا يزال بإمكانها البث عبر معاينات مسودات Slack المنشورة والمحررة بدلا من عرض معاينة البث/الحالة الأصلية بنمط السلسلة.
- يضيف
typingReactionتفاعلا مؤقتا إلى رسالة Slack الواردة أثناء تشغيل الرد، ثم يزيله عند الاكتمال. استخدم shortcode لرمز تعبيري في Slack مثل"hourglass_flowing_sand". channels.slack.execApprovals: تسليم موافقات التنفيذ الأصلي في Slack وتفويض المعتمدين. المخطط نفسه كما في Discord:enabled(true/false/"auto")، وapprovers(معرفات مستخدمي Slack)، وagentFilter، وsessionFilter، وtarget("dm"أو"channel"أو"both").
| مجموعة الإجراءات | الافتراضي | ملاحظات |
|---|---|---|
| reactions | مفعّل | التفاعل + سرد التفاعلات |
| messages | مفعّل | قراءة/إرسال/تحرير/حذف |
| pins | مفعّل | تثبيت/إلغاء تثبيت/سرد |
| memberInfo | مفعّل | معلومات العضو |
| emojiList | مفعّل | قائمة الرموز التعبيرية المخصصة |
Mattermost
يُشحن Mattermost بصفته Plugin مجمّعا في إصدارات OpenClaw الحالية. يمكن للإصدارات الأقدم أو البنى المخصصة تثبيت حزمة npm حالية باستخدامopenclaw plugins install @openclaw/mattermost. تحقق من
npmjs.com/package/@openclaw/mattermost
لمعرفة dist-tags الحالية قبل تثبيت إصدار محدد.
oncall (الرد عند إشارة @، الافتراضي)، onmessage (كل رسالة)، onchar (الرسائل التي تبدأ ببادئة تشغيل).
عند تمكين أوامر Mattermost الأصلية:
- يجب أن يكون
commands.callbackPathمسارًا (مثل/api/channels/mattermost/command)، وليس عنوان URL كاملًا. - يجب أن يُحلّ
commands.callbackUrlإلى نقطة نهاية OpenClaw Gateway وأن يكون قابلًا للوصول من خادم Mattermost. - تتم مصادقة استدعاءات الشرطة المائلة الأصلية باستخدام الرموز المميزة الخاصة بكل أمر التي يعيدها Mattermost أثناء تسجيل أمر الشرطة المائلة. إذا فشل التسجيل أو لم تُفعّل أي أوامر، يرفض OpenClaw الاستدعاءات باستخدام
Unauthorized: invalid command token. - بالنسبة إلى مضيفي الاستدعاء الخاصين/داخل tailnet/الداخليين، قد يتطلب Mattermost أن يتضمن
ServiceSettings.AllowedUntrustedInternalConnectionsمضيف/نطاق الاستدعاء. استخدم قيم المضيف/النطاق، وليس عناوين URL كاملة. channels.mattermost.configWrites: السماح بكتابات التكوين التي يبدأها Mattermost أو رفضها.channels.mattermost.requireMention: طلب@mentionقبل الرد في القنوات.channels.mattermost.groups.<channelId>.requireMention: تجاوز بوابة الإشارة لكل قناة ("*"للافتراضي).- يتجاوز
channels.mattermost.defaultAccountالاختياري اختيار الحساب الافتراضي عندما يطابق معرّف حساب مكوّنًا.
Signal
off، own (الافتراضي)، all، allowlist (من reactionAllowlist).
channels.signal.account: تثبيت بدء تشغيل القناة على هوية حساب Signal محددة.channels.signal.configWrites: السماح بكتابات التكوين التي يبدأها Signal أو رفضها.- يتجاوز
channels.signal.defaultAccountالاختياري اختيار الحساب الافتراضي عندما يطابق معرّف حساب مكوّنًا.
iMessage
يشغّل OpenClaw الأمرimsg rpc (JSON-RPC عبر stdio). لا يلزم عفريت أو منفذ. هذا هو المسار المفضل لإعدادات OpenClaw iMessage الجديدة عندما يستطيع المضيف منح أذونات قاعدة بيانات Messages والأتمتة.
تمت إزالة دعم BlueBubbles. لا يُعد channels.bluebubbles سطح تكوين تشغيل مدعومًا في OpenClaw الحالي. انقل التكوينات القديمة إلى channels.imessage؛ استخدم إزالة BlueBubbles ومسار imsg لـ iMessage للنسخة المختصرة والقادمون من BlueBubbles لجدول الترجمة الكامل.
إذا لم يكن Gateway يعمل على جهاز Mac المسجل دخوله إلى Messages، فأبقِ channels.imessage.enabled=true واضبط channels.imessage.cliPath على غلاف SSH يشغّل imsg "$@" على ذلك الـ Mac. مسار imsg المحلي الافتراضي خاص بـ macOS فقط.
-
يتجاوز
channels.imessage.defaultAccountالاختياري اختيار الحساب الافتراضي عندما يطابق معرّف حساب مكوّنًا. - يتطلب Full Disk Access إلى قاعدة بيانات Messages.
-
فضّل أهداف
chat_id:<id>. استخدمimsg chats --limit 20لسرد المحادثات. -
يمكن أن يشير
cliPathإلى غلاف SSH؛ اضبطremoteHost(hostأوuser@host) لجلب مرفقات SCP. -
يقيّد
attachmentRootsوremoteAttachmentRootsمسارات المرفقات الواردة (الافتراضي:/Users/*/Library/Messages/Attachments). -
يستخدم SCP تحققًا صارمًا من مفتاح المضيف، لذا تأكد من أن مفتاح مضيف الترحيل موجود بالفعل في
~/.ssh/known_hosts. -
channels.imessage.configWrites: السماح بكتابات التكوين التي يبدأها iMessage أو رفضها. -
channels.imessage.actions.*: تمكين إجراءات API الخاصة التي تخضع أيضًا لبوابةimsg status/openclaw channels status --probe. -
channels.imessage.includeAttachmentsمعطل افتراضيًا؛ اضبطه علىtrueقبل توقع وسائط واردة في أدوار الوكيل. -
channels.imessage.catchup.enabled: الاشتراك في إعادة تشغيل الرسائل الواردة التي وصلت أثناء تعطل Gateway. -
channels.imessage.groups: سجل المجموعات وإعدادات كل مجموعة. معgroupPolicy: "allowlist"، كوّن إما مفاتيحchat_idصريحة أو إدخال حرف بدل"*"حتى تتمكن رسائل المجموعة من اجتياز بوابة السجل. -
يمكن لإدخالات
bindings[]ذات المستوى الأعلى معtype: "acp"ربط محادثات iMessage بجلسات ACP مستمرة. استخدم مقبضًا مطبعًا أو هدف دردشة صريحًا (chat_id:*،chat_guid:*،chat_identifier:*) فيmatch.peer.id. دلالات الحقول المشتركة: وكلاء ACP.
مثال غلاف SSH لـ iMessage
مثال غلاف SSH لـ iMessage
Matrix
Matrix مدعوم بـ Plugin ومكوّن ضمنchannels.matrix.
- تستخدم مصادقة الرمز المميز
accessToken؛ وتستخدم مصادقة كلمة المرورuserId+password. - يوجّه
channels.matrix.proxyحركة HTTP الخاصة بـ Matrix عبر وكيل HTTP(S) صريح. يمكن للحسابات المسماة تجاوزه باستخدامchannels.matrix.accounts.<id>.proxy. - يسمح
channels.matrix.network.dangerouslyAllowPrivateNetworkبخوادم المنازل الخاصة/الداخلية.proxyوهذا الاشتراك الشبكي عنصران مستقلان للتحكم. - يحدد
channels.matrix.defaultAccountالحساب المفضل في إعدادات الحسابات المتعددة. - يكون
channels.matrix.autoJoinافتراضيًاoff، لذلك تُتجاهل الغرف المدعو إليها والدعوات الجديدة بأسلوب الرسائل المباشرة حتى تضبطautoJoin: "allowlist"معautoJoinAllowlistأوautoJoin: "always". channels.matrix.execApprovals: تسليم موافقات التنفيذ الأصلية في Matrix وتفويض الموافقين.enabled:trueأوfalseأو"auto"(الافتراضي). في الوضع التلقائي، تُفعّل موافقات التنفيذ عندما يمكن حل الموافقين منapproversأوcommands.ownerAllowFrom.approvers: معرّفات مستخدمي Matrix (مثل@owner:example.org) المسموح لها بالموافقة على طلبات التنفيذ.agentFilter: قائمة سماح اختيارية لمعرّفات الوكلاء. احذفها لإعادة توجيه الموافقات لكل الوكلاء.sessionFilter: أنماط مفاتيح جلسة اختيارية (سلسلة فرعية أو regex).target: مكان إرسال مطالبات الموافقة."dm"(الافتراضي)، أو"channel"(الغرفة الأصلية)، أو"both".- تجاوزات لكل حساب:
channels.matrix.accounts.<id>.execApprovals.
- يتحكم
channels.matrix.dm.sessionScopeفي كيفية تجميع رسائل Matrix المباشرة في جلسات:per-user(الافتراضي) يشارك حسب النظير الموجّه، بينما يعزلper-roomكل غرفة رسائل مباشرة. - تستخدم فحوصات حالة Matrix وعمليات البحث المباشر في الدليل سياسة الوكيل نفسها المستخدمة لحركة التشغيل.
- وُثّق تكوين Matrix الكامل وقواعد الاستهداف وأمثلة الإعداد في Matrix.
Microsoft Teams
Microsoft Teams مدعوم بـ Plugin ومكوّن ضمنchannels.msteams.
- مسارات المفاتيح الأساسية المغطاة هنا:
channels.msteams،channels.msteams.configWrites. - وُثّق تكوين Teams الكامل (بيانات الاعتماد، Webhook، سياسة الرسائل المباشرة/المجموعات، التجاوزات لكل فريق/كل قناة) في Microsoft Teams.
IRC
IRC مدعوم بـ Plugin ومكوّن ضمنchannels.irc.
- مسارات المفاتيح الأساسية المغطاة هنا:
channels.irc،channels.irc.dmPolicy،channels.irc.configWrites،channels.irc.nickserv.*. - يتجاوز
channels.irc.defaultAccountالاختياري اختيار الحساب الافتراضي عندما يطابق معرّف حساب مكوّنًا. - وُثّق تكوين قناة IRC الكامل (المضيف/المنفذ/TLS/القنوات/قوائم السماح/بوابة الإشارة) في IRC.
حسابات متعددة (كل القنوات)
شغّل عدة حسابات لكل قناة (لكل حسابaccountId خاص به):
- يُستخدم
defaultعندما يُحذفaccountId(CLI + التوجيه). - تنطبق رموز البيئة فقط على الحساب الافتراضي.
- تنطبق إعدادات القناة الأساسية على كل الحسابات ما لم تُتجاوز لكل حساب.
- استخدم
bindings[].match.accountIdلتوجيه كل حساب إلى وكيل مختلف. - إذا أضفت حسابًا غير افتراضي عبر
openclaw channels add(أو إعداد القناة) بينما لا تزال تستخدم تكوين قناة ذي مستوى أعلى لحساب واحد، يرقّي OpenClaw أولًا قيم الحساب الواحد ذات المستوى الأعلى والمحددة بنطاق الحساب إلى خريطة حسابات القناة حتى يستمر الحساب الأصلي في العمل. تنقل معظم القنوات هذه القيم إلىchannels.<channel>.accounts.default؛ يمكن لـ Matrix بدلًا من ذلك الحفاظ على هدف مسمى/افتراضي مطابق موجود. - تستمر الارتباطات الحالية الخاصة بالقناة فقط (بدون
accountId) في مطابقة الحساب الافتراضي؛ وتبقى الارتباطات محددة النطاق بالحساب اختيارية. - يصلح
openclaw doctor --fixأيضًا الأشكال المختلطة عبر نقل قيم الحساب الواحد ذات المستوى الأعلى والمحددة بنطاق الحساب إلى الحساب المُرقّى المختار لتلك القناة. تستخدم معظم القنواتaccounts.default؛ يمكن لـ Matrix بدلًا من ذلك الحفاظ على هدف مسمى/افتراضي مطابق موجود.
قنوات Plugin الأخرى
تُكوّن كثير من قنوات Plugin على شكلchannels.<id> وتُوثّق في صفحات القنوات المخصصة لها (مثل Feishu، وMatrix، وLINE، وNostr، وZalo، وNextcloud Talk، وSynology Chat، وTwitch).
راجع فهرس القنوات الكامل: القنوات.
بوابة الإشارة في دردشة المجموعة
تكون رسائل المجموعة افتراضيًا تتطلب إشارة (إشارة بيانات وصفية أو أنماط regex آمنة). ينطبق ذلك على دردشات مجموعات WhatsApp، وTelegram، وDiscord، وGoogle Chat، وiMessage. تُدار الردود المرئية بشكل منفصل. تكون غرف المجموعات/القنوات افتراضيًا علىmessages.groupChat.visibleReplies: "message_tool": يظل OpenClaw يعالج الدور، لكن الردود النهائية العادية تبقى خاصة، ويتطلب إخراج الغرفة المرئي message(action=send). اضبط "automatic" فقط عندما تريد السلوك القديم حيث تُنشر الردود العادية مرة أخرى في الغرفة. لتطبيق السلوك نفسه للردود المرئية المعتمدة على الأداة فقط على المحادثات المباشرة أيضًا، اضبط messages.visibleReplies: "message_tool"؛ يستخدم Codex harness أيضًا هذا السلوك المعتمد على الأداة فقط كإعداد افتراضي غير مضبوط للمحادثات المباشرة.
تتطلب الردود المرئية المعتمدة على الأداة فقط نموذجًا/بيئة تشغيل تستدعي الأدوات بشكل موثوق. إذا
أظهر سجل الجلسة نص مساعد مع didSendViaMessagingTool: false، فهذا يعني أن
النموذج أنتج إجابة نهائية خاصة بدلًا من استدعاء أداة الرسائل.
انتقل إلى نموذج أقوى في استدعاء الأدوات لتلك القناة، أو اضبط
messages.groupChat.visibleReplies: "automatic" لاستعادة الردود النهائية المرئية
القديمة.
إذا لم تكن أداة الرسائل متاحة ضمن سياسة الأدوات النشطة، يعود OpenClaw إلى الردود المرئية التلقائية بدلًا من كبت الاستجابة بصمت. يحذر openclaw doctor من عدم التطابق هذا.
يعيد Gateway تحميل إعدادات messages بشكل فوري بعد حفظ الملف. أعد التشغيل فقط عندما تكون مراقبة الملفات أو إعادة تحميل الإعدادات معطلة في النشر.
أنواع الإشارات:
- إشارات البيانات الوصفية: إشارات @ الأصلية في المنصة. يتم تجاهلها في وضع محادثة WhatsApp الذاتية.
- أنماط النص: أنماط regex آمنة في
agents.list[].groupChat.mentionPatterns. يتم تجاهل الأنماط غير الصالحة والتكرار المتداخل غير الآمن. - لا يُفرض تقييد الإشارات إلا عندما يكون الاكتشاف ممكنًا (الإشارات الأصلية أو نمط واحد على الأقل).
messages.groupChat.historyLimit الإعداد الافتراضي العام. يمكن للقنوات تجاوزه باستخدام channels.<channel>.historyLimit (أو لكل حساب). اضبطه على 0 للتعطيل.
messages.visibleReplies هو الإعداد الافتراضي العام لدور المصدر؛ ويتجاوزه messages.groupChat.visibleReplies لأدوار مصدر المجموعة/القناة. عندما لا يكون messages.visibleReplies مضبوطًا، يمكن للحزمة أن توفر إعدادها الافتراضي المباشر/المصدر الخاص؛ يكون Codex harness افتراضيًا على message_tool. لا تزال قوائم السماح للقنوات وتقييد الإشارات تقرر ما إذا كان الدور سيُعالج.
حدود سجل الرسائل المباشرة
telegram، whatsapp، discord، slack، signal، imessage، msteams.
وضع المحادثة الذاتية
أدرج رقمك الخاص فيallowFrom لتمكين وضع المحادثة الذاتية (يتجاهل إشارات @ الأصلية، ولا يستجيب إلا لأنماط النص):
الأوامر (معالجة أوامر المحادثة)
Command details
Command details
- تضبط هذه الكتلة أسطح الأوامر. للاطلاع على كتالوج الأوامر المضمنة + المجمعة الحالي، راجع أوامر الشرطة المائلة.
- هذه الصفحة هي مرجع لمفاتيح الإعدادات، وليست كتالوج الأوامر الكامل. تُوثق الأوامر المملوكة للقنوات/Plugin مثل أوامر QQ Bot
/bot-pingو/bot-helpو/bot-logs، وLINE/card، وأمر إقران الجهاز/pair، والذاكرة/dreaming، والتحكم بالهاتف/phone، وTalk/voiceفي صفحات القنوات/Plugin الخاصة بها بالإضافة إلى أوامر الشرطة المائلة. - يجب أن تكون أوامر النص رسائل مستقلة تبدأ بـ
/. - يقوم
native: "auto"بتشغيل الأوامر الأصلية لـ Discord/Telegram، ويترك Slack متوقفًا. - يقوم
nativeSkills: "auto"بتشغيل أوامر Skills الأصلية لـ Discord/Telegram، ويترك Slack متوقفًا. - التجاوز لكل قناة:
channels.discord.commands.native(قيمة منطقية أو"auto"). بالنسبة إلى Discord، يتخطىfalseتسجيل الأوامر الأصلية وتنظيفها أثناء بدء التشغيل. - تجاوز تسجيل Skills الأصلية لكل قناة باستخدام
channels.<provider>.commands.nativeSkills. - يضيف
channels.telegram.customCommandsإدخالات إضافية إلى قائمة روبوت Telegram. - يفعّل
bash: trueاستخدام! <cmd>لصدفة المضيف. يتطلبtools.elevated.enabledوأن يكون المرسل ضمنtools.elevated.allowFrom.<channel>. - يفعّل
config: trueالأمر/config(قراءة/كتابةopenclaw.json). لعملاء Gatewaychat.send، تتطلب عمليات الكتابة الدائمة/config set|unsetأيضًاoperator.admin؛ ويبقى/config showللقراءة فقط متاحًا لعملاء المشغل العاديين ذوي نطاق الكتابة. - يفعّل
mcp: trueالأمر/mcpلإعداد خادم MCP المُدار بواسطة OpenClaw ضمنmcp.servers. - يفعّل
plugins: trueالأمر/pluginsلاكتشاف Plugin وتثبيتها وعناصر التحكم في تمكينها/تعطيلها. - يقيّد
channels.<provider>.configWritesتغييرات الإعدادات لكل قناة (الإعداد الافتراضي: true). - للقنوات متعددة الحسابات، يقيّد
channels.<provider>.accounts.<id>.configWritesأيضًا عمليات الكتابة التي تستهدف ذلك الحساب (على سبيل المثال/allowlist --config --account <id>أو/config set channels.<provider>.accounts.<id>...). - يعطل
restart: falseالأمر/restartوإجراءات أداة إعادة تشغيل Gateway. الإعداد الافتراضي:true. ownerAllowFromهي قائمة السماح الصريحة للمالك للأوامر/الأدوات المخصصة للمالك فقط. وهي منفصلة عنallowFrom.- يقوم
ownerDisplay: "hash"بتجزئة معرفات المالك في موجه النظام. اضبطownerDisplaySecretللتحكم في التجزئة. allowFromمخصص لكل مزود. عند ضبطه، يكون هو مصدر التفويض الوحيد (يتم تجاهل قوائم السماح/الإقران الخاصة بالقنوات وuseAccessGroups).- يسمح
useAccessGroups: falseللأوامر بتجاوز سياسات مجموعات الوصول عندما لا يكونallowFromمضبوطًا. - خريطة وثائق الأوامر:
ذات صلة
- مرجع الإعدادات — مفاتيح المستوى الأعلى
- الإعدادات — الوكلاء
- نظرة عامة على القنوات