crypt: change backend encode/decode to output a plain list

This commit changes the output of the rclone backend encode crypt: and
decode commands to output a plain list of decoded or encoded file
names.

This makes the command much more useful for command line scripting.
This commit is contained in:
Nick Craig-Wood 2020-05-13 18:11:45 +01:00
parent 995cd0dc32
commit 52b7337d28

View file

@ -705,24 +705,27 @@ var commandHelp = []fs.CommandHelp{
{ {
Name: "encode", Name: "encode",
Short: "Encode the given filename(s)", Short: "Encode the given filename(s)",
Long: `Encode the given filename(s) Long: `This encodes the filenames given as arguments returning a list of
strings of the encoded results.
Usage Example: Usage Example:
rclone backend encode crypt: file1 [file2...] rclone backend encode crypt: file1 [file2...]
rclone rc backend/command command=encode fs=crypt: file1 [file2...] rclone rc backend/command command=encode fs=crypt: file1 [file2...]
`, `,
}, },
{ {
Name: "decode", Name: "decode",
Short: "Decode the given filename(s)", Short: "Decode the given filename(s)",
Long: `Decode the given filename(s) Long: `This decodes the filenames given as arguments returning a list of
strings of the decoded results. It will return an error if any of the
inputs are invalid.
Usage Example: Usage Example:
rclone backend decode crypt: encryptedfile1 [encryptedfile2...] rclone backend decode crypt: encryptedfile1 [encryptedfile2...]
rclone rc backend/command command=decode fs=crypt: encryptedfile1 [encryptedfile2...] rclone rc backend/command command=decode fs=crypt: encryptedfile1 [encryptedfile2...]
`, `,
}, },
} }
@ -738,20 +741,20 @@ var commandHelp = []fs.CommandHelp{
func (f *Fs) Command(ctx context.Context, name string, arg []string, opt map[string]string) (out interface{}, err error) { func (f *Fs) Command(ctx context.Context, name string, arg []string, opt map[string]string) (out interface{}, err error) {
switch name { switch name {
case "decode": case "decode":
out := make(map[string]string) out := make([]string, 0, len(arg))
for _, encryptedFileName := range arg { for _, encryptedFileName := range arg {
fileName, err := f.DecryptFileName(encryptedFileName) fileName, err := f.DecryptFileName(encryptedFileName)
if err != nil { if err != nil {
return out, errors.Wrap(err, fmt.Sprintf("Failed to decrypt : %s", encryptedFileName)) return out, errors.Wrap(err, fmt.Sprintf("Failed to decrypt : %s", encryptedFileName))
} }
out[encryptedFileName] = fileName out = append(out, fileName)
} }
return out, nil return out, nil
case "encode": case "encode":
out := make(map[string]string) out := make([]string, 0, len(arg))
for _, fileName := range arg { for _, fileName := range arg {
encryptedFileName := f.EncryptFileName(fileName) encryptedFileName := f.EncryptFileName(fileName)
out[fileName] = encryptedFileName out = append(out, encryptedFileName)
} }
return out, nil return out, nil
default: default: