commit
2c7582a454
|
@ -47,7 +47,7 @@ test_script:
|
||||||
# Put your test command here.
|
# Put your test command here.
|
||||||
# Note that you must use the environment variable %PYTHON% to refer to
|
# Note that you must use the environment variable %PYTHON% to refer to
|
||||||
# the interpreter you're using - Appveyor does not do anything special
|
# the interpreter you're using - Appveyor does not do anything special
|
||||||
# to put the Python evrsion you want to use on PATH.
|
# to put the Python version you want to use on PATH.
|
||||||
- |
|
- |
|
||||||
misc\windows-build.cmd %PYTHON%\Scripts\tox.exe
|
misc\windows-build.cmd %PYTHON%\Scripts\tox.exe
|
||||||
|
|
||||||
|
|
1
NEWS.md
1
NEWS.md
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
User-visible changes in "magic-wormhole":
|
User-visible changes in "magic-wormhole":
|
||||||
|
|
||||||
## Release 0.12.0 (04-Apr-2020)
|
## Release 0.12.0 (04-Apr-2020)
|
||||||
|
|
|
@ -102,7 +102,7 @@ author. Application developers can use this one, or they can run their own
|
||||||
(see the [warner/magic-wormhole-mailbox-server
|
(see the [warner/magic-wormhole-mailbox-server
|
||||||
](https://github.com/warner/magic-wormhole-mailbox-server) repository)
|
](https://github.com/warner/magic-wormhole-mailbox-server) repository)
|
||||||
and configure their clients to use it instead. The URL of the public
|
and configure their clients to use it instead. The URL of the public
|
||||||
rendevouz server is passed as a unicode string. Note that because the server
|
rendezvous server is passed as a unicode string. Note that because the server
|
||||||
actually speaks WebSockets, the URL starts with `ws:` instead of `http:`.
|
actually speaks WebSockets, the URL starts with `ws:` instead of `http:`.
|
||||||
|
|
||||||
## Wormhole Parameters
|
## Wormhole Parameters
|
||||||
|
@ -699,4 +699,3 @@ w.send_message(msg) | |
|
||||||
. | d=w.get_message() | dg.wormhole_got_message(msg)
|
. | d=w.get_message() | dg.wormhole_got_message(msg)
|
||||||
w.close() | | dg.wormhole_closed(result)
|
w.close() | | dg.wormhole_closed(result)
|
||||||
. | d=w.close() |
|
. | d=w.close() |
|
||||||
|
|
||||||
|
|
|
@ -59,7 +59,7 @@ ones that I've considered (but haven't implemented yet) include:
|
||||||
would-be vandals from feeling a sense of accomplishment at writing
|
would-be vandals from feeling a sense of accomplishment at writing
|
||||||
their own :). Not sure it would help much, but I vaguely remember
|
their own :). Not sure it would help much, but I vaguely remember
|
||||||
hearing about something similar in the early multi-user unix systems
|
hearing about something similar in the early multi-user unix systems
|
||||||
(a publically-executable /bin/crash or something, which new users
|
(a publicly-executable /bin/crash or something, which new users
|
||||||
tended to only run once before learning some responsibility).
|
tended to only run once before learning some responsibility).
|
||||||
|
|
||||||
Using the secret words as part of the "channel id" isn't safe, since it
|
Using the secret words as part of the "channel id" isn't safe, since it
|
||||||
|
|
|
@ -62,5 +62,3 @@ message body will be the hex-encoded output of a NaCl `SecretBox`, keyed by a
|
||||||
phase+side -specific key (computed with HKDF-SHA256, using the shared PAKE
|
phase+side -specific key (computed with HKDF-SHA256, using the shared PAKE
|
||||||
key as the secret input, and `wormhole:phase:%s%s % (SHA256(side),
|
key as the secret input, and `wormhole:phase:%s%s % (SHA256(side),
|
||||||
SHA256(phase))` as the CTXinfo), with a random nonce.
|
SHA256(phase))` as the CTXinfo), with a random nonce.
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -180,6 +180,3 @@ texinfo_documents = [
|
||||||
author, 'Magic-Wormhole', 'One line description of project.',
|
author, 'Magic-Wormhole', 'One line description of project.',
|
||||||
'Miscellaneous'),
|
'Miscellaneous'),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
The magic-wormhole (Python) distribution provides several things: an
|
The magic-wormhole (Python) distribution provides several things: an
|
||||||
executable tool ("bin/wormhole"), an importable library (`import wormhole`),
|
executable tool ("bin/wormhole"), an importable library (`import wormhole`),
|
||||||
the URL of a publically-available Rendezvous Server, and the definition of a
|
the URL of a publicly-available Rendezvous Server, and the definition of a
|
||||||
protocol used by all three.
|
protocol used by all three.
|
||||||
|
|
||||||
The executable tool provides basic sending and receiving of files,
|
The executable tool provides basic sending and receiving of files,
|
||||||
|
@ -53,4 +53,3 @@ describes this application's use of the client messages.
|
||||||
Application use the `wormhole` library to establish wormhole connections and
|
Application use the `wormhole` library to establish wormhole connections and
|
||||||
exchange data through them. Please see `api.md` for a complete description of
|
exchange data through them. Please see `api.md` for a complete description of
|
||||||
this interface.
|
this interface.
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
|
|
||||||
default: images
|
default: images
|
||||||
|
|
||||||
images: allocator.png boss.png code.png input.png key.png lister.png machines.png mailbox.png nameplate.png order.png receive.png send.png terminator.png dilation.png
|
images: allocator.png boss.png code.png input.png key.png lister.png machines.png mailbox.png nameplate.png order.png receive.png send.png terminator.png dilation.png
|
||||||
|
|
||||||
.PHONY: default images
|
.PHONY: default images
|
||||||
|
|
||||||
|
|
|
@ -25,5 +25,5 @@ digraph {
|
||||||
P_allocated -> S2 [color="orange"]
|
P_allocated -> S2 [color="orange"]
|
||||||
|
|
||||||
S2 [label="S2:\ndone" color="orange"]
|
S2 [label="S2:\ndone" color="orange"]
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,5 +76,4 @@ digraph {
|
||||||
label="rx_welcome -> process (maybe rx_unwelcome)\nsend -> S.send\ngot_message -> got_version or got_phase\ngot_key -> W.got_key\ngot_verifier -> W.got_verifier\nallocate_code -> C.allocate_code\ninput_code -> C.input_code\nset_code -> C.set_code"
|
label="rx_welcome -> process (maybe rx_unwelcome)\nsend -> S.send\ngot_message -> got_version or got_phase\ngot_key -> W.got_key\ngot_verifier -> W.got_verifier\nallocate_code -> C.allocate_code\ninput_code -> C.input_code\nset_code -> C.set_code"
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,5 +94,5 @@ digraph {
|
||||||
S0B -> P3B_done [label="close" color="red"]
|
S0B -> P3B_done [label="close" color="red"]
|
||||||
S1A -> P3A_done [label="close" color="red"]
|
S1A -> P3A_done [label="close" color="red"]
|
||||||
S2A -> S3A [label="close" color="red"]
|
S2A -> S3A [label="close" color="red"]
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@ digraph {
|
||||||
S1B -> S2B [style="invis"]
|
S1B -> S2B [style="invis"]
|
||||||
{rank=same; S1A S1B}
|
{rank=same; S1A S1B}
|
||||||
S1A -> S1B [style="invis"]
|
S1A -> S1B [style="invis"]
|
||||||
|
|
||||||
{rank=same; S2A P2_connected S2B}
|
{rank=same; S2A P2_connected S2B}
|
||||||
S2A [label="S2A:\nmaybe claimed"]
|
S2A [label="S2A:\nmaybe claimed"]
|
||||||
S2A -> P2_connected [label="connected"]
|
S2A -> P2_connected [label="connected"]
|
||||||
|
@ -96,6 +96,5 @@ digraph {
|
||||||
S2B -> P3_release [label="close" color="red"]
|
S2B -> P3_release [label="close" color="red"]
|
||||||
S3B -> P3_release [label="close" color="red"]
|
S3B -> P3_release [label="close" color="red"]
|
||||||
S4B -> S4B [label="close" color="red"]
|
S4B -> S4B [label="close" color="red"]
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@ digraph {
|
||||||
P1_other [shape="box" label="R.got_message"]
|
P1_other [shape="box" label="R.got_message"]
|
||||||
P1_other -> S1
|
P1_other -> S1
|
||||||
|
|
||||||
|
|
||||||
/* the Mailbox will deliver each message exactly once, but doesn't
|
/* the Mailbox will deliver each message exactly once, but doesn't
|
||||||
guarantee ordering: if Alice starts the process, then disconnects,
|
guarantee ordering: if Alice starts the process, then disconnects,
|
||||||
then Bob starts (reading PAKE, sending both his PAKE and his VERSION
|
then Bob starts (reading PAKE, sending both his PAKE and his VERSION
|
||||||
|
|
|
@ -3,7 +3,7 @@ digraph {
|
||||||
|
|
||||||
{rank=same; S0 P0_queue}
|
{rank=same; S0 P0_queue}
|
||||||
{rank=same; S1 P1_send}
|
{rank=same; S1 P1_send}
|
||||||
|
|
||||||
S0 [label="S0: unknown\nkey"]
|
S0 [label="S0: unknown\nkey"]
|
||||||
S0 -> P0_queue [label="send" style="dotted"]
|
S0 -> P0_queue [label="send" style="dotted"]
|
||||||
P0_queue [shape="box" label="queue" style="dotted"]
|
P0_queue [shape="box" label="queue" style="dotted"]
|
||||||
|
|
|
@ -19,7 +19,7 @@ digraph {
|
||||||
Sno -> Sn [label="close"]
|
Sno -> Sn [label="close"]
|
||||||
Smo -> Sm [label="close" color="red"]
|
Smo -> Sm [label="close" color="red"]
|
||||||
S0o -> P_stop [label="close"]
|
S0o -> P_stop [label="close"]
|
||||||
|
|
||||||
Snm [label="Snm:\nnameplate active\nmailbox active\nclosing"
|
Snm [label="Snm:\nnameplate active\nmailbox active\nclosing"
|
||||||
style="dashed"]
|
style="dashed"]
|
||||||
Sn [label="Sn:\nnameplate active\nmailbox done\nclosing"
|
Sn [label="Sn:\nnameplate active\nmailbox done\nclosing"
|
||||||
|
@ -45,6 +45,5 @@ digraph {
|
||||||
|
|
||||||
other [shape="box" style="dashed"
|
other [shape="box" style="dashed"
|
||||||
label="close -> N.close, M.close"]
|
label="close -> N.close, M.close"]
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ Just add ``--tor`` to use a running Tor daemon:
|
||||||
|
|
||||||
```
|
```
|
||||||
wormhole send --tor myfile.jpg
|
wormhole send --tor myfile.jpg
|
||||||
|
|
||||||
wormhole receive --tor
|
wormhole receive --tor
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
|
@ -164,7 +164,7 @@ be handled immediately. The complete example is here:
|
||||||
```python
|
```python
|
||||||
from twisted.internet.defer import inlineCallbacks
|
from twisted.internet.defer import inlineCallbacks
|
||||||
from wormhole.transit import TransitSender
|
from wormhole.transit import TransitSender
|
||||||
|
|
||||||
@inlineCallbacks
|
@inlineCallbacks
|
||||||
def do_transit():
|
def do_transit():
|
||||||
s = TransitSender("tcp:relayhost.example.org:12345")
|
s = TransitSender("tcp:relayhost.example.org:12345")
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
digraph {
|
digraph {
|
||||||
|
|
||||||
/*
|
/*
|
||||||
NM_start [label="Nameplate\nMachine" style="dotted"]
|
NM_start [label="Nameplate\nMachine" style="dotted"]
|
||||||
NM_start -> NM_S_unclaimed [style="invis"]
|
NM_start -> NM_S_unclaimed [style="invis"]
|
||||||
|
|
|
@ -25,7 +25,7 @@ Sender:
|
||||||
Sending 7924 byte file named 'README.md'
|
Sending 7924 byte file named 'README.md'
|
||||||
On the other computer, please run: wormhole receive
|
On the other computer, please run: wormhole receive
|
||||||
Wormhole code is: 7-crossover-clockwork
|
Wormhole code is: 7-crossover-clockwork
|
||||||
|
|
||||||
Sending (<-10.0.1.43:58988)..
|
Sending (<-10.0.1.43:58988)..
|
||||||
100%|=========================| 7.92K/7.92K [00:00<00:00, 6.02MB/s]
|
100%|=========================| 7.92K/7.92K [00:00<00:00, 6.02MB/s]
|
||||||
File sent.. waiting for confirmation
|
File sent.. waiting for confirmation
|
||||||
|
|
|
@ -56,4 +56,3 @@ def web():
|
||||||
reactor.callLater(0, launch_browser)
|
reactor.callLater(0, launch_browser)
|
||||||
reactor.run()
|
reactor.run()
|
||||||
web()
|
web()
|
||||||
|
|
||||||
|
|
|
@ -1017,7 +1017,7 @@ function OFF() {
|
||||||
.attr("stroke", "red")
|
.attr("stroke", "red")
|
||||||
;
|
;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// horizontal scale markers: vertical lines at rational timestamps
|
// horizontal scale markers: vertical lines at rational timestamps
|
||||||
|
|
|
@ -14,4 +14,3 @@
|
||||||
pyinstaller --clean --distpath=dist wormhole.exe.spec
|
pyinstaller --clean --distpath=dist wormhole.exe.spec
|
||||||
|
|
||||||
# result will be in dist/wormhole.exe
|
# result will be in dist/wormhole.exe
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ universal = 1
|
||||||
VCS = git
|
VCS = git
|
||||||
versionfile_source = src/wormhole/_version.py
|
versionfile_source = src/wormhole/_version.py
|
||||||
versionfile_build = wormhole/_version.py
|
versionfile_build = wormhole/_version.py
|
||||||
tag_prefix =
|
tag_prefix =
|
||||||
parentdir_prefix = magic-wormhole
|
parentdir_prefix = magic-wormhole
|
||||||
|
|
||||||
[flake8]
|
[flake8]
|
||||||
|
|
|
@ -77,7 +77,7 @@ from .connection import KCM, Ping, Pong, Ack
|
||||||
# time.
|
# time.
|
||||||
# * If we're writing too slowly, we'll be left in the "unpaused" state: all
|
# * If we're writing too slowly, we'll be left in the "unpaused" state: all
|
||||||
# Subchannel producers are unpaused, and the aggregate is unpaused too
|
# Subchannel producers are unpaused, and the aggregate is unpaused too
|
||||||
# (resumeProducing is the last thing we've been told). In this satte,
|
# (resumeProducing is the last thing we've been told). In this state,
|
||||||
# activity is driven by the Subchannels doing a transport.write, which
|
# activity is driven by the Subchannels doing a transport.write, which
|
||||||
# queues some data on the TCP connection (and then might call
|
# queues some data on the TCP connection (and then might call
|
||||||
# pauseProducing if it's now full).
|
# pauseProducing if it's now full).
|
||||||
|
|
|
@ -8,7 +8,7 @@ from zope.interface import implementer
|
||||||
from ._interfaces import IWordlist
|
from ._interfaces import IWordlist
|
||||||
|
|
||||||
# The PGP Word List, which maps bytes to phonetically-distinct words. There
|
# The PGP Word List, which maps bytes to phonetically-distinct words. There
|
||||||
# are two lists, even and odd, and encodings should alternate between then to
|
# are two lists, even and odd, and encodings should alternate between them to
|
||||||
# detect dropped words. https://en.wikipedia.org/wiki/PGP_Words
|
# detect dropped words. https://en.wikipedia.org/wiki/PGP_Words
|
||||||
|
|
||||||
# Thanks to Warren Guy for transcribing them:
|
# Thanks to Warren Guy for transcribing them:
|
||||||
|
|
|
@ -51,7 +51,7 @@ class WrongPasswordError(WormholeError):
|
||||||
"""
|
"""
|
||||||
Key confirmation failed. Either you or your correspondent typed the code
|
Key confirmation failed. Either you or your correspondent typed the code
|
||||||
wrong, or a would-be man-in-the-middle attacker guessed incorrectly. Try
|
wrong, or a would-be man-in-the-middle attacker guessed incorrectly. Try
|
||||||
sending the file again.
|
sending the file again.
|
||||||
"""
|
"""
|
||||||
# or the data blob was corrupted, and that's why decrypt failed
|
# or the data blob was corrupted, and that's why decrypt failed
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -88,5 +88,3 @@ class Connect(unittest.TestCase):
|
||||||
|
|
||||||
yield t_left.d
|
yield t_left.d
|
||||||
yield t_right.d
|
yield t_right.d
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -624,4 +624,3 @@ class TestManager(unittest.TestCase):
|
||||||
self.flushLoggedErrors(UnknownDilationMessageType)
|
self.flushLoggedErrors(UnknownDilationMessageType)
|
||||||
|
|
||||||
# TODO: test transit relay is used
|
# TODO: test transit relay is used
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user