12

我刚开始尝试构建新的 Gmail 插件,并遇到以下错误消息:

“您无权调用 fetch”

在脚本编辑器中测试插件时会发生这种情况,并且在我的 Gmail 中部署时也会发生这种情况。这是代码示例:

function getContextualAddOn(e) {
    var API_KEY = 'TESTKEY';
    var URL = 'https://[REDACTED]';
    var options = {
        'method' : 'post',
        'contentType': 'application/json',
        'headers': {
            'x-api-key': API_KEY
        },
        'payload' : JSON.stringify({ 'foo': 'bar' })
    };

    var response = UrlFetchApp.fetch(URL, options);

    [more code that builds a card] 
}

如您所见,这是一个非常简单的UrlFetchApp.fetch. 我是 Apps 脚本的新手,所以我的清单中可能缺少一些权限声明或范围。我尝试了一个更简单的示例,只是使用UrlFetchApp.getRequest,但也失败了“您没有权限调用getRequest

插件的清单与示例中的相同:

{
  "timeZone": "America/New_York",
  "dependencies": {
  },
  "exceptionLogging": "STACKDRIVER",

  "oauthScopes": [
    "https://www.googleapis.com/auth/gmail.addons.execute",
    "https://www.googleapis.com/auth/gmail.addons.current.message.readonly",
    "https://www.googleapis.com/auth/userinfo.email"
  ],
  "urlFetchWhitelist": [
    "https://[REDACTED]"
  ],
  "gmail": {
    "name": "Test Add-On",
    "logoUrl": "some url",
    "primaryColor": "#4285F4",
    "secondaryColor": "#4285F4",
    "contextualTriggers": [{
      "unconditional": {},
      "onTriggerFunction": "getContextualAddOn"
    }],
    "version": "TRUSTED_TESTER_V2"
  }
}

UrlFetchApp应该允许在 Gmail 插件中使用,或者这只是一个错误?我是否需要在清单中添加一些内容或在脚本编辑器中启用其他选项?

4

3 回答 3

29

UrlFetchApp服务需要一个额外的范围,https://www.googleapis.com/auth/script.external_request. 将其添加到您的范围列表中,代码应该可以工作。

每个 Apps 脚本方法所需的范围列在参考文档(示例)的“授权”部分下。或者,您可以通过临时删除清单的部分并在File > Project properties > ScopesoauthScopes中查看代码的自动确定范围来发现脚本所需的范围。(如果您在清单中定义任何范围,这将禁用 Apps 脚本的“自动范围检测”行为。)

参考

于 2017-10-25T17:38:37.440 回答
1

接受的答案是从 2017 年开始的。我不知道 Google 从那时起是否更改了其授权政策,但只是在项目属性设置中添加一个新范围是行不通的。

你如何触发调用的函数fetch?你不能使用简单的触发器来做到这一点。它们会自动触发,因此它们无法访问需要授权的服务。UrlFetchApp绝对需要许可。没有办法通过简单的触发器打开一个对话框来询问用户的内容。

作为脚本所有者,您可以添加新的授权范围,但是当您与最终用户一起部署此脚本时会发生什么?他们将如何授予脚本对某些不熟悉的服务器进行 API 调用的权限?

为了解决这个问题,您需要使用可安装的触发器。无论简单触发器中可用的什么,可安装触发器中都有等效的。

假设您要在打开电子表格时调用 API。

在脚本编辑器中,转到编辑 >> 当前项目的触发器并设置一个新触发器。

  • Run下,选择要触发的函数的名称。在 OP 的情况下,它是getContextualAddOn(e)函数。

  • 选择事件源下,选择来自电子表格。

  • 事件类型下,选择打开时。

  • 根据需要配置其他设置并保存。

于 2020-07-24T03:54:55.317 回答
0

改用可安装触发器并编写您自己的绑定到可安装触发器的函数。

https://developers.google.com/apps-script/guides/triggers/installable#g_suite_application_triggers

这为我解决了这个问题。

于 2020-05-03T14:04:14.067 回答