祝大家好运!
我有一个谷歌脚本,它通过使用 getUsers() 函数检查电子邮件地址是否是组的成员。
至今:
- 我已激活“Admin SDK 目录服务”
- 我有管理员权限
对于大多数组来说,这很神奇,但是在某些组的情况下我会遇到授权错误。
来自日志的错误消息:
- “您无权查看该组的成员列表:foo@bar”
知道可能是什么问题吗?任何事情都非常感谢。谢谢!
祝大家好运!
我有一个谷歌脚本,它通过使用 getUsers() 函数检查电子邮件地址是否是组的成员。
至今:
对于大多数组来说,这很神奇,但是在某些组的情况下我会遇到授权错误。
来自日志的错误消息:
知道可能是什么问题吗?任何事情都非常感谢。谢谢!
问题在于 GroupsApp 服务使用 GROUP 的权限来确定您是否可以查看成员列表。群组的默认设置是将此访问权限限制为群组的所有者和管理员。所以你有两个选择:
1) 让自己成为群组的所有者或管理员,或者
2) 使用 Admin SDK 检查组成员身份。Admin SDK 允许任何超级管理员查看组中的用户列表。要确定用户是否是组的成员,您需要检索组,然后遍历成员列表,然后将每个成员与您要查找的用户进行比较:
function isMember(groupKey,userKey){
//groupKey: testGroup@yourdomain.com
//userKey: userEmail@yourdomain.com
var memberList = [];
//Get the members list from the group
var response = AdminDirectory.Members.list(groupKey);
memberList = memberList.concat(response.members);
while (response.nextPageToken){
response = AdminDirectory.Members.list(groupKey,{pageToken: response.nextPageToken});
memberList = memberList.concat(response.members);
}
if (memberList.length > 1){
for (var x in memberList){
if (memberList[x].email == userKey){return true;}
}
}
}
更多信息在这里