drive: fix ChangeNotify polling for shared drives

Before this fix we neglected to add the shared drive ID to the request
when asking for an initial change notify token and this caused a lot
more results to be returned than was necessary.
This commit is contained in:
Nick Craig-Wood 2019-10-20 16:05:53 +01:00
parent 59026c4761
commit 3ef0c73826

View file

@ -2314,9 +2314,11 @@ func (f *Fs) ChangeNotify(ctx context.Context, notifyFunc func(string, fs.EntryT
func (f *Fs) changeNotifyStartPageToken() (pageToken string, err error) { func (f *Fs) changeNotifyStartPageToken() (pageToken string, err error) {
var startPageToken *drive.StartPageToken var startPageToken *drive.StartPageToken
err = f.pacer.Call(func() (bool, error) { err = f.pacer.Call(func() (bool, error) {
startPageToken, err = f.svc.Changes.GetStartPageToken(). changes := f.svc.Changes.GetStartPageToken().SupportsAllDrives(true)
SupportsAllDrives(true). if f.isTeamDrive {
Do() changes.DriveId(f.opt.TeamDriveID)
}
startPageToken, err = changes.Do()
return shouldRetry(err) return shouldRetry(err)
}) })
if err != nil { if err != nil {
@ -2339,7 +2341,7 @@ func (f *Fs) changeNotifyRunner(ctx context.Context, notifyFunc func(string, fs.
changesCall.SupportsAllDrives(true) changesCall.SupportsAllDrives(true)
changesCall.IncludeItemsFromAllDrives(true) changesCall.IncludeItemsFromAllDrives(true)
if f.isTeamDrive { if f.isTeamDrive {
changesCall.TeamDriveId(f.opt.TeamDriveID) changesCall.DriveId(f.opt.TeamDriveID)
} }
changeList, err = changesCall.Context(ctx).Do() changeList, err = changesCall.Context(ctx).Do()
return shouldRetry(err) return shouldRetry(err)