-
-
Save woodwardtw/22a199ecca73ff15a0eb to your computer and use it in GitHub Desktop.
function listFolders(folder) { | |
var sheet = SpreadsheetApp.getActiveSheet(); | |
sheet.appendRow(["Name", "Sharing Access", "Sharing Permission", "Get Editors", "Get Viewers", "Date", "Size", "URL", "Download", "Description", "Type"]); //writes the headers | |
var folder = DriveApp.getFolderById("YOUR_FOLDER_ID");//that long chunk of random numbers/letters in the URL when you navigate to the folder | |
var files = folder.getFiles();//initial loop on loose files w/in the folder | |
var cnt = 0; | |
var file; | |
while (files.hasNext()) { | |
var file = files.next(); | |
var listEditors = file.getEditors(); //gets the editor email(s), doesn't show your own as it's assumed | |
var editors = []; | |
for (var cnt = 0; cnt < listEditors.length; cnt++) { | |
editors.push(listEditors[cnt].getEmail()); | |
Logger.log(editors); | |
}; | |
var listViewers = file.getViewers(); //gets the viewer email(s) | |
var viewers = []; | |
for (var cnt = 0; cnt < listViewers.length; cnt++) { | |
viewers.push(listViewers[cnt].getEmail()); | |
Logger.log(viewers); | |
} | |
cnt++; //data chunk pushes all the file info to the ss | |
data = [ | |
file.getName(), | |
file.getSharingAccess(), | |
file.getSharingPermission(), | |
editors.toString(), | |
viewers.toString(), | |
file.getDateCreated(), | |
file.getSize(), | |
file.getUrl(), | |
"https://docs.google.com/uc?export=download&confirm=no_antivirus&id=" + file.getId(), | |
file.getDescription(), | |
file.getMimeType(), | |
]; | |
sheet.appendRow(data); | |
}; | |
var subfolders = folder.getFolders(); //same thing as above but for all the subfolders in the folder | |
while (subfolders.hasNext()) { | |
//Logger.log(folder); | |
var name = subfolders.next(); | |
var files = name.getFiles(); | |
var cnt = 0; | |
var file; | |
while (files.hasNext()) { | |
var file = files.next(); | |
var listEditors = file.getEditors(); | |
var editors = []; | |
for (var cnt = 0; cnt < listEditors.length; cnt++) { | |
editors.push(listEditors[cnt].getEmail()); | |
Logger.log(editors); | |
}; | |
var listViewers = file.getViewers(); | |
var viewers = []; | |
for (var cnt = 0; cnt < listViewers.length; cnt++) { | |
viewers.push(listViewers[cnt].getEmail()); | |
Logger.log(viewers); | |
} | |
cnt++; | |
data = [ | |
file.getName(), | |
file.getSharingAccess(), | |
file.getSharingPermission(), | |
editors.toString(), | |
viewers.toString(), | |
file.getDateCreated(), | |
file.getSize(), | |
file.getUrl(), | |
"https://docs.google.com/uc?export=download&confirm=no_antivirus&id=" + file.getId(), | |
file.getDescription(), | |
file.getMimeType(), | |
]; | |
sheet.appendRow(data); | |
}; | |
} | |
} |
How do I use this thing?
For anyone looking at this today:
Hi Tom. Just wondering if this script is still current (works with the Google Drive code of today).
As of the posting of this comment, it appears to still work.
google script that lists a lot of info about the files in a particular folder/sub folder structure
Can we use your script to scan our entire Google Drive, and not just a particular folder?
Apparently not. You can scan the top level of your entire drive by setting the folder id to "root", but it won't scan the subdirectories if you do.
The following fork looks like it might address this issue, but the script takes so long that it's likely to time out... making it necessary to do it folder by folder :(
https://gist.github.com/rzrbld/ba50a0f51b081a5699cb1d4996e4925a
Try this one if all you want is to find files with open sharing:
https://gist.github.com/ichaer/d7b91d348a250e09146057857f7b3cc2
☝️ This version doesn't list all the subfolders recursively. That is, you'll only get a list of the shared items inside the specified folder and the ones in it subfolders, but not the ones contained in the subsequent subfolders.
Here you have a version that does it recursively. It also allows you to specify a list of emails to not take into account. That is, if the documents are only shared privately with the emails contained in that list, the script will not include that shared document in the resulting sheet 😊
Can we use your script to scan our entire Google Drive, and not just a particular folder?