شما میتوانید از متدهای مجموعه Watches برای دریافت اعلانها هنگام تغییر دادهها در فرمها استفاده کنید. این صفحه یک مرور کلی مفهومی و دستورالعملهایی برای تنظیم و دریافت اعلانهای فوری ارائه میدهد.
نمای کلی
قابلیت اعلانهای فوری API فرمهای گوگل به برنامهها اجازه میدهد تا هنگام تغییر دادهها در فرمها، در اعلانها مشترک شوند. اعلانها معمولاً ظرف چند دقیقه پس از تغییر، به یک موضوع Cloud Pub/Sub ارسال میشوند.
برای دریافت اعلانهای فوری، باید یک موضوع Cloud Pub/Sub تنظیم کنید و هنگام ایجاد watch برای نوع رویداد مناسب، نام آن موضوع را ارائه دهید.
در زیر تعاریف مفاهیم کلیدی مورد استفاده در این سند آمده است:
- یک هدف ، مکانی است که اعلانها به آنجا ارسال میشوند. تنها هدف پشتیبانیشده، یک موضوع Cloud Pub/Sub است.
- نوع رویداد ، دستهای از اعلانها است که یک برنامه شخص ثالث میتواند در آن مشترک شود.
- یک watch دستورالعملی به Forms API است تا اعلانهایی را برای یک نوع رویداد خاص در یک فرم خاص به یک هدف ارسال کند.
زمانی که برای یک نوع رویداد در یک فرم خاص، یک watch ایجاد میکنید، هدف آن watch (که یک Cloud Pub/Sub topic است) تا زمان انقضای watch، اعلانهایی از آن رویدادها در آن فرم دریافت میکند. watch شما یک هفته طول میکشد، اما میتوانید با ارسال درخواستی به watches.renew() آن را در هر زمانی قبل از انقضا تمدید کنید.
موضوع Cloud Pub/Sub شما فقط اعلانهایی درباره فرمهایی دریافت میکند که میتوانید با اعتبارنامههایی که ارائه میدهید مشاهده کنید. به عنوان مثال، اگر کاربر مجوز برنامه شما را لغو کند یا دسترسی ویرایش به یک فرم مشاهده شده را از دست بدهد، دیگر اعلانهایی ارسال نمیشود.
انواع رویدادهای موجود
API فرمهای گوگل در حال حاضر دو دسته رویداد ارائه میدهد:
-
EventType.SCHEMAکه در مورد ویرایشهای محتوا و تنظیمات فرم اطلاع میدهد. -
EventType.RESPONSES، که زمان ارسال پاسخهای فرم (چه جدید و چه بهروزرسانیشده) را اطلاع میدهد.
پاسخهای اعلان
اعلانها با JSON کدگذاری میشوند و شامل موارد زیر هستند:
- شناسه فرم فعال کننده
- شناسه ساعت فعال کننده
- نوع رویدادی که باعث ایجاد اعلان شده است
- فیلدهای دیگر تنظیم شده توسط Cloud Pub/Sub، مانند
messageIdوpublishTime
اعلانها حاوی دادههای دقیق فرم یا پاسخ نیستند . پس از دریافت هر اعلان، یک فراخوانی API جداگانه برای دریافت دادههای جدید مورد نیاز است. برای نحوه انجام این کار، به روش پیشنهادی مراجعه کنید.
قطعه کد زیر یک نمونه اعلان برای تغییر طرحواره را نشان میدهد:
{
"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 را بررسی کنید و برای پروژه کنسول Google Cloud خود، پرداخت را فعال کنید.
ایجاد یک موضوع عمومی/زیرموضوعی ابری به یکی از سه روش زیر:
- با استفاده از کنسول گوگل کلود
- با استفاده از ابزار خط فرمان (برای استفاده ساده از برنامهنویسی) یا
- با استفاده از Cloud Pub/Sub API .
یک اشتراک در Cloud Pub/Sub ایجاد کنید تا به Cloud Pub/Sub بگویید چگونه اعلانهای شما را ارسال کند.
در نهایت، قبل از ایجاد watchهایی که موضوع شما را هدف قرار میدهند، باید به حساب سرویس اعلانهای فرمها (forms-notifications@system.gserviceaccount.com) اجازه انتشار در موضوع خود را بدهید .
یک ساعت مچی ایجاد کنید
وقتی موضوعی دارید که حساب سرویس اعلانهای فشاری Forms API میتواند در آن منتشر شود، میتوانید با استفاده از متد watch.create() اعلانها را ایجاد کنید. این متد تأیید میکند که حساب سرویس اعلانهای فشاری میتواند به موضوع Cloud Pub/Sub ارائه شده دسترسی داشته باشد و اگر نتواند به موضوع دسترسی پیدا کند، ناموفق میشود؛ برای مثال، اگر موضوع وجود نداشته باشد یا شما مجوز انتشار در آن موضوع را به آن نداده باشید.
پایتون
نود جی اس
حذف یک ساعت
پایتون
نود جی اس
مجوز
مانند تمام فراخوانیهای Forms API، فراخوانیهای watches.create() باید با یک توکن مجوزدهی مجاز شوند. این توکن باید شامل محدودهای باشد که دسترسی خواندن به دادههایی که اعلانها در مورد آنها ارسال میشوند را اعطا کند.
- برای تغییرات طرحواره، این به معنای هر محدودهای است که با استفاده از forms.get() دسترسی خواندن به فرمها را اعطا میکند.
- برای پاسخها، این به معنای هر محدودهای است که دسترسی خواندن به پاسخهای فرم را اعطا میکند، برای مثال با استفاده از forms.responses.list() .
برای اینکه اعلانها ارسال شوند، برنامه باید مجوز OAuth را از کاربر مجاز با محدودههای مورد نیاز حفظ کند. اگر کاربر اتصال برنامه را قطع کند، اعلانها متوقف میشوند و ممکن است watch با خطا به حالت تعلیق درآید. برای از سرگیری اعلانها پس از بازیابی مجوز، به Renew a watch مراجعه کنید.
فهرست کردن watch های یک فرم
پایتون
نود جی اس
تمدید ساعت
پایتون
نود جی اس
تنظیم سرعت
اعلانها محدود شدهاند—هر ساعت میتواند حداکثر هر سی ثانیه یک اعلان دریافت کند. این آستانه فرکانس قابل تغییر است.
به دلیل محدود کردن سرعت، یک اعلان واحد ممکن است با چندین رویداد مطابقت داشته باشد. به عبارت دیگر، یک اعلان نشان میدهد که یک یا چند رویداد از آخرین اعلان رخ داده است.
محدودیتها
در هر زمان، برای یک فرم و نوع رویداد مشخص، هر پروژه Cloud Console میتواند موارد زیر را داشته باشد:
- در مجموع تا 20 ساعت
- حداکثر یک ساعت برای هر کاربر نهایی
علاوه بر این، در هر زمان، هر فرم در کل پروژههای Cloud Console به ۵۰ بازدید برای هر نوع رویداد محدود است.
یک watch زمانی با یک کاربر نهایی مرتبط میشود که با اعتبارنامههای آن کاربر ایجاد یا تمدید شود. اگر کاربر نهایی مرتبط دسترسی به فرم را از دست بدهد یا دسترسی برنامه به فرم را لغو کند، watch به حالت تعلیق در میآید.
قابلیت اطمینان
به هر دیدهبان، حداقل یک بار پس از هر رویداد، در تمام شرایط به جز شرایط فوقالعاده، اطلاع داده میشود. در اکثر موارد، ظرف چند دقیقه پس از وقوع رویداد، اطلاعرسانی انجام میشود.
خطاها
اگر اعلانهای مربوط به یک watch به طور مداوم تحویل داده نشوند، وضعیت watch به SUSPENDED تبدیل میشود و فیلد errorType آن تنظیم میشود. برای تنظیم مجدد وضعیت watch معلق به ACTIVE و از سرگیری اعلانها، به Renew a watch مراجعه کنید.
کاربرد پیشنهادی
- از یک موضوع Cloud Pub/Sub به عنوان هدف چندین Watch استفاده کنید.
- هنگام دریافت اعلان در مورد یک موضوع، شناسه فرم در بار داده اعلان گنجانده شده است. از آن به همراه نوع رویداد استفاده کنید تا بدانید چه دادههایی را باید واکشی کنید و از کدام فرم آن را دریافت کنید.
- برای دریافت دادههای بهروزرسانیشده پس از اعلان با
EventType.RESPONSES، تابع forms.responses.list() را فراخوانی کنید.- فیلتر روی درخواست را روی
timestamp > timestamp_of_the_last_response_you_fetchedتنظیم کنید.
- فیلتر روی درخواست را روی
- برای دریافت دادههای بهروزرسانیشده پس از اعلان با
EventType.SCHEMA، تابع forms.get() را فراخوانی کنید.