API администратора Google: ошибка не авторизована
У меня есть скрипт, который я хотел бы, чтобы обычный пользователь нашего домена мог запускать. Я выдвинул это как дополнение для документов, но когда мои пользователи запускают скрипт, они получают эту ошибку:
GoogleJsonResponseException: не авторизован для доступа к этому ресурсу /API.
Я считаю, что это связано с этими линиями.
var user = Session.getActiveUser().getEmail();
var groupList = AdminDirectory.Groups.list({"userKey":user}).groups;
Я полагаю, что для пользователя без прав администратора должна быть возможность AdminDirectory
за list()
и другие команды только для чтения (но не для записи). Тем не менее, документация, которую я смог найти, не соответствовала этой проблеме.
Контекст для вышеуказанных строк:
function onOpen(e) {
var ui = DocumentApp.getUi();
ui.createMenu('Sign Document')
.addItem('Support Staff Signiture', 'getGroups')
.addToUi();
}
function getGroups() {
var user = Session.getActiveUser().getEmail();
try {
var groupList = AdminDirectory.Groups.list({"userKey":user}).groups;
}
catch (e) {
DocumentApp.getUi().prompt("There was an error! Report this to tech! Error: " + e);
}
var doc = DocumentApp.getActiveDocument();
var docID = doc.getId();
for (var i = 0; i < groupList.length; i++){
switch (groupList[i].name) {
case "CAC Staff":
var source_folder = DriveApp.getFolderById('ID');
var dest_folder = DriveApp.getFolderById('ID');
var googleSheet = SpreadsheetApp.openById('ID');
break;
case "HS Staff":
var source_folder = DriveApp.getFolderById('ID');
var dest_folder = DriveApp.getFolderById('ID');
var googleSheet = SpreadsheetApp.openById('ID');
break;
case "JH Staff":
var source_folder = DriveApp.getFolderById('ID');
var dest_folder = DriveApp.getFolderById('ID');
var googleSheet = SpreadsheetApp.openById('ID');
break;
case "JS Staff":
var source_folder = DriveApp.getFolderById('ID');
var dest_folder = DriveApp.getFolderById('ID');
var googleSheet = SpreadsheetApp.openById('ID');
break;
case "WS Staff":
var source_folder = DriveApp.getFolderById('ID');
var dest_folder = DriveApp.getFolderById('ID');
var googleSheet = SpreadsheetApp.openById('ID');
break;
case "CS Staff":
var source_folder = DriveApp.getFolderById('ID');
var dest_folder = DriveApp.getFolderById('ID');
var googleSheet = SpreadsheetApp.openById('ID');
break;
}
if (googleSheet) {
try {
setStatus(user, googleSheet, doc);
moveFiles(source_folder, dest_folder, docID);
}
catch(e) {
var error = e;
DocumentApp.getUi().alert('There was an error! Report this error to tech! ' + e);
}
}
}
var prompt = 'Document sent to your main office!';
DocumentApp.getUi().alert(prompt);
}
function setStatus(you, ss, doc) {
var date = new Date();
var curDate = Utilities.formatDate(new Date(), "CST", "MM/dd/yyyy")
var thisMonth = date.getMonth() + 1;
var lastMonth = date.getMonth();
var docURL = doc.getUrl();
var body = doc.getBody().editAsText();
var a = 0;
do {
a++;
var text = body.findText("Month: " + a);
if (a >= 13) {
var prompt = 'Error! Report this error to tech! Document Month = null';
DocumentApp.getUi().alert(prompt);
return;
}
} while (text === null);
var monthString = text.getElement().asText().getText();
var docMonth = monthString.replace("Month: ", "");
var a = 0;
do {
a++
var text = body.findText("Week: " + a);
} while (text === null);
var weekString = text.getElement().asText().getText();
var week = weekString.replace("Week: ", "");
var thisMonth = date.getMonth() + 1;
//this Month
if (thisMonth == docMonth) {
var sheet = ss.getSheetByName('This Month');
var lastRow = sheet.getLastRow();
var lastColumn = sheet.getLastColumn();
var range = sheet.getRange(1,1,lastRow,lastColumn);
var data = range.getValues();
for (var i = 0; i < data.length; i++) {
if (data[i][0] == you) {
switch (week) {
case '1':
data[i][1] = "=HYPERLINK("+"\""+docURL+"\","+"\""+curDate+"\""+")";
break;
case '2':
data[i][2] = "=HYPERLINK("+"\""+docURL+"\","+"\""+curDate+"\""+")";
break;
case '3':
data[i][3] = "=HYPERLINK("+"\""+docURL+"\","+"\""+curDate+"\""+")";
break;
case '4':
data[i][4] = "=HYPERLINK("+"\""+docURL+"\","+"\""+curDate+"\""+")";
}
}
}
range.setValues(data);
}
//last Month
if (thisMonth == (docMonth - 1)) {
var sheet = ss.getSheetByName('Last Month');
var lastRow = sheet.getLastRow();
var lastColumn = sheet.getLastColumn();
var range = sheet.getRange(1, 1, lastRow, lastColumn);
var data = range.getValues();
for (var i = 0; i < data.length; i++) {
if (data[i][0] == you) {
switch(week) {
case '1':
data[i][1] = "=HYPERLINK("+"\""+docURL+"\","+"\""+curDate+"\""+")";
break;
case '2':
data[i][2] = "=HYPERLINK("+"\""+docURL+"\","+"\""+curDate+"\""+")";
break;
case '3':
data[i][3] = "=HYPERLINK("+"\""+docURL+"\","+"\""+curDate+"\""+")";
break;
case '4':
data[i][4] = "=HYPERLINK("+"\""+docURL+"\","+"\""+curDate+"\""+")";
}
}
}
range.setValues(data);
}
//More than last month
if ((thisMonth - docMonth) >= 2) {
DocumentApp.getUi().alert('This Document is too old to sign!');
return;
}
}
function moveFiles(source_folder, dest_folder, docID) {
var file = DriveApp.getFileById(docID);
dest_folder.addFile(file);
source_folder.removeFile(file);
}