forked from TrueCloudLab/rclone
b2: add --b2-hard-delete to permanently delete instead of hide files - Fixes #1547
This commit is contained in:
parent
7b81f12dad
commit
d134d78979
2 changed files with 35 additions and 23 deletions
49
b2/b2.go
49
b2/b2.go
|
@ -51,6 +51,7 @@ var (
|
||||||
uploadCutoff = fs.SizeSuffix(200E6)
|
uploadCutoff = fs.SizeSuffix(200E6)
|
||||||
b2TestMode = fs.StringP("b2-test-mode", "", "", "A flag string for X-Bz-Test-Mode header.")
|
b2TestMode = fs.StringP("b2-test-mode", "", "", "A flag string for X-Bz-Test-Mode header.")
|
||||||
b2Versions = fs.BoolP("b2-versions", "", false, "Include old versions in directory listings.")
|
b2Versions = fs.BoolP("b2-versions", "", false, "Include old versions in directory listings.")
|
||||||
|
b2HardDelete = fs.BoolP("b2-hard-delete", "", false, "Permanently delete files on remote removal, otherwise hide files.")
|
||||||
errNotWithVersions = errors.New("can't modify or delete files in --b2-versions mode")
|
errNotWithVersions = errors.New("can't modify or delete files in --b2-versions mode")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -786,6 +787,31 @@ func (f *Fs) Precision() time.Duration {
|
||||||
return time.Millisecond
|
return time.Millisecond
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// hide hides a file on the remote
|
||||||
|
func (f *Fs) hide(Name string) error {
|
||||||
|
bucketID, err := f.getBucketID()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
opts := rest.Opts{
|
||||||
|
Method: "POST",
|
||||||
|
Path: "/b2_hide_file",
|
||||||
|
}
|
||||||
|
var request = api.HideFileRequest{
|
||||||
|
BucketID: bucketID,
|
||||||
|
Name: Name,
|
||||||
|
}
|
||||||
|
var response api.File
|
||||||
|
err = f.pacer.Call(func() (bool, error) {
|
||||||
|
resp, err := f.srv.CallJSON(&opts, &request, &response)
|
||||||
|
return f.shouldRetry(resp, err)
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrapf(err, "failed to hide %q", Name)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// deleteByID deletes a file version given Name and ID
|
// deleteByID deletes a file version given Name and ID
|
||||||
func (f *Fs) deleteByID(ID, Name string) error {
|
func (f *Fs) deleteByID(ID, Name string) error {
|
||||||
opts := rest.Opts{
|
opts := rest.Opts{
|
||||||
|
@ -1361,27 +1387,10 @@ func (o *Object) Remove() error {
|
||||||
if *b2Versions {
|
if *b2Versions {
|
||||||
return errNotWithVersions
|
return errNotWithVersions
|
||||||
}
|
}
|
||||||
bucketID, err := o.fs.getBucketID()
|
if *b2HardDelete {
|
||||||
if err != nil {
|
return o.fs.deleteByID(o.id, o.remote)
|
||||||
return err
|
|
||||||
}
|
}
|
||||||
opts := rest.Opts{
|
return o.fs.hide(o.fs.root + o.remote)
|
||||||
Method: "POST",
|
|
||||||
Path: "/b2_hide_file",
|
|
||||||
}
|
|
||||||
var request = api.HideFileRequest{
|
|
||||||
BucketID: bucketID,
|
|
||||||
Name: o.fs.root + o.remote,
|
|
||||||
}
|
|
||||||
var response api.File
|
|
||||||
err = o.fs.pacer.Call(func() (bool, error) {
|
|
||||||
resp, err := o.fs.srv.CallJSON(&opts, &request, &response)
|
|
||||||
return o.fs.shouldRetry(resp, err)
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return errors.Wrap(err, "failed to delete file")
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// MimeType of an Object if known, "" otherwise
|
// MimeType of an Object if known, "" otherwise
|
||||||
|
|
|
@ -138,10 +138,13 @@ used.
|
||||||
|
|
||||||
When rclone uploads a new version of a file it creates a [new version
|
When rclone uploads a new version of a file it creates a [new version
|
||||||
of it](https://www.backblaze.com/b2/docs/file_versions.html).
|
of it](https://www.backblaze.com/b2/docs/file_versions.html).
|
||||||
Likewise when you delete a file, the old version will still be
|
Likewise when you delete a file, the old version will be marked hidden
|
||||||
available.
|
and still be available. Conversely, you may opt in to a "hard delete"
|
||||||
|
of files with the `--b2-hard-delete` flag which would permanently remove
|
||||||
|
the file instead of hiding it.
|
||||||
|
|
||||||
Old versions of files are visible using the `--b2-versions` flag.
|
Old versions of files, where available, are visible using the
|
||||||
|
`--b2-versions` flag.
|
||||||
|
|
||||||
If you wish to remove all the old versions then you can use the
|
If you wish to remove all the old versions then you can use the
|
||||||
`rclone cleanup remote:bucket` command which will delete all the old
|
`rclone cleanup remote:bucket` command which will delete all the old
|
||||||
|
|
Loading…
Reference in a new issue