توضّح هذه الصفحة كيفية إعداد خطاف ويب لإرسال رسائل غير متزامنة إلى مساحة في Chat باستخدام مشغّلات خارجية. على سبيل المثال، يمكنك إعداد تطبيق مراقبة لإرسال إشعار إلى الموظفين المناوبين على Chat عند تعطُّل أحد الخوادم. لإرسال رسالة متزامنة باستخدام تطبيق Chat، راجِع مقالة إرسال رسالة.
باستخدام هذا النوع من تصميم البنية، لا يمكن للمستخدمين التفاعل مع خطاف الويب أو التطبيق الخارجي المرتبط لأنّ الاتصال أحادي الاتجاه. لا يمكن إجراء محادثات باستخدام الردود التلقائية على الويب. ولا يمكنهم الرد على الرسائل الواردة من المستخدمين أو تلقّيها أو تلقّي أحداث التفاعل مع تطبيق Chat. للردّ على الرسائل، عليك إنشاء تطبيق Chat بدلاً من إنشاء خطاف ويب.
على الرغم من أنّ خطاف الويب ليس تطبيقًا من تطبيقات Chat من الناحية الفنية، إذ إنّ خطافات الويب تربط التطبيقات باستخدام طلبات HTTP عادية، تشير هذه الصفحة إليه على أنّه تطبيق من تطبيقات Chat لتسهيل الفهم. لا يعمل كل خطاف ويب إلا في مساحة Chat التي تم تسجيله فيها. تعمل خطافات الويب الواردة في الرسائل المباشرة، ولكن فقط عندما يكون تفعيل تطبيقات Chat متاحًا لجميع المستخدمين. لا يمكنك نشر خطافات الويب في Google Workspace Marketplace.
يوضّح المخطّط التالي بنية webhook مرتبطًا بتطبيق Chat:
في الرسم البياني السابق، يتضمّن تطبيق Chat مسار المعلومات التالي:
- تتلقّى منطق تطبيق Chat المعلومات من خدمات خارجية تابعة لجهات خارجية، مثل نظام إدارة المشاريع أو أداة إصدار التذاكر.
- تتم استضافة منطق تطبيق Chat إما في نظام مستند إلى السحابة الإلكترونية أو نظام محلي يمكنه إرسال الرسائل باستخدام عنوان URL للردّ التلقائي على الويب إلى مساحة Chat معيّنة.
- يمكن للمستخدمين تلقّي رسائل من تطبيق Chat في مساحة Chat المحدّدة، ولكن لا يمكنهم التفاعل مع تطبيق Chat.
المتطلبات الأساسية
Python
- حساب Google Workspace من إصدار Business أو Enterprise مع إذن الوصول إلى Google Chat يجب أن تسمح مؤسسة Google Workspace للمستخدمين بإضافة ردود تلقائية واردة على الويب واستخدامها.
- الإصدار 3.6 أو الإصدارات الأحدث من Python
- أداة إدارة الحزم pip
مكتبة
httplib2
لتثبيت المكتبة، نفِّذ الأمر التالي في واجهة سطر الأوامر:pip install httplib2
مساحة في Google Chat لإنشاء مساحة باستخدام Google Chat API، اطّلِع على مقالة إنشاء مساحة. لإنشاء مساحة في Chat، يُرجى الانتقال إلى مستندات مركز المساعدة.
Node.js
- حساب Google Workspace من إصدار Business أو Enterprise مع إذن الوصول إلى Google Chat يجب أن تسمح مؤسسة Google Workspace للمستخدمين بإضافة ردود تلقائية واردة على الويب واستخدامها.
- Node.js 14 أو إصدار أحدث
- npm، وهي أداة لإدارة الحِزم
- مساحة في Google Chat لإنشاء مساحة باستخدام Google Chat API، اطّلِع على مقالة إنشاء مساحة. لإنشاء مساحة في Chat، يُرجى الانتقال إلى مستندات مركز المساعدة.
Java
- حساب Google Workspace من إصدار Business أو Enterprise مع إذن الوصول إلى Google Chat يجب أن تسمح مؤسسة Google Workspace للمستخدمين بإضافة ردود تلقائية واردة على الويب واستخدامها.
- Java 11 أو إصدار أحدث
- أداة إدارة الحِزم Maven
- مساحة في Google Chat لإنشاء مساحة باستخدام Google Chat API، اطّلِع على مقالة إنشاء مساحة. لإنشاء مساحة في Chat، يُرجى الانتقال إلى مستندات مركز المساعدة.
برمجة تطبيقات
- حساب Google Workspace من إصدار Business أو Enterprise مع إذن الوصول إلى Google Chat يجب أن تسمح مؤسسة Google Workspace للمستخدمين بإضافة ردود تلقائية واردة على الويب واستخدامها.
- أنشئ مشروعًا مستقلاً في "برمجة تطبيقات Google"، وفعِّل خدمة Chat المتقدّمة.
- مساحة في Google Chat لإنشاء مساحة باستخدام Google Chat API، اطّلِع على مقالة إنشاء مساحة. لإنشاء مساحة في Chat، يُرجى الانتقال إلى مستندات مركز المساعدة.
إنشاء رابط خارجي
لإنشاء ردّ تلقائي على الويب، عليك تسجيله في مساحة Chat التي تريد تلقّي الرسائل فيها، ثم كتابة نص برمجي يرسل الرسائل.
تسجيل رابط الرد التلقائي الوارد على الويب
- في المتصفّح، افتح Chat. لا يمكن ضبط الردود التلقائية على الويب من تطبيق Chat للأجهزة الجوّالة.
- انتقِل إلى المساحة التي تريد إضافة خطاف ويب إليها.
- بجانب عنوان المساحة، انقر على سهم التوسيع، ثم انقر على التطبيقات وعمليات الدمج.
انقر على
إضافة خطافات ويب.في حقل الاسم، أدخِل
Quickstart Webhook
.في الحقل عنوان URL الخاص بالصورة الرمزية، أدخِل
https://developers.google.com/chat/images/chat-product-icon.png
.انقر على حفظ.
لنسخ عنوان URL الخاص بالرابط الخارجي، انقر على
المزيد، ثم انقر على نسخ الرابط.
كتابة نص الردّ التلقائي على الويب
يرسل نص الردّ التلقائي على الويب النموذجي رسالة إلى المساحة التي تم تسجيل الردّ التلقائي على الويب فيها، وذلك عن طريق إرسال طلب POST
إلى عنوان URL الخاص بالردّ التلقائي على الويب. تردّ واجهة برمجة التطبيقات Chat API بمثيل من Message
.
اختَر لغة لتعلّم كيفية إنشاء نص برمجي لخطاف ويب:
Python
في دليل العمل، أنشئ ملفًا باسم
quickstart.py
.في
quickstart.py
، الصِق الرمز التالي:استبدِل قيمة المتغيّر
url
بعنوان URL الخاص بالرابط الخارجي الذي نسخته عند تسجيل الرابط الخارجي.
Node.js
في دليل العمل، أنشئ ملفًا باسم
index.js
.في
index.js
، الصِق الرمز التالي:استبدِل قيمة المتغيّر
url
بعنوان URL الخاص بالرابط الخارجي الذي نسخته عند تسجيل الرابط الخارجي.
Java
في دليل العمل، أنشئ ملفًا باسم
pom.xml
.في
pom.xml
، انسخ ما يلي والصِقه:في دليل العمل، أنشئ بنية الدليل التالية
src/main/java
.في الدليل
src/main/java
، أنشئ ملفًا باسمApp.java
.في
App.java
، الصِق الرمز التالي:استبدِل قيمة المتغيّر
URL
بعنوان URL الخاص بخطاف الويب الذي نسخته عند تسجيل خطاف الويب.
برمجة تطبيقات
في المتصفّح، انتقِل إلى برمجة تطبيقات Google.
انقر على مشروع جديد.
ألصِق الرمز التالي:
استبدِل قيمة المتغيّر
url
بعنوان URL الخاص بخطاف الويب الذي نسخته عند تسجيل خطاف الويب.
تشغيل نص الرد التلقائي على الإنترنت
في واجهة سطر الأوامر، شغِّل النص البرمجي:
Python
python3 quickstart.py
Node.js
node index.js
Java
mvn compile exec:java -Dexec.mainClass=App
برمجة تطبيقات
- انقر على تشغيل.
عند تشغيل الرمز، يرسل الردّ التلقائي على الويب رسالة إلى المساحة التي سجّلت فيها الردّ التلقائي.
بدء سلسلة محادثات أو الردّ عليها
حدِّد
spaces.messages.thread.threadKey
كجزء من نص طلب الرسالة. استنادًا إلى ما إذا كنت تبدأ سلسلة محادثات أو تردّ عليها، استخدِم القيم التالية للسمةthreadKey
:إذا كنت تريد بدء سلسلة محادثات، اضبط قيمة
threadKey
على سلسلة عشوائية، ولكن احفظ هذه القيمة لنشر ردّ في سلسلة المحادثات.في حال الرد على سلسلة محادثات، حدِّد
threadKey
الذي تم ضبطه عند بدء سلسلة المحادثات. على سبيل المثال، لنشر ردّ في سلسلة المحادثات التي استخدمت فيها الرسالة الأوليةMY-THREAD
، اضبطMY-THREAD
.
حدِّد سلوك سلسلة المحادثات في حال عدم العثور على
threadKey
المحدّد:الرد على سلسلة محادثات أو بدء سلسلة محادثات جديدة أضِف المَعلمة
messageReplyOption=REPLY_MESSAGE_FALLBACK_TO_NEW_THREAD
إلى عنوان URL الخاص بالردّ التلقائي على الويب. يؤدي تمرير مَعلمة عنوان URL هذه إلى أن يبحث Chat عن سلسلة محادثات حالية باستخدامthreadKey
المحدّد. في حال العثور على سلسلة محادثات، يتم نشر الرسالة كردّ على تلك السلسلة. إذا لم يتم العثور على أي منها، ستبدأ الرسالة سلسلة محادثات جديدة تتوافق معthreadKey
.الردّ على سلسلة محادثات أو عدم اتّخاذ أي إجراء أضِف المَعلمة
messageReplyOption=REPLY_MESSAGE_OR_FAIL
إلى عنوان URL الخاص بالردّ التلقائي على الويب. يؤدي تمرير مَعلمة عنوان URL هذه إلى أن يبحث Chat عن سلسلة محادثات حالية باستخدامthreadKey
المحدّد. في حال العثور على سلسلة محادثات، يتم نشر الرسالة كردّ على تلك السلسلة. إذا لم يتم العثور على أي منها، لن يتم إرسال الرسالة.
لمزيد من المعلومات، يُرجى الانتقال إلى
messageReplyOption
.
يبدأ نموذج الرمز التالي سلسلة محادثات أو يردّ عليها:
Python
Node.js
برمجة تطبيقات
معالجة الأخطاء
قد يتعذّر إرسال طلبات Webhook لعدة أسباب، بما في ذلك:
- الطلب غير صالح.
- تم حذف الرابط الخارجي أو المساحة التي تستضيف الرابط الخارجي.
- المشاكل المتقطّعة، مثل الاتصال بالشبكة أو حدود الحصة
عند إنشاء ردّ تلقائي على الويب، يجب التعامل مع الأخطاء بشكل مناسب من خلال:
- تسجيل الخطأ
- بالنسبة إلى الأخطاء المستندة إلى الوقت أو الحصة أو الاتصال بالشبكة، أعِد محاولة الطلب باستخدام خوارزمية الرقود الأسي الثنائي.
- عدم اتّخاذ أي إجراء، وهو أمر مناسب إذا لم يكن إرسال رسالة Webhook مهمًا.
تعرض Google Chat API الأخطاء على شكل
google.rpc.Status
،
الذي يتضمّن خطأ HTTP code
يشير إلى نوع الخطأ الذي
حدث، سواء كان خطأ في البرنامج (السلسلة 400) أو خطأ في الخادم (السلسلة 500). لمراجعة جميع عمليات الربط ببروتوكول HTTP، يُرجى الاطّلاع على google.rpc.Code
.
{
"code": 503,
"message": "The service is currently unavailable.",
"status": "UNAVAILABLE"
}
لمعرفة كيفية تفسير رموز حالة HTTP والتعامل مع الأخطاء، راجِع مقالة الأخطاء.
القيود والاعتبارات
- عند إنشاء رسالة
باستخدام خطاف ويب في Google Chat API، لا يتضمّن الرد الرسالة الكاملة.
يتم ملء الحقلَين
name
وthread.name
فقط في الردّ. - تخضع خطافات الويب لحصة المساحة الواحدة في
spaces.messages.create
: طلب واحد في الثانية، تتم مشاركته بين جميع خطافات الويب في المساحة. قد يرفض Chat أيضًا طلبات Webhook التي تتجاوز استعلامًا واحدًا في الثانية في المساحة نفسها. لمزيد من المعلومات حول حصص Chat API، يُرجى الاطّلاع على حدود الاستخدام.