يمكنك استخدام الطرق في مجموعة Watches لتلقّي إشعارات عند تغيُّر البيانات في النماذج. تقدّم هذه الصفحة نظرة عامة على الإشعارات الفورية وتعليمات حول كيفية إعدادها وتلقّيها.
نظرة عامة
تتيح ميزة الإشعارات الفورية في Google Forms API للتطبيقات الاشتراك في تلقّي إشعارات عند حدوث تغييرات في البيانات في النماذج. يتم تسليم الإشعارات إلى موضوع Cloud Pub/Sub، عادةً في غضون دقائق من حدوث التغيير.
لتلقّي إشعارات فورية، عليك إعداد موضوع في Cloud Pub/Sub وتقديم اسم هذا الموضوع عند إنشاء مراقبة لنوع الحدث المناسب.
في ما يلي تعريفات للمفاهيم الرئيسية المستخدَمة في هذه المستندات:
- الهدف هو المكان الذي يتم إرسال الإشعارات إليه. الهدف الوحيد المتاح هو موضوع Cloud Pub/Sub.
- نوع الحدث هو فئة من الإشعارات التي يمكن لتطبيق تابع لجهة خارجية الاشتراك فيها.
- المراقبة هي تعليمات موجّهة إلى Forms API لإرسال إشعارات بشأن نوع حدث معيّن في نموذج معيّن إلى هدف.
بعد إنشاء مراقبة لنوع حدث في نموذج معيّن، يتلقّى هدف المراقبة (وهو موضوع في Cloud Pub/Sub) إشعارات من هذه الأحداث في هذا النموذج إلى أن تنتهي صلاحية المراقبة. تدوم مدة صلاحية الساعة أسبوعًا، ولكن يمكنك تمديدها في أي وقت قبل انتهاء صلاحيتها من خلال إرسال طلب إلى watches.renew().
يتلقّى موضوع Cloud Pub/Sub إشعارات فقط بشأن النماذج التي يمكنك الاطّلاع عليها باستخدام بيانات الاعتماد التي تقدّمها. على سبيل المثال، إذا ألغى المستخدم الإذن من تطبيقك أو فقد إذن التعديل في نموذج تتم مراقبته، لن يتم إرسال الإشعارات بعد ذلك.
أنواع الأحداث المتاحة
توفّر Google Forms API حاليًا فئتَين من الأحداث:
-
EventType.SCHEMA، التي تُرسل إشعارات بشأن التعديلات التي يتم إجراؤها على محتوى النموذج وإعداداته. EventType.RESPONSES، الذي يرسل إشعارًا عند إرسال ردود النموذج (الجديدة والمعدَّلة).
ردود الإشعارات
يتم ترميز الإشعارات باستخدام JSON وتحتوي على ما يلي:
- رقم تعريف النموذج الذي يؤدي إلى تشغيل الإجراء
- رقم تعريف المشاهدة التي أدّت إلى ظهور الإعلان
- نوع الحدث الذي أدى إلى ظهور الإشعار
- الحقول الأخرى التي يتم ضبطها من خلال Cloud Pub/Sub، مثل
messageIdوpublishTime
لا تحتوي الإشعارات على بيانات تفصيلية عن النماذج أو الردود. بعد تلقّي كل إشعار، يجب إجراء طلب منفصل من واجهة برمجة التطبيقات لاسترداد البيانات الجديدة. اطّلِع على الاستخدام المقترَح لمعرفة كيفية إجراء ذلك.
يوضّح المقتطف التالي نموذج إشعار بتغيير في المخطط:
{
"attributes": {
"eventType": "SCHEMA",
"formId": "18Xgmr4XQb-l0ypfCNGQoHAw2o82foMr8J0HPHdagS6g",
"watchId": "892515d1-a902-444f-a2fe-42b718fe8159"
},
"messageId": "767437830649",
"publishTime": "2021-03-31T01:34:08.053Z"
}
يوضّح المقتطف التالي نموذج إشعار بردّ جديد:
{
"attributes": {
"eventType": "RESPONSES",
"formId": "18Xgmr4XQb-l0ypfCNGQoHAw2o82foMr8J0HPHdagS6g",
"watchId": "5d7e5690-b1ff-41ce-8afb-b469912efd7d"
},
"messageId": "767467004397",
"publishTime": "2021-03-31T01:43:57.285Z"
}
إعداد موضوع Cloud Pub/Sub
يتم إرسال الإشعارات إلى مواضيع Cloud Pub/Sub. من خلال Cloud Pub/Sub، يمكنك تلقّي إشعارات على رابط ويب أو عن طريق طلب البيانات بشكل متكرّر من نقطة نهاية الاشتراك.
لإعداد موضوع Cloud Pub/Sub، اتّبِع الخطوات التالية:
- أكمِل المتطلبات الأساسية في Cloud Pub/Sub.
- إعداد عميل Cloud Pub/Sub
- راجِع أسعار Cloud Pub/Sub، وفعِّل الفوترة لمشروعك على Developer Console.
يمكنك إنشاء موضوع Cloud Pub/Sub بإحدى الطرق الثلاث التالية:
- باستخدام Play Console (الأسهل)
- باستخدام أداة سطر الأوامر (للاستخدام البرمجي البسيط) أو
- باستخدام Cloud Pub/Sub API.
إنشاء اشتراك في Cloud Pub/Sub لتحديد طريقة تسليم الإشعارات من خلال Cloud Pub/Sub
أخيرًا، قبل إنشاء عمليات مراقبة تستهدف موضوعك، عليك منح الإذن لحساب خدمة الإشعارات في "نماذج Google" (forms-notifications@system.gserviceaccount.com) بالنشر في موضوعك.
إنشاء ساعة
بعد الحصول على موضوع يمكن لحساب خدمة الإشعارات الفورية في Forms API نشره، يمكنك إنشاء إشعارات باستخدام طريقة watches.create(). تتحقّق هذه الطريقة من إمكانية وصول حساب خدمة الإشعارات الفورية إلى موضوع Cloud Pub/Sub المقدَّم، وفي حال عدم إمكانية الوصول إلى الموضوع، سيحدث خطأ، مثلاً إذا كان الموضوع غير متوفّر أو لم تمنحه إذن النشر في هذا الموضوع.
Python
Node.js
حذف ساعة
Python
Node.js
التفويض
مثل جميع طلبات البيانات من Forms API، يجب أن يتم السماح بإرسال الطلبات إلى watches.create() باستخدام رمز موافقة مميز. يجب أن تتضمّن الرمز المميّز نطاقًا يمنح إذن الوصول للقراءة إلى البيانات التي يتم إرسال إشعارات بشأنها.
- بالنسبة إلى تغييرات المخطط، يعني ذلك أي نطاق يمنح إذن الوصول للقراءة إلى النماذج باستخدام forms.get().
- بالنسبة إلى الردود، يعني ذلك أي نطاق يمنح إذن الوصول للقراءة إلى ردود النماذج، على سبيل المثال باستخدام forms.responses.list().
لكي يتم تسليم الإشعارات، يجب أن يحتفظ التطبيق بإذن OAuth من المستخدم المفوَّض بالنطاقات المطلوبة. في حال قطع المستخدم اتصال التطبيق، تتوقف الإشعارات وقد يتم تعليق الساعة مع ظهور خطأ. لاستئناف تلقّي الإشعارات بعد استعادة التفويض، يُرجى الاطّلاع على مقالة تجديد تفويض ساعة.
عرض قائمة بالساعات التي تمّت إضافتها إلى نموذج
Python
Node.js
تجديد اشتراك في ساعة
Python
Node.js
التقييد
يتم الحدّ من عدد الإشعارات، إذ يمكن أن تتلقّى كل ساعة إشعارًا واحدًا كحدّ أقصى كل ثلاثين ثانية. يخضع حدّ التكرار هذا للتغيير.
بسبب الحدّ من عدد الإشعارات، قد يتوافق إشعار واحد مع أحداث متعددة. بعبارة أخرى، يشير الإشعار إلى وقوع حدث واحد أو أكثر منذ آخر إشعار.
الحدود
في أي وقت، يمكن أن يتضمّن كل مشروع على Cloud Console نموذجًا ونوع حدث معيّنًا مما يلي:
- ما يصل إلى 20 مشاهدة إجمالاً
- مشاهدة واحدة كحدّ أقصى لكل مستخدم نهائي
بالإضافة إلى ذلك، يقتصر عدد عمليات المشاهدة لكل نموذج في أي وقت على 50 عملية لكل نوع حدث في الإجمالي على مستوى جميع مشاريع Cloud Console.
يتم ربط الساعة بمستخدم نهائي عند إنشائها أو تجديدها باستخدام بيانات اعتماد هذا المستخدم. يتم تعليق عملية المراقبة إذا فقد المستخدم النهائي المرتبط إمكانية الوصول إلى النموذج أو إذا ألغى إذن وصول التطبيق إلى النموذج.
الموثوقية
يتم إعلام كل ساعة مرة واحدة على الأقل بعد كل حدث في جميع الحالات باستثناء الحالات الاستثنائية. في معظم الحالات، يتم إرسال إشعار في غضون دقائق من وقوع الحدث.
الأخطاء
إذا تعذّر بشكل متكرّر إرسال الإشعارات إلى الساعة، ستصبح حالة الساعة SUSPENDED وسيتم ضبط الحقل errorType في الساعة. لإعادة ضبط حالة الساعة المعلقة إلى ACTIVE واستئناف الإشعارات، يُرجى الاطّلاع على تجديد اشتراك ساعة.
الاستخدام المقترَح
- استخدام موضوع Cloud Pub/Sub واحد كهدف للعديد من عمليات المراقبة
- عند تلقّي إشعار بشأن موضوع معيّن، يتم تضمين معرّف النموذج في حمولة الإشعار. استخدِمها مع نوع الحدث لمعرفة البيانات التي يجب استرجاعها والشكل الذي يجب استرجاعها منه.
- لاسترداد البيانات المعدَّلة بعد تلقّي إشعار يتضمّن
EventType.RESPONSES، استخدِم الدالة forms.responses.list().- اضبط الفلتر على الطلب على
timestamp > timestamp_of_the_last_response_you_fetched.
- اضبط الفلتر على الطلب على
- لجلب البيانات المعدَّلة بعد تلقّي إشعار يتضمّن
EventType.SCHEMA، استخدِم الدالة forms.get().