magic-wormhole/NEWS.md
2016-04-20 18:36:26 -07:00

158 lines
7.7 KiB
Markdown

User-visible changes in "magic-wormhole":
## Release 0.7.5 (?)
* The CLI tools now use the Twisted-based library exclusively.
* The blocking-flavor "Transit" library has been removed. Transit is the
bulk-transfer protocol used by send-file/send-directory, and is no
longer used by the CLI tools (which have switched to twisted-flavor
Transit). Upcoming protocol improvements (both performance and
connectivity) proved too difficult to implement in a blocking fashion.
* The Twisted-flavor "Wormhole" library now uses WebSockets to connect,
rather than HTTP. The blocking-flavor library continues to use HTTP.
"Wormhole" is the one-message-at-a-time relay-based protocol, and is
used to set up Transit for the send-file and send-directory modes of
the CLI tool.
* Twisted-flavor input_code() now does readline-based code entry, with
tab completion.
* The code has been split into four separate importable packages:
* "wormhole", this contains the blocking library and shared code
* "txwormhole": twisted lbirary
* "wormhole_cli": CLI scripts
* "wormhole_server": code for the Rendezvous and Transit Relay servers
* The package now installs two executables: "wormhole" (for send and
receive), and "wormhole-server" (to start and manage the relay
servers).
* Packaging: magic-wormhole now depends upon "Twisted" and "autobahn".
Autobahn pulls in txaio (a future version of magic-wormhole may work
with txaio, but not yet). To work around a bug in autobahn, it also
(temporarily) depends upon "pytrie". This dependency will be removed
when the next autobahn release is available.
## Release 0.7.0 (28-Mar-2016)
* `wormhole send DIRNAME/` used to deal very badly with the trailing slash
(sending a directory with an empty name). This is now fixed.
* Preliminary Tor support was added. Install `magic-wormhole[tor]`, make sure
you have a Tor executable on your $PATH, and run `wormhole --tor send`.
This will launch a new Tor process. Do not use this in anger/fear until it
has been tested more carefully. This feature is likely to be unstable for a
while, and lacks tests.
* The relay now prunes unused channels properly.
* Added --dump-timing= to record timeline of events, for debugging and
performance improvements. You can combine timing data from both sides to
see where the delays are happening. The server now returns timestamps in
its responses, to measure round-trip delays. A web-based visualization tool
was added in `misc/dump-timing.py`.
* twisted.transit was not properly handling multiple records received in a
single chunk. Some producer/consumer helper methods were added. You can now
run e.g. `wormhole --twisted send` to force the use of the Twisted
implementation.
* The Twisted wormhole now uses a persistent connection for all relay
messages, which should be slightly faster.
* Add `--no-listen` to prevent Transit from listening for inbound connections
(or advertising any addresses): this is only useful for testing.
* The tests now collect code coverage information, and upload them to
https://codecov.io/github/warner/magic-wormhole?ref=master .
## Release 0.6.3 (29-Feb-2016)
Mostly internal changes:
* twisted.transit was added, so Twisted-based applications can use it now.
This includes Producer/Consumer -based flow control. The Transit protocol
and API are documented in docs/transit.md .
* The transit relay server can blur filesizes, rounding them to some
roughly-logarithmic interval.
* Use --relay-helper="" to disable use of the transit relay entirely,
limiting the file transfer to direct connections.
* The new --hide-progress option disables the progress bar.
* Made some windows-compatibility fixes, but all tests do not yet pass.
## Release 0.6.2 (12-Jan-2016)
* the server can now "blur" usage information: this turns off HTTP logging,
and rounds timestamps to coarse intervals
* `wormhole server usage` now shows Transit usage too, not just Rendezvous
## Release 0.6.1 (03-Dec-2015)
* `wormhole` can now send/receive entire directories. They are zipped before
transport.
* Python 3 is now supported for async (Twisted) library use, requiring at
least Twisted-15.5.0.
* A bug was fixed which prevented py3-based clients from using the relay
transit server (not used if the two sides can reach each other directly).
* The `--output-file=` argument was finally implemented, which allows the
receiver to override the filename that it writes. This may help scripted
usage.
* Support for Python-2.6 was removed, since the recent Twisted-15.5.0 removed
it too. It might still work, but is no longer automatically tested.
* The transit relay now implements proper flow control (Producer/Consumer),
so it won't buffer the entire file when the sender can push data faster
than the receiver can accept it. The sender should now throttle down to the
receiver's maximum rate.
## Release 0.6.0 (23-Nov-2015)
* Add key-confirmation message so "wormhole send" doesn't hang when the
receiver mistypes the code.
* Fix `wormhole send --text -` to read the text message from stdin. `wormhole
receive >outfile` works, but currently appends an extra newline, which may
be removed in a future release.
* Arrange for 0.4.0 senders to print an error message when connecting to a
current (0.5.0) server, instead of an ugly stack trace. Unfortunately 0.4.0
receivers still display the traceback, since they don't check the welcome
message before using a missing API. 0.5.0 and 0.6.0 will do better.
* Improve channel deallocation upon error.
* Inform the server of our "mood" when the connection closes, so it can track
the rate of successful/unsuccessful transfers. The server DB now stores a
summary of each transfer (waiting time and reported outcome).
* Rename (and deprecate) one server API (the non-EventSource form of "get"),
leaving it in place until after the next release. 0.5.0 clients should
interoperate with both the 0.6.0 server and 0.6.0 clients, but eventually
they'll stop working.
## Release 0.5.0 (07-Oct-2015)
* Change the CLI to merge send-file with send-text, and receive-file with
receive-text. Add confirmation before accepting a file.
* Change the remote server API significantly, breaking compatibility with
0.4.0 peers. Fix EventSource to match W3C spec and real browser behavior.
* Add py3 (3.3, 3.4, 3.5) compatibility for blocking calls (but not Twisted).
* internals
* Introduce Channel and ChannelManager to factor out the HTTP/EventSource
technology in use (making room for WebSocket or Tor in the future).
* Change app-visible API to allow multiple message phases.
* Change most API arguments from bytes to unicode strings (appid, URLs,
wormhole code, derive_key purpose string, message phase). Derived keys are
bytes, of course.
* Add proper unit tests.
## Release 0.4.0 (22-Sep-2015)
This changes the protocol (to a symmetric form), breaking compatibility with
0.3.0 peers. Now both blocking-style and Twisted-style use a symmetric
protocol, and the two sides do not need to figure out (ahead of time) which
one goes first. The internal layout was rearranged, so applications that
import wormhole must be updated.
## Release 0.3.0 (24-Jun-2015)
Add preliminary Twisted support, only for symmetric endpoints (no
initator/receiver distinction). Lacks code-entry tab-completion. May still
leave timers lingering. Add test suite (only for Twisted, so far).
Use a sqlite database for Relay server state, to survive reboots with less
data loss. Add "--advertise-version=" to "wormhole relay start", to override
the version we recommend to clients.
## Release 0.2.0 (10-Apr-2015)
Initial release: supports blocking/synchronous asymmetric endpoints
(Initiator on one side, Receiver on the other). Codes can be generated by
Initiator, or created externally and passed into both (as long as they start
with digits: NNN-anything).