使用 Node.js 运行时在 Cloud Functions 中创建 Google Workspace 插件。
目标
- 设置环境。
- 创建和部署 Cloud Functions 函数。
- 创建和部署该插件。
- 安装插件。
前提条件
- Google Cloud 项目。
- 确保为 Cloud 项目启用结算功能。了解 操作方法 验证项目的结算状态。
- Cloud SDK 使用 Cloud Storage 存储分区。
设置环境
在 Google Cloud 控制台中打开您的 Cloud 项目
- 在 Google Cloud 控制台中,前往选择项目页面。
- 选择您要使用的 Google Cloud 项目。或者,点击创建项目,然后按照屏幕上的说明操作。如果您创建的是 Google Cloud 项目,则可能需要为项目启用结算功能。
配置 OAuth 权限请求页面
Google Workspace 插件需要配置同意屏幕。正在配置 插件的 OAuth 同意屏幕定义了 Google 。
- 在 Google Cloud 控制台中,点击“菜单”图标 > API 和服务 > OAuth 同意屏幕。
- 对于用户类型,选择内部,然后点击创建。
- 填写应用注册表单,然后点击保存并继续。
现在,您可以跳过添加范围,然后点击保存并继续。 以后,如果您要创建一款应用供用户使用 Google Workspace 组织,您必须将用户类型更改为外部,然后执行以下操作: 添加您的应用所需的授权范围。
- 查看应用注册摘要。如需进行更改,请点击修改。如果应用 点击 Back to Dashboard(返回信息中心)。
创建和部署 Cloud Functions 函数
在本地终端中,启用 Cloud Functions、Cloud Build, Google Workspace Add-ons API:
gcloud services enable cloudfunctions cloudbuild.googleapis.com gsuiteaddons.googleapis.com
在空目录中,使用以下命令创建文件
function.js
示例代码:/** * Cloud Function that loads the homepage for a * Google Workspace Add-on. * * @param {Object} req Request sent from Google * @param {Object} res Response to send back */ exports.loadHomePage = function addonsHomePage (req, res) { res.send(createAction()); }; /** Creates a card with two widgets. */ function createAction() { return { "action": { "navigations": [ { "pushCard": { "header": { "title": "Cats!" }, "sections": [ { "widgets": [ { "textParagraph": { "text": "Your random cat:" } }, { "image": { "imageUrl": "https://cataas.com/cat" } } ] } ] } } ] } }; }
部署函数的方法如下:
gcloud functions deploy loadHomePage --runtime nodejs12 --trigger-http
如果出现提示,请指定不允许对 函数。函数可能需要几分钟时间才能完成部署。
创建插件部署
找到插件的服务账号电子邮件地址:
gcloud workspace-add-ons get-authorization
向服务账号授予
cloudfunctions.invoker
角色:gcloud functions add-iam-policy-binding loadHomePage \ --role roles/cloudfunctions.invoker \ --member serviceAccount:SERVICE_ACCOUNT_EMAIL
获取已部署函数的网址。如需获取网址,请运行以下命令 命令,然后在
httpsTrigger
部分下查找url
字段:gcloud functions describe loadHomePage
使用以下示例代码创建文件
deployment.json
。将 将URL
替换为在 上一步。{ "oauthScopes": ["https://www.googleapis.com/auth/gmail.addons.execute"], "addOns": { "common": { "name": "My HTTP Add-on", "logoUrl": "https://raw.githubusercontent.com/webdog/octicons-png/main/black/beaker.png", "homepageTrigger": { "runFunction": "URL" } }, "gmail": {}, "drive": {}, "calendar": {}, "docs": {}, "sheets": {}, "slides": {} } }
创建部署:
gcloud workspace-add-ons deployments create quickstart \ --deployment-file=deployment.json
安装插件
在开发模式下安装部署:
gcloud workspace-add-ons deployments install quickstart
打开或重新加载 Gmail 以查看插件。在 找到烧杯图标。
点击该图标即可打开插件。如果系统提示 授权该插件。
可选:清理
为避免系统向您的账号收取费用,请删除您 创建时间:
从您的 Google 账号中卸载该插件:
gcloud workspace-add-ons deployments uninstall quickstart
为避免系统因本快速入门中使用的资源产生费用,请删除 Cloud 项目:
gcloud projects delete PROJECT_ID
将 PROJECT_ID 替换为执行此查询的 Cloud 项目的 ID 与快速入门示例相同。您可以在以下位置找到 Cloud 项目 ID: Google Cloud 控制台 “信息中心”页面。
后续步骤
如需为您的 Google Workspace 插件添加更多功能,请参阅 以下指南: