HTTP-based
Built as a layer on top of the popular HTTP protocol, tus can easily be integrated into applications using existing libraries, proxies and firewalls, and can be used directly from any website.
People are sharing more and more photos and videos every day, but mobile networks remain fragile. Platform APIs are often a mess and every project builds its own file uploader. There are a thousand one-week projects that barely work, when all we need is one real project. One project done right.
We are going to do this right. Our aim is to make file uploads reliable once and for all. tus is a new, open protocol for resumable uploads built on HTTP. It offers simple, cheap and reusable stacks for clients and servers. It supports any language, any platform and any network.
It may seem to be an impossible dream. Perhaps that is because no one has solved it yet. Still, we are confident and we are going to give it our best shot. Join us on GitHub and help us make the world a better place. Say "No!" to lost cat videos! Say "Yes!" to tus!
HTTP-based
Built as a layer on top of the popular HTTP protocol, tus can easily be integrated into applications using existing libraries, proxies and firewalls, and can be used directly from any website.
Production-ready
tus is ready for use in production. It has undergone numerous rounds of improvements and received valuable feedback from people working at Vimeo, Google and multiple other well-known companies.
Open source
tus is brought to you by the people behind
Transloadit but the source code to all of
our implementations, this website and even the protocol itself is accessible to
everyone under MIT license, directly from our GitHub
organization.
Minimalistic design…
The specification only requires a very small set of features to be implemented by clients and servers. tus embraces simplicity, fast development and iteration speed for everyone.
…yet still extensible
tus nevertheless features a sizable list of extensions that introduce additional functionality, such as parallel uploading or checksums and expiration. All of these may be implemented according to your preferences.
Community-owned
We believe in an open and accessible evolution of this protocol. At any stage since the beginning of tus, feedback has been appreciated and integrated. We look forward to your contributions as well.
Additionally, there are many other projects built and maintained by our community.
Darkflib is now watching tus/tus-resumable-upload-protocol
Isaac-Liggett is now watching tus/tus-js-client
alexozer forked tus/tus-go-client
treecko16 is now watching tus/tus-go-client
dsandriyanov commented on Fix custom url session usage in tus/TUSKit
JasonFeng365 is now watching tus/tus-java-client
borud is now watching tus/tus-go-client
alireza-fa is now watching tus/tusd
talyo94 is now watching tus/tus-node-server
ixxie forked tus/tus.io
MauriceCarlo is now watching tus/tus-node-server
caasi commented on tus: invalid or missing Location header, originated from request in tus/tus-js-client
Marshall-Hao is now watching tus/tus-js-client
Serg-Pogrebnyak commented on Problem with background file upload and token refresh handling in tus/TUSKit
Acconut commented on Added API testing button in tus/tus-resumable-upload-protocol
Acconut closed pull request Added API testing button for tus/tus-resumable-upload-protocol
donnywals commented on Issue with TUSKit uploads pausing in the background and high memory usage when pausing and resuming uploads. in tus/TUSKit
donnywals commented on Fix custom url session usage in tus/TUSKit