rc: add option blocks parameter to options/get and options/info

This commit is contained in:
Nick Craig-Wood 2024-07-16 14:06:37 +01:00
parent 97d6a00483
commit afd2663057
2 changed files with 59 additions and 8 deletions

View file

@ -7,6 +7,7 @@ package rc
import ( import (
"context" "context"
"fmt" "fmt"
"strings"
"github.com/rclone/rclone/fs" "github.com/rclone/rclone/fs"
"github.com/rclone/rclone/fs/filter" "github.com/rclone/rclone/fs/filter"
@ -41,6 +42,11 @@ func init() {
Help: `Returns an object where keys are option block names and values are an Help: `Returns an object where keys are option block names and values are an
object with the current option values in. object with the current option values in.
Parameters:
- blocks: optional string of comma separated blocks to include
- all are included if this is missing or ""
Note that these are the global options which are unaffected by use of Note that these are the global options which are unaffected by use of
the _config and _filter parameters. If you wish to read the parameters the _config and _filter parameters. If you wish to read the parameters
set in _config then use options/config and for _filter use options/filter. set in _config then use options/config and for _filter use options/filter.
@ -51,13 +57,33 @@ map to the external options very easily with a few exceptions.
}) })
} }
// Filter the blocks according to name
func filterBlocks(in Params, f func(oi fs.OptionsInfo)) (err error) {
blocksStr, err := in.GetString("blocks")
if err != nil && !IsErrParamNotFound(err) {
return err
}
blocks := map[string]struct{}{}
for _, name := range strings.Split(blocksStr, ",") {
if name != "" {
blocks[name] = struct{}{}
}
}
for _, oi := range fs.OptionsRegistry {
if _, found := blocks[oi.Name]; found || len(blocks) == 0 {
f(oi)
}
}
return nil
}
// Show the list of all the option blocks // Show the list of all the option blocks
func rcOptionsGet(ctx context.Context, in Params) (out Params, err error) { func rcOptionsGet(ctx context.Context, in Params) (out Params, err error) {
out = make(Params) out = make(Params)
for _, opt := range fs.OptionsRegistry { err = filterBlocks(in, func(oi fs.OptionsInfo) {
out[opt.Name] = opt.Opt out[oi.Name] = oi.Opt
} })
return out, nil return out, err
} }
func init() { func init() {
@ -68,6 +94,11 @@ func init() {
Help: `Returns an object where keys are option block names and values are an Help: `Returns an object where keys are option block names and values are an
array of objects with info about each options. array of objects with info about each options.
Parameters:
- blocks: optional string of comma separated blocks to include
- all are included if this is missing or ""
These objects are in the same format as returned by "config/providers". They are These objects are in the same format as returned by "config/providers". They are
described in the [option blocks](#option-blocks) section. described in the [option blocks](#option-blocks) section.
`, `,
@ -77,10 +108,10 @@ described in the [option blocks](#option-blocks) section.
// Show the info of all the option blocks // Show the info of all the option blocks
func rcOptionsInfo(ctx context.Context, in Params) (out Params, err error) { func rcOptionsInfo(ctx context.Context, in Params) (out Params, err error) {
out = make(Params) out = make(Params)
for _, opt := range fs.OptionsRegistry { err = filterBlocks(in, func(oi fs.OptionsInfo) {
out[opt.Name] = opt.Options out[oi.Name] = oi.Options
} })
return out, nil return out, err
} }
func init() { func init() {

View file

@ -86,6 +86,16 @@ func TestOptionsGet(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
require.NotNil(t, out) require.NotNil(t, out)
assert.Equal(t, Params{"potato": &testOptions}, out) assert.Equal(t, Params{"potato": &testOptions}, out)
in = Params{"blocks": "sausage,potato,rhubarb"}
out, err = call.Fn(context.Background(), in)
require.NoError(t, err)
require.NotNil(t, out)
assert.Equal(t, Params{"potato": &testOptions}, out)
in = Params{"blocks": "sausage"}
out, err = call.Fn(context.Background(), in)
require.NoError(t, err)
require.NotNil(t, out)
assert.Equal(t, Params{}, out)
} }
func TestOptionsGetMarshal(t *testing.T) { func TestOptionsGetMarshal(t *testing.T) {
@ -120,6 +130,16 @@ func TestOptionsInfo(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
require.NotNil(t, out) require.NotNil(t, out)
assert.Equal(t, Params{"potato": testInfo}, out) assert.Equal(t, Params{"potato": testInfo}, out)
in = Params{"blocks": "sausage,potato,rhubarb"}
out, err = call.Fn(context.Background(), in)
require.NoError(t, err)
require.NotNil(t, out)
assert.Equal(t, Params{"potato": testInfo}, out)
in = Params{"blocks": "sausage"}
out, err = call.Fn(context.Background(), in)
require.NoError(t, err)
require.NotNil(t, out)
assert.Equal(t, Params{}, out)
} }
func TestOptionsSet(t *testing.T) { func TestOptionsSet(t *testing.T) {