magic-wormhole/src/wormhole/_mailbox.py

178 lines
5.9 KiB
Python
Raw Normal View History

2016-12-30 05:30:59 +00:00
from attr import attrs, attrib
from automat import MethodicalMachine
@attrs
class _Mailbox_Machine(object):
_m = attrib()
m = MethodicalMachine()
@m.state(initial=True)
def initial(self): pass
@m.state()
def S1A(self): pass # know nothing, not connected
@m.state()
def S1B(self): pass # know nothing, yes connected
@m.state()
def S2A(self): pass # not claimed, not connected
@m.state()
def S2B(self): pass # maybe claimed, yes connected
@m.state()
def S2C(self): pass # maybe claimed, not connected
@m.state()
def S3A(self): pass # claimed, maybe opened, not connected
@m.state()
def S3B(self): pass # claimed, maybe opened, yes connected
@m.state()
def S4A(self): pass # maybe released, maybe opened, not connected
@m.state()
def S4B(self): pass # maybe released, maybe opened, yes connected
@m.state()
def S5A(self): pass # released, maybe open, not connected
@m.state()
def S5B(self): pass # released, maybe open, yes connected
@m.state()
def SrcA(self): pass # waiting for release+close, not connected
@m.state()
def SrcB(self): pass # waiting for release+close, yes connected
@m.state()
def SrA(self): pass # waiting for release, not connected
@m.state()
def SrB(self): pass # waiting for release, yes connected
@m.state()
def ScA(self): pass # waiting for close, not connected
@m.state()
def ScB(self): pass # waiting for close, yes connected
@m.state()
def SsB(self): pass # closed, stopping
@m.state()
def Ss(self): pass # stopped
def connected(self, ws):
self._ws = ws
self.M_connected()
@m.input()
def M_start_unconnected(self): pass
@m.input()
def M_start_connected(self): pass
@m.input()
def M_set_nameplate(self): pass
@m.input()
def M_connected(self): pass
@m.input()
def M_lost(self): pass
@m.input()
def M_send(self, msg): pass
@m.input()
def M_rx_claimed(self): pass
@m.input()
def M_rx_msg_from_me(self, msg): pass
@m.input()
def M_rx_msg_from_them(self, msg): pass
@m.input()
def M_rx_released(self): pass
@m.input()
def M_rx_closed(self): pass
@m.input()
def M_stop(self): pass
@m.input()
2016-12-30 05:30:59 +00:00
def M_stopped(self): pass
@m.output()
def tx_claim(self): pass
@m.output()
def tx_open(self): pass
@m.output()
def queue(self, msg): pass
@m.output()
def store_mailbox(self): pass # trouble(mb)
@m.output()
def tx_add(self, msg): pass
@m.output()
def tx_add_queued(self): pass
@m.output()
def tx_release(self): pass
@m.output()
def tx_close(self): pass
@m.output()
2016-12-30 05:30:59 +00:00
def process_msg_from_them(self, msg): pass
@m.output()
def dequeue(self, msg): pass
@m.output()
def C_stop(self): pass
2016-12-30 05:30:59 +00:00
initial.upon(M_start_connected, enter=S1A, outputs=[])
initial.upon(M_start_unconnected, enter=S1B, outputs=[])
S1A.upon(M_connected, enter=S1B, outputs=[])
S1A.upon(M_set_nameplate, enter=S2A, outputs=[])
S1A.upon(M_stop, enter=SsB, outputs=[C_stop])
2016-12-30 05:30:59 +00:00
S1B.upon(M_lost, enter=S1A, outputs=[])
S1B.upon(M_set_nameplate, enter=S2B, outputs=[tx_claim])
S1B.upon(M_stop, enter=SsB, outputs=[C_stop])
2016-12-30 05:30:59 +00:00
S2A.upon(M_connected, enter=S2B, outputs=[tx_claim])
S2A.upon(M_stop, enter=SsB, outputs=[C_stop])
2016-12-30 05:30:59 +00:00
S2A.upon(M_send, enter=S2A, outputs=[queue])
S2B.upon(M_lost, enter=S2C, outputs=[])
S2B.upon(M_send, enter=S2B, outputs=[queue])
S2B.upon(M_stop, enter=SrB, outputs=[tx_release])
2016-12-30 05:30:59 +00:00
S2B.upon(M_rx_claimed, enter=S3B, outputs=[store_mailbox, tx_open,
tx_add_queued])
S2C.upon(M_connected, enter=S2B, outputs=[tx_claim])
S2C.upon(M_send, enter=S2C, outputs=[queue])
S2C.upon(M_stop, enter=SrA, outputs=[])
2016-12-30 05:30:59 +00:00
S3A.upon(M_connected, enter=S3B, outputs=[tx_open, tx_add_queued])
S3A.upon(M_send, enter=S3A, outputs=[queue])
S3A.upon(M_stop, enter=SrcA, outputs=[])
2016-12-30 05:30:59 +00:00
S3B.upon(M_lost, enter=S3A, outputs=[])
S3B.upon(M_rx_msg_from_them, enter=S4B, outputs=[#tx_release, # trouble
process_msg_from_them])
S3B.upon(M_rx_msg_from_me, enter=S3B, outputs=[dequeue])
S3B.upon(M_rx_claimed, enter=S3B, outputs=[])
S3B.upon(M_send, enter=S3B, outputs=[queue, tx_add])
S3B.upon(M_stop, enter=SrcB, outputs=[tx_release, tx_close])
2016-12-30 05:30:59 +00:00
S4A.upon(M_connected, enter=S4B, outputs=[tx_open, tx_add_queued, tx_release])
S4A.upon(M_send, enter=S4A, outputs=[queue])
S4A.upon(M_stop, enter=SrcA, outputs=[])
2016-12-30 05:30:59 +00:00
S4B.upon(M_lost, enter=S4A, outputs=[])
S4B.upon(M_send, enter=S4B, outputs=[queue, tx_add])
S4B.upon(M_rx_msg_from_them, enter=S4B, outputs=[process_msg_from_them])
S4B.upon(M_rx_msg_from_me, enter=S4B, outputs=[dequeue])
S4B.upon(M_rx_released, enter=S5B, outputs=[])
S4B.upon(M_stop, enter=SrcB, outputs=[tx_release, tx_close])
2016-12-30 05:30:59 +00:00
S5A.upon(M_connected, enter=S5B, outputs=[tx_open, tx_add_queued])
S5A.upon(M_send, enter=S5A, outputs=[queue])
S5A.upon(M_stop, enter=ScA, outputs=[])
2016-12-30 05:30:59 +00:00
S5B.upon(M_lost, enter=S5A, outputs=[])
S5B.upon(M_send, enter=S5B, outputs=[queue, tx_add])
S5B.upon(M_rx_msg_from_them, enter=S5B, outputs=[process_msg_from_them])
S5B.upon(M_rx_msg_from_me, enter=S5B, outputs=[dequeue])
S5B.upon(M_stop, enter=ScB, outputs=[tx_close])
SrcA.upon(M_connected, enter=SrcB, outputs=[tx_release, tx_close])
SrcB.upon(M_lost, enter=SrcA, outputs=[])
SrcB.upon(M_rx_closed, enter=SrB, outputs=[])
SrcB.upon(M_rx_released, enter=ScB, outputs=[])
SrB.upon(M_lost, enter=SrA, outputs=[])
SrA.upon(M_connected, enter=SrB, outputs=[tx_release])
SrB.upon(M_rx_released, enter=SsB, outputs=[C_stop])
ScB.upon(M_lost, enter=ScA, outputs=[])
ScB.upon(M_rx_closed, enter=SsB, outputs=[C_stop])
ScA.upon(M_connected, enter=ScB, outputs=[tx_close])
2016-12-30 05:30:59 +00:00
SsB.upon(M_stopped, enter=Ss, outputs=[])
2016-12-30 05:30:59 +00:00