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.
القنوات والتوجيه
يوجّه OpenClaw الردود إلى القناة نفسها التي جاءت منها الرسالة. لا يختار النموذج قناة؛ فالتوجيه حتمي وتتحكم فيه إعدادات المضيف.المصطلحات الأساسية
- القناة:
telegram,whatsapp,discord,irc,googlechat,slack,signal,imessage,line، بالإضافة إلى قنوات Plugin.webchatهي قناة واجهة WebChat الداخلية وليست قناة صادرة قابلة للإعداد. - AccountId: نسخة حساب لكل قناة (عند الدعم).
- حساب القناة الافتراضي الاختياري: يختار
channels.<channel>.defaultAccountالحساب المستخدم عندما لا يحدد مسار صادرaccountId.- في إعدادات الحسابات المتعددة، عيّن افتراضيًا صريحًا (
defaultAccountأوaccounts.default) عندما يكون حسابان أو أكثر مهيأين. بدونه، قد يختار التوجيه الاحتياطي أول معرّف حساب مُطبّع.
- في إعدادات الحسابات المتعددة، عيّن افتراضيًا صريحًا (
- AgentId: مساحة عمل معزولة + مخزن جلسات (“عقل”).
- SessionKey: مفتاح الحاوية المستخدم لتخزين السياق والتحكم في التزامن.
بادئات الهدف الصادر
قد تتضمن الأهداف الصادرة الصريحة بادئة موفّر، مثلtelegram:123 أو tg:123. يتعامل Core مع تلك البادئة كتلميح لاختيار القناة فقط عندما تكون القناة المحددة هي last أو غير محسومة بطريقة أخرى، وفقط عندما يعلن Plugin المحمّل عن تلك البادئة. إذا كان المستدعي قد اختار قناة صريحة بالفعل، فيجب أن تطابق بادئة الموفّر تلك القناة؛ تفشل التركيبات العابرة للقنوات مثل تسليم WhatsApp إلى telegram:123 قبل التطبيع الخاص بهدف Plugin.
تبقى بادئات نوع الهدف والخدمة مثل channel:<id> وuser:<id> وroom:<id> وthread:<id> وimessage:<handle> وsms:<number> داخل قواعد القناة المحددة. وهي لا تحدد الموفّر بمفردها.
أشكال مفاتيح الجلسات (أمثلة)
تُدمج الرسائل المباشرة في جلسة main الخاصة بالوكيل افتراضيًا:agent:<agentId>:<mainKey>(الافتراضي:agent:main:main)
- المجموعات:
agent:<agentId>:<channel>:group:<id> - القنوات/الغرف:
agent:<agentId>:<channel>:channel:<id>
- تضيف مواضيع Slack/Discord اللاحقة
:thread:<threadId>إلى المفتاح الأساسي. - تضمّن مواضيع منتديات Telegram اللاحقة
:topic:<topicId>في مفتاح المجموعة.
agent:main:telegram:group:-1001234567890:topic:42agent:main:discord:channel:123456:thread:987654
تثبيت مسار الرسائل المباشرة الرئيسية
عندما يكونsession.dmScope هو main، قد تشارك الرسائل المباشرة جلسة رئيسية واحدة.
لمنع الكتابة فوق lastRoute الخاص بالجلسة بواسطة رسائل مباشرة من غير المالك،
يستنتج OpenClaw مالكًا مثبّتًا من allowFrom عندما تكون كل هذه الشروط صحيحة:
- يحتوي
allowFromعلى إدخال واحد فقط غير شامل. - يمكن تطبيع الإدخال إلى معرّف مرسل ملموس لتلك القناة.
- لا يطابق مرسل الرسالة المباشرة الواردة ذلك المالك المثبّت.
lastRoute لجلسة main.
التسجيل الوارد المحمي
يمكن لـ Plugins القنوات وسم سجل جلسة وارد بأنهcreateIfMissing: false
عندما يجب ألا ينشئ المسار المحمي جلسة OpenClaw جديدة. في ذلك الوضع،
قد يحدّث OpenClaw بيانات التعريف وlastRoute لجلسة موجودة، لكنه
لا ينشئ إدخال جلسة للمسار فقط لمجرد ملاحظة رسالة.
قواعد التوجيه (كيف يتم اختيار وكيل)
يختار التوجيه وكيلًا واحدًا لكل رسالة واردة:- تطابق النظير الدقيق (
bindingsمعpeer.kind+peer.id). - تطابق النظير الأصل (وراثة الموضوع).
- تطابق الخادم + الأدوار (Discord) عبر
guildId+roles. - تطابق الخادم (Discord) عبر
guildId. - تطابق الفريق (Slack) عبر
teamId. - تطابق الحساب (
accountIdعلى القناة). - تطابق القناة (أي حساب على تلك القناة،
accountId: "*"). - الوكيل الافتراضي (
agents.list[].default، وإلا أول إدخال في القائمة، مع الرجوع إلىmain).
peer, guildId, teamId, roles)، يجب أن تطابق كل الحقول المقدمة حتى ينطبق ذلك الربط.
يحدد الوكيل المطابق مساحة العمل ومخزن الجلسات المستخدمين.
مجموعات البث (تشغيل عدة وكلاء)
تتيح لك مجموعات البث تشغيل عدة وكلاء للنظير نفسه عندما يرد OpenClaw عادةً (على سبيل المثال: في مجموعات WhatsApp، بعد بوابة الذكر/التفعيل). الإعداد:نظرة عامة على الإعداد
agents.list: تعريفات الوكلاء المسماة (مساحة العمل، النموذج، إلخ).bindings: ربط القنوات/الحسابات/النظراء الواردة بالوكلاء.
تخزين الجلسات
توجد مخازن الجلسات تحت دليل الحالة (الافتراضي~/.openclaw):
~/.openclaw/agents/<agentId>/sessions/sessions.json- توجد نصوص JSONL بجانب المخزن
session.store وقوالب {agentId}.
يمسح اكتشاف جلسات Gateway وACP أيضًا مخازن الوكلاء المدعومة بالقرص تحت جذر
agents/ الافتراضي وتحت جذور session.store ذات القوالب. يجب أن تبقى
المخازن المكتشفة داخل جذر الوكيل المحسوم ذلك وأن تستخدم ملف
sessions.json عاديًا. يتم تجاهل الروابط الرمزية والمسارات خارج الجذر.
سلوك WebChat
يرتبط WebChat بـ الوكيل المحدد ويستخدم افتراضيًا جلسة main الخاصة بالوكيل. وبسبب ذلك، يتيح لك WebChat رؤية السياق العابر للقنوات لذلك الوكيل في مكان واحد.سياق الرد
تتضمن الردود الواردة:ReplyToIdوReplyToBodyوReplyToSenderعند توفرها.- يُضاف السياق المقتبس إلى
Bodyككتلة[Replying to ...].