LINE
يتصل LINE بـ OpenClaw عبر LINE Messaging API. يعمل plugin كمستقبل webhook على gateway ويستخدم channel access token وchannel secret الخاصين بك للمصادقة. الحالة: plugin مضمّن. الرسائل المباشرة، ودردشات المجموعات، والوسائط، والمواقع، ورسائل Flex، ورسائل القوالب، والردود السريعة مدعومة. التفاعلات والخيوط غير مدعومة.Plugin مضمّن
يأتي LINE كـ plugin مضمّن في إصدارات OpenClaw الحالية، لذا فإن النسخ المجمعة العادية لا تحتاج إلى تثبيت منفصل. إذا كنت تستخدم إصدارًا أقدم أو تثبيتًا مخصصًا لا يتضمن LINE، فقم بتثبيته يدويًا:الإعداد
- أنشئ حساب LINE Developers وافتح Console: https://developers.line.biz/console/
- أنشئ Provider (أو اختر واحدًا) وأضف قناة Messaging API.
- انسخ Channel access token وChannel secret من إعدادات القناة.
- فعّل Use webhook في إعدادات Messaging API.
- اضبط عنوان URL الخاص بـ webhook على نقطة نهاية gateway لديك (يتطلب HTTPS):
channels.line.webhookPath أو
channels.line.accounts.<id>.webhookPath وحدّث عنوان URL وفقًا لذلك.
ملاحظة أمنية:
- يعتمد التحقق من توقيع LINE على جسم الطلب (HMAC على الجسم الخام)، لذلك يطبق OpenClaw حدودًا صارمة على حجم جسم ما قبل المصادقة ومهلة زمنية قبل التحقق.
- يعالج OpenClaw أحداث webhook من بايتات الطلب الخام التي تم التحقق منها. يتم تجاهل قيم
req.bodyالتي حوّلتها برمجيات middleware في الطبقة العليا حفاظًا على سلامة التوقيع.
التكوين
الحد الأدنى من التكوين:LINE_CHANNEL_ACCESS_TOKENLINE_CHANNEL_SECRET
tokenFile وsecretFile إلى ملفات عادية. يتم رفض الروابط الرمزية.
حسابات متعددة:
التحكم في الوصول
تستخدم الرسائل المباشرة pairing افتراضيًا. يحصل المرسلون غير المعروفين على رمز pairing ويتم تجاهل رسائلهم حتى تتم الموافقة عليها.channels.line.dmPolicy: pairing | allowlist | open | disabledchannels.line.allowFrom: معرّفات مستخدمي LINE المسموح لهم في الرسائل المباشرةchannels.line.groupPolicy: allowlist | open | disabledchannels.line.groupAllowFrom: معرّفات مستخدمي LINE المسموح لهم في المجموعات- عمليات تجاوز لكل مجموعة:
channels.line.groups.<groupId>.allowFrom - ملاحظة وقت التشغيل: إذا كان
channels.lineمفقودًا بالكامل، يعود وقت التشغيل إلىgroupPolicy="allowlist"لفحوصات المجموعات (حتى إذا كانchannels.defaults.groupPolicyمعيّنًا).
- مستخدم:
U+ 32 حرفًا سداسيًا عشريًا - مجموعة:
C+ 32 حرفًا سداسيًا عشريًا - غرفة:
R+ 32 حرفًا سداسيًا عشريًا
سلوك الرسائل
- يتم تقسيم النص إلى أجزاء عند 5000 حرف.
- تتم إزالة تنسيق Markdown؛ وتتحول كتل التعليمات البرمجية والجداول إلى بطاقات Flex عندما يكون ذلك ممكنًا.
- يتم تخزين الردود المتدفقة مؤقتًا؛ ويتلقى LINE أجزاء كاملة مع رسم متحرك للتحميل أثناء عمل الوكيل.
- يتم تقييد تنزيلات الوسائط بواسطة
channels.line.mediaMaxMb(الافتراضي 10).
بيانات القناة (الرسائل الغنية)
استخدمchannelData.line لإرسال الردود السريعة أو المواقع أو بطاقات Flex أو
رسائل القوالب.
/card لإعدادات رسائل Flex المسبقة:
دعم ACP
يدعم LINE ربط المحادثات عبر ACP (Agent Communication Protocol):/acp spawn <agent> --bind hereيربط دردشة LINE الحالية بجلسة ACP من دون إنشاء خيط فرعي.- تعمل ارتباطات ACP المكوّنة وجلسات ACP النشطة المرتبطة بالمحادثة على LINE كما هو الحال في قنوات المحادثة الأخرى.
الوسائط الصادرة
يدعم plugin الخاص بـ LINE إرسال الصور ومقاطع الفيديو والملفات الصوتية عبر أداة رسائل الوكيل. يتم إرسال الوسائط عبر مسار التسليم الخاص بـ LINE مع معالجة مناسبة للمعاينة والتتبع:- الصور: تُرسل كرسائل صور LINE مع إنشاء معاينة تلقائيًا.
- مقاطع الفيديو: تُرسل مع معالجة صريحة للمعاينة ونوع المحتوى.
- الصوت: يُرسل كرسائل صوتية LINE.
استكشاف الأخطاء وإصلاحها
- فشل التحقق من webhook: تأكد من أن عنوان URL الخاص بـ webhook يستخدم HTTPS وأن
channelSecretيطابق ما في LINE Console. - لا توجد أحداث واردة: تأكد من أن مسار webhook يطابق
channels.line.webhookPathوأن gateway يمكن الوصول إليه من LINE. - أخطاء تنزيل الوسائط: ارفع قيمة
channels.line.mediaMaxMbإذا تجاوزت الوسائط الحد الافتراضي.
ذو صلة
- نظرة عامة على القنوات — جميع القنوات المدعومة
- Pairing — مصادقة الرسائل المباشرة وتدفق pairing
- المجموعات — سلوك الدردشة الجماعية وتقييد الإشارات
- توجيه القنوات — توجيه الجلسات للرسائل
- الأمان — نموذج الوصول والتقوية