Open Source Continuous File Synchronization; contains branches to build Syncthing as a C library
Go to file
filoozom 23593c3d20 Update getHomeDir() to use "os/user"
os.Getenv("HOME") doesn't work properly on Windows (and maybe other systems?) and the package "os/user" gives us a convenient way to find the home directory for every OS.
2014-03-02 16:07:12 +01:00
assets Logo 2014-02-07 22:33:58 +01:00
auto Use simple script for asset embedding 2014-02-23 13:54:23 +01:00
buffers Memory usage optimizations 2013-12-29 20:33:57 -05:00
cid Add some support packages 2014-03-01 11:11:37 +01:00
discover golint 2014-02-24 13:29:30 +01:00
files Add some support packages 2014-03-01 11:11:37 +01:00
gui Add peer node sync status in GUI (fixes #46) 2014-02-13 12:51:55 +01:00
integration Synchronize zero sized files (fixes #44) 2014-01-29 21:52:27 +01:00
protocol golint 2014-02-24 13:29:30 +01:00
testdata Show warnings in GUI (fixes #66) 2014-02-12 23:18:41 +01:00
xdr golint 2014-02-24 13:29:30 +01:00
.gitignore Move build artefacts dir 2014-01-06 06:11:19 +01:00
assets.sh Use simple script for asset embedding 2014-02-23 13:54:23 +01:00
blocks_test.go Show warnings in GUI (fixes #66) 2014-02-12 23:18:41 +01:00
blocks.go go vet 2014-02-24 13:24:03 +01:00
build.sh Use simple script for asset embedding 2014-02-23 13:54:23 +01:00
config.go Allow setting a friendly name for the local node (fixes #65) 2014-02-10 20:54:57 +01:00
CONTRIBUTING.md CONTRIBUTING.md 2014-01-28 19:10:39 +01:00
filemonitor.go Show warnings in GUI (fixes #66) 2014-02-12 23:18:41 +01:00
filequeue_test.go go vet 2014-02-24 13:24:03 +01:00
filequeue.go Reorder locking to avoid deadlock (fixes #64) 2014-02-13 12:51:51 +01:00
gui_development.go Edit configuration in GUI; use XML configuration 2014-02-03 15:42:59 +01:00
gui_embedded.go Use simple script for asset embedding 2014-02-23 13:54:23 +01:00
gui_unix.go Don't build with CPU usage on Solaris 2014-01-10 15:32:30 +01:00
gui.go Rework XDR encoding 2014-02-20 17:42:17 +01:00
LICENSE Rework XDR encoding 2014-02-20 17:42:17 +01:00
locktrace.go Lock tracing, fixes 2013-12-24 20:31:25 -05:00
logger.go Initialize logging earlier (fix panic in tests) 2014-02-13 08:59:27 +01:00
main.go Update getHomeDir() to use "os/user" 2014-03-02 16:07:12 +01:00
model_test.go Fix tests 2014-02-23 13:58:10 +01:00
model.go deadcode 2014-02-24 13:34:24 +01:00
openurl.go Open GUI on startup 2014-03-02 12:52:32 +01:00
README.md drone.io badge 2014-02-24 14:06:22 +01:00
suppressor_test.go golint 2014-02-24 13:29:30 +01:00
suppressor.go golint 2014-02-24 13:29:30 +01:00
tls.go golint 2014-02-24 13:29:30 +01:00
usage.go Rework config/flags (fixes #13) 2014-01-26 14:45:03 +01:00
util.go Rework XDR encoding 2014-02-20 17:42:17 +01:00
walk_test.go Show warnings in GUI (fixes #66) 2014-02-12 23:18:41 +01:00
walk.go Fix tests 2014-02-23 13:58:10 +01:00

syncthing Build Status

This is the syncthing project. The following are the project goals:

  1. Define a protocol for synchronization of a file repository between a number of collaborating nodes. The protocol should be well defined, unambigous, easily understood, free to use, efficient, secure and languange neutral. This is the Block Exchange Protocol.

  2. Provide the reference implementation to demonstrate the usability of said protocol. This is the syncthing utility. It is the hope that alternative, compatible implementations of the protocol will come to exist.

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

All documentation and protocol specifications are licensed under the Creative Commons Attribution 4.0 International License.

All code is licensed under the MIT License.