forked from TrueCloudLab/rclone
dropbox: set visibility in link sharing when --expire is set
Note that due to a bug in the dropbox SDK you'll need to set --expire to access this. See: https://github.com/dropbox/dropbox-sdk-go-unofficial/issues/75 See: https://forum.rclone.org/t/rclone-link-dropbox-permissions/23211
This commit is contained in:
parent
9393225a1d
commit
fcba51557f
2 changed files with 29 additions and 6 deletions
|
@ -1084,13 +1084,30 @@ func (f *Fs) PublicLink(ctx context.Context, remote string, expire fs.Duration,
|
||||||
fs.Debugf(f, "attempting to share '%s' (absolute path: %s)", remote, absPath)
|
fs.Debugf(f, "attempting to share '%s' (absolute path: %s)", remote, absPath)
|
||||||
createArg := sharing.CreateSharedLinkWithSettingsArg{
|
createArg := sharing.CreateSharedLinkWithSettingsArg{
|
||||||
Path: absPath,
|
Path: absPath,
|
||||||
// FIXME this gives settings_error/not_authorized/.. errors
|
Settings: &sharing.SharedLinkSettings{
|
||||||
// and the expires setting isn't in the documentation so remove
|
RequestedVisibility: &sharing.RequestedVisibility{
|
||||||
// for now.
|
Tagged: dropbox.Tagged{Tag: sharing.RequestedVisibilityPublic},
|
||||||
// Settings: &sharing.SharedLinkSettings{
|
},
|
||||||
// Expires: time.Now().Add(time.Duration(expire)).UTC().Round(time.Second),
|
Audience: &sharing.LinkAudience{
|
||||||
// },
|
Tagged: dropbox.Tagged{Tag: sharing.LinkAudiencePublic},
|
||||||
|
},
|
||||||
|
Access: &sharing.RequestedLinkAccessLevel{
|
||||||
|
Tagged: dropbox.Tagged{Tag: sharing.RequestedLinkAccessLevelViewer},
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
if expire < fs.DurationOff {
|
||||||
|
expiryTime := time.Now().Add(time.Duration(expire)).UTC().Round(time.Second)
|
||||||
|
createArg.Settings.Expires = expiryTime
|
||||||
|
}
|
||||||
|
// FIXME note we can't set Settings for non enterprise dropbox
|
||||||
|
// because of https://github.com/dropbox/dropbox-sdk-go-unofficial/issues/75
|
||||||
|
// however this only goes wrong when we set Expires, so as a
|
||||||
|
// work-around remove Settings unless expire is set.
|
||||||
|
if expire == fs.DurationOff {
|
||||||
|
createArg.Settings = nil
|
||||||
|
}
|
||||||
|
|
||||||
var linkRes sharing.IsSharedLinkMetadata
|
var linkRes sharing.IsSharedLinkMetadata
|
||||||
err = f.pacer.Call(func() (bool, error) {
|
err = f.pacer.Call(func() (bool, error) {
|
||||||
linkRes, err = f.sharing.CreateSharedLinkWithSettings(&createArg)
|
linkRes, err = f.sharing.CreateSharedLinkWithSettings(&createArg)
|
||||||
|
|
|
@ -285,6 +285,12 @@ dropbox:dir` will return the error `Failed to purge: There are too
|
||||||
many files involved in this operation`. As a work-around do an
|
many files involved in this operation`. As a work-around do an
|
||||||
`rclone delete dropbox:dir` followed by an `rclone rmdir dropbox:dir`.
|
`rclone delete dropbox:dir` followed by an `rclone rmdir dropbox:dir`.
|
||||||
|
|
||||||
|
When using `rclone link` you'll need to set `--expire` if using a
|
||||||
|
non-personal account otherwise the visibility may not be correct.
|
||||||
|
(Note that `--expire` isn't supported on personal accounts). See the
|
||||||
|
[forum discussion](https://forum.rclone.org/t/rclone-link-dropbox-permissions/23211) and the
|
||||||
|
[dropbox SDK issue](https://github.com/dropbox/dropbox-sdk-go-unofficial/issues/75).
|
||||||
|
|
||||||
### Get your own Dropbox App ID ###
|
### Get your own Dropbox App ID ###
|
||||||
|
|
||||||
When you use rclone with Dropbox in its default configuration you are using rclone's App ID. This is shared between all the rclone users.
|
When you use rclone with Dropbox in its default configuration you are using rclone's App ID. This is shared between all the rclone users.
|
||||||
|
|
Loading…
Reference in a new issue