v1.62

PikPak

PikPak is a private cloud drive.

Paths are specified as remote:path, and may be as deep as required, e.g. remote:directory/subdirectory.

Configuration

Here is an example of making a remote for PikPak.

First run:

  1. rclone config

This will guide you through an interactive setup process:

  1. No remotes found, make a new one?
  2. n) New remote
  3. s) Set configuration password
  4. q) Quit config
  5. n/s/q> n
  6. Enter name for new remote.
  7. name> remote
  8. Option Storage.
  9. Type of storage to configure.
  10. Choose a number from below, or type in your own value.
  11. XX / PikPak
  12. \ (pikpak)
  13. Storage> XX
  14. Option user.
  15. Pikpak username.
  16. Enter a value.
  17. user> USERNAME
  18. Option pass.
  19. Pikpak password.
  20. Choose an alternative below.
  21. y) Yes, type in my own password
  22. g) Generate random password
  23. y/g> y
  24. Enter the password:
  25. password:
  26. Confirm the password:
  27. password:
  28. Edit advanced config?
  29. y) Yes
  30. n) No (default)
  31. y/n>
  32. Configuration complete.
  33. Options:
  34. - type: pikpak
  35. - user: USERNAME
  36. - pass: *** ENCRYPTED ***
  37. - token: {"access_token":"eyJ...","token_type":"Bearer","refresh_token":"os...","expiry":"2023-01-26T18:54:32.170582647+09:00"}
  38. Keep this "remote" remote?
  39. y) Yes this is OK (default)
  40. e) Edit this remote
  41. d) Delete this remote
  42. y/e/d> y

Modification times and hashes

PikPak keeps modification times on objects, and updates them when uploading objects, but it does not support changing only the modification time

The MD5 hash algorithm is supported.

Standard options

Here are the Standard options specific to pikpak (PikPak).

--pikpak-user

Pikpak username.

Properties:

  • Config: user
  • Env Var: RCLONE_PIKPAK_USER
  • Type: string
  • Required: true

--pikpak-pass

Pikpak password.

NB Input to this must be obscured - see rclone obscure.

Properties:

  • Config: pass
  • Env Var: RCLONE_PIKPAK_PASS
  • Type: string
  • Required: true

Advanced options

Here are the Advanced options specific to pikpak (PikPak).

--pikpak-device-id

Device ID used for authorization.

Properties:

  • Config: device_id
  • Env Var: RCLONE_PIKPAK_DEVICE_ID
  • Type: string
  • Required: false

--pikpak-user-agent

HTTP user agent for pikpak.

Defaults to “Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:129.0) Gecko/20100101 Firefox/129.0” or “—pikpak-user-agent” provided on command line.

Properties:

  • Config: user_agent
  • Env Var: RCLONE_PIKPAK_USER_AGENT
  • Type: string
  • Default: “Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:129.0) Gecko/20100101 Firefox/129.0”

--pikpak-root-folder-id

ID of the root folder. Leave blank normally.

Fill in for rclone to use a non root folder as its starting point.

Properties:

  • Config: root_folder_id
  • Env Var: RCLONE_PIKPAK_ROOT_FOLDER_ID
  • Type: string
  • Required: false

--pikpak-use-trash

Send files to the trash instead of deleting permanently.

Defaults to true, namely sending files to the trash. Use --pikpak-use-trash=false to delete files permanently instead.

Properties:

  • Config: use_trash
  • Env Var: RCLONE_PIKPAK_USE_TRASH
  • Type: bool
  • Default: true

--pikpak-trashed-only

Only show files that are in the trash.

This will show trashed files in their original directory structure.

Properties:

  • Config: trashed_only
  • Env Var: RCLONE_PIKPAK_TRASHED_ONLY
  • Type: bool
  • Default: false

Use original file links instead of media links.

This avoids issues caused by invalid media links, but may reduce download speeds.

