diff --git a/cmd/stdiscosrv/README.md b/cmd/stdiscosrv/README.md index f224eca7f..695386e91 100644 --- a/cmd/stdiscosrv/README.md +++ b/cmd/stdiscosrv/README.md @@ -38,3 +38,7 @@ In all cases, the appropriate tables and indexes will be created at first startup. If it doesn't exit with an error, you're fine. See `stdiscosrv -help` for other options. + +##### Third-party attribution + +[cznic/lldb](https://github.com/cznic/lldb), Copyright (C) 2014 The lldb Authors. diff --git a/cmd/strelaypoolsrv/README.md b/cmd/strelaypoolsrv/README.md index e80016313..c9e5dd911 100644 --- a/cmd/strelaypoolsrv/README.md +++ b/cmd/strelaypoolsrv/README.md @@ -13,3 +13,9 @@ If you still want to run it, you can run `go get github.com/syncthing/relaypools from the build server. See `relaypoolsrv -help` for configuration options. + +##### Third-party attributions + +[oschwald/geoip2-golang](https://github.com/oschwald/geoip2-golang), [oschwald/maxminddb-golang](https://github.com/oschwald/maxminddb-golang), Copyright (C) 2015 [Gregory J. Oschwald](mailto:oschwald@gmail.com). + +[lib/pq](https://github.com/lib/pq), Copyright (C) 2011-2013 'pq' Contributors Portions Copyright (C) 2011 Blake Mizerany. diff --git a/cmd/strelaysrv/README.md b/cmd/strelaysrv/README.md index 4e2499f5a..59367b868 100644 --- a/cmd/strelaysrv/README.md +++ b/cmd/strelaysrv/README.md @@ -12,17 +12,15 @@ from the build server. :exclamation:Warnings:exclamation: - Read or regret ----- -By default, all relay servers will join the default public relay pool, which means that the relay server will be availble for public use, and **will consume your bandwidth** helping others to connect. +By default, all relay servers will join to the default public relay pool, which means that the relay server will be availble for public use, and **will consume your bandwidth** helping others to connect. -If you wish to disable this behaviour, please specify `-pools=""` argument. +If you wish to disable this behaviour, please specify the `-pools=""` argument. Please note that `strelaysrv` is only usable by `syncthing` **version v0.12 and onwards**. -To run `strelaysrv` you need to have port 22067 available to the internet, which means you might need to allow it through your firewall if you **have a public IP, or setup a port-forwarding** (22067 to 22067) if you are behind a router. +To run `strelaysrv` you need to have port 22067 available to the internet, which means you might need to port forward it and/or allow it through your firewall. -Furthermore, **by default strelaysrv will also expose a /status HTTP endpoint on port 22070**, which is used by the pool servers to peek at metrics of the strelaysrv, such as what are the current transfer rates, how many clients are connected, etc, etc. If you wish this information to be available, similarlly you might want to allow it through your firewall, or port-forward it (22070 to 22070) on your NAT device. - -This is **not mandatory** for the strelaysrv to function, and is used only to gather metrics and present them in the overview page of the pool server, displaying stats about the specific relay. +Furthermore, by default `strelaysrv` will also expose a /status HTTP endpoint on port 22070, which is used by the pool servers to read metrics of the `strelaysrv`, such as the current transfer rates, how many clients are connected, etc. If you wish this information to be available you may need to port forward and allow it through your firewall. This is not mandatory for the `strelaysrv` to function, and is used only to gather metrics and present them in the overview page of the pool server. At the point of writing the endpoint output looks as follows: @@ -66,7 +64,7 @@ If you wish to disable the /status endpoint, provide `-status-srv=""` as one of Running for public use ---- -Make sure you have a public IP with port 22067 open, or make sure you have port-forwarding (22067 to 22067) if you are behind a router. +Make sure you have a public IP with port 22067 open, or have forwarded port 22067 if you are behind a NAT. Run the `strelaysrv` with no arguments (or `-debug` if you want more output), and that should be enough for the server to join the public relay pool. You should see a message saying: @@ -79,37 +77,37 @@ See `strelaysrv -help` for other options, such as rate limits, timeout intervals Running for private use ----- -Once you've started the `strelaysrv`, it will generate a key pair and print an URI: +Once you've started the `strelaysrv`, it will generate a key pair and print a URI: ```bash relay://:22067/?id=EZQOIDM-6DDD4ZI-DJ65NSM-4OQWRAT-EIKSMJO-OZ552BO-WQZEGYY-STS5RQM&pingInterval=1m0s&networkTimeout=2m0s&sessionLimitBps=0&globalLimitBps=0&statusAddr=:22070 ``` -This URI contains partial address of the relay server, as well as it's options which in the future may be taken into account when choosing the best suitable relay out of multiple available. +This URI contains a partial address of the relay server, as well as its options which in the future may be taken into account when choosing the most suitable relay. -Because `-listen` option was not used, the `strelaysrv` does not know it's external IP, therefore you should replace the host part of the URI with your public IP address on which the `strelaysrv` will be available: +Because the `-listen` option was not used `strelaysrv` does not know its external IP, therefore you should replace the host part of the URI with your public IP address on which the `strelaysrv` will be available: ```bash -relay://123.123.123.123:22067/?id=EZQOIDM-6DDD4ZI-DJ65NSM-4OQWRAT-EIKSMJO-OZ552BO-WQZEGYY-STS5RQM&pingInterval=1m0s&networkTimeout=2m0s&sessionLimitBps=0&globalLimitBps=0&statusAddr=:22070 +relay://192.0.2.1:22067/?id=EZQOIDM-6DDD4ZI-DJ65NSM-4OQWRAT-EIKSMJO-OZ552BO-WQZEGYY-STS5RQM&pingInterval=1m0s&networkTimeout=2m0s&sessionLimitBps=0&globalLimitBps=0&statusAddr=:22070 ``` If you do not care about certificate pinning (improved security) or do not care about passing verbose settings to the clients, you can shorten the URL to just the host part: ```bash -relay://123.123.123.123:22067 +relay://192.0.2.1:22067 ``` -This URI can then be used in `syncthing` as one of the relay servers. +This URI can then be used in `syncthing` clients as one of the relay servers by adding the URI to the "Sync Protocol Listen Address" field, under Actions and Settings. See `strelaysrv -help` for other options, such as rate limits, timeout intervals, etc. Other items available in this repo ---- ##### testutil -A test utility which can be used to test connectivity of a relay server. -You need to generate two x509 key pairs (key.pem and cert.pem), one for the client, another one for the server, in separate directories. +A test utility which can be used to test the connectivity of a relay server. +You need to generate two x509 key pairs (key.pem and cert.pem), one for the client and one for the server, in separate directories. Afterwards, start the client: ```bash -./testutil -relay="relay://uri.of.relay" -keys=certs/client/ -join +./testutil -relay="relay://192.0.2.1:22067" -keys=certs/client/ -join ``` This prints out the client ID: @@ -120,7 +118,7 @@ This prints out the client ID: In the other terminal run the following: ```bash - ./testutil -relay="relay://uri.of.relay" -keys=certs/server/ -connect=BG2C5ZA-W7XPFDO-LH222Z6-65F3HJX-ADFTGRT-3SBFIGM-KV26O2Q-E5RMRQ2 + ./testutil -relay="relay://192.0.2.1:22067" -keys=certs/server/ -connect=BG2C5ZA-W7XPFDO-LH222Z6-65F3HJX-ADFTGRT-3SBFIGM-KV26O2Q-E5RMRQ2 ``` Which should then give you an interactive prompt, where you can type things in one terminal, and they get relayed to the other terminal. @@ -137,5 +135,3 @@ Relay related libraries used by this repo Only used by the testutil. [Available here](https://github.com/syncthing/syncthing/tree/master/lib/relay/client) - - diff --git a/cmd/syncthing/main.go b/cmd/syncthing/main.go index f92329a1e..a29a6c167 100644 --- a/cmd/syncthing/main.go +++ b/cmd/syncthing/main.go @@ -141,11 +141,11 @@ show time only (2). Development Settings -------------------- -The following environment variables modify syncthing's behavior in ways that +The following environment variables modify Syncthing's behavior in ways that are mostly useful for developers. Use with care. STNODEFAULTFOLDER Don't create a default folder when starting for the first - time. This variable will be ignored anytime after the first + time. This variable will be ignored anytime after the first run. STGUIASSETS Directory to load GUI assets from. Overrides compiled in @@ -154,8 +154,8 @@ are mostly useful for developers. Use with care. STTRACE A comma separated string of facilities to trace. The valid facility strings listed below. - STPROFILER Set to a listen address such as "127.0.0.1:9090" to start the - profiler with HTTP access. + STPROFILER Set to a listen address such as "127.0.0.1:9090" to start + the profiler with HTTP access. STCPUPROFILE Write a CPU profile to cpu-$pid.pprof on exit. @@ -168,6 +168,20 @@ are mostly useful for developers. Use with care. STPERFSTATS Write running performance statistics to perf-$pid.csv. Not supported on Windows. + STDEADLOCK Used for debugging internal deadlocks. Use only under + direction of a developer. + + STDEADLOCKTIMEOUT Used for debugging internal deadlocks; sets debug + sensitivity. Use only under direction of a developer. + + STDEADLOCKTHRESHOLD Used for debugging internal deadlocks; sets debug + sensitivity. Use only under direction of a developer. + + STNORESTART Equivalent to the -no-restart argument. Disable the + Syncthing monitor process which handles restarts for some + configuration changes, upgrades, crashes and also log file + writing (stdout is still written). + STNOUPGRADE Disable automatic upgrades. STHASHING Select the SHA256 hashing package to use. Possible values @@ -180,7 +194,7 @@ are mostly useful for developers. Use with care. GOGC Percentage of heap growth at which to trigger GC. Default is 100. Lower numbers keep peak memory usage down, at the price - of CPU usage (ie. performance). + of CPU usage (i.e. performance). Debugging Facilities @@ -262,7 +276,7 @@ func parseCommandLineOptions() RuntimeOptions { flag.IntVar(&options.logFlags, "logflags", options.logFlags, "Select information in log line prefix (see below)") flag.BoolVar(&options.noBrowser, "no-browser", false, "Do not start browser") flag.BoolVar(&options.browserOnly, "browser-only", false, "Open GUI in browser") - flag.BoolVar(&options.noRestart, "no-restart", options.noRestart, "Do not restart; just exit") + flag.BoolVar(&options.noRestart, "no-restart", options.noRestart, "Disable monitor process, managed restarts and log file writing") flag.BoolVar(&options.resetDatabase, "reset-database", false, "Reset the database, forcing a full rescan and resync") flag.BoolVar(&options.resetDeltaIdxs, "reset-deltas", false, "Reset delta index IDs, forcing a full index exchange") flag.BoolVar(&options.doUpgrade, "upgrade", false, "Perform upgrade") diff --git a/gui/default/syncthing/core/aboutModalView.html b/gui/default/syncthing/core/aboutModalView.html index 4df7c60a0..39c88c144 100644 --- a/gui/default/syncthing/core/aboutModalView.html +++ b/gui/default/syncthing/core/aboutModalView.html @@ -9,7 +9,7 @@
-

