v1.68

Gofile

Gofile is a content storage and distribution platform. Its aim is to provide as much service as possible for free or at a very low price.

The initial setup for Gofile involves logging in to the web interface and going to the “My Profile” section. Copy the “Account API token” for use in the config file.

Note that if you wish to connect rclone to Gofile you will need a premium account.

Configuration

Here is an example of how to make a remote called remote. 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 / Gofile
  12. \ (gofile)
  13. Storage> gofile
  14. Option access_token.
  15. API Access token
  16. You can get this from the web control panel.
  17. Enter a value. Press Enter to leave empty.
  18. access_token> YOURACCESSTOKEN
  19. Edit advanced config?
  20. y) Yes
  21. n) No (default)
  22. y/n> n
  23. Configuration complete.
  24. Options:
  25. - type: gofile
  26. - access_token: YOURACCESSTOKEN
  27. Keep this "remote" remote?
  28. y) Yes this is OK (default)
  29. e) Edit this remote
  30. d) Delete this remote
  31. y/e/d> y

Once configured you can then use rclone like this,

List directories and files in the top level of your Gofile

  1. rclone lsf remote:

To copy a local directory to an Gofile directory called backup

  1. rclone copy /home/source remote:backup

Modification times and hashes

Gofile supports modification times with a resolution of 1 second.

Gofile supports MD5 hashes, so you can use the --checksum flag.

Restricted filename characters

In addition to the default restricted characters set the following characters are also replaced:

CharacterValueReplacement
!0x21
0x22
*0x2A
:0x3A
<0x3C
>0x3E
?0x3F
\0x5C
|0x7C

File names can also not start or end with the following characters. These only get replaced if they are the first or last character in the name:

CharacterValueReplacement
.0x2E

Invalid UTF-8 bytes will also be replaced, as they can’t be used in JSON strings.

Gofile supports rclone link to make public links to files or directories. If you specify a directory it will download as a zip file. You can use the --expire flag to specify the time the link should be valid. Note that rclone link --unlink removes all the public links for a file.

Root folder ID

You can set the root_folder_id for rclone. This is the directory (identified by its Folder ID) that rclone considers to be the root of your Gofile drive.

Normally you will leave this blank and rclone will determine the correct root to use itself and fill in the value in the config file.

However you can set this to restrict rclone to a specific folder hierarchy.

In order to do this you will have to find the Folder ID of the directory you wish rclone to display.

You can do this with rclone

  1. $ rclone lsf -Fip --dirs-only remote:
  2. d6341f53-ee65-4f29-9f59-d11e8070b2a0;Files/
  3. f4f5c9b8-6ece-478b-b03e-4538edfe5a1c;Photos/
  4. d50e356c-29ca-4b27-a3a7-494d91026e04;Videos/

The ID to use is the part before the ; so you could set

  1. root_folder_id = d6341f53-ee65-4f29-9f59-d11e8070b2a0

To restrict rclone to the Files directory.

Standard options

Here are the Standard options specific to gofile (Gofile).

--gofile-access-token

API Access token

You can get this from the web control panel.

Properties:

  • Config: access_token
  • Env Var: RCLONE_GOFILE_ACCESS_TOKEN
  • Type: string
  • Required: false

Advanced options

Here are the Advanced options specific to gofile (Gofile).

--gofile-root-folder-id

ID of the root folder

Leave this blank normally, rclone will fill it in automatically.

If you want rclone to be restricted to a particular folder you can fill it in - see the docs for more info.

Properties:

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

--gofile-account-id

Account ID

Leave this blank normally, rclone will fill it in automatically.

Properties:

  • Config: account_id
  • Env Var: RCLONE_GOFILE_ACCOUNT_ID
  • Type: string
  • Required: false

--gofile-list-chunk

Number of items to list in each call

Properties:

  • Config: list_chunk
  • Env Var: RCLONE_GOFILE_LIST_CHUNK
  • Type: int
  • Default: 1000

--gofile-encoding

The encoding for the backend.

See the encoding section in the overview for more info.

Properties:

  • Config: encoding
  • Env Var: RCLONE_GOFILE_ENCODING
  • Type: Encoding
  • Default: Slash,LtGt,DoubleQuote,Colon,Question,Asterisk,Pipe,BackSlash,Del,Ctl,LeftPeriod,RightPeriod,InvalidUtf8,Dot,Exclamation

--gofile-description

Description of the remote.

Properties:

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

Limitations

Gofile only supports filenames up to 255 characters in length, where a character is a unicode character.

Directories should not be cached for more than 24h otherwise files in the directory may not be downloadable. In practice this means when using a VFS based rclone command such as rclone mount you should make sure --dir-cache-time is less than 24h.

Note that Gofile is currently limited to a total of 100,000 items. If you attempt to upload more than that you will get error-limit-100000. This limit may be lifted in the future.

Duplicated files

Gofile is capable of having files with duplicated file names. For instance two files called hello.txt in the same directory.

Rclone cannot sync that to a normal file system but it can be fixed with the rclone dedupe command.

Duplicated files cause problems with the syncing and you will see messages in the log about duplicates.

Use rclone dedupe to fix duplicated files.