Properties:

  • Config: no_media_link
  • Env Var: RCLONE_PIKPAK_NO_MEDIA_LINK
  • Type: bool
  • Default: false

--pikpak-hash-memory-limit

Files bigger than this will be cached on disk to calculate hash if required.

Properties:

  • Config: hash_memory_limit
  • Env Var: RCLONE_PIKPAK_HASH_MEMORY_LIMIT
  • Type: SizeSuffix
  • Default: 10Mi

--pikpak-chunk-size

Chunk size for multipart uploads.

Large files will be uploaded in chunks of this size.

Note that this is stored in memory and there may be up to “—transfers” * “—pikpak-upload-concurrency” chunks stored at once in memory.

If you are transferring large files over high-speed links and you have enough memory, then increasing this will speed up the transfers.

Rclone will automatically increase the chunk size when uploading a large file of known size to stay below the 10,000 chunks limit.

Increasing the chunk size decreases the accuracy of the progress statistics displayed with “-P” flag.

Properties:

  • Config: chunk_size
  • Env Var: RCLONE_PIKPAK_CHUNK_SIZE
  • Type: SizeSuffix
  • Default: 5Mi

--pikpak-upload-concurrency

Concurrency for multipart uploads.

This is the number of chunks of the same file that are uploaded concurrently for multipart uploads.

Note that chunks are stored in memory and there may be up to “—transfers” * “—pikpak-upload-concurrency” chunks stored at once in memory.

If you are uploading small numbers of large files over high-speed links and these uploads do not fully utilize your bandwidth, then increasing this may help to speed up the transfers.

Properties:

  • Config: upload_concurrency
  • Env Var: RCLONE_PIKPAK_UPLOAD_CONCURRENCY
  • Type: int
  • Default: 5

--pikpak-encoding

The encoding for the backend.

See the encoding section in the overview for more info.

Properties:

  • Config: encoding
  • Env Var: RCLONE_PIKPAK_ENCODING
  • Type: Encoding
  • Default: Slash,LtGt,DoubleQuote,Colon,Question,Asterisk,Pipe,BackSlash,Ctl,LeftSpace,RightSpace,RightPeriod,InvalidUtf8,Dot

--pikpak-description

Description of the remote.

Properties:

  • Config: description
  • Env Var: RCLONE_PIKPAK_DESCRIPTION
  • Type: string
  • Required: false

Backend commands

Here are the commands specific to the pikpak backend.

Run them with

  1. rclone backend COMMAND remote:

The help below will explain what arguments each command takes.

See the backend command for more info on how to pass options and arguments.

These can be run on a running backend using the rc command backend/command.

addurl

Add offline download task for url

  1. rclone backend addurl remote: [options] [<arguments>+]

This command adds offline download task for url.

Usage:

  1. rclone backend addurl pikpak:dirpath url

Downloads will be stored in ‘dirpath’. If ‘dirpath’ is invalid, download will fallback to default ‘My Pack’ folder.

decompress

Request decompress of a file/files in a folder

  1. rclone backend decompress remote: [options] [<arguments>+]

This command requests decompress of file/files in a folder.

Usage:

  1. rclone backend decompress pikpak:dirpath {filename} -o password=password
  2. rclone backend decompress pikpak:dirpath {filename} -o delete-src-file

An optional argument ‘filename’ can be specified for a file located in ‘pikpak:dirpath’. You may want to pass ‘-o password=password’ for a password-protected files. Also, pass ‘-o delete-src-file’ to delete source files after decompression finished.

Result:

  1. {
  2. "Decompressed": 17,
  3. "SourceDeleted": 0,
  4. "Errors": 0
  5. }

Limitations

Hashes may be empty

PikPak supports MD5 hash, but sometimes given empty especially for user-uploaded files.

Deleted files still visible with trashed-only

Deleted files will still be visible with --pikpak-trashed-only even after the trash emptied. This goes away after few days.