Copyright © 2014-2016 the following Contributors:

+

Copyright © 2014-2017 the following Contributors:

Jakob Borg, Audrius Butkevicius, Alexander Graf, Anderson Mesquita, Antony Male, Ben Schulz, Caleb Callaway, Daniel Harte, Lars K.W. Gohlke, Lode Hoste, Michael Ploujnikov, Philippe Schommers, Ryan Sullivan, Sergey Mishin, Stefan Tatschner, Aaron Bieber, Adam Piggott, Adel Qalieh, Alessandro G., Alexandre Viau, Andrew Dunham, Andrey D, Antoine Lamielle, Arthur Axel fREW Schmidt, Bart De Vries, Ben Curthoys, Ben Sidhom, Benny Ng, Brandon Philips, Brendan Long, Brian R. Becker, Carsten Hagemann, Cathryne Linenweaver, Cedric Staniewski, Chris Howie, Chris Joel, Colin Kennedy, Daniel Bergmann, Daniel Martí, David Rimmer, Denis A., Dennis Wilson, Dominik Heidler, Elias Jarlebring, Emil Hessman, Erik Meitner, Federico Castagnini, Felix Ableitner, Felix Unterpaintner, Francois-Xavier Gsell, Frank Isemann, Gilli Sigurdsson, Heiko Zuerker, Jaakko Hannikainen, Jacek Szafarkiewicz, Jake Peterson, James Patterson, Jaroslav Malec, Jens Diemer, Jochen Voss, Johan Vromans, Karol Różycki, Kelong Cong, Ken'ichi Kamada, Kevin Allen, Kevin White, Jr., Kurt Fitzner, Laurent Etiemble, Leo Arias, Lord Landon Agahnim, Majed Abdulaziz, Marc Laporte, Marc Pujol, Marcin Dziadus, Mark Pulford, Mateusz Naściszewski, Matt Burke, Max Schulze, Michael Jephcote, Michael Tilli, Nate Morrison, Pascal Jungblut, Peter Hoeg, Phill Luby, Piotr Bejda, Roman Zaynetdinov, Scott Klupfel, Simon Frei, Stefan Kuntz, Tim Abell, Tim Howes, Tobias Nygren, Tomas Cerveny, Tully Robinson, Tyler Brazier, Unrud, Veeti Paananen, Victor Buinsky, Vil Brekin, William A. Kennington III, Wulf Weich, Xavier O., Yannic A. @@ -20,15 +20,22 @@ Jakob Borg, Audrius Butkevicius, Alexander Graf, Anderson Mesquita, Antony Male,

Syncthing includes the following software or portions thereof: