إدارة الجلسات
يتعامل OpenClaw مع جلسة دردشة مباشرة واحدة لكل وكيل على أنها الأساسية. تُطوى الدردشات المباشرة إلىagent:<agentId>:<mainKey> (الافتراضي main)، بينما تحصل دردشات المجموعات/القنوات على مفاتيحها الخاصة. يتم احترام session.mainKey.
استخدم session.dmScope للتحكم في كيفية تجميع الرسائل المباشرة:
main(الافتراضي): تشترك جميع الرسائل المباشرة في الجلسة الرئيسية من أجل الاستمرارية.per-peer: عزل حسب معرّف المُرسِل عبر القنوات.per-channel-peer: عزل حسب القناة + المُرسِل (موصى به لصناديق الوارد متعددة المستخدمين).per-account-channel-peer: عزل حسب الحساب + القناة + المُرسِل (موصى به لصناديق الوارد متعددة الحسابات). استخدمsession.identityLinksلربط معرّفات الأقران المسبوقة بموفّر بهوية معيارية، بحيث يشترك الشخص نفسه في جلسة رسالة مباشرة واحدة عبر القنوات عند استخدامper-peerأوper-channel-peerأوper-account-channel-peer.
وضع الرسائل المباشرة الآمن (موصى به للإعدادات متعددة المستخدمين)
تحذير أمني: إذا كان وكيلك يمكنه تلقي رسائل مباشرة من عدة أشخاص، فيجب عليك بشدة تمكين وضع الرسائل المباشرة الآمن. بدونه، يشترك جميع المستخدمين في سياق محادثة واحد، ما قد يؤدي إلى تسريب معلومات خاصة بين المستخدمين.مثال على المشكلة مع الإعدادات الافتراضية:
- أليس (
<SENDER_A>) تراسل وكيلك حول موضوع خاص (على سبيل المثال، موعد طبي) - بوب (
<SENDER_B>) يراسل وكيلك ويسأل «عمّ كنا نتحدث؟» - لأن الرسالتين المباشرتين تشتركان في الجلسة نفسها، قد يجيب النموذج بوب باستخدام سياق أليس السابق.
dmScope لعزل الجلسات لكل مستخدم:
- لديك موافقات إقران لأكثر من مُرسِل واحد
- أنت تستخدم قائمة سماح DM تحتوي على عدة إدخالات
- تضبط
dmPolicy: "open" - يمكن لأرقام هواتف أو حسابات متعددة مراسلة وكيلك
- الافتراضي هو
dmScope: "main"للاستمرارية (تشارك جميع الرسائل المباشرة الجلسة الرئيسية). هذا مناسب لإعدادات المستخدم الواحد. - لصناديق الوارد متعددة الحسابات على القناة نفسها، يُفضَّل
per-account-channel-peer. - إذا تواصل الشخص نفسه معك عبر قنوات متعددة، استخدم
session.identityLinksلدمج جلسات الرسائل المباشرة في هوية معيارية واحدة. - يمكنك التحقق من إعدادات الرسائل المباشرة لديك باستخدام
openclaw security audit(انظر الأمان).
الـ Gateway هو مصدر الحقيقة
تعود ملكية حالة الجلسة بالكامل إلى الـ Gateway (النسخة «الرئيسية» من OpenClaw). يجب على عملاء واجهة المستخدم (تطبيق macOS، WebChat، إلخ) الاستعلام من الـ Gateway عن قوائم الجلسات وعدّادات الرموز بدل قراءة الملفات المحلية.- في الوضع البعيد، يوجد مخزن الجلسات الذي يهمك على مضيف Gateway البعيد، وليس على جهاز Mac لديك.
- تأتي عدّادات الرموز المعروضة في واجهات المستخدم من حقول مخزن الـ Gateway (
inputTokensوoutputTokensوtotalTokensوcontextTokens). لا تقوم العملاء بتحليل نصوص JSONL «لتصحيح» الإجماليات.
أين تعيش الحالة
- على مضيف Gateway:
- ملف المخزن:
~/.openclaw/agents/<agentId>/sessions/sessions.json(لكل وكيل).
- ملف المخزن:
- النصوص:
~/.openclaw/agents/<agentId>/sessions/<SessionId>.jsonl(تستخدم جلسات مواضيع Telegram.../<SessionId>-topic-<threadId>.jsonl). - المخزن عبارة عن خريطة
sessionKey -> { sessionId, updatedAt, ... }. حذف الإدخالات آمن؛ إذ تُعاد إنشاؤها عند الطلب. - قد تتضمن إدخالات المجموعات
displayNameوchannelوsubjectوroomوspaceلوضع تسميات للجلسات في واجهات المستخدم. - تتضمن إدخالات الجلسة بيانات وصفية
origin(تسمية + تلميحات توجيه) كي تتمكن واجهات المستخدم من شرح مصدر الجلسة. - لا يقرأ OpenClaw مجلدات جلسات Pi/Tau القديمة.
تقليم الجلسات
يقوم OpenClaw افتراضيًا بقص نتائج الأدوات القديمة من السياق الموجود في الذاكرة مباشرة قبل استدعاءات LLM. لا يؤدي ذلك إلى إعادة كتابة سجل JSONL. انظر /concepts/session-pruning.تفريغ الذاكرة قبل الضغط
عندما تقترب الجلسة من الضغط التلقائي، يمكن لـ OpenClaw تنفيذ تفريغ ذاكرة صامت يذكّر النموذج بكتابة ملاحظات دائمة على القرص. يعمل هذا فقط عندما تكون مساحة العمل قابلة للكتابة. انظر الذاكرة والضغط.ربط وسائل النقل → مفاتيح الجلسات
- تتبع الدردشات المباشرة
session.dmScope(الافتراضيmain).main:agent:<agentId>:<mainKey>(استمرارية عبر الأجهزة/القنوات).- يمكن لأرقام هواتف وقنوات متعددة أن تُربط بالمفتاح الرئيسي نفسه للوكيل؛ وتعمل كوسائط نقل إلى محادثة واحدة.
per-peer:agent:<agentId>:dm:<peerId>.per-channel-peer:agent:<agentId>:<channel>:dm:<peerId>.per-account-channel-peer:agent:<agentId>:<channel>:<accountId>:dm:<peerId>(يكون accountId افتراضيًاdefault).- إذا طابق
session.identityLinksمعرّف قرين مسبوقًا بموفّر (على سبيل المثالtelegram:123)، فإن المفتاح المعياري يستبدل<peerId>بحيث يشترك الشخص نفسه في جلسة واحدة عبر القنوات.
- تعزل الدردشات الجماعية الحالة:
agent:<agentId>:<channel>:group:<id>(تستخدم الغرف/القنواتagent:<agentId>:<channel>:channel:<id>).- تُلحِق مواضيع منتديات Telegram
:topic:<threadId>بمعرّف المجموعة للعزل. - لا تزال مفاتيح
group:<id>القديمة معترفًا بها لأغراض الترحيل.
- تُلحِق مواضيع منتديات Telegram
- قد تستخدم السياقات الواردة
group:<id>؛ تُستنتج القناة منProviderوتُطبَّع إلى الصيغة المعياريةagent:<agentId>:<channel>:group:<id>. - مصادر أخرى:
- مهام Cron:
cron:<job.id> - Webhooks:
hook:<uuid>(ما لم يُحدَّد صراحة بواسطة الخطاف) - تشغيل العُقد:
node-<nodeId>
- مهام Cron:
دورة الحياة
- سياسة إعادة الضبط: تُعاد استخدام الجلسات حتى تنتهي صلاحيتها، ويُقيَّم الانتهاء عند الرسالة الواردة التالية.
- إعادة ضبط يومية: الافتراضي الساعة 4:00 صباحًا بالتوقيت المحلي على مضيف Gateway. تُعد الجلسة قديمة إذا كان آخر تحديث لها أقدم من أحدث وقت لإعادة الضبط اليومية.
- إعادة ضبط الخمول (اختياري): يضيف
idleMinutesنافذة خمول منزلقة. عند تكوين كلٍ من إعادة الضبط اليومية والخمول، فإن الأقرب انتهاءً يفرض جلسة جديدة. - الخمول فقط (قديم): إذا ضبطت
session.idleMinutesدون أي تهيئةsession.reset/resetByType، يبقى OpenClaw في وضع الخمول فقط للتوافق العكسي. - تجاوزات حسب النوع (اختياري): يتيح
resetByTypeتجاوز السياسة لأنواع الجلساتdirectوgroupوthread(thread = سلاسل Slack/Discord، مواضيع Telegram، سلاسل Matrix عندما يوفّرها الموصل). - تجاوزات حسب القناة (اختياري): يتجاوز
resetByChannelسياسة إعادة الضبط لقناة ما (ينطبق على جميع أنواع الجلسات لتلك القناة ويتقدّم علىreset/resetByType). - محفزات إعادة الضبط: يؤدّي وجود
/newأو/resetحرفيًا (بالإضافة إلى أي إضافات فيresetTriggers) إلى بدء معرّف جلسة جديد وتمرير بقية الرسالة. يقبل/new <model>اسمًا مستعارًا للنموذج أوprovider/modelأو اسم الموفّر (مطابقة تقريبية) لتعيين نموذج الجلسة الجديدة. إذا أُرسِل/newأو/resetبمفرده، يُجري OpenClaw دورة تحية «مرحبًا» قصيرة لتأكيد إعادة الضبط. - إعادة الضبط اليدوية: احذف مفاتيح محددة من المخزن أو أزل نص JSONL؛ تعيد الرسالة التالية إنشاءها.
- مهام Cron المعزولة تُنشئ دائمًا
sessionIdجديدًا لكل تشغيل (لا إعادة استخدام في الخمول).
Send policy (اختياري)
حظر التسليم لأنواع جلسات محددة دون إدراج معرّفات فردية./send on→ السماح لهذه الجلسة/send off→ الرفض لهذه الجلسة/send inherit→ مسح التجاوز واستخدام قواعد التهيئة أرسل هذه كرسائل مستقلة لكي تُسجَّل.
التهيئة (مثال إعادة تسمية اختياري)
الفحص
openclaw status— يعرض مسار المخزن والجلسات الأخيرة.openclaw sessions --json— يفرغ كل إدخال (التصفية باستخدام--active <minutes>).openclaw gateway call sessions.list --params '{}'— يجلب الجلسات من Gateway العامل (استخدم--url/--tokenللوصول إلى Gateway بعيد).- أرسل
/statusكرسالة مستقلة في الدردشة لمعرفة ما إذا كان الوكيل متاحًا، وكمية سياق الجلسة المستخدمة، ومفاتيح التفكير/الإسهاب الحالية، وموعد آخر تحديث لاعتمادات WhatsApp Web (يساعد على اكتشاف الحاجة لإعادة الربط). - أرسل
/context listأو/context detailلمعرفة ما الموجود في موجه النظام وملفات مساحة العمل المحقونة (وأكبر المساهمين في السياق). - أرسل
/stopكرسالة مستقلة لإيقاف التشغيل الحالي، ومسح المتابعات الموضوعة في الطابور لتلك الجلسة، وإيقاف أي تشغيلات لوكلاء فرعيين انبثقت منها (يتضمن الرد عدد الإيقافات). - أرسل
/compact(تعليمات اختيارية) كرسالة مستقلة لتلخيص السياق الأقدم وتحرير مساحة النافذة. انظر /concepts/compaction. - يمكن فتح نصوص JSONL مباشرة لمراجعة الدورات كاملة.
نصائح
- أبقِ المفتاح الرئيسي مخصصًا لحركة 1:1؛ ودَع المجموعات تحتفظ بمفاتيحها الخاصة.
- عند أتمتة التنظيف، احذف المفاتيح الفردية بدل المخزن كاملًا للحفاظ على السياق في أماكن أخرى.
بيانات تعريف مصدر الجلسة
يسجّل كل إدخال جلسة مصدره (بأفضل جهد) فيorigin:
label: تسمية بشرية (محلولة من تسمية المحادثة + موضوع المجموعة/القناة)provider: معرّف قناة مُطبَّع (بما في ذلك الامتدادات)from/to: معرّفات توجيه خام من الغلاف الواردaccountId: معرّف حساب الموفّر (عند تعدد الحسابات)threadId: معرّف السلسلة/الموضوع عندما تدعم القناة ذلك
تُملأ حقول المصدر للرسائل المباشرة والقنوات والمجموعات. إذا كان الموصل يحدّث توجيه التسليم فقط (على سبيل المثال، للحفاظ على حداثة الجلسة الرئيسية للرسائل المباشرة)، فيجب عليه مع ذلك توفير سياق وارد كي تحتفظ الجلسة ببياناتها التوضيحية. يمكن للامتدادات القيام بذلك بإرسالConversationLabelوGroupSubjectوGroupChannelوGroupSpaceوSenderNameفي السياق الوارد واستدعاءrecordSessionMetaFromInbound(أو تمرير السياق نفسه إلىupdateLastRoute).