این صفحه نحوه ساخت افزونهای برای Google Workspace را توضیح میدهد که با استفاده از سرویس HTTP در Google Chat کار میکند.
این آموزش سریع به شما نشان میدهد که چگونه یک سرویس HTTP با استفاده از سرویسهای Google Cloud بسازید. برای ساخت برنامه چت، شما یک تابع Cloud Run مینویسید و آن را مستقر میکنید که برنامه چت از آن برای پاسخ به پیام کاربر استفاده میکند.
با معماری HTTP، شما Chat را طوری پیکربندی میکنید که با استفاده از HTTP با Google Cloud یا یک سرور داخلی ادغام شود، همانطور که در نمودار زیر نشان داده شده است:
در نمودار قبلی، کاربری که با یک برنامه چت HTTP تعامل دارد، جریان اطلاعات زیر را دارد:
- کاربر پیامی را در چت به یک برنامه چت، چه در پیام مستقیم و چه در فضای چت، ارسال میکند.
- یک درخواست HTTP به یک وب سرور ارسال میشود که میتواند یک سیستم ابری یا داخلی باشد و شامل منطق برنامه چت است.
- به صورت اختیاری، منطق برنامه چت میتواند با سرویسهای Google Workspace (مانند Calendar و Sheets)، سایر سرویسهای گوگل (مانند Maps، YouTube و Vertex AI) یا سایر سرویسهای وب (مانند سیستم مدیریت پروژه یا ابزار تیکتینگ) ادغام شود.
- وب سرور یک پاسخ HTTP را به سرویس برنامه چت در Chat ارسال میکند.
- پاسخ به کاربر تحویل داده میشود.
- به صورت اختیاری، برنامه چت میتواند API چت را برای ارسال پیامها یا انجام سایر عملیات به صورت غیرهمزمان فراخوانی کند.
این معماری به شما انعطافپذیری لازم برای استفاده از کتابخانهها و کامپوننتهای موجود در سیستمتان را میدهد، زیرا این برنامههای چت را میتوان با استفاده از زبانهای برنامهنویسی مختلف طراحی کرد.
اهداف
- محیط خود را تنظیم کنید.
- یک تابع Cloud Run ایجاد و مستقر کنید.
- افزونهی Google Workspace را برای برنامهی چت پیکربندی کنید.
- برنامه را تست کنید.
پیشنیازها
- یک حساب کاربری تجاری یا سازمانی Google Workspace با دسترسی به Google Chat .
- یک پروژه Google Cloud با قابلیت پرداخت فعال. برای بررسی اینکه آیا پرداخت در یک پروژه موجود فعال است یا خیر، به تأیید وضعیت پرداخت پروژههای خود مراجعه کنید. برای ایجاد یک پروژه و تنظیم پرداخت، به ایجاد یک پروژه Google Cloud مراجعه کنید.
محیط را تنظیم کنید
قبل از استفاده از APIهای گوگل، باید آنها را در یک پروژه گوگل کلود فعال کنید. میتوانید یک یا چند API را در یک پروژه گوگل کلود فعال کنید.در کنسول Google Cloud، APIهای Cloud Build، Cloud Functions API، Cloud Pub/Sub API، Cloud Logging API، Artifact Registry API و Cloud Run API را فعال کنید.
یک تابع Cloud Run ایجاد و مستقر کنید
یک تابع Cloud Run ایجاد و پیادهسازی کنید که یک کارت چت با نام نمایشی و تصویر آواتار فرستنده ایجاد میکند. وقتی برنامه چت پیامی دریافت میکند، تابع را اجرا کرده و با کارت پاسخ میدهد.
برای ایجاد و استقرار این تابع برای برنامه چت خود، مراحل زیر را انجام دهید:
نود جی اس
در کنسول گوگل کلود، به صفحه Cloud Run بروید:
مطمئن شوید که پروژه مربوط به برنامه چت شما انتخاب شده است.
روی نوشتن یک تابع کلیک کنید.
در صفحه ایجاد سرویس ، تابع خود را تنظیم کنید:
- در فیلد نام سرویس ،
addonchatappوارد کنید. - در لیست منطقه ، یک منطقه را انتخاب کنید.
- در لیست Runtime ، جدیدترین نسخه Node.js را انتخاب کنید.
- در بخش احراز هویت ، گزینه «احراز هویت الزامی» را انتخاب کنید.
- روی Create کلیک کنید و منتظر بمانید تا Cloud Run سرویس را ایجاد کند. کنسول شما را به تب Source هدایت میکند.
- در فیلد نام سرویس ،
در برگه منبع :
- در قسمت Entry point ، متن پیشفرض را حذف کرده و
avatarAppوارد کنید. - محتویات فایل
index.jsرا با کد زیر جایگزین کنید:
/** * Google Cloud Run function that responds to messages sent from a * Google Chat space. * * @param {Object} req Request sent from Google Chat space * @param {Object} res Response to send back */ import { http } from '@google-cloud/functions-framework'; http('avatarApp', (req, res) => { if (req.method === 'GET' || !req.body.chat) { return res.send('Hello! This function is meant to be used ' + 'in a Google Chat Space.'); } // Stores the Google Chat event as a variable. const chatMessage = req.body.chat.messagePayload.message; // Replies with the sender's avatar in a card. const displayName = chatMessage.sender.displayName; const avatarUrl = chatMessage.sender.avatarUrl; res.send({ hostAppDataAction: { chatDataAction: { createMessageAction: { message: { text: 'Here\'s your avatar', cardsV2: [{ cardId: 'avatarCard', card: { name: 'Avatar Card', header: { title: `Hello ${displayName}!`, }, sections: [{ widgets: [{ textParagraph: { text: 'Your avatar picture: ' } }, { image: { imageUrl: avatarUrl } }] }] } }] }}}}}); });- محتویات فایل
package.jsonرا با کد زیر جایگزین کنید:
{ "name": "avatar-app", "version": "1.0.0", "description": "Google Chat Avatar App", "main": "index.js", "type": "module", "scripts": { "start": "node index.js" }, "dependencies": { "@google-cloud/functions-framework": "^3.0.0" } }- روی ذخیره و استقرار مجدد کلیک کنید.
- در قسمت Entry point ، متن پیشفرض را حذف کرده و
پایتون
در کنسول گوگل کلود، به صفحه Cloud Run بروید:
مطمئن شوید که پروژه مربوط به برنامه چت شما انتخاب شده است.
روی نوشتن یک تابع کلیک کنید.
در صفحه ایجاد سرویس ، تابع خود را تنظیم کنید:
- در فیلد نام سرویس ،
addonchatappوارد کنید. - در لیست منطقه ، یک منطقه را انتخاب کنید.
- در لیست Runtime ، جدیدترین نسخه پایتون را انتخاب کنید.
- در بخش احراز هویت ، گزینه «احراز هویت الزامی» را انتخاب کنید.
- روی Create کلیک کنید و منتظر بمانید تا Cloud Run سرویس را ایجاد کند. کنسول شما را به تب Source هدایت میکند.
- در فیلد نام سرویس ،
در برگه منبع :
- در قسمت Entry point ، متن پیشفرض را حذف کرده و
avatar_appوارد کنید. - محتویات
main.pyرا با کد زیر جایگزین کنید:
from typing import Any, Mapping import flask import functions_framework @functions_framework.http def avatar_app(req: flask.Request) -> Mapping[str, Any]: """Google Cloud Run Function that handles requests from Google Chat Args: flask.Request: the request Returns: Mapping[str, Any]: the response """ if req.method == "GET": return "Hello! This function must be called from Google Chat." request_json = req.get_json(silent=True) # Stores the Google Chat event as a variable. chat_message = request_json["chat"]["messagePayload"]["message"] # Replies with the sender's avatar in a card. display_name = chat_message["sender"]["displayName"] avatar_url = chat_message["sender"]["avatarUrl"] return { "hostAppDataAction": { "chatDataAction": { "createMessageAction": { "message": { "text": "Here's your avatar", "cardsV2": [{ "cardId": "avatarCard", "card": { "name": "Avatar Card", "header": { "title": f"Hello {display_name}!" }, "sections": [{ "widgets": [{ "textParagraph": { "text": "Your avatar picture:" } }, { "image": { "imageUrl": avatar_url } }] }] } }] }}}}}- روی ذخیره و استقرار مجدد کلیک کنید.
- در قسمت Entry point ، متن پیشفرض را حذف کرده و
جاوا
در کنسول گوگل کلود، به صفحه Cloud Run بروید:
مطمئن شوید که پروژه مربوط به برنامه چت شما انتخاب شده است.
روی نوشتن یک تابع کلیک کنید.
در صفحه ایجاد سرویس ، تابع خود را تنظیم کنید:
- در فیلد نام سرویس ،
addonchatappوارد کنید. - در لیست منطقه ، یک منطقه را انتخاب کنید.
- در لیست Runtime ، جدیدترین نسخه جاوا را انتخاب کنید.
- در بخش احراز هویت ، گزینه «احراز هویت الزامی» را انتخاب کنید.
- روی Create کلیک کنید و منتظر بمانید تا Cloud Run سرویس را ایجاد کند. کنسول شما را به تب Source هدایت میکند.
- در فیلد نام سرویس ،
در برگه منبع :
- در قسمت Entry point ، متن پیشفرض را حذف کرده و
AvatarAppوارد کنید. - فایل پیشفرض جاوا را به
src/main/java/gcfv2/AvatarApp.javaتغییر نام دهید. - محتویات
AvatarApp.javaرا با کد زیر جایگزین کنید:
import java.util.List; import com.google.api.services.chat.v1.model.CardWithId; import com.google.api.services.chat.v1.model.GoogleAppsCardV1Card; import com.google.api.services.chat.v1.model.GoogleAppsCardV1CardHeader; import com.google.api.services.chat.v1.model.GoogleAppsCardV1Image; import com.google.api.services.chat.v1.model.GoogleAppsCardV1Section; import com.google.api.services.chat.v1.model.GoogleAppsCardV1TextParagraph; import com.google.api.services.chat.v1.model.GoogleAppsCardV1Widget; import com.google.api.services.chat.v1.model.Message; import com.google.cloud.functions.HttpFunction; import com.google.cloud.functions.HttpRequest; import com.google.cloud.functions.HttpResponse; import com.google.gson.Gson; import com.google.gson.JsonObject; public class AvatarApp implements HttpFunction { private static final Gson gson = new Gson(); @Override public void service(HttpRequest request, HttpResponse response) throws Exception { JsonObject body = gson.fromJson(request.getReader(), JsonObject.class); if (request.getMethod().equals("GET") || !body.has("chat")) { response.getWriter().write("Hello! This function is meant to be used " + "in a Google Chat Space.."); return; } // Stores the Google Chat event as a variable. JsonObject chatMessage = body.getAsJsonObject("chat") .getAsJsonObject("messagePayload").getAsJsonObject("message"); // Replies with the sender's avatar in a card. String displayName = chatMessage.getAsJsonObject("sender").get("displayName").getAsString(); String avatarUrl = chatMessage.getAsJsonObject("sender").get("avatarUrl").getAsString(); Message message = createMessage(displayName, avatarUrl); JsonObject createMessageAction = new JsonObject(); createMessageAction.add("message", gson.fromJson(gson.toJson(message), JsonObject.class)); JsonObject chatDataAction = new JsonObject(); chatDataAction.add("createMessageAction", createMessageAction); JsonObject hostAppDataAction = new JsonObject(); hostAppDataAction.add("chatDataAction", chatDataAction); JsonObject dataActions = new JsonObject(); dataActions.add("hostAppDataAction", hostAppDataAction); response.getWriter().write(gson.toJson(dataActions)); } Message createMessage(String displayName, String avatarUrl) { GoogleAppsCardV1CardHeader cardHeader = new GoogleAppsCardV1CardHeader(); cardHeader.setTitle(String.format("Hello %s!", displayName)); GoogleAppsCardV1TextParagraph textParagraph = new GoogleAppsCardV1TextParagraph(); textParagraph.setText("Your avatar picture: "); GoogleAppsCardV1Widget avatarWidget = new GoogleAppsCardV1Widget(); avatarWidget.setTextParagraph(textParagraph); GoogleAppsCardV1Image image = new GoogleAppsCardV1Image(); image.setImageUrl(avatarUrl); GoogleAppsCardV1Widget avatarImageWidget = new GoogleAppsCardV1Widget(); avatarImageWidget.setImage(image); GoogleAppsCardV1Section section = new GoogleAppsCardV1Section(); section.setWidgets(List.of(avatarWidget, avatarImageWidget)); GoogleAppsCardV1Card card = new GoogleAppsCardV1Card(); card.setName("Avatar Card"); card.setHeader(cardHeader); card.setSections(List.of(section)); CardWithId cardWithId = new CardWithId(); cardWithId.setCardId("avatarCard"); cardWithId.setCard(card); Message message = new Message(); message.setText("Here's your avatar"); message.setCardsV2(List.of(cardWithId)); return message; } }- در قسمت Entry point ، متن پیشفرض را حذف کرده و
محتویات
pom.xmlرا با کد زیر جایگزین کنید:<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.google.chat</groupId> <artifactId>avatar-app</artifactId> <version>1.0-SNAPSHOT</version> <properties> <maven.compiler.target>17</maven.compiler.target> <maven.compiler.source>17</maven.compiler.source> </properties> <dependencies> <dependency> <groupId>com.google.cloud.functions</groupId> <artifactId>functions-framework-api</artifactId> <version>1.0.4</version> </dependency> <!-- https://mvnrepository.com/artifact/com.google.code.gson/gson --> <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> <version>2.9.1</version> </dependency> <!-- https://mvnrepository.com/artifact/com.google.apis/google-api-services-chat --> <dependency> <groupId>com.google.apis</groupId> <artifactId>google-api-services-chat</artifactId> <version>v1-rev20230115-2.0.0</version> </dependency> </dependencies> <!-- Required for Java functions in the inline editor --> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.1</version> <configuration> <excludes> <exclude>.google/</exclude> </excludes> </configuration> </plugin> </plugins> </build> </project>- روی ذخیره و استقرار مجدد کلیک کنید.
صفحه جزئیات سرویس Cloud Run باز میشود. منتظر بمانید تا عملکرد اجرا شود.
افزونه را پیکربندی کنید
پس از استقرار عملکرد Cloud Run، این مراحل را برای ایجاد یک افزونه و استقرار برنامه Google Chat دنبال کنید:
در کنسول گوگل کلود، به صفحه Cloud Run بروید:
مطمئن شوید پروژهای که Cloud Run را برای آن فعال کردهاید، انتخاب شده است.
در لیست توابع، روی addonchatapp کلیک کنید.
در صفحه جزئیات سرویس ، آدرس اینترنتی (URL) تابع را کپی کنید. آدرس اینترنتی به
run.appختم میشود.در فیلد جستجوی Google Cloud، عبارت «Google Chat API» را جستجو کنید، سپس روی Google Chat API کلیک کنید و سپس روی مدیریت (Manage) کلیک کنید.
روی پیکربندی کلیک کنید و برنامه Google Chat را تنظیم کنید:
- در قسمت نام برنامه ،
Add-on Chat appوارد کنید. - در قسمت آدرس اینترنتی آواتار ،
https://developers.google.com/workspace/add-ons/images/quickstart-app-avatar.pngرا وارد کنید. - در قسمت توضیحات ،
Add-on Chat appوارد کنید. - در بخش عملکرد ، گزینه «پیوستن به فضاها و مکالمات گروهی» را انتخاب کنید.
- در قسمت تنظیمات اتصال ، آدرس اینترنتی نقطه پایانی HTTP را انتخاب کنید.
- ایمیل حساب سرویس را کپی کنید. هنگام تأیید افزونه برای فراخوانی تابع، به این ایمیل نیاز دارید.
- در قسمت Triggers ، گزینه Use a common HTTP endpoint URL for all triggers را انتخاب کنید و URL مربوط به تریگر تابع Cloud Run را در کادر مربوطه جایگذاری کنید.
- در قسمت «قابلیت مشاهده» ، گزینه «این برنامه چت گوگل را برای افراد و گروههای خاص در دامنه خود در دسترس قرار دهید» را انتخاب کنید و آدرس ایمیل خود را وارد کنید.
- در قسمت گزارشها ، گزینه ثبت خطاها را برای ثبت گزارشها انتخاب کنید.
- در قسمت نام برنامه ،
روی ذخیره کلیک کنید.
در مرحله بعد، به برنامه چت اجازه دهید تا عملکرد Cloud Run را فراخوانی کند.
به گوگل چت اجازه دهید تا تابع شما را فراخوانی کند
برای مجاز کردن افزونهی Google Workspace برای فراخوانی تابع خود، حساب سرویس افزونهی Google Workspace را با نقش فراخوانیکنندهی سرویس Cloud Run اضافه کنید.
در کنسول گوگل کلود، به صفحه Cloud Run بروید:
در لیست سرویسهای Cloud Run، کادر کنار تابع دریافت را علامت بزنید. (روی خود تابع کلیک نکنید.)
روی مجوزها کلیک کنید. پنل مجوزها باز میشود.
روی افزودن مدیر اصلی کلیک کنید.
در بخش «مدیران جدید» ، آدرس ایمیل حساب سرویس افزونه Google Workspace مرتبط با برنامه چت خود را وارد کنید.
آدرس ایمیل حساب سرویس در صفحه پیکربندی Chat API، در مسیر Connection settings > HTTP endpoint URL > Service Account Email قرار دارد:
در بخش «انتخاب یک نقش» ، Cloud Run > Cloud Run Service Invoker را انتخاب کنید.
روی ذخیره کلیک کنید.
برنامه چت آماده دریافت و پاسخ به پیامها در چت است.
برنامه چت خود را آزمایش کنید
برای آزمایش برنامه چت خود، یک فضای پیام مستقیم با برنامه چت باز کنید و پیامی ارسال کنید:
با استفاده از حساب Google Workspace که هنگام اضافه کردن خود به عنوان یک آزمایشگر مورد اعتماد ارائه دادید، Google Chat را باز کنید.
- روی گپ جدید کلیک کنید.
- در فیلد «افزودن ۱ یا چند نفر» ، نام برنامه چت خود را تایپ کنید.
برنامه چت خود را از بین نتایج انتخاب کنید. یک پیام مستقیم باز میشود.
- در پیام مستقیم جدید با برنامه،
Helloرا تایپ کنید وenterفشار دهید.
پیام برنامه چت حاوی کارتی است که نام و تصویر آواتار فرستنده را نمایش میدهد، همانطور که در تصویر زیر نشان داده شده است:

برای افزودن آزمایشکنندگان مورد اعتماد و کسب اطلاعات بیشتر در مورد آزمایش ویژگیهای تعاملی، به بخش «آزمایش ویژگیهای تعاملی برای برنامههای Google Chat» مراجعه کنید.
عیبیابی
وقتی یک برنامه یا کارت چت گوگل خطایی را برمیگرداند، رابط چت پیامی با عنوان «مشکلی پیش آمده است» یا «درخواست شما قابل پردازش نیست» نمایش میدهد. گاهی اوقات رابط کاربری چت هیچ پیام خطایی را نمایش نمیدهد، اما برنامه یا کارت چت نتیجه غیرمنتظرهای را ایجاد میکند؛ برای مثال، ممکن است پیام کارت ظاهر نشود.
اگرچه ممکن است پیام خطا در رابط کاربری چت نمایش داده نشود، پیامهای خطای توصیفی و دادههای گزارش برای کمک به شما در رفع خطاها هنگام فعال بودن ثبت خطا برای برنامههای چت در دسترس هستند. برای کمک به مشاهده، اشکالزدایی و رفع خطاها، به عیبیابی و رفع خطاهای گوگل چت مراجعه کنید.
تمیز کردن
برای جلوگیری از تحمیل هزینه به حساب Google Cloud خود برای منابع استفاده شده در این آموزش، توصیه میکنیم پروژه Cloud را حذف کنید.
- در کنسول گوگل کلود، به صفحه مدیریت منابع بروید. روی منو > مدیریت و دسترسی به منابع (IAM & Admin) > مدیریت منابع (Manage Resources) کلیک کنید.
- در لیست پروژهها، پروژهای را که میخواهید حذف کنید انتخاب کنید و سپس روی «حذف کلیک کنید.
- در کادر محاورهای، شناسه پروژه را تایپ کنید و سپس برای حذف پروژه، روی خاموش کردن (Shut down) کلیک کنید.