From e649cf4d5016d9a66e7912540d7d57eb990eda70 Mon Sep 17 00:00:00 2001 From: Nick Craig-Wood Date: Tue, 25 Apr 2023 15:01:44 +0100 Subject: [PATCH] uptobox: add --uptobox-private flag to make all uploaded files private See: #6946 --- backend/uptobox/uptobox.go | 31 ++++++++++++++++++++++++++++--- 1 file changed, 28 insertions(+), 3 deletions(-) diff --git a/backend/uptobox/uptobox.go b/backend/uptobox/uptobox.go index 4f09ad8e6..be2da1569 100644 --- a/backend/uptobox/uptobox.go +++ b/backend/uptobox/uptobox.go @@ -45,6 +45,11 @@ func init() { Options: []fs.Option{{ Help: "Your access token.\n\nGet it from https://uptobox.com/my_account.", Name: "access_token", + }, { + Help: "Set to make uploaded files private", + Name: "private", + Advanced: true, + Default: false, }, { Name: config.ConfigEncoding, Help: config.ConfigEncodingHelp, @@ -63,6 +68,7 @@ func init() { // Options defines the configuration for this backend type Options struct { AccessToken string `config:"access_token"` + Private bool `config:"private"` Enc encoder.MultiEncoder `config:"encoding"` } @@ -75,6 +81,7 @@ type Fs struct { srv *rest.Client pacer *fs.Pacer IDRegexp *regexp.Regexp + public string // "0" to make objects private } // Object represents an Uptobox object @@ -211,6 +218,9 @@ func NewFs(ctx context.Context, name string, root string, config configmap.Mappe CanHaveEmptyDirectories: true, ReadMimeType: false, }).Fill(ctx, f) + if f.opt.Private { + f.public = "0" + } client := fshttp.NewClient(ctx) f.srv = rest.NewClient(client).SetRoot(apiBaseURL) @@ -531,7 +541,12 @@ func (f *Fs) putUnchecked(ctx context.Context, in io.Reader, remote string, size } // rename file to final name - err = f.updateFileInformation(ctx, &api.UpdateFileInformation{Token: f.opt.AccessToken, FileCode: match[1], NewName: f.opt.Enc.FromStandardName(leaf)}) + err = f.updateFileInformation(ctx, &api.UpdateFileInformation{ + Token: f.opt.AccessToken, + FileCode: match[1], + NewName: f.opt.Enc.FromStandardName(leaf), + Public: f.public, + }) if err != nil { return nil, err } @@ -696,7 +711,12 @@ func (f *Fs) Move(ctx context.Context, src fs.Object, remote string) (fs.Object, // rename to final name if we need to if needRename { - err := f.updateFileInformation(ctx, &api.UpdateFileInformation{Token: f.opt.AccessToken, FileCode: srcObj.code, NewName: f.opt.Enc.FromStandardName(dstLeaf)}) + err := f.updateFileInformation(ctx, &api.UpdateFileInformation{ + Token: f.opt.AccessToken, + FileCode: srcObj.code, + NewName: f.opt.Enc.FromStandardName(dstLeaf), + Public: f.public, + }) if err != nil { return nil, fmt.Errorf("move: failed final rename: %w", err) } @@ -888,7 +908,12 @@ func (f *Fs) Copy(ctx context.Context, src fs.Object, remote string) (fs.Object, } if needRename { - err := f.updateFileInformation(ctx, &api.UpdateFileInformation{Token: f.opt.AccessToken, FileCode: newObj.(*Object).code, NewName: f.opt.Enc.FromStandardName(dstLeaf)}) + err := f.updateFileInformation(ctx, &api.UpdateFileInformation{ + Token: f.opt.AccessToken, + FileCode: newObj.(*Object).code, + NewName: f.opt.Enc.FromStandardName(dstLeaf), + Public: f.public, + }) if err != nil { return nil, fmt.Errorf("copy: failed final rename: %w", err) }