3

我想使用 Admin SDK 获取 Google 组中的成员列表。

但我不知道如何做到这一点。我在下面找到了链接 - https://developers.google.com/admin-sdk/directory/v1/guides/manage-group-members

但我不知道如何在 Google 应用脚本中使用 POST 方法。

有人可以举个例子吗?

更新

我得到如下输出,但我想为组的每个成员分别访问每个元素(角色、电子邮件)。那可能吗??

{ "role": "OWNER", "kind": "admin#directory#member", "type": "USER", "etag": "\"fdo0/1gUrEe8bli75zvzmqFHyH3cPzlQ\"", "id": "107108832717913338955", "email": "useremailid@domain.com", "status": "ACTIVE" }

提前致谢。

4

2 回答 2

5

请按照步骤,

  1. 使用超级管理员帐户登录您的 G 盘。
  2. 创建一张 Google 表格。
  3. 转到工作表工具菜单 - 脚本编辑器.. 保存脚本项目项目。启用管理 SDK
  4. 应用程序脚本编辑器单击资源菜单选择高级 Google 服务- 在弹出的管理目录 API 中,然后单击Google Developers Console链接。开发者控制台 -- 点击 Library --> 搜索 API 框输入 Admin sdk --> 点击 admin Sdk api 链接 ==>启用并关闭开发控制台。

=== 在 Apps 脚本编辑器中粘贴以下代码。

var onSheet = SpreadsheetApp.getActiveSpreadsheet();
var groupKey = "googlegroupid@domainName.com"

function MainGetUserList()
{
    var rows = [];
    var pageToken, page;
    do {
        page = AdminDirectory.Members.list(groupKey,
        {
            domainName: 'YOURDOMAINNAME.@com',
            maxResults: 500,
            pageToken: pageToken,
        });
        var members = page.members
        if (members)
        {
            for (var i = 0; i < members.length; i++)
            {
                var member = members[i];
                var row = [groupKey, member.email, member.role, member.status];
                rows.push(row);
            }
        }
        pageToken = page.nextPageToken;
    } while (pageToken);
    if (rows.length > 1)
    {
        var sheetData = onSheet.getSheetByName("Sheet1")
        var header = ['Group Name', 'User Id', 'User role', 'User Status'];
        sheetData.clear()
        sheetData.appendRow(header).setFrozenRows(1);
        sheetData.getRange(2, 1, rows.length, header.length).setValues(rows);
    }
}

==> 运行 MainGetUserList() 函数允许权限,打开你的 Google Sheet 刷新它。

完毕。

我已经测试了这 20k 个成员。谢谢

于 2016-09-19T09:45:45.710 回答
0

尝试用于Members:list检索组中所有成员的列表。

HTTP 请求

GET https://www.googleapis.com/admin/directory/v1/groups/groupKey/members

您的应用程序发送到 Directory API 的每个请求都必须包含授权令牌。该令牌还会向 Google 识别您的应用程序。您的应用程序必须使用OAuth 2.0来授权请求​​。

HTTP 响应:

{
  "kind": "admin#directory#members",
  "etag": etag,
  "members": [
    members Resource
  ],
  "nextPageToken": string
}
于 2016-08-10T09:56:57.430 回答