Open Source Continuous File Synchronization
Go to file
2014-02-01 11:22:41 +01:00
auto Parallell -> parallel (ref #13) 2014-01-26 16:48:20 +01:00
buffers Memory usage optimizations 2013-12-29 20:33:57 -05:00
discover Rework config/flags (fixes #13) 2014-01-26 14:45:03 +01:00
github.com/jessevdk/go-flags Pull in go-flags, modified to build on Solaris 2013-12-23 11:18:46 -05:00
gui Add version info to GUI (fixes #41) 2014-01-23 13:13:15 +01:00
integration Synchronize zero sized files (fixes #44) 2014-01-29 21:52:27 +01:00
model Synchronize zero sized files (fixes #44) 2014-01-29 21:52:27 +01:00
protocol Add Options message to protocol 2014-01-23 13:12:45 +01:00
.gitignore Move build artefacts dir 2014-01-06 06:11:19 +01:00
build.sh Streamline build script 2014-02-01 10:10:07 +01:00
config.go Parallell -> parallel (ref #13) 2014-01-26 16:48:20 +01:00
CONTRIBUTING.md CONTRIBUTING.md 2014-01-28 19:10:39 +01:00
gui_unix.go Don't build with CPU usage on Solaris 2014-01-10 15:32:30 +01:00
gui.go Always show self in cluster list (fixes #43) 2014-02-01 11:22:41 +01:00
LICENSE REBASE! 2013-12-15 11:43:40 +01:00
locktrace.go Lock tracing, fixes 2013-12-24 20:31:25 -05:00
logger.go Deadlock fix and cleanups 2014-01-13 10:29:23 -07:00
main.go Actually load index cache again (fixes #45) 2014-01-29 22:02:38 +01:00
README.md Point to the wiki for documentation (fixes #10) 2014-01-07 12:07:56 +01:00
tls.go Longer RSA key and stronger node ID hash (ref #23) 2014-01-07 22:04:30 +01:00
usage.go Rework config/flags (fixes #13) 2014-01-26 14:45:03 +01:00
util.go Dead code removal 2014-01-06 12:45:43 +01:00

syncthing

This is syncthing, an open BitTorrent Sync alternative. It is currently far from ready for mass consumption, but it is a usable proof of concept and tech demo. The following are the project goals:

  1. Define an open, secure, language neutral protocol usable for efficient synchronization of a file repository between an arbitrary number of nodes. This is the Block Exchange Protocol (BEP).

  2. Provide the reference implementation to demonstrate the usability of said protocol. This is the syncthing utility.

The two are evolving together; the protocol is not to be considered stable until syncthing 1.0 is released, at which point it is locked down for incompatible changes.

Syncthing does not use the BitTorrent protocol. The reasons for this are

  1. we don't know if BitTorrent Sync does either, so there's nothing to be compatible with, 2) BitTorrent includes a lot of functionality for making sure large swarms of selfish agents behave and somehow work towards a common goal. Here we have a much smaller swarm of cooperative agents and a simpler approach will suffice.

Documentation

The syncthing documentation is kept on the GitHub Wiki.

License

MIT