83e55f1f3e
Previously, w.when_verified() was documented to fire only after a valid encrypted message was received, but in fact it fired as soon as the shared key was derived (before any encrypted messages are seen, so no actual "verification" could occur yet). This fixes that, and also adds a new w.when_key() API call which fires at the earlier point. Having something which fires early is useful for the CLI commands that want to print a pacifier message when the peer is responding slowly. In particular it helps detect the case where 'wormhole send' has quit early (after depositing the PAKE message on the server, but before the receiver has started). In this case, the receiver will compute the shared key, but then wait forever hoping for a VERSION that will never come. By starting a timer when w.when_key() fires, and cancelling it when w.when_verified() fires, we have a good place to tell the user that something is taking longer than it should have. This shifts responsibility for notifying Boss.got_verifier, out of Key and into Receive, since Receive is what notices the first valid encrypted message. It also shifts the Boss's ordering expectations: it now receives B.happy() before B.got_verifier(), and consequently got_verifier ought to arrive in the S2_happy state rather than S1_lonely.
116 lines
5.9 KiB
Plaintext
116 lines
5.9 KiB
Plaintext
digraph {
|
|
Wormhole [shape="oval" color="blue" fontcolor="blue"]
|
|
Boss [shape="box" label="Boss\n(manager)"
|
|
color="blue" fontcolor="blue"]
|
|
Nameplate [label="Nameplate\n(claimer)"
|
|
shape="box" color="blue" fontcolor="blue"]
|
|
Mailbox [label="Mailbox\n(opener)"
|
|
shape="box" color="blue" fontcolor="blue"]
|
|
Connection [label="Rendezvous\nConnector"
|
|
shape="oval" color="blue" fontcolor="blue"]
|
|
#websocket [color="blue" fontcolor="blue"]
|
|
Order [shape="box" label="Ordering" color="blue" fontcolor="blue"]
|
|
Key [shape="box" label="Key" color="blue" fontcolor="blue"]
|
|
Send [shape="box" label="Send" color="blue" fontcolor="blue"]
|
|
Receive [shape="box" label="Receive" color="blue" fontcolor="blue"]
|
|
Code [shape="box" label="Code" color="blue" fontcolor="blue"]
|
|
Lister [shape="box" label="(nameplate)\nLister"
|
|
color="blue" fontcolor="blue"]
|
|
Allocator [shape="box" label="(nameplate)\nAllocator"
|
|
color="blue" fontcolor="blue"]
|
|
Input [shape="box" label="(interactive\ncode)\nInput"
|
|
color="blue" fontcolor="blue"]
|
|
Terminator [shape="box" color="blue" fontcolor="blue"]
|
|
InputHelperAPI [shape="oval" label="input\nhelper\nAPI"
|
|
color="blue" fontcolor="blue"]
|
|
|
|
#Connection -> websocket [color="blue"]
|
|
#Connection -> Order [color="blue"]
|
|
|
|
Wormhole -> Boss [style="dashed"
|
|
label="allocate_code\ninput_code\nset_code\nsend\nclose\n(once)"
|
|
color="red" fontcolor="red"]
|
|
#Wormhole -> Boss [color="blue"]
|
|
Boss -> Wormhole [style="dashed" label="got_code\ngot_key\ngot_verifier\ngot_version\nreceived (seq)\nclosed\n(once)"]
|
|
|
|
#Boss -> Connection [color="blue"]
|
|
Boss -> Connection [style="dashed" label="start"
|
|
color="red" fontcolor="red"]
|
|
Connection -> Boss [style="dashed" label="rx_welcome\nrx_error\nerror"]
|
|
|
|
Boss -> Send [style="dashed" color="red" fontcolor="red" label="send"]
|
|
|
|
#Boss -> Mailbox [color="blue"]
|
|
Mailbox -> Order [style="dashed" label="got_message (once)"]
|
|
Key -> Boss [style="dashed" label="got_key\nscared"]
|
|
Order -> Key [style="dashed" label="got_pake"]
|
|
Order -> Receive [style="dashed" label="got_message"]
|
|
#Boss -> Key [color="blue"]
|
|
Key -> Mailbox [style="dashed"
|
|
label="add_message (pake)\nadd_message (version)"]
|
|
Receive -> Send [style="dashed" label="got_verified_key"]
|
|
Send -> Mailbox [style="dashed" color="red" fontcolor="red"
|
|
label="add_message (phase)"]
|
|
|
|
Key -> Receive [style="dashed" label="got_key"]
|
|
Receive -> Boss [style="dashed"
|
|
label="happy\nscared\ngot_verifier\ngot_message"]
|
|
Nameplate -> Connection [style="dashed"
|
|
label="tx_claim\ntx_release"]
|
|
Connection -> Nameplate [style="dashed"
|
|
label="connected\nlost\nrx_claimed\nrx_released"]
|
|
Mailbox -> Nameplate [style="dashed" label="release"]
|
|
Nameplate -> Mailbox [style="dashed" label="got_mailbox"]
|
|
Nameplate -> Input [style="dashed" label="got_wordlist"]
|
|
|
|
Mailbox -> Connection [style="dashed" color="red" fontcolor="red"
|
|
label="tx_open\ntx_add\ntx_close"
|
|
]
|
|
Connection -> Mailbox [style="dashed"
|
|
label="connected\nlost\nrx_message\nrx_closed\nstopped"]
|
|
|
|
Connection -> Lister [style="dashed"
|
|
label="connected\nlost\nrx_nameplates"
|
|
]
|
|
Lister -> Connection [style="dashed"
|
|
label="tx_list"
|
|
]
|
|
|
|
#Boss -> Code [color="blue"]
|
|
Connection -> Allocator [style="dashed"
|
|
label="connected\nlost\nrx_allocated"]
|
|
Allocator -> Connection [style="dashed" color="red" fontcolor="red"
|
|
label="tx_allocate"
|
|
]
|
|
Lister -> Input [style="dashed"
|
|
label="got_nameplates"
|
|
]
|
|
#Code -> Lister [color="blue"]
|
|
Input -> Lister [style="dashed" color="red" fontcolor="red"
|
|
label="refresh"
|
|
]
|
|
Boss -> Code [style="dashed" color="red" fontcolor="red"
|
|
label="allocate_code\ninput_code\nset_code"]
|
|
Code -> Boss [style="dashed" label="got_code"]
|
|
Code -> Key [style="dashed" label="got_code"]
|
|
Code -> Nameplate [style="dashed" label="set_nameplate"]
|
|
|
|
Code -> Input [style="dashed" color="red" fontcolor="red" label="start"]
|
|
Input -> Code [style="dashed" label="got_nameplate\nfinished_input"]
|
|
InputHelperAPI -> Input [label="refresh_nameplates\nget_nameplate_completions\nchoose_nameplate\nget_word_completions\nchoose_words" color="orange" fontcolor="orange"]
|
|
|
|
Code -> Allocator [style="dashed" color="red" fontcolor="red"
|
|
label="allocate"]
|
|
Allocator -> Code [style="dashed" label="allocated"]
|
|
|
|
Nameplate -> Terminator [style="dashed" label="nameplate_done"]
|
|
Mailbox -> Terminator [style="dashed" label="mailbox_done"]
|
|
Terminator -> Nameplate [style="dashed" label="close"]
|
|
Terminator -> Mailbox [style="dashed" label="close"]
|
|
Terminator -> Connection [style="dashed" label="stop"]
|
|
Connection -> Terminator [style="dashed" label="stopped"]
|
|
Terminator -> Boss [style="dashed" label="closed\n(once)"]
|
|
Boss -> Terminator [style="dashed" color="red" fontcolor="red"
|
|
label="close"]
|
|
}
|