mirror of
https://github.com/dutchcoders/transfer.sh.git
synced 2025-01-07 18:00:18 +01:00
No description
cmd | ||
extras | ||
server | ||
vendor | ||
.bowerrc | ||
.dockerignore | ||
.gitignore | ||
.jshintrc | ||
.travis.yml | ||
Dockerfile | ||
LICENSE | ||
lock.json | ||
main.go | ||
manifest.json | ||
README.md | ||
Vagrantfile |
transfer.sh
Easy and fast file sharing from the command-line. This code contains the server with everything you need to create your own instance.
Transfer.sh support currently the s3 (Amazon S3) provider and local file system (local).
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
Add alias to .bashrc or .zshrc:
===
transfer() {
# write to output to tmpfile because of progress bar
tmpfile=$( mktemp -t transferXXX )
curl --progress-bar --upload-file $1 https://transfer.sh/$(basename $1) >> $tmpfile;
cat $tmpfile;
rm -f $tmpfile;
echo;
}
alias transfer=transfer
===
$ transfer test.txt
Alias virus scan transfer >> .bashrc or .zshrc:
===
tansfercheck() {
if [ $# -eq 0 ];
then echo -e "No arguments specified. Usage:\n transfercheck /tmp/test.md\ncat /tmp/test.md | transfercheck test.md";
return 1;
fi
# write to output to tmpfile for progress bar
tmpfile=$( mktemp -t transferXXX)
if tty -s;
then basefile=$(basename "$1" | sed -e 's/[^a-zA-Z0-9._-]/-/g');
curl -X PUT --progress-bar --upload-file $1 https://transfer.sh/$basefile/virustotal >> $tmpfile;
else curl -X PUT --progress-bar --upload-file "-" "https://transfer.sh/$1/virustotal" >> $tmpfile ;
fi
cat $tmpfile;
rm -f $tmpfile;
}
alias transfercheck=transfercheck
===
$ transfercheck suspicious.pdf
Usage
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 | ||
temp-path | path to temp folder | system temp | |
web-path | path to static web files (for development) | ||
provider | which storage provider to use | (s3 or local) | |
aws-access-key | aws access key | AWS_ACCESS_KEY | |
aws-secret-key | aws access key | AWS_SECRET_KEY | |
bucket | aws bucket | BUCKET | |
basedir | path storage for local provider | ||
lets-encrypt-hosts | hosts to use for lets encrypt certificates (comma seperated) | ||
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.
Development
Make sure your GOPATH is set correctly.
go run main.go -provider=local --listener :8080 --temp-path=/tmp/ --basedir=/tmp/
Build
go build -o transfersh main.go
Docker
For easy deployment we've created a Docker container.
docker run --publish 8080:8080 dutchcoders/transfer.sh:latest --provider local --basedir /tmp/
Contributions
Contributions are welcome.
Creators
Remco Verhoef
Uvis Grinfelds
Copyright and license
Code and documentation copyright 2011-2014 Remco Verhoef. Code released under the MIT license.