1
0
mirror of https://github.com/rclone/rclone.git synced 2025-01-13 20:38:12 +02:00
rclone/docs/content/yandex.md

205 lines
5.4 KiB
Markdown
Raw Normal View History

2015-12-30 14:45:43 +02:00
---
title: "Yandex"
description: "Yandex Disk"
---
2021-07-20 20:45:41 +02:00
# {{< icon "fa fa-space-shuttle" >}}Yandex Disk
2015-12-30 14:45:43 +02:00
[Yandex Disk](https://disk.yandex.com) is a cloud storage solution created by [Yandex](https://yandex.com).
2015-12-30 14:45:43 +02:00
## Configuration
2015-12-30 14:45:43 +02:00
Here is an example of making a yandex configuration. First run
rclone config
This will guide you through an interactive setup process:
```
No remotes found - make a new one
n) New remote
s) Set configuration password
n/s> n
2015-12-30 14:45:43 +02:00
name> remote
Type of storage to configure.
Choose a number from below, or type in your own value
[snip]
XX / Yandex Disk
\ "yandex"
[snip]
Storage> yandex
2015-12-30 14:45:43 +02:00
Yandex Client Id - leave blank normally.
client_id>
2015-12-30 14:45:43 +02:00
Yandex Client Secret - leave blank normally.
client_secret>
2015-12-30 14:45:43 +02:00
Remote config
Use auto config?
* Say Y if not sure
* Say N if you are working on a remote or headless machine
y) Yes
n) No
y/n> y
2015-12-30 14:45:43 +02:00
If your browser doesn't open automatically go to the following link: http://127.0.0.1:53682/auth
Log in and authorize rclone for access
Waiting for code...
Got code
--------------------
[remote]
client_id =
client_secret =
token = {"access_token":"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx","token_type":"OAuth","expiry":"2016-12-29T12:27:11.362788025Z"}
2015-12-30 14:45:43 +02:00
--------------------
y) Yes this is OK
e) Edit this remote
d) Delete this remote
y/e/d> y
```
See the [remote setup docs](/remote_setup/) for how to set it up on a
machine with no Internet browser available.
Note that rclone runs a webserver on your local machine to collect the
token as returned from Yandex Disk. This only runs from the moment it
opens your browser to the moment you get back the verification code.
This is on `http://127.0.0.1:53682/` and this it may require you to
unblock it temporarily if you are running a host firewall.
Once configured you can then use `rclone` like this,
2015-12-30 14:45:43 +02:00
See top level directories
rclone lsd remote:
Make a new directory
rclone mkdir remote:directory
List the contents of a directory
rclone ls remote:directory
Sync `/home/local/directory` to the remote path, deleting any
excess files in the path.
rclone sync -i /home/local/directory remote:directory
2015-12-30 14:45:43 +02:00
Yandex paths may be as deep as required, e.g. `remote:directory/subdirectory`.
2019-10-05 11:22:43 +02:00
### Modified time
2015-12-30 14:45:43 +02:00
Modified times are supported and are stored accurate to 1 ns in custom
metadata called `rclone_modified` in RFC3339 with nanoseconds format.
### MD5 checksums
2015-12-30 14:45:43 +02:00
MD5 checksums are natively supported by Yandex Disk.
### Emptying Trash
If you wish to empty your trash you can use the `rclone cleanup remote:`
command which will permanently delete all your trashed files. This command
does not take any path arguments.
### Quota information
2018-11-19 19:52:36 +02:00
To view your current quota you can use the `rclone about remote:`
command which will display your usage limit (quota) and the current usage.
### Restricted filename characters
2019-10-05 11:22:43 +02:00
The [default restricted characters set](/overview/#restricted-characters)
are replaced.
Invalid UTF-8 bytes will also be [replaced](/overview/#invalid-utf8),
as they can't be used in JSON strings.
{{< rem autogenerated options start" - DO NOT EDIT - instead edit fs.RegInfo in backend/yandex/yandex.go then run make backenddocs" >}}
### Standard Options
Here are the standard options specific to yandex (Yandex Disk).
#### --yandex-client-id
2020-09-02 17:59:04 +02:00
OAuth Client Id
Leave blank normally.
- Config: client_id
- Env Var: RCLONE_YANDEX_CLIENT_ID
- Type: string
- Default: ""
#### --yandex-client-secret
2020-09-02 17:59:04 +02:00
OAuth Client Secret
Leave blank normally.
- Config: client_secret
- Env Var: RCLONE_YANDEX_CLIENT_SECRET
- Type: string
- Default: ""
2018-11-24 15:44:25 +02:00
### Advanced Options
Here are the advanced options specific to yandex (Yandex Disk).
2020-09-02 17:59:04 +02:00
#### --yandex-token
2018-11-24 15:44:25 +02:00
2020-09-02 17:59:04 +02:00
OAuth Access Token as a JSON blob.
2018-11-24 15:44:25 +02:00
2020-09-02 17:59:04 +02:00
- Config: token
- Env Var: RCLONE_YANDEX_TOKEN
- Type: string
- Default: ""
#### --yandex-auth-url
Auth server URL.
Leave blank to use the provider defaults.
- Config: auth_url
- Env Var: RCLONE_YANDEX_AUTH_URL
- Type: string
- Default: ""
#### --yandex-token-url
Token server url.
Leave blank to use the provider defaults.
- Config: token_url
- Env Var: RCLONE_YANDEX_TOKEN_URL
- Type: string
- Default: ""
2018-11-24 15:44:25 +02:00
2020-02-01 12:31:42 +02:00
#### --yandex-encoding
This sets the encoding for the backend.
See: the [encoding section in the overview](/overview/#encoding) for more info.
- Config: encoding
- Env Var: RCLONE_YANDEX_ENCODING
- Type: MultiEncoder
- Default: Slash,Del,Ctl,InvalidUtf8,Dot
{{< rem autogenerated options stop >}}
## Limitations
When uploading very large files (bigger than about 5 GiB) you will need
to increase the `--timeout` parameter. This is because Yandex pauses
(perhaps to calculate the MD5SUM for the entire file) before returning
confirmation that the file has been uploaded. The default handling of
timeouts in rclone is to assume a 5 minute pause is an error and close
the connection - you'll see `net/http: timeout awaiting response
headers` errors in the logs if this is happening. Setting the timeout
to twice the max size of file in GiB should be enough, so if you want
to upload a 30 GiB file set a timeout of `2 * 30 = 60m`, that is
`--timeout 60m`.
Having a Yandex Mail account is mandatory to use the Yandex.Disk subscription.
Token generation will work without a mail account, but Rclone won't be able to complete any actions.
```
[403 - DiskUnsupportedUserAccountTypeError] User account type is not supported.
```