drive: make --drive-auth-owner-only look in all directories

Previously it was ignoring directories which weren't owned by the user
which meant it was ignoring files owned by the user in those
directories.
This commit is contained in:
Nick Craig-Wood 2018-02-20 14:33:52 +00:00
parent 00adf40f9f
commit 25bbc5d22b

View file

@ -712,14 +712,14 @@ func (f *Fs) List(dir string) (entries fs.DirEntries, err error) {
_, err = f.list(directoryID, "", false, false, false, func(item *drive.File) bool { _, err = f.list(directoryID, "", false, false, false, func(item *drive.File) bool {
remote := path.Join(dir, item.Name) remote := path.Join(dir, item.Name)
switch { switch {
case *driveAuthOwnerOnly && !isAuthOwned(item):
// ignore object or directory
case item.MimeType == driveFolderType: case item.MimeType == driveFolderType:
// cache the directory ID for later lookups // cache the directory ID for later lookups
f.dirCache.Put(remote, item.Id) f.dirCache.Put(remote, item.Id)
when, _ := time.Parse(timeFormatIn, item.ModifiedTime) when, _ := time.Parse(timeFormatIn, item.ModifiedTime)
d := fs.NewDir(remote, when).SetID(item.Id) d := fs.NewDir(remote, when).SetID(item.Id)
entries = append(entries, d) entries = append(entries, d)
case *driveAuthOwnerOnly && !isAuthOwned(item):
// ignore object
case item.Md5Checksum != "" || item.Size > 0: case item.Md5Checksum != "" || item.Size > 0:
// If item has MD5 sum or a length it is a file stored on drive // If item has MD5 sum or a length it is a file stored on drive
o, err := f.newObjectWithInfo(remote, item) o, err := f.newObjectWithInfo(remote, item)