Я хочу создать надстройку, которая обрабатывает все комментарии, добавленные пользователем в документ Google Docs. Я могу использовать Диск.Комментарии.список, чтобы получить список всех комментариев в документе, и Session.getEffectiveUser, чтобы получить идентификатор пользователя, запускающего скрипт.
Пробовал фильтровать по адресу электронной почты. Однако результаты Drive.Comments.list
не включают author.emailAddress. Здесь — это пример, показывающий, что displayName
включен. Здесь — это пример, показывающий, что emailAddress
не включен. документация для emailAddress
действительно говорит This may not be present in certain contexts if the user has not made their email address visible to the requester.
Однако emailAddress
отсутствует даже для комментариев, добавленных пользователем, запускающим скрипт. А так фильтрация по адресу электронной почты не работает.
Затем я попытался отфильтровать по отображаемому имени. Однако Session.getEffectiveUser
не дает способа получить отображаемое имя. Есть ли другой способ получить отображаемое имя пользователя, запускающего скрипт?
Попробуйте о.получить Это возвращает адрес электронной почты пользователя.
{
"kind": "drive#about",
"user": {
"kind": "drive#user",
"displayName": "Linda Lawton",
"photoLink": "https://lh3.googleusercontent.com/a-/AOh14GhroCYJp2P9xeYeYk1npchBPK-zbtTxzNQo0WAHI20=s64",
"me": true,
"permissionId": ddd88225573437243",
"emailAddress": "[email protected]"
},
Это действительно лучший вариант, который у вас есть. Хотя, если у вас есть область профиля, добавленная в ваше приложение, вы можете захотеть просто проверить профиль пользователя напрямую.
Адрес электронной почты от
about.get
не помогает, так как комментарии не включают адрес электронной почты автора комментария. ОднакоdisplayName
отabout.get
работает. PS: В комментариях естьphotoLink
автора комментария, и это можно использовать как уникальный идентификатор. Однако я думаю, что у многих пользователей, которые не установили свою аватарку, будет пустаяphotoLink
. И поэтому мне придется полагаться на сопоставлениеdisplayName
, что может привести к редким ложным срабатываниям, если два пользователя имеют одно и то же имя.