Documentation ¶
Overview ¶
Package rc implements a remote control server and registry for rclone
To register your internal calls, call rc.Add(path, function). Your function should take and return a Param. It can also return an error. Use rc.NewError to wrap an existing error along with an http response type if another response other than 500 internal error is required on error.
Index ¶
- Variables
- func Add(call Call)
- func GetFs(ctx context.Context, in Params) (f fs.Fs, err error)
- func GetFsAndRemote(ctx context.Context, in Params) (f fs.Fs, remote string, err error)
- func GetFsAndRemoteNamed(ctx context.Context, in Params, fsName, remoteName string) (f fs.Fs, remote string, err error)
- func GetFsNamed(ctx context.Context, in Params, fsName string) (f fs.Fs, err error)
- func GetFsNamedFileOK(ctx context.Context, in Params, fsName string) (newCtx context.Context, f fs.Fs, err error)
- func IsErrParamInvalid(err error) bool
- func IsErrParamNotFound(err error) bool
- func NotErrParamNotFound(err error) bool
- func Reshape(out interface{}, in interface{}) error
- func WriteJSON(w io.Writer, out Params) error
- type Call
- type ErrParamInvalid
- type ErrParamNotFound
- type Func
- type Options
- type Params
- func (p Params) Copy() (out Params)
- func (p Params) Get(key string) (interface{}, error)
- func (p Params) GetBool(key string) (bool, error)
- func (p Params) GetDuration(key string) (time.Duration, error)
- func (p Params) GetFloat64(key string) (float64, error)
- func (p Params) GetFsDuration(key string) (fs.Duration, error)
- func (p Params) GetHTTPRequest() (*http.Request, error)
- func (p Params) GetHTTPResponseWriter() (http.ResponseWriter, error)
- func (p Params) GetInt64(key string) (int64, error)
- func (p Params) GetString(key string) (string, error)
- func (p Params) GetStruct(key string, out interface{}) error
- func (p Params) GetStructMissingOK(key string, out interface{}) error
- type Registry
Constants ¶
This section is empty.
Variables ¶
var Calls = NewRegistry()
Calls is the global registry of Call objects
var OptionsInfo = fs.Options{{ Name: "rc", Default: false, Help: "Enable the remote control server", Groups: "RC", }, { Name: "rc_files", Default: "", Help: "Path to local files to serve on the HTTP server", Groups: "RC", }, { Name: "rc_serve", Default: false, Help: "Enable the serving of remote objects", Groups: "RC", }, { Name: "rc_serve_no_modtime", Default: false, Help: "Don't read the modification time (can speed things up)", Groups: "RC", }, { Name: "rc_no_auth", Default: false, Help: "Don't require auth for certain methods", Groups: "RC", }, { Name: "rc_web_gui", Default: false, Help: "Launch WebGUI on localhost", Groups: "RC", }, { Name: "rc_web_gui_update", Default: false, Help: "Check and update to latest version of web gui", Groups: "RC", }, { Name: "rc_web_gui_force_update", Default: false, Help: "Force update to latest version of web gui", Groups: "RC", }, { Name: "rc_web_gui_no_open_browser", Default: false, Help: "Don't open the browser automatically", Groups: "RC", }, { Name: "rc_web_fetch_url", Default: "https://api.github.com/repos/rclone/rclone-webui-react/releases/latest", Help: "URL to fetch the releases for webgui", Groups: "RC", }, { Name: "rc_enable_metrics", Default: false, Help: "Enable the Prometheus metrics path at the remote control server", Groups: "RC,Metrics", }, { Name: "rc_job_expire_duration", Default: 60 * time.Second, Help: "Expire finished async jobs older than this value", Groups: "RC", }, { Name: "rc_job_expire_interval", Default: 10 * time.Second, Help: "Interval to check for expired async jobs", Groups: "RC", }, { Name: "metrics_addr", Default: []string{}, Help: "IPaddress:Port or :Port to bind metrics server to", Groups: "Metrics", }}. AddPrefix(libhttp.ConfigInfo, "rc", "RC"). AddPrefix(libhttp.AuthConfigInfo, "rc", "RC"). AddPrefix(libhttp.TemplateConfigInfo, "rc", "RC"). AddPrefix(libhttp.ConfigInfo, "metrics", "Metrics"). AddPrefix(libhttp.AuthConfigInfo, "metrics", "Metrics"). AddPrefix(libhttp.TemplateConfigInfo, "metrics", "Metrics"). SetDefault("rc_addr", []string{"localhost:5572"})
OptionsInfo describes the Options in use
Functions ¶
func GetFsAndRemote ¶
GetFsAndRemote gets the `fs` parameter from in, makes a remote or fetches it from the cache then gets the `remote` parameter from in too.
func GetFsAndRemoteNamed ¶
func GetFsAndRemoteNamed(ctx context.Context, in Params, fsName, remoteName string) (f fs.Fs, remote string, err error)
GetFsAndRemoteNamed gets the fsName parameter from in, makes a remote or fetches it from the cache then gets the remoteName parameter from in too.
func GetFsNamed ¶
GetFsNamed gets an fs.Fs named fsName either from the cache or creates it afresh
func GetFsNamedFileOK ¶
func GetFsNamedFileOK(ctx context.Context, in Params, fsName string) (newCtx context.Context, f fs.Fs, err error)
GetFsNamedFileOK gets an fs.Fs named fsName either from the cache or creates it afresh
If the fs.Fs points to a single file then it returns a new ctx with filters applied to make the listings return only that file.
func IsErrParamInvalid ¶
IsErrParamInvalid returns whether err is ErrParamInvalid
func IsErrParamNotFound ¶
IsErrParamNotFound returns whether err is ErrParamNotFound
func NotErrParamNotFound ¶
NotErrParamNotFound returns true if err != nil and !IsErrParamNotFound(err)
This is for checking error returns of the Get* functions to ignore error not found returns and take the default value.
Types ¶
type Call ¶
type Call struct { Path string // path to activate this RC Fn Func `json:"-"` // function to call Title string // help for the function AuthRequired bool // if set then this call requires authorisation to be set Help string // multi-line markdown formatted help NeedsRequest bool // if set then this call will be passed the original request object as _request NeedsResponse bool // if set then this call will be passed the original response object as _response }
Call defines info about a remote control function and is used in the Add function to create new entry points.
type ErrParamInvalid ¶
type ErrParamInvalid struct {
// contains filtered or unexported fields
}
ErrParamInvalid - this is returned from the Get* functions if the parameter is invalid.
Returning an error of this type from an rc.Func will cause the http method to return http.StatusBadRequest
func NewErrParamInvalid ¶
func NewErrParamInvalid(err error) ErrParamInvalid
NewErrParamInvalid returns new ErrParamInvalid from given error
type ErrParamNotFound ¶
type ErrParamNotFound string
ErrParamNotFound - this is returned from the Get* functions if the parameter isn't found along with a zero value of the requested item.
Returning an error of this type from an rc.Func will cause the http method to return http.StatusBadRequest
func (ErrParamNotFound) Error ¶
func (e ErrParamNotFound) Error() string
Error turns this error into a string
type Options ¶
type Options struct { HTTP libhttp.Config `config:"rc"` Auth libhttp.AuthConfig `config:"rc"` Template libhttp.TemplateConfig `config:"rc"` Enabled bool `config:"rc"` // set to enable the server Files string `config:"rc_files"` // set to enable serving files locally Serve bool `config:"rc_serve"` // set to serve files from remotes ServeNoModTime bool `config:"rc_serve_no_modtime"` // don't read the modification time NoAuth bool `config:"rc_no_auth"` // set to disable auth checks on AuthRequired methods WebUI bool `config:"rc_web_gui"` // set to launch the web ui WebGUIUpdate bool `config:"rc_web_gui_update"` // set to check new update WebGUIForceUpdate bool `config:"rc_web_gui_force_update"` // set to force download new update WebGUINoOpenBrowser bool `config:"rc_web_gui_no_open_browser"` // set to disable auto opening browser WebGUIFetchURL string `config:"rc_web_fetch_url"` // set the default url for fetching webgui EnableMetrics bool `config:"rc_enable_metrics"` // set to disable prometheus metrics on /metrics MetricsHTTP libhttp.Config `config:"metrics"` MetricsAuth libhttp.AuthConfig `config:"metrics"` MetricsTemplate libhttp.TemplateConfig `config:"metrics"` JobExpireDuration time.Duration `config:"rc_job_expire_duration"` JobExpireInterval time.Duration `config:"rc_job_expire_interval"` }
Options contains options for the remote control server
var Opt Options
Opt is the default values used for Options
type Params ¶
type Params map[string]interface{}
Params is the input and output type for the Func
func Error ¶
Error creates the standard response for an errored rc call using an rc.Param from a path, input Params, error and a suggested HTTP response code.
It returns a Params and an updated status code
func (Params) Get ¶
Get gets a parameter from the input
If the parameter isn't found then error will be of type ErrParamNotFound and the returned value will be nil.
func (Params) GetBool ¶
GetBool gets a boolean parameter from the input
If the parameter isn't found then error will be of type ErrParamNotFound and the returned value will be false.
func (Params) GetDuration ¶
GetDuration get the duration parameters from in
func (Params) GetFloat64 ¶
GetFloat64 gets a float64 parameter from the input
If the parameter isn't found then error will be of type ErrParamNotFound and the returned value will be 0.
func (Params) GetFsDuration ¶
GetFsDuration get the duration parameters from in
func (Params) GetHTTPRequest ¶
GetHTTPRequest gets a http.Request parameter associated with the request with the key "_request"
If the parameter isn't found then error will be of type ErrParamNotFound and the returned value will be nil.
func (Params) GetHTTPResponseWriter ¶
func (p Params) GetHTTPResponseWriter() (http.ResponseWriter, error)
GetHTTPResponseWriter gets a http.ResponseWriter parameter associated with the request with the key "_response"
If the parameter isn't found then error will be of type ErrParamNotFound and the returned value will be nil.
func (Params) GetInt64 ¶
GetInt64 gets an int64 parameter from the input
If the parameter isn't found then error will be of type ErrParamNotFound and the returned value will be 0.
func (Params) GetString ¶
GetString gets a string parameter from the input
If the parameter isn't found then error will be of type ErrParamNotFound and the returned value will be "".
func (Params) GetStruct ¶
GetStruct gets a struct from key from the input into the struct pointed to by out. out must be a pointer type.
If the parameter isn't found then error will be of type ErrParamNotFound and out will be unchanged.
func (Params) GetStructMissingOK ¶
GetStructMissingOK works like GetStruct but doesn't return an error if the key is missing
type Registry ¶
type Registry struct {
// contains filtered or unexported fields
}
Registry holds the list of all the registered remote control functions
func NewRegistry ¶
func NewRegistry() *Registry
NewRegistry makes a new registry for remote control functions
Directories ¶
Path | Synopsis |
---|---|
Package jobs manages background jobs that the rc is running.
|
Package jobs manages background jobs that the rc is running. |
Package rcflags implements command line flags to set up the remote control
|
Package rcflags implements command line flags to set up the remote control |
Package rcserver implements the HTTP endpoint to serve the remote control
|
Package rcserver implements the HTTP endpoint to serve the remote control |
Package webgui provides plugin functionality to the Web GUI.
|
Package webgui provides plugin functionality to the Web GUI. |