Błąd wyzwalacza: Przepraszamy, wystąpił błąd serwera podczas odczytu z pamięci. Kod błędu PERMISSION_DENIED

Dec 03 2020

Mój skrypt Gapps wywołany z wyzwalacza opartego na czasie rejestruje mnóstwo błędów „Przepraszamy, wystąpił błąd serwera podczas odczytu z pamięci. Kod błędu PERMISSION_DENIED”. Zakładam, że są użytkownicy, którzy zainstalowali aplikację i wyzwalali, ale później usunęli uprawnienia do uruchamiania skryptu. Co oczywiście może powodować ten problem. Nadal próbuję i nie udaje mi się tego uniknąć ...

Oto jak instaluje się wyzwalacz:

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();
      
}

To jest wyzwalana funkcja:

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
}

I autoryzacja testów funkcji:

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;
  }
}

Zakładam, że funkcja isScriptAuthorized zwraca wartość false, jeśli skrypt nie jest autoryzowany, a skrypt kończy się wdzięcznie, ale wydaje się, że tak nie jest ...

Masz jakiś pomysł na to?

Aktualizacja 1 Udostępniłem skrypt dla wszystkich użytkowników jako obejściehttps://issuetracker.google.com/issues/175139769i tego samego dnia wiadomość została zmieniona na „Do wykonania tej czynności wymagana jest autoryzacja”, więc nie będzie już PERMISSION_DENIED. Dalsze badanie.

Aktualizacja 2 Tak, jak zauważył @ziganotschka, jest to związane z V8. Aby dokładnie to przetestować, użyłem następującego skryptu:

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");
}

Odpowiedzi

2 ziganotschka Dec 03 2020 at 18:10

Wygląda na to, że jest to błąd związany ze środowiskiem wykonawczym v8

Spójrz tutaj i tutaj .

Wydaje się, że ten problem występuje, gdy użytkownicy są zalogowani na wielu kontach jednocześnie.

Podczas gdy Google naprawia błąd, sugeruję tymczasowe wyłączenie środowiska wykonawczego v8, aby uniknąć problemu.