Reference server implementation in Go of tus: the open protocol for resumable file uploads
Go to file
Kevin van Zonneveld 15c3a6f898 Improve error message when downloading an incomplete file 2013-03-29 22:51:08 +01:00
scripts Revert "Turn every @todo 404 into an actual 404" 2013-03-28 15:20:47 +01:00
src/cmd/tusd Improve error message when downloading an incomplete file 2013-03-29 22:51:08 +01:00
.gitignore Ignore tus_data dir 2013-03-18 11:06:55 +01:00
README.md Update Readme 2013-03-26 15:45:20 +01:00

README.md

tusd - Let's fix file uploading

It's 2013, and adding reliable file uploading to your app is still too damn hard. tus is an open source project dedicated to create the best file uploading protocol, server and clients.

Sounds interesting? Get notified when it's ready: http://tus.io/

Roadmap

The initial goal for this project to come up with a good and simple solution for resumable file uploads over http.

  • Defining a good http API (first proposal created)
  • Implementing a minimal and robust server for it (in progress)
  • Creating an HTML5 client (in progress, proof of concept working)
  • Setting up an online demo (done)
  • Integrating Amazon S3 for storage
  • Creating an iOS client

Future features will be based on your feedback. A few potential ideas:

  • Alternative transfer mechanisms: FTP, UDP, E-Mail, etc.
  • Security: Authentication Tokens, HTTPS, etc.
  • Support for running tusd instances in a geographically distributed cluster (reverse CDN)
  • Alternative storage backends: Cloud Files, Dropbox, etc.
  • More clients: Android, PhoneGap, etc.
  • Service integrations: Transloadit, Zencoder, Encoding.com, Youtube, Vimeo, Facebook, AWS Transcoder, etc.
  • File meta data analysis
  • Thumbnail generation

Once the project matures, we hope to offer a hosted service and support contracts. However, all code will continue to be released as open source, and you'll always be able to run your own deployments easily. There will be no bait and switch.

Getting started

Requirements:

Installing tusd:

Clone the git repository and cd into it.

git clone git@github.com:tus/tusd.git
cd tusd

Running tusd:

Run it with go:

go run src/cmd/tusd/*.go

License

We are currently making this decision, and will clarify this ASAP.