mirror of
https://github.com/rclone/rclone.git
synced 2025-01-20 21:28:41 +01:00
drive: set all metadata permissions and return error summary
Before this change when setting permissions from the metadata rclone would stop on the first error. This change causes rclone to attempt to set all the permissions and return an error summary at the end.
This commit is contained in:
parent
efbaca3a95
commit
46b3854330
@ -9,6 +9,7 @@ import (
|
|||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/rclone/rclone/fs"
|
"github.com/rclone/rclone/fs"
|
||||||
|
"github.com/rclone/rclone/lib/errcount"
|
||||||
"golang.org/x/sync/errgroup"
|
"golang.org/x/sync/errgroup"
|
||||||
drive "google.golang.org/api/drive/v3"
|
drive "google.golang.org/api/drive/v3"
|
||||||
"google.golang.org/api/googleapi"
|
"google.golang.org/api/googleapi"
|
||||||
@ -135,24 +136,26 @@ func (f *Fs) getPermission(ctx context.Context, fileID, permissionID string, use
|
|||||||
|
|
||||||
// Set the permissions on the info
|
// Set the permissions on the info
|
||||||
func (f *Fs) setPermissions(ctx context.Context, info *drive.File, permissions []*drive.Permission) (err error) {
|
func (f *Fs) setPermissions(ctx context.Context, info *drive.File, permissions []*drive.Permission) (err error) {
|
||||||
|
errs := errcount.New()
|
||||||
for _, perm := range permissions {
|
for _, perm := range permissions {
|
||||||
if perm.Role == "owner" {
|
if perm.Role == "owner" {
|
||||||
// ignore owner permissions - these are set with owner
|
// ignore owner permissions - these are set with owner
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
cleanPermissionForWrite(perm)
|
cleanPermissionForWrite(perm)
|
||||||
err = f.pacer.Call(func() (bool, error) {
|
err := f.pacer.Call(func() (bool, error) {
|
||||||
_, err = f.svc.Permissions.Create(info.Id, perm).
|
_, err := f.svc.Permissions.Create(info.Id, perm).
|
||||||
SupportsAllDrives(true).
|
SupportsAllDrives(true).
|
||||||
SendNotificationEmail(false).
|
SendNotificationEmail(false).
|
||||||
Context(ctx).Do()
|
Context(ctx).Do()
|
||||||
return f.shouldRetry(ctx, err)
|
return f.shouldRetry(ctx, err)
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to set permission: %w", err)
|
fs.Errorf(f, "Failed to set permission: %v", err)
|
||||||
|
errs.Add(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return errs.Err("failed to set permission")
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clean attributes from permissions which we can't write
|
// Clean attributes from permissions which we can't write
|
||||||
|
Loading…
Reference in New Issue
Block a user