Ошибка триггера: к сожалению, произошла ошибка сервера при чтении из хранилища. Код ошибки PERMISSION_DENIED

Dec 03 2020

Мой сценарий Gapps, вызываемый из триггера, основанного на времени, регистрирует множество ошибок: «К сожалению, произошла ошибка сервера при чтении из хранилища. Код ошибки PERMISSION_DENIED». Я предполагаю, что есть пользователи, которые установили приложение и триггер, но позже удалили разрешения для запуска скрипта. Что, очевидно, может вызвать эту проблему. Я все еще пытаюсь и не могу этого избежать ...

Так устанавливается триггер:

var triggerFunction = "processRecurrentLists";  //trigger callback function name

//---------------------------------------------
function createTriggers(tmz) {
  // Trigger running at 1am depending on timezone specified in settings
  // If no timezone specified, script timezone is used (GMT)
  ScriptApp.newTrigger(triggerFunction)
      .timeBased()
      .everyDays(1)
      .inTimezone(tmz)
      .atHour(1)
      .create();
      
}

Это запущенная функция:

function processRecurrentLists() {
  // Check if the actions of the trigger requires authorization that has not
  // been granted yet; if not, then end - nothing to do.
  if (!isScriptAuthorized()) {
    console.warn("RecGTasks script is not authorized to run. Please, authorize first.");
    return;
  }

  // ... more code here
}

И авторизация тестирования функций:

function isScriptAuthorized() {
  try {
    var authInfo = ScriptApp.getAuthorizationInfo(ScriptApp.AuthMode.FULL);
    return (authInfo.getAuthorizationStatus() == ScriptApp.AuthorizationStatus.NOT_REQUIRED);
  } catch (e) {
    console.warn("Script not authorized. err=%s",e.message);
    return false;
  }
}

Я предполагаю, что функция isScriptAuthorized возвращает false, если скрипт не авторизован и скрипт завершается корректно, но, похоже, это не так ...

Есть идеи по этому поводу?

Обновление 1 Я сделал скрипт доступным для всех пользователей в качестве обходного пути дляhttps://issuetracker.google.com/issues/175139769и в тот же день сообщение изменилось на «Для выполнения этого действия требуется авторизация», так что больше PERMISSION_DENIED больше не будет. Дальнейшее расследование.

Обновление 2 Да, как указал @ziganotschka, это связано с V8. Для тщательного тестирования я использовал следующий сценарий:

function doGet() {
  // if trigger not installed
  if (ScriptApp
      .getProjectTriggers()
      .filter(function(t){return t.getHandlerFunction() === "myFunction"})
      .length == 0
     ){
    // create trigger firing every 1min
    ScriptApp.newTrigger("myFunction")
    .timeBased()
    .everyMinutes(1)
    .create();      
  }
  return HtmlService.createHtmlOutput('<h1>Trigger test installed</h1>');
}

function myFunction() { 
  Logger.log("Hello from triggered function");
  return ("Hello from server");
}

Ответы

2 ziganotschka Dec 03 2020 at 18:10

Похоже, это ошибка, связанная со средой выполнения v8

Взгляните здесь и здесь .

Эта проблема возникает, когда пользователи входят в систему сразу с несколькими учетными записями.

Пока Google исправляет ошибку, я предлагаю вам временно отключить среду выполнения v8, чтобы избежать проблемы.