3

祝大家好运!

我有一个谷歌脚本,它通过使用 getUsers() 函数检查电子邮件地址是否是组的成员。

至今:

  • 我已激活“Admin SDK 目录服务”
  • 我有管理员权限

对于大多数组来说,这很神奇,但是在某些组的情况下我会遇到授权错误。

来自日志的错误消息:

  • “您无权查看该组的成员列表:foo@bar”

知道可能是什么问题吗?任何事情都非常感谢。谢谢!

4

1 回答 1

4

问题在于 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;}
     }
   }
 }

更多信息在这里

于 2016-05-31T18:00:31.727 回答