5

Rhino最近我将我的谷歌幻灯片脚本运行时从V8. 我测试了我的附加组件,但出现错误:

We're sorry, a server error occurred while reading from storage. Error code PERMISSION_DENIED.

我的脚本使用PropertiesService.getUserProperties(). 我发现我必须从我的谷歌帐户中注销并再次登录,它才有效

我可以想象,对于使用此插件的其他用户来说,这也可能是一件痛苦的事情。还有其他方法可以解决此错误吗?

appscript.json配置

{
  "timeZone": "Europe/Bratislava",
  "runtimeVersion": "V8",
  "dependencies": {
  },
  "exceptionLogging": "STACKDRIVER"
}

此外,我正在使用clasp将代码推送到 App 脚本在我的 PC 上开发附加组件。

更新

我创建了最小的项目来重现这个错误,我发现这PropertiesService.getUserProperties()不是问题。事实证明,从 切换Rhino到后V8,我无法调用任何 appscript 函数。

// Code.gs
function onInstall(event) {
    onOpen(event);
}

function onOpen(event) {
    SlidesApp.getUi().createAddonMenu()
        .addItem('Open the sidebar', '_showSidebar')
        .addToUi();
    _showSidebar();
}

function _showSidebar() {
    var ui = HtmlService
        .createHtmlOutputFromFile('index')
        .setTitle('Test add-on');
    SlidesApp.getUi().showSidebar(ui);
}

function getCurrentSlideObjectId() {
    var page = SlidesApp.getActivePresentation().getSelection().getCurrentPage();
    if (page && page.getPageType() === SlidesApp.PageType.SLIDE) {
        return page.getObjectId();
    }
    return null;
}

带模板:

<!DOCTYPE html>
<html>
  <head>
    <base target="_top">
    
    <script>
       const onButtonClick = () => {
         google.script.run
          .withSuccessHandler(success)
          .withFailureHandler(error)
          .getCurrentSlideObjectId()
       }
       const success = (currentSlideObjectId) => {
         console.log("It works!", currentSlideObjectId);
       }
       const error = (error) => {
         error = typeof error === 'string' ? new Error(error) : error;
         console.error(typeof error === 'object' && error !== null ? error.message : error);
       }
    </script>
  </head>
  <body>
    <button onclick="onButtonClick()">Click me</button>
  </body>
</html>

目前,我使用 2 个不同的账户登录到我的谷歌驱动器。在登录 Google chrome 以外的其他 acc 上测试插件时,会出现错误。

We're sorry, a server error occurred while reading from storage. Error code PERMISSION_DENIED.

4

1 回答 1

2

这是 Google IssueTracker 的一个已知问题,附加组件在某些情况下可能会导致PERMISSION_DENIED,您可以继续点击+1以增加问题的流行度。正如Rubén所说,这个问题也可能跟随多个登录用户,所以+1如果你的场景与那个线程相似,请继续使用。

于 2020-06-30T07:21:18.880 回答