برای برنامههای گوگل چت که بر روی نقاط پایانی HTTP ساخته شدهاند، این بخش نحوه تأیید اینکه درخواستهای ارسالی به نقطه پایانی شما از Chat میآیند را توضیح میدهد.
برای ارسال رویدادهای تعاملی به نقطه پایانی برنامه چت شما، گوگل درخواستهایی را به سرویس شما ارسال میکند. برای تأیید اینکه درخواست از گوگل میآید، چت یک توکن حامل را در هدر Authorization هر درخواست HTTPS به نقطه پایانی شما قرار میدهد. به عنوان مثال:
POST
Host: yourappurl.com
Authorization: Bearer AbCdEf123456
Content-Type: application/json
User-Agent: Google-Dynamite
رشته AbCdEf123456 در مثال قبلی، توکن مجوز حامل است. این یک توکن رمزنگاری است که توسط گوگل تولید شده است. نوع توکن حامل و مقدار فیلد audience به نوع مخاطب احراز هویتی که هنگام پیکربندی برنامه چت انتخاب کردهاید، بستگی دارد.
اگر برنامه چت خود را با استفاده از توابع Cloud Run پیادهسازی کردهاید، Cloud IAM تأیید توکن را به طور خودکار انجام میدهد. شما باید حساب سرویس Google Chat را به عنوان یک فراخوانیکننده مجاز اضافه کنید. اگر برنامه شما سرور HTTP مخصوص به خود را پیادهسازی میکند، میتوانید توکن حامل خود را با استفاده از یک کتابخانه کلاینت Google API متنباز تأیید کنید:
- Java : https://github.com/google/google-api-java-client
- پایتون : https://github.com/google/google-api-python-client
- Node.js : https://github.com/google/google-api-nodejs-client
- .NET : https://github.com/google/google-api-dotnet-client
If the token doesn't verify for the Chat app, your service should respond to the request with an HTTPS response code 401 (Unauthorized) .
درخواستها را با استفاده از توابع Cloud Run تأیید کنید
اگر منطق تابع شما با استفاده از توابع Cloud Run پیادهسازی شده است، باید در قسمت Authentication Audience از تنظیمات اتصال برنامه چت، HTTP endpoint URL را انتخاب کنید و مطمئن شوید که HTTP endpoint URL در پیکربندی با URL تابع Cloud Run مطابقت دارد.
Then, you need to authorize the Google Chat service account chat@system.gserviceaccount.com as an invoker using the following steps:
کنسول
After deploying your function or service to Google Cloud:
In the Google Cloud console, go to the Cloud Run page:
In the Cloud Run services list, click the checkbox next to the receiving function. (Don't click the function itself.)
Click Permissions at the top of the screen. The Permissions panel opens.
روی افزودن مدیر اصلی کلیک کنید.
In the New principals field, enter
chat@system.gserviceaccount.com.From the Select a role menu, select the role Cloud Run
اجرای ابری Invoker .
روی ذخیره کلیک کنید.
جیکلاود
Use the gcloud functions add-invoker-policy-binding command:
gcloud functions add-invoker-policy-binding RECEIVING_FUNCTION \
--member='serviceAccount:chat@system.gserviceaccount.com' Replace RECEIVING_FUNCTION with the name of your Chat app's function.
درخواستهای HTTP را با یک شناسه توکن (ID Token) تأیید اعتبار کنید
اگر فیلد مخاطب احراز هویت در تنظیمات اتصال برنامه چت روی HTTP endpoint URL تنظیم شده باشد، توکن مجوز حامل در درخواست، یک توکن شناسه OpenID Connect (OIDC) امضا شده توسط گوگل است. فیلد email روی chat@system.gserviceaccount.com تنظیم شده است. فیلد مخاطب احراز هویت روی URL ای تنظیم شده است که شما Google Chat را برای ارسال درخواستها به برنامه چت خود پیکربندی کردهاید. به عنوان مثال، اگر نقطه پایانی پیکربندی شده برنامه چت شما https://example.com/app/ باشد، فیلد مخاطب احراز هویت در توکن شناسه https://example.com/app/ خواهد بود.
این روش احراز هویت توصیه شده است اگر نقطه پایانی HTTP شما روی سرویسی که از احراز هویت مبتنی بر IAM پشتیبانی میکند (مانند Cloud Run) میزبانی نمیشود. با استفاده از این روش، سرویس HTTP شما به اطلاعاتی در مورد URL نقطه پایانی که در آن اجرا میشود نیاز دارد، اما به اطلاعاتی در مورد شماره پروژه Cloud نیازی ندارد.
The following samples show how to verify that the bearer token was issued by Google Chat and targeted at your app using the Google OAuth client library.
جاوا
پایتون
نود جی اس
درخواستها را با شماره پروژه JWT تأیید اعتبار کنید
اگر فیلد «مخاطب احراز هویت» در تنظیمات اتصال برنامه چت روی « Project Number » تنظیم شده باشد، توکن مجوز حامل در درخواست، یک توکن وب JSON (JWT) خودامضا شده است که توسط chat@system.gserviceaccount.com صادر و امضا شده است. فیلد audience روی شماره پروژه Google Cloud که برای ساخت برنامه چت خود استفاده کردهاید تنظیم شده است. برای مثال، اگر شماره پروژه Cloud برنامه چت شما 1234567890 باشد، فیلد audience در JWT 1234567890 خواهد بود.
این روش احراز هویت فقط در صورتی توصیه میشود که ترجیح میدهید از شماره پروژه ابری برای تأیید درخواستها به جای آدرس اینترنتی نقطه پایانی HTTP استفاده کنید. به عنوان مثال، اگر میخواهید آدرس اینترنتی نقطه پایانی را به مرور زمان تغییر دهید در حالی که شماره پروژه ابری یکسانی را حفظ کنید، یا اگر میخواهید از نقطه پایانی یکسانی برای چندین شماره پروژه ابری استفاده کنید و میخواهید فیلد audience را با لیستی از شماره پروژههای ابری مقایسه کنید.
The following samples show how to verify that the bearer token was issued by Google Chat and targeted at your project using the Google OAuth client library.
جاوا
پایتون
نود جی اس
مباحث مرتبط
- For an overview of authentication and authorization in Google Workspace, see Learn about authentication and authorization .
- For an overview of authentication and authorization in Chat, see Authentication overview .
- Set up authentication and authorization with user credentials or a service account .