2018-03-05 11:44:16 +00:00
|
|
|
---
|
|
|
|
title: "Remote Control"
|
|
|
|
description: "Remote controlling rclone"
|
|
|
|
date: "2018-03-05"
|
|
|
|
---
|
|
|
|
|
|
|
|
# Remote controlling rclone #
|
|
|
|
|
|
|
|
If rclone is run with the `--rc` flag then it starts an http server
|
|
|
|
which can be used to remote control rclone.
|
|
|
|
|
2018-03-16 20:45:34 +00:00
|
|
|
**NB** this is experimental and everything here is subject to change!
|
|
|
|
|
2018-03-14 19:48:37 +00:00
|
|
|
## Supported parameters
|
|
|
|
|
|
|
|
#### --rc ####
|
|
|
|
Flag to start the http server listen on remote requests
|
|
|
|
|
|
|
|
#### --rc-addr=IP ####
|
|
|
|
IPaddress:Port or :Port to bind server to. (default "localhost:5572")
|
|
|
|
|
|
|
|
#### --rc-cert=KEY ####
|
|
|
|
SSL PEM key (concatenation of certificate and CA certificate)
|
|
|
|
|
|
|
|
#### --rc-client-ca=PATH ####
|
|
|
|
Client certificate authority to verify clients with
|
|
|
|
|
|
|
|
#### --rc-htpasswd=PATH ####
|
|
|
|
htpasswd file - if not provided no authentication is done
|
|
|
|
|
|
|
|
#### --rc-key=PATH ####
|
|
|
|
SSL PEM Private key
|
|
|
|
|
|
|
|
#### --rc-max-header-bytes=VALUE ####
|
|
|
|
Maximum size of request header (default 4096)
|
|
|
|
|
|
|
|
#### --rc-user=VALUE ####
|
|
|
|
User name for authentication.
|
|
|
|
|
|
|
|
#### --rc-pass=VALUE ####
|
|
|
|
Password for authentication.
|
|
|
|
|
|
|
|
#### --rc-realm=VALUE ####
|
|
|
|
Realm for authentication (default "rclone")
|
|
|
|
|
|
|
|
#### --rc-server-read-timeout=DURATION ####
|
|
|
|
Timeout for server reading data (default 1h0m0s)
|
|
|
|
|
|
|
|
#### --rc-server-write-timeout=DURATION ####
|
|
|
|
Timeout for server writing data (default 1h0m0s)
|
2018-03-05 11:44:16 +00:00
|
|
|
|
|
|
|
## Accessing the remote control via the rclone rc command
|
|
|
|
|
|
|
|
Rclone itself implements the remote control protocol in its `rclone
|
|
|
|
rc` command.
|
|
|
|
|
|
|
|
You can use it like this
|
|
|
|
|
2018-03-16 20:45:34 +00:00
|
|
|
```
|
|
|
|
$ rclone rc rc/noop param1=one param2=two
|
|
|
|
{
|
|
|
|
"param1": "one",
|
|
|
|
"param2": "two"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Run `rclone rc` on its own to see the help for the installed remote
|
|
|
|
control commands.
|
|
|
|
|
|
|
|
## Supported commands
|
|
|
|
|
|
|
|
### cache/expire: Purge a remote from cache
|
|
|
|
|
|
|
|
Purge a remote from the cache backend. Supports either a directory or a file.
|
|
|
|
Params:
|
|
|
|
- remote = path to remote (required)
|
|
|
|
- withData = true/false to delete cached data (chunks) as well (optional)
|
|
|
|
|
|
|
|
### vfs/forget: Forget files or directories in the directory cache.
|
|
|
|
|
|
|
|
This forgets the paths in the directory cache causing them to be
|
|
|
|
re-read from the remote when needed.
|
|
|
|
|
|
|
|
If no paths are passed in then it will forget all the paths in the
|
|
|
|
directory cache.
|
|
|
|
|
|
|
|
rclone rc vfs/forget
|
|
|
|
|
|
|
|
Otherwise pass files or dirs in as file=path or dir=path. Any
|
|
|
|
parameter key starting with file will forget that file and any
|
|
|
|
starting with dir will forget that dir, eg
|
|
|
|
|
|
|
|
rclone rc vfs/forget file=hello file2=goodbye dir=home/junk
|
|
|
|
|
|
|
|
### rc/noop: Echo the input to the output parameters
|
|
|
|
|
|
|
|
This echoes the input parameters to the output parameters for testing
|
|
|
|
purposes. It can be used to check that rclone is still alive and to
|
|
|
|
check that parameter passing is working properly.
|
|
|
|
|
|
|
|
### rc/error: This returns an error
|
|
|
|
|
|
|
|
This returns an error with the input as part of its error string.
|
|
|
|
Useful for testing error handling.
|
|
|
|
|
|
|
|
### rc/list: List all the registered remote control commands
|
|
|
|
|
|
|
|
This lists all the registered remote control commands as a JSON map in
|
|
|
|
the commands response.
|
|
|
|
|
2018-03-05 11:44:16 +00:00
|
|
|
## Accessing the remote control via HTTP
|
|
|
|
|
|
|
|
Rclone implements a simple HTTP based protocol.
|
|
|
|
|
|
|
|
Each endpoint takes an JSON object and returns a JSON object or an
|
|
|
|
error. The JSON objects are essentially a map of string names to
|
|
|
|
values.
|
|
|
|
|
|
|
|
All calls must made using POST.
|
|
|
|
|
|
|
|
The input objects can be supplied using URL parameters, POST
|
|
|
|
parameters or by supplying "Content-Type: application/json" and a JSON
|
|
|
|
blob in the body. There are examples of these below using `curl`.
|
|
|
|
|
|
|
|
The response will be a JSON blob in the body of the response. This is
|
|
|
|
formatted to be reasonably human readable.
|
|
|
|
|
|
|
|
If an error occurs then there will be an HTTP error status (usually
|
|
|
|
400) and the body of the response will contain a JSON encoded error
|
|
|
|
object.
|
|
|
|
|
|
|
|
### Using POST with URL parameters only
|
|
|
|
|
|
|
|
```
|
|
|
|
curl -X POST 'http://localhost:5572/rc/noop/?potato=1&sausage=2'
|
|
|
|
```
|
|
|
|
|
|
|
|
Response
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"potato": "1",
|
|
|
|
"sausage": "2"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Here is what an error response looks like:
|
|
|
|
|
|
|
|
```
|
|
|
|
curl -X POST 'http://localhost:5572/rc/error/?potato=1&sausage=2'
|
|
|
|
```
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"error": "arbitrary error on input map[potato:1 sausage:2]",
|
|
|
|
"input": {
|
|
|
|
"potato": "1",
|
|
|
|
"sausage": "2"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that curl doesn't return errors to the shell unless you use the `-f` option
|
|
|
|
|
|
|
|
```
|
|
|
|
$ curl -f -X POST 'http://localhost:5572/rc/error/?potato=1&sausage=2'
|
|
|
|
curl: (22) The requested URL returned error: 400 Bad Request
|
|
|
|
$ echo $?
|
|
|
|
22
|
|
|
|
```
|
|
|
|
|
|
|
|
### Using POST with a form
|
|
|
|
|
|
|
|
```
|
|
|
|
curl --data "potato=1" --data "sausage=2" http://localhost:5572/rc/noop/
|
|
|
|
```
|
|
|
|
|
|
|
|
Response
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"potato": "1",
|
|
|
|
"sausage": "2"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that you can combine these with URL parameters too with the POST
|
|
|
|
parameters taking precedence.
|
|
|
|
|
|
|
|
```
|
|
|
|
curl --data "potato=1" --data "sausage=2" "http://localhost:5572/rc/noop/?rutabaga=3&sausage=4"
|
|
|
|
```
|
|
|
|
|
|
|
|
Response
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"potato": "1",
|
|
|
|
"rutabaga": "3",
|
|
|
|
"sausage": "4"
|
|
|
|
}
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
### Using POST with a JSON blob
|
|
|
|
|
|
|
|
```
|
|
|
|
curl -H "Content-Type: application/json" -X POST -d '{"potato":2,"sausage":1}' http://localhost:5572/rc/noop/
|
|
|
|
```
|
|
|
|
|
|
|
|
response
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"password": "xyz",
|
|
|
|
"username": "xyz"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
This can be combined with URL parameters too if required. The JSON
|
|
|
|
blob takes precedence.
|
|
|
|
|
|
|
|
```
|
|
|
|
curl -H "Content-Type: application/json" -X POST -d '{"potato":2,"sausage":1}' 'http://localhost:5572/rc/noop/?rutabaga=3&potato=4'
|
|
|
|
```
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"potato": 2,
|
|
|
|
"rutabaga": "3",
|
|
|
|
"sausage": 1
|
|
|
|
}
|
|
|
|
```
|