82 lines
3.9 KiB
Markdown
82 lines
3.9 KiB
Markdown
|
|
User-visible changes in "magic-wormhole":
|
|
|
|
## Release ?? (??)
|
|
|
|
* `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).
|