169 похожих чатов

Спрошу по-другому. Есть модальное окно, которое создаётся скриптом от имени владельца

таблицы (через встроенный триггер). У других пользователей таблицы доступа к скриптам нет (всё только через триггер).

В этом окне есть кнопка, на которую подвязан скрипт, на который есть доступ у всех редакторов (он вшит в таблицу).

Вопрос: Что будет, если обычный пользователь таблицы (с правами редактора), запустивший модальное окно триггером, нажмёт в этом окне на вышеуказанную кнопку?

У меня запуск скрипта (который по кнопке) в журнале отображается, но с длительностью 0 секунд и с фэйл-статусом. При этом, разумеется, ничего не происходит.

Тот же трюк, но от имени владельца таблицы, у которого доступы на всё, работает на ура.

В чём может быть проблема?

2 ответов

18 просмотров

Так, но вы же показываете окно, когда пользователь нажимает кнопку? Часть интерфейса принадлежит ему. Не смотрите на то, кому принадлежит код, смотрите на то, чей токен участвует в работе в данный момент. Так вот. У вас триггер, который создает меню от имени владельца. Там кнопка, которую нажимает редактор. Отображается интерфейс, который определен в коде проекта. Если это тот же проект, не код из библиотеки, то проблем с пополнением у редактора быть не должно. Тут, скорее всего, проблема в публикации самого проекта, если вы говорите, что обращаетесь из браузере клиента через fetch обратно в скрипт. Вы, как бы, получаете расслоение приложения: - первая часть работает через окружение SpreadsheetApp.Ui - вторая — через webapp Так вот, чтобы вызвать вторую часть, вам нужно использовать не просто fetch, а конкретный токен текущего редактора. Тогда все должно работать как надо. Опять же, задача не из простых, т.к. вам нужно передать токен на клиента (имеется ввиду SpreadsheetApp.Ui взаимодействие), т.е. в JS сайдбара.

Павел Костылюк- Автор вопроса
Alexander Ivanov
Так, но вы же показываете окно, когда пользователь...

Весь проект развёрнут как библиотека, включая html-файлы. У библиотеки один владелец, доступ никому не выдан. Скрипты библиотеки запускаются встроенным триггером от имени владельца этой самой библиотеки. Проблема в том, что при передаче управления из html обратно в GAS, у пользователя с правами редактора ничего не происходит. А у владельца всего этого "хозяйства" всё работает.

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта