2021-12-07 20:24:58 +01:00
|
|
|
# transfer.sh [![Go Report Card](https://goreportcard.com/badge/github.com/dutchcoders/transfer.sh)](https://goreportcard.com/report/github.com/dutchcoders/transfer.sh) [![Docker pulls](https://img.shields.io/docker/pulls/dutchcoders/transfer.sh.svg)](https://hub.docker.com/r/dutchcoders/transfer.sh/) [![Build Status](https://github.com/dutchcoders/transfer.sh/actions/workflows/test.yml/badge.svg?branch=main)](https://github.com/dutchcoders/transfer.sh/actions/workflows/test.yml?query=branch%3Amain)
|
2014-10-16 20:01:43 +02:00
|
|
|
|
2014-10-20 14:54:42 +02:00
|
|
|
Easy and fast file sharing from the command-line. This code contains the server with everything you need to create your own instance.
|
|
|
|
|
2021-02-21 18:21:42 +01:00
|
|
|
Transfer.sh currently supports the s3 (Amazon S3), gdrive (Google Drive), storj (Storj) providers, and local file system (local).
|
2014-10-16 20:01:43 +02:00
|
|
|
|
2019-05-08 09:13:28 +02:00
|
|
|
## Disclaimer
|
2019-05-08 09:12:40 +02:00
|
|
|
|
2021-07-18 10:40:13 +02:00
|
|
|
The service at transfersh.com is of unknown origin and reported as cloud malware.
|
2021-01-06 13:22:48 +01:00
|
|
|
|
2014-10-16 20:08:40 +02:00
|
|
|
## Usage
|
|
|
|
|
2018-08-13 22:14:54 +02:00
|
|
|
### Upload:
|
|
|
|
```bash
|
2014-10-16 20:08:40 +02:00
|
|
|
$ curl --upload-file ./hello.txt https://transfer.sh/hello.txt
|
2018-08-13 22:14:54 +02:00
|
|
|
```
|
2014-10-16 20:08:40 +02:00
|
|
|
|
2021-10-03 03:56:17 +02:00
|
|
|
### Encrypt & Upload:
|
2018-08-13 22:14:54 +02:00
|
|
|
```bash
|
2014-10-16 20:08:40 +02:00
|
|
|
$ cat /tmp/hello.txt|gpg -ac -o-|curl -X PUT --upload-file "-" https://transfer.sh/test.txt
|
2018-08-13 22:14:54 +02:00
|
|
|
````
|
2014-10-16 20:08:40 +02:00
|
|
|
|
2021-10-03 03:56:17 +02:00
|
|
|
### Download & Decrypt:
|
2018-08-13 22:14:54 +02:00
|
|
|
```bash
|
2014-10-16 20:08:40 +02:00
|
|
|
$ curl https://transfer.sh/1lDau/test.txt|gpg -o- > /tmp/hello.txt
|
2018-08-13 22:14:54 +02:00
|
|
|
```
|
2014-10-16 20:08:40 +02:00
|
|
|
|
2021-10-03 03:56:17 +02:00
|
|
|
### Upload to Virustotal:
|
2018-08-13 22:14:54 +02:00
|
|
|
```bash
|
2014-10-16 20:08:40 +02:00
|
|
|
$ curl -X PUT --upload-file nhgbhhj https://transfer.sh/test.txt/virustotal
|
2017-04-25 00:01:39 +02:00
|
|
|
```
|
2018-08-13 22:14:54 +02:00
|
|
|
|
2019-05-11 23:49:16 +02:00
|
|
|
### Deleting
|
|
|
|
```bash
|
|
|
|
$ curl -X DELETE <X-Url-Delete Response Header URL>
|
|
|
|
```
|
|
|
|
|
|
|
|
## Request Headers
|
|
|
|
|
|
|
|
### Max-Downloads
|
|
|
|
```bash
|
|
|
|
$ curl --upload-file ./hello.txt https://transfer.sh/hello.txt -H "Max-Downloads: 1" # Limit the number of downloads
|
|
|
|
```
|
|
|
|
|
|
|
|
### Max-Days
|
|
|
|
```bash
|
|
|
|
$ curl --upload-file ./hello.txt https://transfer.sh/hello.txt -H "Max-Days: 1" # Set the number of days before deletion
|
|
|
|
```
|
|
|
|
|
|
|
|
## Response Headers
|
|
|
|
|
|
|
|
### X-Url-Delete
|
|
|
|
|
2021-10-08 10:55:56 +02:00
|
|
|
The URL used to request the deletion of a file and returned as a response header.
|
2019-05-11 23:49:16 +02:00
|
|
|
```bash
|
|
|
|
curl -sD - --upload-file ./hello https://transfer.sh/hello.txt | grep 'X-Url-Delete'
|
|
|
|
X-Url-Delete: https://transfer.sh/hello.txt/BAYh0/hello.txt/PDw0NHPcqU
|
|
|
|
```
|
|
|
|
|
2019-08-23 22:10:41 +02:00
|
|
|
## Examples
|
2018-08-13 22:14:54 +02:00
|
|
|
|
2019-08-23 22:10:41 +02:00
|
|
|
See good usage examples on [examples.md](examples.md)
|
2017-10-11 10:21:10 +02:00
|
|
|
|
2018-08-13 22:14:54 +02:00
|
|
|
## Link aliases
|
|
|
|
|
|
|
|
Create direct download link:
|
|
|
|
|
|
|
|
https://transfer.sh/1lDau/test.txt --> https://transfer.sh/get/1lDau/test.txt
|
|
|
|
|
|
|
|
Inline file:
|
|
|
|
|
|
|
|
https://transfer.sh/1lDau/test.txt --> https://transfer.sh/inline/1lDau/test.txt
|
|
|
|
|
2017-03-22 22:44:56 +01:00
|
|
|
## Usage
|
2014-10-16 20:01:43 +02:00
|
|
|
|
2017-03-22 22:50:17 +01:00
|
|
|
Parameter | Description | Value | Env
|
|
|
|
--- | --- | --- | ---
|
2020-05-03 15:28:59 +02:00
|
|
|
listener | port to use for http (:80) | | LISTENER |
|
|
|
|
profile-listener | port to use for profiler (:6060) | | PROFILE_LISTENER |
|
|
|
|
force-https | redirect to https | false | FORCE_HTTPS
|
|
|
|
tls-listener | port to use for https (:443) | | TLS_LISTENER |
|
|
|
|
tls-listener-only | flag to enable tls listener only | | TLS_LISTENER_ONLY |
|
|
|
|
tls-cert-file | path to tls certificate | | TLS_CERT_FILE |
|
|
|
|
tls-private-key | path to tls private key | | TLS_PRIVATE_KEY |
|
|
|
|
http-auth-user | user for basic http auth on upload | | HTTP_AUTH_USER |
|
|
|
|
http-auth-pass | pass for basic http auth on upload | | HTTP_AUTH_PASS |
|
|
|
|
ip-whitelist | comma separated list of ips allowed to connect to the service | | IP_WHITELIST |
|
|
|
|
ip-blacklist | comma separated list of ips not allowed to connect to the service | | IP_BLACKLIST |
|
|
|
|
temp-path | path to temp folder | system temp | TEMP_PATH |
|
|
|
|
web-path | path to static web files (for development or custom front end) | | WEB_PATH |
|
|
|
|
proxy-path | path prefix when service is run behind a proxy | | PROXY_PATH |
|
2020-05-03 11:19:32 +02:00
|
|
|
proxy-port | port of the proxy when the service is run behind a proxy | | PROXY_PORT |
|
2021-12-15 21:06:54 +01:00
|
|
|
email-contact | email contact for the front end | | EMAIL_CONTACT |
|
2020-05-03 15:28:59 +02:00
|
|
|
ga-key | google analytics key for the front end | | GA_KEY |
|
2019-12-01 18:19:29 +01:00
|
|
|
provider | which storage provider to use | (s3, storj, gdrive or local) |
|
2020-05-03 15:28:59 +02:00
|
|
|
uservoice-key | user voice key for the front end | | USERVOICE_KEY |
|
|
|
|
aws-access-key | aws access key | | AWS_ACCESS_KEY |
|
|
|
|
aws-secret-key | aws access key | | AWS_SECRET_KEY |
|
|
|
|
bucket | aws bucket | | BUCKET |
|
|
|
|
s3-endpoint | Custom S3 endpoint. | | S3_ENDPOINT |
|
|
|
|
s3-region | region of the s3 bucket | eu-west-1 | S3_REGION |
|
|
|
|
s3-no-multipart | disables s3 multipart upload | false | S3_NO_MULTIPART |
|
|
|
|
s3-path-style | Forces path style URLs, required for Minio. | false | S3_PATH_STYLE |
|
2020-12-15 16:42:12 +01:00
|
|
|
storj-access | Access for the project | | STORJ_ACCESS |
|
|
|
|
storj-bucket | Bucket to use within the project | | STORJ_BUCKET |
|
2020-05-03 15:28:59 +02:00
|
|
|
basedir | path storage for local/gdrive provider | | BASEDIR |
|
|
|
|
gdrive-client-json-filepath | path to oauth client json config for gdrive provider | | GDRIVE_CLIENT_JSON_FILEPATH |
|
|
|
|
gdrive-local-config-path | path to store local transfer.sh config cache for gdrive provider| | GDRIVE_LOCAL_CONFIG_PATH |
|
|
|
|
gdrive-chunk-size | chunk size for gdrive upload in megabytes, must be lower than available memory (8 MB) | | GDRIVE_CHUNK_SIZE |
|
|
|
|
lets-encrypt-hosts | hosts to use for lets encrypt certificates (comma seperated) | | HOSTS |
|
|
|
|
log | path to log file| | LOG |
|
|
|
|
cors-domains | comma separated list of domains for CORS, setting it enable CORS | | CORS_DOMAINS |
|
|
|
|
clamav-host | host for clamav feature | | CLAMAV_HOST |
|
2022-01-09 22:14:10 +01:00
|
|
|
perform-clamav-prescan | prescan every upload through clamav feature (clamav-host must be a local clamd unix socket) | | PERFORM_CLAMAV_PRESCAN |
|
2020-05-03 15:28:59 +02:00
|
|
|
rate-limit | request per minute | | RATE_LIMIT |
|
2020-12-31 20:08:42 +01:00
|
|
|
max-upload-size | max upload size in kilobytes | | MAX_UPLOAD_SIZE |
|
2021-01-05 17:23:47 +01:00
|
|
|
purge-days | number of days after the uploads are purged automatically | | PURGE_DAYS |
|
|
|
|
purge-interval | interval in hours to run the automatic purge for (not applicable to S3 and Storj) | | PURGE_INTERVAL |
|
2021-05-20 08:26:07 +02:00
|
|
|
random-token-length | length of the random token for the upload path (double the size for delete path) | 6 | RANDOM_TOKEN_LENGTH |
|
2017-03-22 22:44:56 +01:00
|
|
|
|
|
|
|
If you want to use TLS using lets encrypt certificates, set lets-encrypt-hosts to your domain, set tls-listener to :443 and enable force-https.
|
|
|
|
|
2020-03-23 09:22:58 +01:00
|
|
|
If you want to use TLS using your own certificates, set tls-listener to :443, force-https, tls-cert-file and tls-private-key.
|
2014-10-16 20:48:07 +02:00
|
|
|
|
2017-03-22 22:44:56 +01:00
|
|
|
## Development
|
2014-10-16 20:48:07 +02:00
|
|
|
|
2019-05-11 14:42:59 +02:00
|
|
|
Switched to GO111MODULE
|
2014-10-16 20:48:07 +02:00
|
|
|
|
2018-08-13 22:14:54 +02:00
|
|
|
```bash
|
2018-10-26 23:28:47 +02:00
|
|
|
go run main.go --provider=local --listener :8080 --temp-path=/tmp/ --basedir=/tmp/
|
2014-10-16 20:48:07 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
## Build
|
2014-10-16 20:08:40 +02:00
|
|
|
|
2019-05-11 14:42:59 +02:00
|
|
|
```bash
|
2020-09-19 12:40:52 +02:00
|
|
|
$ git clone git@github.com:dutchcoders/transfer.sh.git
|
|
|
|
$ cd transfer.sh
|
|
|
|
$ go build -o transfersh main.go
|
2014-10-16 20:48:07 +02:00
|
|
|
```
|
2014-10-16 20:08:40 +02:00
|
|
|
|
2014-11-13 21:41:43 +01:00
|
|
|
## Docker
|
|
|
|
|
2022-04-03 14:55:15 +02:00
|
|
|
For easy deployment, we've created an official Docker container. There are two variants, differing only by which user runs the process.
|
|
|
|
|
|
|
|
The default one will run as `root`:
|
2014-11-13 21:41:43 +01:00
|
|
|
|
2018-08-13 22:14:54 +02:00
|
|
|
```bash
|
2017-03-22 22:44:56 +01:00
|
|
|
docker run --publish 8080:8080 dutchcoders/transfer.sh:latest --provider local --basedir /tmp/
|
2014-11-13 21:41:43 +01:00
|
|
|
```
|
|
|
|
|
2022-04-03 14:55:15 +02:00
|
|
|
The one tagged with the suffix `-noroot` will use `5000` as both UID and GID:
|
|
|
|
```bash
|
|
|
|
docker run --publish 8080:8080 dutchcoders/transfer.sh:latest-noroot --provider local --basedir /tmp/
|
|
|
|
```
|
|
|
|
|
|
|
|
### Building the Container
|
|
|
|
You can also build the container yourself. This allows you to choose which UID/GID will be used, e.g. when using NFS mounts:
|
|
|
|
```bash
|
|
|
|
# Build arguments:
|
|
|
|
# * RUNAS: If empty, the container will run as root.
|
|
|
|
# Set this to anything to enable UID/GID selection.
|
|
|
|
# * PUID: UID of the process. Needs RUNAS != "". Defaults to 5000.
|
|
|
|
# * PGID: GID of the process. Needs RUNAS != "". Defaults to 5000.
|
|
|
|
|
|
|
|
docker build -t transfer.sh-noroot --build-arg RUNAS=doesntmatter --build-arg PUID=1337 --build-arg PGID=1338 .
|
|
|
|
```
|
|
|
|
|
2019-06-23 20:48:52 +02:00
|
|
|
## S3 Usage
|
|
|
|
|
|
|
|
For the usage with a AWS S3 Bucket, you just need to specify the following options:
|
|
|
|
- provider
|
|
|
|
- aws-access-key
|
|
|
|
- aws-secret-key
|
|
|
|
- bucket
|
|
|
|
- s3-region
|
|
|
|
|
|
|
|
If you specify the s3-region, you don't need to set the endpoint URL since the correct endpoint will used automatically.
|
|
|
|
|
|
|
|
### Custom S3 providers
|
|
|
|
|
2019-12-01 18:40:03 +01:00
|
|
|
To use a custom non-AWS S3 provider, you need to specify the endpoint as defined from your cloud provider.
|
|
|
|
|
|
|
|
## Storj Network Provider
|
|
|
|
|
2021-10-08 10:55:56 +02:00
|
|
|
To use the Storj Network as a storage provider you need to specify the following flags:
|
2019-12-01 18:40:03 +01:00
|
|
|
- provider `--provider storj`
|
2020-03-06 15:43:14 +01:00
|
|
|
- storj-access _(either via flag or environment variable STORJ_ACCESS)_
|
2019-12-01 18:40:03 +01:00
|
|
|
- storj-bucket _(either via flag or environment variable STORJ_BUCKET)_
|
|
|
|
|
|
|
|
### Creating Bucket and Scope
|
|
|
|
|
2021-10-08 10:55:56 +02:00
|
|
|
You need to create an access grant (or copy it from the uplink configuration) and a bucket in preparation.
|
2019-12-01 18:40:03 +01:00
|
|
|
|
2021-10-08 10:55:56 +02:00
|
|
|
To get started, log in to your account and go to the Access Grant Menu and start the Wizard on the upper right.
|
2019-12-01 18:40:03 +01:00
|
|
|
|
2021-02-21 18:21:42 +01:00
|
|
|
Enter your access grant name of choice, hit *Next* and restrict it as necessary/preferred.
|
2021-10-08 10:55:56 +02:00
|
|
|
Afterwards continue either in CLI or within the Browser. Next, you'll be asked for a Passphrase used as Encryption Key.
|
|
|
|
**Make sure to save it in a safe place. Without it, you will lose the ability to decrypt your files!**
|
2019-12-01 18:40:03 +01:00
|
|
|
|
2021-10-08 10:55:56 +02:00
|
|
|
Afterwards, you can copy the access grant and then start the startup of the transfer.sh endpoint.
|
|
|
|
It is recommended to provide both the access grant and the bucket name as ENV Variables for enhanced security.
|
2019-12-01 18:40:03 +01:00
|
|
|
|
|
|
|
Example:
|
|
|
|
```
|
2021-02-21 18:21:42 +01:00
|
|
|
export STORJ_BUCKET=<BUCKET NAME>
|
|
|
|
export STORJ_ACCESS=<ACCESS GRANT>
|
2020-03-06 15:43:14 +01:00
|
|
|
transfer.sh --provider storj
|
2019-12-01 18:40:03 +01:00
|
|
|
```
|
2019-06-23 20:48:52 +02:00
|
|
|
|
2019-11-14 02:58:21 +01:00
|
|
|
## Google Drive Usage
|
|
|
|
|
|
|
|
For the usage with Google drive, you need to specify the following options:
|
|
|
|
- provider
|
|
|
|
- gdrive-client-json-filepath
|
|
|
|
- gdrive-local-config-path
|
|
|
|
- basedir
|
|
|
|
|
|
|
|
### Creating Gdrive Client Json
|
|
|
|
|
2021-10-08 10:55:56 +02:00
|
|
|
You need to create an OAuth Client id from console.cloud.google.com, download the file, and place it into a safe directory.
|
2019-11-14 02:58:21 +01:00
|
|
|
|
|
|
|
### Usage example
|
|
|
|
|
|
|
|
```go run main.go --provider gdrive --basedir /tmp/ --gdrive-client-json-filepath /[credential_dir] --gdrive-local-config-path [directory_to_save_config] ```
|
|
|
|
|
2022-04-03 06:17:51 +02:00
|
|
|
## Shell functions
|
|
|
|
|
|
|
|
### Bash and zsh (multiple files uploaded as zip archive)
|
|
|
|
##### Add this to .bashrc or .zshrc or its equivalent
|
|
|
|
```bash
|
|
|
|
transfer(){ if [ $# -eq 0 ];then echo "No arguments specified.\nUsage:\n transfer <file|directory>\n ... | transfer <file_name>">&2;return 1;fi;if tty -s;then file="$1";file_name=$(basename "$file");if [ ! -e "$file" ];then echo "$file: No such file or directory">&2;return 1;fi;if [ -d "$file" ];then file_name="$file_name.zip" ,;(cd "$file"&&zip -r -q - .)|curl --progress-bar --upload-file "-" "https://transfer.sh/$file_name"|tee /dev/null,;else cat "$file"|curl --progress-bar --upload-file "-" "https://transfer.sh/$file_name"|tee /dev/null;fi;else file_name=$1;curl --progress-bar --upload-file "-" "https://transfer.sh/$file_name"|tee /dev/null;fi;}
|
|
|
|
```
|
|
|
|
|
|
|
|
#### Now you can use transfer function
|
|
|
|
```
|
|
|
|
$ transfer hello.txt
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
### Zsh (with delete url outpu)
|
|
|
|
##### Add this to .zshrc or its equivalent
|
|
|
|
```bash
|
|
|
|
transfer()
|
|
|
|
{
|
|
|
|
local file="${1}"
|
|
|
|
local filename="${file##*/}"
|
|
|
|
# show delete link from the response header after upload. the command "sed" is necessary to clean up the output, "gsub()" in "awk" does not work.
|
|
|
|
curl --request PUT --progress-bar --dump-header - --upload-file "${file}" "https://transfer.sh/${filename}" | sed "s/#//g" | awk '/x-url-delete/ { print "Delete command: curl --request DELETE " $2 } END{ print "Download link: " $1 }'
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
#### Sample ouput
|
|
|
|
```bash
|
|
|
|
$ transfer image.img
|
|
|
|
######################################################################################################################################################################################################################################## 100.0%
|
|
|
|
Delete command: curl --request DELETE https://transfer.sh/Ge9cuW/image.img/<some_delete_token>
|
|
|
|
Download link: https://transfer.sh/Ge9cuW/image.img
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2014-10-16 20:08:40 +02:00
|
|
|
## Contributions
|
|
|
|
|
|
|
|
Contributions are welcome.
|
|
|
|
|
2018-08-13 08:56:08 +02:00
|
|
|
## Creators
|
2014-10-16 20:08:40 +02:00
|
|
|
|
|
|
|
**Remco Verhoef**
|
|
|
|
- <https://twitter.com/remco_verhoef>
|
|
|
|
- <https://twitter.com/dutchcoders>
|
|
|
|
|
|
|
|
**Uvis Grinfelds**
|
|
|
|
|
2018-10-27 00:15:55 +02:00
|
|
|
## Maintainer
|
|
|
|
|
|
|
|
**Andrea Spacca**
|
|
|
|
|
2021-02-16 23:36:32 +01:00
|
|
|
**Stefan Benten**
|
|
|
|
|
2021-10-03 03:56:17 +02:00
|
|
|
## Copyright and License
|
2014-10-16 20:08:40 +02:00
|
|
|
|
2018-08-13 22:14:54 +02:00
|
|
|
Code and documentation copyright 2011-2018 Remco Verhoef.
|
2021-07-10 20:20:19 +02:00
|
|
|
Code and documentation copyright 2018-2020 Andrea Spacca.
|
|
|
|
Code and documentation copyright 2020- Andrea Spacca and Stefan Benten.
|
|
|
|
|
2018-08-13 08:56:08 +02:00
|
|
|
Code released under [the MIT license](LICENSE).
|