more diagram work
This commit is contained in:
parent
8a9b50b320
commit
b1f313b116
220
docs/w.dot
220
docs/w.dot
|
@ -1,72 +1,134 @@
|
||||||
digraph {
|
digraph {
|
||||||
W_S_nothing [label="know\nnothing"]
|
/* could shave a RTT by committing to the nameplate early, before
|
||||||
W_S_nothing -> W_S_know_nameplate [label="set_nameplate()"]
|
finishing the rest of the code input. While the user is still
|
||||||
W_S_know_nameplate [label="know (just)\nnameplate"]
|
typing/completing the code, we claim the nameplate, open the mailbox,
|
||||||
|
and retrieve the peer's PAKE message. Then as soon as the user
|
||||||
|
finishes entering the code, we build our own PAKE message, send PAKE,
|
||||||
|
compute the key, send VERSION. Starting from the Return, this saves
|
||||||
|
two round trips. OTOH it adds consequences to hitting Tab. */
|
||||||
|
|
||||||
W_P_build_and_post_pake [label="build_pake()\nMM_send(pake)" shape="box"]
|
WM_start [label="Wormhole\nMachine" style="dotted"]
|
||||||
W_S_know_code [label="know code\n"]
|
WM_start -> WM_S_nothing [style="invis"]
|
||||||
W_P_compute_key [label="compute_key()" shape="box"]
|
|
||||||
W_P_post_version [label="MM_send(version)\nnotify_verifier()" shape="box"]
|
|
||||||
W_S_know_key [label="know_key\nunverified" color="orange"]
|
|
||||||
W_P_verify [label="verify(msg)" shape="box"]
|
|
||||||
W_P_accept_msg [label="deliver\ninbound\nmsg()" shape="box"]
|
|
||||||
W_S_verified_key [color="green"]
|
|
||||||
W_P_mood_scary [shape="box" label="mood(scary)"]
|
|
||||||
W_P_notify_failure [shape="box" label="notify_failure()" color="red"]
|
|
||||||
W_P_mood_happy [shape="box" label="mood(happy)"]
|
|
||||||
W_S_closed [label="closed"]
|
|
||||||
W_P_mood_lonely [shape="box" label="mood(lonely)"]
|
|
||||||
W_P_queue1 [shape="box" style="dotted" label="queue\noutbound msg"]
|
|
||||||
W_P_queue2 [shape="box" style="dotted" label="queue\noutbound msg"]
|
|
||||||
W_P_queue3 [shape="box" style="dotted" label="queue\noutbound msg"]
|
|
||||||
W_P_queue4 [shape="box" style="dotted" label="queue\noutbound msg"]
|
|
||||||
W_P_send [shape="box" label="MM_send(msg)"]
|
|
||||||
W_P_send_queued [shape="box" label="MM_send()\nany queued\nmessages"]
|
|
||||||
|
|
||||||
W_S_nothing -> W_P_build_and_post_pake [label="set_code()"]
|
WM_S_nothing [label="know\nnothing"]
|
||||||
W_S_nothing -> W_P_queue1 [label="API_send" style="dotted"]
|
WM_S_nothing -> WM_P_queue1 [label="API_send" style="dotted"]
|
||||||
W_P_queue1 -> W_S_nothing [style="dotted"]
|
WM_P_queue1 [shape="box" style="dotted" label="queue\noutbound msg"]
|
||||||
W_S_know_nameplate -> W_P_got_pakeinfo [label="W_rx_pake"]
|
WM_P_queue1 -> WM_S_nothing [style="dotted"]
|
||||||
W_S_know_nameplate -> W_P_build_and_post_pake [label="set_code()"]
|
WM_S_nothing -> WM_P_build_and_post_pake [label="WM_set_code()"]
|
||||||
W_P_got_pakeinfo [shape="box" label="got wordlist"]
|
|
||||||
W_P_got_pakeinfo -> W_S_know_pake2
|
|
||||||
W_S_know_pake2 [label="know their pake"]
|
|
||||||
W_S_know_pake2 -> W_P_compute_key [label="set_code()"]
|
|
||||||
W_S_know_pake2 -> W_P_queue4 [label="API_send" style="dotted"]
|
|
||||||
W_P_queue4 -> W_S_know_pake2 [style="dotted"]
|
|
||||||
W_P_build_and_post_pake -> W_S_know_code
|
|
||||||
W_S_know_code -> W_P_compute_key [label="W_rx_pake"]
|
|
||||||
W_S_know_code -> W_P_queue2 [label="API_send" style="dotted"]
|
|
||||||
W_P_queue2 -> W_S_know_code [style="dotted"]
|
|
||||||
W_P_compute_key -> W_P_post_version [label="pake ok"]
|
|
||||||
W_P_post_version -> W_S_know_key
|
|
||||||
W_P_compute_key -> W_P_mood_scary [label="pake bad"]
|
|
||||||
W_P_mood_scary -> W_P_notify_failure
|
|
||||||
W_P_notify_failure -> W_S_closed
|
|
||||||
W_S_know_key -> W_P_verify [label="W_rx_msg()"] /* version or phase */
|
|
||||||
W_S_know_key -> W_P_mood_lonely [label="close"] /* more like impatient */
|
|
||||||
W_S_know_key -> W_P_queue3 [label="API_send" style="dotted"]
|
|
||||||
W_P_queue3 -> W_S_know_key [style="dotted"]
|
|
||||||
W_P_verify -> W_P_accept_msg [label="verify good"]
|
|
||||||
W_P_accept_msg -> W_P_send_queued
|
|
||||||
W_P_send_queued -> W_S_verified_key
|
|
||||||
W_P_verify -> W_P_mood_scary [label="verify bad"]
|
|
||||||
W_S_verified_key -> W_P_verify [label="W_rx_msg()"] /* probably phase */
|
|
||||||
W_S_verified_key -> W_P_mood_happy [label="close"]
|
|
||||||
W_P_mood_happy -> W_S_closed
|
|
||||||
W_S_verified_key -> W_P_send [label="API_send"]
|
|
||||||
W_P_send -> W_S_verified_key
|
|
||||||
W_S_know_code -> W_P_mood_lonely [label="close"]
|
|
||||||
W_P_mood_lonely -> W_S_closed
|
|
||||||
|
|
||||||
|
WM_P_build_and_post_pake [label="NM_set_nameplate()\nbuild_pake()\nMM_send(pake)" shape="box"]
|
||||||
|
WM_P_build_and_post_pake -> WM_S_know_code
|
||||||
|
|
||||||
|
WM_S_know_code [label="know code\n"]
|
||||||
|
WM_S_know_code -> WM_P_queue2 [label="API_send" style="dotted"]
|
||||||
|
WM_P_queue2 [shape="box" style="dotted" label="queue\noutbound msg"]
|
||||||
|
WM_P_queue2 -> WM_S_know_code [style="dotted"]
|
||||||
|
WM_S_know_code -> WM_P_compute_key [label="WM_rx_pake"]
|
||||||
|
WM_S_know_code -> WM_P_mood_lonely [label="close"]
|
||||||
|
|
||||||
|
WM_P_compute_key [label="compute_key()" shape="box"]
|
||||||
|
WM_P_compute_key -> WM_P_post_version [label="pake ok"]
|
||||||
|
WM_P_compute_key -> WM_P_mood_scary [label="pake bad"]
|
||||||
|
|
||||||
|
WM_P_mood_scary [shape="box" label="MM_close()\nmood=scary"]
|
||||||
|
WM_P_mood_scary -> WM_P_notify_failure
|
||||||
|
|
||||||
|
WM_P_notify_failure [shape="box" label="notify_failure()" color="red"]
|
||||||
|
WM_P_notify_failure -> WM_S_closed
|
||||||
|
|
||||||
|
WM_P_post_version [label="MM_send(version)\nnotify_verifier()" shape="box"]
|
||||||
|
WM_P_post_version -> WM_S_know_key
|
||||||
|
|
||||||
|
WM_S_know_key [label="know_key\nunverified" color="orange"]
|
||||||
|
WM_S_know_key -> WM_P_queue3 [label="API_send" style="dotted"]
|
||||||
|
WM_P_queue3 [shape="box" style="dotted" label="queue\noutbound msg"]
|
||||||
|
WM_P_queue3 -> WM_S_know_key [style="dotted"]
|
||||||
|
WM_S_know_key -> WM_P_verify [label="WM_rx_msg()"] /* version or phase */
|
||||||
|
WM_S_know_key -> WM_P_mood_lonely [label="close"] /* more like impatient */
|
||||||
|
|
||||||
|
WM_P_verify [label="verify(msg)" shape="box"]
|
||||||
|
WM_P_verify -> WM_P_accept_msg [label="verify good"]
|
||||||
|
WM_P_verify -> WM_P_mood_scary [label="verify bad"]
|
||||||
|
|
||||||
|
WM_P_accept_msg [label="deliver\ninbound\nmsg()" shape="box"]
|
||||||
|
WM_P_accept_msg -> WM_P_send_queued
|
||||||
|
|
||||||
|
WM_P_send_queued [shape="box" label="MM_send()\nany queued\nmessages"]
|
||||||
|
WM_P_send_queued -> WM_S_verified_key
|
||||||
|
|
||||||
|
WM_S_verified_key [color="green"]
|
||||||
|
WM_S_verified_key -> WM_P_verify [label="WM_rx_msg()"] /* probably phase */
|
||||||
|
WM_S_verified_key -> WM_P_mood_happy [label="close"]
|
||||||
|
WM_S_verified_key -> WM_P_send [label="API_send"]
|
||||||
|
|
||||||
|
WM_P_mood_happy [shape="box" label="MM_close()\nmood=happy"]
|
||||||
|
WM_P_mood_happy -> WM_S_closed
|
||||||
|
|
||||||
|
WM_P_mood_lonely [shape="box" label="MM_close()\nmood=lonely"]
|
||||||
|
WM_P_mood_lonely -> WM_S_closed
|
||||||
|
|
||||||
|
WM_P_send [shape="box" label="MM_send(msg)"]
|
||||||
|
WM_P_send -> WM_S_verified_key
|
||||||
|
|
||||||
|
WM_S_closed [label="closed"]
|
||||||
|
|
||||||
|
|
||||||
|
WCM_start [label="Wormhole Code\nMachine" style="dotted"]
|
||||||
|
WCM_start -> WCM_S_unknown [style="invis"]
|
||||||
|
WCM_S_unknown [label="unknown"]
|
||||||
|
WCM_S_unknown -> WCM_P_set_code [label="set"]
|
||||||
|
WCM_P_set_code [shape="box" label="WM_set_code()"]
|
||||||
|
WCM_P_set_code -> WCM_S_known
|
||||||
|
WCM_S_known [label="known"]
|
||||||
|
|
||||||
|
WCM_S_unknown -> WCM_P_list_nameplates [label="input"]
|
||||||
|
WCM_S_typing_nameplate [label="typing\nnameplate"]
|
||||||
|
|
||||||
|
WCM_S_typing_nameplate -> WCM_P_nameplate_completion [label="<tab>"]
|
||||||
|
WCM_P_nameplate_completion [shape="box" label="completion?"]
|
||||||
|
WCM_P_nameplate_completion -> WCM_P_list_nameplates
|
||||||
|
WCM_P_list_nameplates [shape="box" label="NLM_update_nameplates()"]
|
||||||
|
WCM_P_list_nameplates -> WCM_S_typing_nameplate
|
||||||
|
|
||||||
|
WCM_S_typing_nameplate -> WCM_P_got_nameplates [label="C_rx_nameplates()"]
|
||||||
|
WCM_P_got_nameplates [shape="box" label="stash nameplates\nfor completion"]
|
||||||
|
WCM_P_got_nameplates -> WCM_S_typing_nameplate
|
||||||
|
WCM_S_typing_nameplate -> WCM_P_finish_nameplate [label="finished\nnameplate"]
|
||||||
|
WCM_P_finish_nameplate [shape="box" label="lookup wordlist\nfor completion"]
|
||||||
|
WCM_P_finish_nameplate -> WCM_S_typing_code
|
||||||
|
WCM_S_typing_code [label="typing\ncode"]
|
||||||
|
WCM_S_typing_code -> WCM_P_code_completion [label="<tab>"]
|
||||||
|
WCM_P_code_completion [shape="box" label="completion"]
|
||||||
|
WCM_P_code_completion -> WCM_S_typing_code
|
||||||
|
|
||||||
|
WCM_S_typing_code -> WCM_P_set_code [label="finished\ncode"]
|
||||||
|
|
||||||
|
WCM_S_unknown -> WCM_P_allocate [label="allocate"]
|
||||||
|
WCM_P_allocate [shape="box" label="C_allocate_nameplate()"]
|
||||||
|
WCM_P_allocate -> WCM_S_allocate_waiting
|
||||||
|
WCM_S_allocate_waiting [label="waiting"]
|
||||||
|
WCM_S_allocate_waiting -> WCM_P_allocate_generate [label="WCM_rx_allocation()"]
|
||||||
|
WCM_P_allocate_generate [shape="box" label="generate\nrandom code"]
|
||||||
|
WCM_P_allocate_generate -> WCM_P_set_code
|
||||||
|
|
||||||
|
/* ConnectionMachine */
|
||||||
|
/*WCM_S_known -> CM_start [style="invis"]
|
||||||
|
CM_start [label="Connection\nMachine" style="dotted"]
|
||||||
|
CM_start -> CM_S_neither [style="invis"]
|
||||||
|
CM_S_neither [label="neither"]*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
NM_start [label="Nameplate\nMachine" style="dotted"]
|
||||||
|
NM_start -> NM_S_unclaimed [style="invis"]
|
||||||
NM_S_unclaimed [label="no nameplate"]
|
NM_S_unclaimed [label="no nameplate"]
|
||||||
NM_S_unclaimed -> NM_S_unclaimed [label="NM_release()"]
|
NM_S_unclaimed -> NM_S_unclaimed [label="NM_release()"]
|
||||||
NM_P_set_nameplate [shape="box" label="post_claim()"]
|
NM_P_set_nameplate [shape="box" label="post_claim()"]
|
||||||
NM_S_unclaimed -> NM_P_set_nameplate [label="set_nameplate()"]
|
NM_S_unclaimed -> NM_P_set_nameplate [label="NM_set_nameplate()"]
|
||||||
NM_S_claiming [label="claim pending"]
|
NM_S_claiming [label="claim pending"]
|
||||||
NM_P_set_nameplate -> NM_S_claiming
|
NM_P_set_nameplate -> NM_S_claiming
|
||||||
NM_S_claiming -> NM_P_rx_claimed [label="rx claimed"]
|
NM_S_claiming -> NM_P_rx_claimed [label="rx claimed"]
|
||||||
NM_P_rx_claimed [label="set_mailbox()" shape="box"]
|
NM_P_rx_claimed [label="MM_set_mailbox()" shape="box"]
|
||||||
NM_P_rx_claimed -> NM_S_claimed
|
NM_P_rx_claimed -> NM_S_claimed
|
||||||
NM_S_claimed [label="claimed"]
|
NM_S_claimed [label="claimed"]
|
||||||
NM_S_claimed -> NM_P_release [label="NM_release()"]
|
NM_S_claimed -> NM_P_release [label="NM_release()"]
|
||||||
|
@ -79,6 +141,8 @@ digraph {
|
||||||
NM_S_released -> NM_S_released [label="NM_release()"]
|
NM_S_released -> NM_S_released [label="NM_release()"]
|
||||||
|
|
||||||
|
|
||||||
|
MM_start [label="Mailbox\nMachine" style="dotted"]
|
||||||
|
MM_start -> MM_S_want_mailbox [style="invis"]
|
||||||
MM_S_want_mailbox [label="want mailbox"]
|
MM_S_want_mailbox [label="want mailbox"]
|
||||||
MM_S_want_mailbox -> MM_P_queue1 [label="MM_send()" style="dotted"]
|
MM_S_want_mailbox -> MM_P_queue1 [label="MM_send()" style="dotted"]
|
||||||
MM_P_queue1 [shape="box" style="dotted" label="queue message"]
|
MM_P_queue1 [shape="box" style="dotted" label="queue message"]
|
||||||
|
@ -88,21 +152,36 @@ digraph {
|
||||||
MM_P_send_queued [shape="box" label="post add() for\nqueued messages"]
|
MM_P_send_queued [shape="box" label="post add() for\nqueued messages"]
|
||||||
MM_P_open_mailbox -> MM_P_send_queued
|
MM_P_open_mailbox -> MM_P_send_queued
|
||||||
MM_P_send_queued -> MM_S_open
|
MM_P_send_queued -> MM_S_open
|
||||||
MM_S_open [label="open\nunused"]
|
MM_S_open [label="open\n(unused)"]
|
||||||
MM_S_open -> MM_P_send_queued [label="MM_send()"]
|
MM_S_open -> MM_P_send1 [label="MM_send()"]
|
||||||
|
MM_P_send1 [shape="box" label="post add()\nfor message"]
|
||||||
|
MM_P_send1 -> MM_S_open
|
||||||
|
MM_S_open -> MM_P_release1 [label="MM_close()"]
|
||||||
|
MM_P_release1 [shape="box" label="NM_release()"]
|
||||||
|
MM_P_release1 -> MM_P_close
|
||||||
|
|
||||||
MM_S_open -> MM_P_rx [label="rx message"]
|
MM_S_open -> MM_P_rx [label="rx message"]
|
||||||
MM_P_rx [shape="box" label="W_rx_pake()\nor W_rx_msg()"]
|
MM_P_rx [shape="box" label="WM_rx_pake()\nor WM_rx_msg()"]
|
||||||
MM_P_rx -> MM_P_release
|
MM_P_rx -> MM_P_release2
|
||||||
MM_P_release [shape="box" label="NM_release()"]
|
MM_P_release2 [shape="box" label="NM_release()"]
|
||||||
MM_P_release -> MM_S_used
|
MM_P_release2 -> MM_S_used
|
||||||
MM_S_used [label="open\nused"]
|
MM_S_used [label="open\n(used)"]
|
||||||
MM_S_used -> MM_P_rx [label="rx message"]
|
MM_S_used -> MM_P_rx [label="rx message"]
|
||||||
MM_S_used -> MM_P_send [label="MM_send()"]
|
MM_S_used -> MM_P_send2 [label="MM_send()"]
|
||||||
MM_P_send [shape="box" label="post message"]
|
MM_P_send2 [shape="box" label="post add()\nfor message"]
|
||||||
MM_P_send -> MM_S_used
|
MM_P_send2 -> MM_S_used
|
||||||
|
MM_S_used -> MM_P_close [label="MM_close()"]
|
||||||
|
MM_P_close [shape="box" label="post_close(mood)"]
|
||||||
|
MM_P_close -> MM_S_closing
|
||||||
|
MM_S_closing [label="waiting"]
|
||||||
|
MM_S_closing -> MM_S_closing [label="MM_close()"]
|
||||||
|
MM_S_closing -> MM_S_closed [label="rx closed"]
|
||||||
|
MM_S_closed [label="closed"]
|
||||||
|
MM_S_closed -> MM_S_closed [label="MM_close()"]
|
||||||
|
|
||||||
/* upgrading to new PAKE algorithm */
|
/* upgrading to new PAKE algorithm, the slower form (the faster form
|
||||||
|
puts the pake_abilities record in the nameplate_info message) */
|
||||||
|
/*
|
||||||
P2_start [label="(PAKE\nupgrade)\nstart"]
|
P2_start [label="(PAKE\nupgrade)\nstart"]
|
||||||
P2_start -> P2_P_send_abilities [label="set_code()"]
|
P2_start -> P2_P_send_abilities [label="set_code()"]
|
||||||
P2_P_send_abilities [shape="box" label="send pake_abilities"]
|
P2_P_send_abilities [shape="box" label="send pake_abilities"]
|
||||||
|
@ -119,4 +198,5 @@ digraph {
|
||||||
P2_P_send_pakev2 [shape="box" label="send pake_v2"]
|
P2_P_send_pakev2 [shape="box" label="send pake_v2"]
|
||||||
P2_P_send_pakev2 -> P2_P_process_v2 [label="rx pake_v2"]
|
P2_P_send_pakev2 -> P2_P_process_v2 [label="rx pake_v2"]
|
||||||
P2_P_process_v2 [shape="box" label="process v2"]
|
P2_P_process_v2 [shape="box" label="process v2"]
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user