Google电子表格 - 通过脚本获取共享权限

时间:2014-10-01 07:52:14

标签: javascript google-apps-script permissions google-sheets google-drive-api

是否可以通过javascript获取谷歌电子表格中的用户和权限列表?

我在共享的Google驱动器上有几个电子表格,我想检查一下,如何通过脚本设置共享权限。我与超过20个其他用户共享这些电子表格,因此很难手动检查每个电子表格。

有可能吗?

是否有可能在整个谷歌硬盘上面运行一些脚本?例如,如果我想获得带有共享权限列表的驱动器上所有google spredsheets和文件夹的列表,我可以在google驱动器上面写一些javascript吗?

非常感谢

1 个答案:

答案 0 :(得分:1)

免责声明 - 这是我的第一个Goolge Apps脚本,因此我不能100%确定这是您想要的。

我使用DocsList API列出了给定Google云端硬盘文件夹中每个ownereditorsviewersspreadsheet

function start() {
  var folder = DocsList.getFolderById("...put folder ID here..."),
      files = folder.getFilesByType(DocsList.FileType.SPREADSHEET), file = null, spreadsheet = null,
      owner = null, editors = null, editor = null, viewers = null, viewer = null,
      i = 0, j = 0;

  for (i = 0; i < files.length; i += 1) {
    file = files[i];
    Logger.log("===== Spreadsheet " + (i + 1) + "/" + files.length + ": " + file.getName() + " =====");
    spreadsheet = SpreadsheetApp.openById(file.getId());
    owner = spreadsheet.getOwner();
    Logger.log("- Owner: " + owner.getEmail());
    editors = spreadsheet.getEditors();
    for (j = 0; j < editors.length; j += 1) {
      editor = editors[j];
      Logger.log("- Editor " + (j + 1) + "/" + editors.length + ": " + editor.getEmail());
    }
    viewers = spreadsheet.getViewers();
    for (j = 0; j < viewers.length; j += 1) {
      viewer = viewers[j];
      Logger.log("- Viewer " + (j + 1) + "/" + viewers.length + ": " + viewer.getEmail());
    }
  }
}

请注意,查看者列表也包含评论者,这两个组不是由此API分隔的。我测试了这段代码,它对我有用。您可以轻松将其概括为iterate over every folder