2017-03-22 22:48:08 +01:00
|
|
|
# transfer.sh [![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/dutchcoders/transfer.sh?utm_source=badge&utm_medium=badge&utm_campaign=&utm_campaign=pr-badge&utm_content=badge) [![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://travis-ci.org/dutchcoders/transfer.sh.svg?branch=master)](https://travis-ci.org/dutchcoders/transfer.sh)
|
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.
|
|
|
|
|
2018-06-19 15:30:26 +02:00
|
|
|
Transfer.sh support currently the s3 (Amazon S3) and gdrive (Google Drive) providers and local file system (local).
|
2014-10-16 20:01:43 +02:00
|
|
|
|
2014-10-16 20:08:40 +02:00
|
|
|
## Usage
|
|
|
|
|
|
|
|
```
|
|
|
|
Upload:
|
|
|
|
$ curl --upload-file ./hello.txt https://transfer.sh/hello.txt
|
|
|
|
|
|
|
|
Encrypt & upload:
|
|
|
|
$ cat /tmp/hello.txt|gpg -ac -o-|curl -X PUT --upload-file "-" https://transfer.sh/test.txt
|
|
|
|
|
|
|
|
Download & decrypt:
|
|
|
|
$ curl https://transfer.sh/1lDau/test.txt|gpg -o- > /tmp/hello.txt
|
|
|
|
|
|
|
|
Upload to virustotal:
|
|
|
|
$ curl -X PUT --upload-file nhgbhhj https://transfer.sh/test.txt/virustotal
|
|
|
|
|
2017-04-25 00:01:39 +02:00
|
|
|
```
|
|
|
|
## Add alias to .bashrc or .zshrc
|
|
|
|
```
|
2014-10-16 20:08:40 +02:00
|
|
|
transfer() {
|
2018-06-24 23:33:27 +02:00
|
|
|
curl --progress-bar --upload-file $1 https://transfer.sh/$(basename $1) | tee /dev/null;
|
2014-10-16 20:08:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
alias transfer=transfer
|
2017-04-25 00:01:39 +02:00
|
|
|
```
|
|
|
|
Now run it like this
|
|
|
|
```
|
2014-10-16 20:08:40 +02:00
|
|
|
$ transfer test.txt
|
|
|
|
```
|
|
|
|
|
2017-10-11 10:21:10 +02:00
|
|
|
### On Windows
|
|
|
|
|
2018-06-18 08:40:09 +02:00
|
|
|
Put a file called transfer.cmd somewhere in your PATH with this inside it:
|
2017-10-11 10:21:10 +02:00
|
|
|
```
|
|
|
|
@echo off
|
|
|
|
setlocal
|
2018-06-18 08:36:44 +02:00
|
|
|
:: use env vars to pass names to PS, to avoid escaping issues
|
|
|
|
set FN=%~nx1
|
|
|
|
set FULL=%1
|
|
|
|
powershell -noprofile -command "$(Invoke-Webrequest -Method put -Infile $Env:FULL https://transfer.sh/$Env:FN).Content"
|
2017-10-11 10:21:10 +02:00
|
|
|
```
|
|
|
|
|
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
|
|
|
|
--- | --- | --- | ---
|
|
|
|
listener | port to use for http (:80) | |
|
|
|
|
profile-listener | port to use for profiler (:6060)| |
|
|
|
|
force-https | redirect to https | false |
|
|
|
|
tls-listener | port to use for https (:443) | |
|
|
|
|
tls-cert-file | path to tls certificate | |
|
|
|
|
tls-private-key | path to tls private key | |
|
2018-06-23 18:46:28 +02:00
|
|
|
http-auth-user | user for basic http auth on upload | |
|
|
|
|
http-auth-pass | pass for basic http auth on upload | |
|
2017-03-22 22:50:17 +01:00
|
|
|
temp-path | path to temp folder | system temp |
|
|
|
|
web-path | path to static web files (for development) | |
|
2018-06-26 18:39:56 +02:00
|
|
|
ga-key | google analytics key for the front end | |
|
|
|
|
uservoice-key | user voice key for the front end | |
|
2018-06-19 15:30:26 +02:00
|
|
|
provider | which storage provider to use | (s3, grdrive or local) |
|
2017-03-22 22:44:56 +01:00
|
|
|
aws-access-key | aws access key | | AWS_ACCESS_KEY
|
|
|
|
aws-secret-key | aws access key | | AWS_SECRET_KEY
|
|
|
|
bucket | aws bucket | | BUCKET
|
2018-06-19 15:30:26 +02:00
|
|
|
basedir | path storage for local/gdrive provider| |
|
|
|
|
gdrive-client-json-filepath | path to client json config for gdrive provider| |
|
|
|
|
gdrive-local-config-path | path to local transfer.sh config cache for gdrive provider| |
|
|
|
|
lets-encrypt-hosts | hosts to use for lets encrypt certificates (comma seperated) | |
|
2017-03-22 22:44:56 +01:00
|
|
|
log | path to log file| |
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
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
|
|
|
|
2017-03-22 22:44:56 +01:00
|
|
|
Make sure your GOPATH is set correctly.
|
2014-10-16 20:48:07 +02:00
|
|
|
|
2017-03-22 22:44:56 +01: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
|
|
|
|
2014-10-16 20:48:07 +02:00
|
|
|
```
|
2017-03-22 22:44:56 +01:00
|
|
|
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
|
|
|
|
|
2017-03-22 22:48:08 +01:00
|
|
|
For easy deployment we've created a Docker container.
|
2014-11-13 21:41:43 +01:00
|
|
|
|
|
|
|
```
|
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
|
|
|
```
|
|
|
|
|
2014-10-16 20:08:40 +02:00
|
|
|
## Contributions
|
|
|
|
|
|
|
|
Contributions are welcome.
|
|
|
|
|
|
|
|
## Creators
|
|
|
|
|
|
|
|
**Remco Verhoef**
|
|
|
|
- <https://twitter.com/remco_verhoef>
|
|
|
|
- <https://twitter.com/dutchcoders>
|
|
|
|
|
|
|
|
**Uvis Grinfelds**
|
|
|
|
|
|
|
|
## Copyright and license
|
|
|
|
|
2014-10-16 21:25:04 +02:00
|
|
|
Code and documentation copyright 2011-2014 Remco Verhoef.
|
|
|
|
Code released under [the MIT license](LICENSE).
|