الاكتشاف ووسائط النقل
لدى OpenClaw مشكلتان متميزتان تبدوان متشابهتين ظاهريًا:- التحكّم عن بُعد للمشغّل: تطبيق شريط القوائم على macOS الذي يتحكّم في Gateway يعمل في مكان آخر.
- إقران العُقد: عُقد iOS/Android (وعُقد مستقبلية) تعثر على Gateway وتُجري إقرانًا آمنًا.
openclaw gateway)، مع إبقاء العملاء (تطبيق mac وiOS) كمستهلكين.
المصطلحات
- Gateway: عملية Gateway واحدة طويلة التشغيل تمتلك الحالة (الجلسات، الإقران، سجل العُقد) وتُشغّل القنوات. تستخدم معظم الإعدادات واحدة لكل مضيف؛ كما يمكن إعداد عدة Gateways معزولة.
- Gateway WS (مستوى التحكّم): نقطة نهاية WebSocket على
127.0.0.1:18789افتراضيًا؛ ويمكن ربطها بـ LAN/شبكة tailnet عبرgateway.bind. - نقل WS مباشر: نقطة نهاية Gateway WS مواجهة لـ LAN/شبكة tailnet (من دون SSH).
- نقل SSH (احتياطي): التحكّم عن بُعد عبر تمرير
127.0.0.1:18789من خلال SSH. - جسر TCP قديم (مهجور/مزال): نقل عُقد أقدم (انظر بروتوكول الجسر)؛ لم يعد مُعلنًا للاكتشاف.
لماذا نحتفظ بكلٍّ من «المباشر» وSSH
- WS المباشر يوفّر أفضل تجربة استخدام على الشبكة نفسها وضمن شبكة tailnet:
- اكتشاف تلقائي على LAN عبر Bonjour
- رموز إقران + قوائم تحكّم بالوصول (ACLs) مملوكة لـ Gateway
- لا حاجة لوصول shell؛ يمكن إبقاء سطح البروتوكول محكمًا وقابلًا للتدقيق
- SSH يبقى الاحتياطي الشامل:
- يعمل أينما يتوفر وصول SSH (حتى عبر شبكات غير مترابطة)
- يتجاوز مشكلات البثّ المتعدد/mDNS
- لا يتطلب منافذ واردة جديدة بخلاف SSH
مُدخلات الاكتشاف (كيف يتعرّف العملاء على مكان Gateway)
1. Bonjour / mDNS (LAN فقط)
يعمل Bonjour على أساس أفضل جهد ولا يعبر الشبكات. يُستخدم فقط لتسهيل «الشبكة المحلية نفسها». الاتجاه المستهدف:- يقوم Gateway بالإعلان عن نقطة نهاية WS الخاصة به عبر Bonjour.
- يتصفح العملاء ويعرضون قائمة «اختر Gateway»، ثم يحفظون نقطة النهاية المختارة.
تفاصيل منارة الخدمة
- أنواع الخدمة:
_openclaw-gw._tcp(منارة نقل Gateway)
- مفاتيح TXT (غير سرّية):
role=gatewaylanHost=<hostname>.localsshPort=22(أو أيًّا مما يتم الإعلان عنه)gatewayPort=18789(Gateway WS + HTTP)gatewayTls=1(فقط عند تمكين TLS)gatewayTlsSha256=<sha256>(فقط عند تمكين TLS وتوفّر البصمة)canvasPort=18793(منفذ مضيف canvas الافتراضي؛ يقدّم/__openclaw__/canvas/)cliPath=<path>(اختياري؛ مسار مطلق إلى نقطة إدخال أو ملف ثنائي قابل للتشغيل لـopenclaw)tailnetDns=<magicdns>(تلميح اختياري؛ يُكتشف تلقائيًا عند توفّر Tailscale)
- يجب على العملاء التعامل مع قيم TXT كإرشادات لواجهة المستخدم فقط. يجب أن يفضّل التوجيه (المضيف/المنفذ) نقطة نهاية الخدمة التي تم حلّها (SRV + A/AAAA) بدلاً من القيم المقدمة عبر TXT مثل
lanHostأوtailnetDnsأوgatewayPort. - يجب ألا يسمح تثبيت TLS مطلقًا لقيمة
gatewayTlsSha256المُعلَن عنها بتجاوز بصمة مثبتة مسبقًا. - يجب على عقد iOS/Android اعتبار الاتصالات المباشرة المعتمدة على الاكتشاف على أنها TLS فقط واشتراط تأكيد صريح «الوثوق بهذه البصمة» قبل تخزين بصمة لأول مرة (تحقق خارج النطاق).
- استخدم هذه الصفحة لعمليات اليوم الأول للتشغيل وعمليات اليوم الثاني لخدمة Gateway.
OPENCLAW_DISABLE_BONJOUR=1يعطّل الإعلان.gateway.bindضمن~/.openclaw/openclaw.jsonيتحكّم في وضع ربط Gateway.OPENCLAW_SSH_PORTيتجاوز منفذ SSH المُعلن في TXT (الافتراضي 22).OPENCLAW_TAILNET_DNSينشر تلميحtailnetDns(MagicDNS).OPENCLAW_CLI_PATHيتجاوز مسار CLI المُعلن.
2. شبكة Tailnet (عبر الشبكات)
في إعدادات على نمط لندن/فيينا، لن يفيد Bonjour. الهدف «المباشر» الموصى به هو:- اسم Tailscale MagicDNS (مفضّل) أو عنوان IP ثابت ضمن شبكة tailnet.
tailnetDns كتلميح اختياري للعملاء (بما في ذلك منارات النطاق الواسع).
3. هدف يدوي / SSH
عندما لا يوجد مسار مباشر (أو يكون المباشر معطّلًا)، يمكن للعملاء دائمًا الاتصال عبر SSH بتمرير منفذ Gateway على local loopback. انظر الوصول عن بُعد.اختيار وسيلة النقل (سياسة العميل)
سلوك العميل الموصى به:- إذا كانت نقطة نهاية مباشرة مُقترنة ومُهيّأة ويمكن الوصول إليها، فاستخدمها.
- وإلا، إذا عثر Bonjour على Gateway على LAN، فاعرض خيار «استخدم هذا الـ Gateway» بنقرة واحدة واحفظه كنقطة النهاية المباشرة.
- وإلا، إذا كان اسم DNS/عنوان IP لشبكة tailnet مُهيّأ، فجرّب الاتصال المباشر.
- وإلا، ارجع إلى SSH.
الإقران + المصادقة (النقل المباشر)
Gateway هو مصدر الحقيقة لقبول العُقد/العملاء.- تُنشأ طلبات الإقران وتُوافق أو تُرفض داخل Gateway (انظر إقران Gateway).
- يفرض Gateway ما يلي:
- المصادقة (رمز/زوج مفاتيح)
- النطاقات/قوائم التحكّم بالوصول ACLs (Gateway ليس وسيطًا خامًا لكل طريقة)
- حدود المعدّل
المسؤوليات حسب المكوّن
- Gateway: يعلن منارات الاكتشاف، يمتلك قرارات الإقران، ويستضيف نقطة نهاية WS.
- تطبيق macOS: يساعدك على اختيار Gateway، ويعرض مطالبات الإقران، ويستخدم SSH فقط كخيار احتياطي.
- عُقد iOS/Android: تتصفح Bonjour كتسهيل وتَتصل بـ Gateway WS المُقترن.