Regional platforms
LINE
LINE يتصل بـ OpenClaw عبر LINE Messaging API. يعمل الـ Plugin كمستقبِل Webhook على الـ Gateway ويستخدم رمز وصول القناة + سر القناة لديك للمصادقة.
الحالة: Plugin قابل للتنزيل. الرسائل المباشرة، دردشات المجموعات، الوسائط، المواقع، رسائل Flex، رسائل القوالب، والردود السريعة مدعومة. التفاعلات والسلاسل غير مدعومة.
التثبيت
ثبّت LINE قبل إعداد القناة:
openclaw plugins install @openclaw/lineنسخة محلية (عند التشغيل من مستودع git):
openclaw plugins install ./path/to/local/line-pluginالإعداد
- أنشئ حساب LINE Developers وافتح وحدة التحكم: https://developers.line.biz/console/
- أنشئ (أو اختر) موفّرًا وأضف قناة Messaging API.
- انسخ Channel access token وChannel secret من إعدادات القناة.
- فعّل Use webhook في إعدادات Messaging API.
- اضبط عنوان Webhook URL على نقطة نهاية الـ Gateway لديك (يتطلب HTTPS):
https://gateway-host/line/webhookيستجيب الـ Gateway للتحقق من Webhook الخاص بـ LINE (GET) ويقرّ بالأحداث الواردة
الموقّعة (POST) فورًا بعد التحقق من التوقيع والحمولة؛ وتستمر معالجة الوكيل
بشكل غير متزامن.
إذا كنت تحتاج إلى مسار مخصص، فاضبط channels.line.webhookPath أو
channels.line.accounts.<id>.webhookPath وحدّث عنوان URL وفقًا لذلك.
ملاحظة أمنية:
- يعتمد تحقق توقيع LINE على النص الأساسي (HMAC على النص الخام)، لذلك يطبق OpenClaw حدودًا صارمة على النص قبل المصادقة ومهلة زمنية قبل التحقق.
- يعالج OpenClaw أحداث Webhook من بايتات الطلب الخام المتحقق منها. يتم تجاهل قيم
req.bodyالمحوّلة بواسطة البرمجيات الوسيطة upstream حفاظًا على سلامة التوقيع.
التكوين
الحد الأدنى من التكوين:
{ channels: { line: { enabled: true, channelAccessToken: "LINE_CHANNEL_ACCESS_TOKEN", channelSecret: "LINE_CHANNEL_SECRET", dmPolicy: "pairing", }, },}تكوين الرسائل المباشرة العامة:
{ channels: { line: { enabled: true, channelAccessToken: "LINE_CHANNEL_ACCESS_TOKEN", channelSecret: "LINE_CHANNEL_SECRET", dmPolicy: "open", allowFrom: ["*"], }, },}متغيرات البيئة (الحساب الافتراضي فقط):
LINE_CHANNEL_ACCESS_TOKENLINE_CHANNEL_SECRET
ملفات الرمز/السر:
{ channels: { line: { tokenFile: "/path/to/line-token.txt", secretFile: "/path/to/line-secret.txt", }, },}يجب أن يشير tokenFile وsecretFile إلى ملفات عادية. تُرفض الروابط الرمزية.
حسابات متعددة:
{ channels: { line: { accounts: { marketing: { channelAccessToken: "...", channelSecret: "...", webhookPath: "/line/marketing", }, }, }, },}التحكم في الوصول
الرسائل المباشرة افتراضيًا تستخدم الاقتران. يحصل المرسلون غير المعروفين على رمز اقتران ويتم تجاهل رسائلهم حتى تتم الموافقة عليهم.
openclaw pairing list lineopenclaw pairing approve line <CODE>قوائم السماح والسياسات:
channels.line.dmPolicy:pairing | allowlist | open | disabledchannels.line.allowFrom: معرّفات مستخدمي LINE المسموح بها للرسائل المباشرة؛ يتطلبdmPolicy: "open"القيمة["*"]channels.line.groupPolicy:allowlist | open | disabledchannels.line.groupAllowFrom: معرّفات مستخدمي LINE المسموح بها للمجموعات- تجاوزات لكل مجموعة:
channels.line.groups.<groupId>.allowFrom - يمكن الرجوع إلى مجموعات وصول المرسلين الثابتة من
allowFromوgroupAllowFromوallowFromالخاصة بكل مجموعة باستخدامaccessGroup:<name>. - ملاحظة وقت التشغيل: إذا كان
channels.lineمفقودًا بالكامل، يعود وقت التشغيل إلىgroupPolicy="allowlist"لفحوصات المجموعات (حتى إذا كانchannels.defaults.groupPolicyمضبوطًا).
معرّفات LINE حساسة لحالة الأحرف. تبدو المعرّفات الصالحة كالتالي:
- المستخدم:
U+ 32 حرفًا سداسيًا - المجموعة:
C+ 32 حرفًا سداسيًا - الغرفة:
R+ 32 حرفًا سداسيًا
سلوك الرسائل
- يُقسّم النص عند 5000 حرف.
- تُزال تنسيقات Markdown؛ وتُحوّل كتل الكود والجداول إلى بطاقات Flex عندما يكون ذلك ممكنًا.
- تُخزّن الاستجابات المتدفقة مؤقتًا؛ يتلقى LINE أجزاء كاملة مع رسم تحميل أثناء عمل الوكيل.
- تنزيلات الوسائط محدودة بواسطة
channels.line.mediaMaxMb(الافتراضي 10). - تُحفظ الوسائط الواردة تحت
~/.openclaw/media/inbound/قبل تمريرها إلى الوكيل، بما يطابق مخزن الوسائط المشترك المستخدم بواسطة Plugins القنوات المجمعة الأخرى.
بيانات القناة (الرسائل الغنية)
استخدم channelData.line لإرسال ردود سريعة أو مواقع أو بطاقات Flex أو رسائل قوالب.
{ text: "Here you go", channelData: { line: { quickReplies: ["Status", "Help"], location: { title: "Office", address: "123 Main St", latitude: 35.681236, longitude: 139.767125, }, flexMessage: { altText: "Status card", contents: { /* Flex payload */ }, }, templateMessage: { type: "confirm", text: "Proceed?", confirmLabel: "Yes", confirmData: "yes", cancelLabel: "No", cancelData: "no", }, }, },}يشحن Plugin LINE أيضًا أمر /card لإعدادات رسائل Flex المسبقة:
/card info "Welcome" "Thanks for joining!"دعم ACP
يدعم LINE ارتباطات محادثات ACP (Agent Communication Protocol):
- يربط
/acp spawn <agent> --bind hereدردشة LINE الحالية بجلسة ACP دون إنشاء سلسلة فرعية. - تعمل ارتباطات ACP المكوّنة وجلسات ACP النشطة المرتبطة بالمحادثة على LINE كما تعمل في قنوات المحادثة الأخرى.
راجع وكلاء ACP للتفاصيل.
الوسائط الصادرة
يدعم Plugin LINE إرسال الصور والفيديوهات وملفات الصوت عبر أداة رسائل الوكيل. تُرسل الوسائط عبر مسار التسليم الخاص بـ LINE مع معالجة مناسبة للمعاينة والتتبع:
- الصور: تُرسل كرسائل صور LINE مع إنشاء معاينة تلقائي.
- الفيديوهات: تُرسل مع معالجة صريحة للمعاينة ونوع المحتوى.
- الصوت: يُرسل كرسائل صوت LINE.
يجب أن تكون عناوين URL للوسائط الصادرة عناوين HTTPS عامة. يتحقق OpenClaw من اسم مضيف الهدف قبل تسليم عنوان URL إلى LINE ويرفض أهداف loopback المحلية، وlink-local، والشبكات الخاصة.
تعود عمليات إرسال الوسائط العامة إلى مسار الصور فقط الحالي عندما لا يتوفر مسار خاص بـ LINE.
استكشاف الأخطاء وإصلاحها
- فشل التحقق من Webhook: تأكد من أن عنوان Webhook URL يستخدم HTTPS وأن
channelSecretيطابق وحدة تحكم LINE. - لا توجد أحداث واردة: تأكد من أن مسار Webhook يطابق
channels.line.webhookPathوأن الـ Gateway يمكن الوصول إليه من LINE. - أخطاء تنزيل الوسائط: ارفع
channels.line.mediaMaxMbإذا تجاوزت الوسائط الحد الافتراضي.
ذو صلة
- نظرة عامة على القنوات — كل القنوات المدعومة
- الاقتران — مصادقة الرسائل المباشرة وتدفق الاقتران
- المجموعات — سلوك دردشة المجموعات وبوابة الإشارات
- توجيه القنوات — توجيه الجلسات للرسائل
- الأمان — نموذج الوصول والتقوية