+on-west compiles

This commit is contained in:
Ted Blackman 2019-06-09 09:26:01 +03:00
parent 6570851228
commit a7b51f348b

View File

@ -707,7 +707,7 @@
%sunk !! %sunk !!
%vega !! %vega !!
%wegh !! %wegh !!
%west !! %west (on-west:event-core [ship message]:task)
== ==
:: ::
[moves ames-gate] [moves ames-gate]
@ -833,6 +833,49 @@
(emit duct %pass /alien %j %pubs sndr.packet) (emit duct %pass /alien %j %pubs sndr.packet)
:: ::
event-core event-core
:: +enqueue-alien-message: store message to untrusted source
::
:: Also requests key and life from Jael on first contact.
::
++ enqueue-alien-message
|= [=ship =message]
^+ event-core
::
=/ rcvr-state (~(get by peers.ames-state) ship)
:: create a default $pending-requests on first contact
::
=+ ^- [already-pending=? todos=pending-requests]
?~ rcvr-state
[%.n *pending-requests]
[%.y ?>(?=(%alien -.u.rcvr-state) +.u.rcvr-state)]
:: enqueue unsent message and apply to permanent state
::
=. snd-messages.todos [[duct message] snd-messages.todos]
::
=. peers.ames-state
(~(put by peers.ames-state) ship %alien todos)
:: ask jael for .ship life and keys on first contact
::
=? event-core !already-pending
(emit duct %pass /alien %j %pubs ship)
::
event-core
:: +on-west: handle request to send message
::
++ on-west
|= [=ship =message]
^+ event-core
::
=/ rcvr-state (~(get by peers.ames-state) ship)
::
?. ?=([~ %known *] rcvr-state)
(enqueue-alien-message ship message)
::
=/ =peer-state +.u.rcvr-state
=/ =channel [[our ship] now +>.ames-state -.peer-state]
::
abet:(on-west:(make-peer-core peer-state channel) message)
:: +make-peer-core: create nested |peer-core for per-peer processing
:: ::
++ make-peer-core ++ make-peer-core
|= [=peer-state =channel] |= [=peer-state =channel]
@ -846,6 +889,7 @@
(~(put by peers.ames-state) her.channel %known peer-state) (~(put by peers.ames-state) her.channel %known peer-state)
:: ::
event-core event-core
:: +on-hear-packet: handle receipt of ack or message fragment
:: ::
++ on-hear-packet ++ on-hear-packet
|= [=lane =shut-packet] |= [=lane =shut-packet]
@ -857,17 +901,12 @@
(~(get by rcv.peer-state) bone.shut-packet) (~(get by rcv.peer-state) bone.shut-packet)
[lane shut-packet] [lane shut-packet]
:: ::
%+ on-hear-ack (on-hear-ack lane shut-packet)
%- fall :_ *message-pump-state
(~(get by snd.peer-state) bone.shut-packet)
[lane shut-packet]
:: +on-hear-ack: handle receipt of ack on packet or message, from unix :: +on-hear-ack: handle receipt of ack on packet or message, from unix
:: ::
++ on-hear-ack ++ on-hear-ack
|= [=message-pump-state =lane =shut-packet] |= [=lane =shut-packet]
^+ peer-core ^+ peer-core
::
=/ message-pump (make-message-pump message-pump-state channel)
:: distinguish ack on single packet from ack on whole message :: distinguish ack on single packet from ack on whole message
:: ::
:: TODO: move conditional to message pump? :: TODO: move conditional to message pump?
@ -877,30 +916,50 @@
?: ?=(%& -.p.meat.shut-packet) ?: ?=(%& -.p.meat.shut-packet)
[%hear-fragment-ack message-num.shut-packet p.p.meat.shut-packet] [%hear-fragment-ack message-num.shut-packet p.p.meat.shut-packet]
[%hear-message-ack message-num.shut-packet p.p.meat.shut-packet] [%hear-message-ack message-num.shut-packet p.p.meat.shut-packet]
:: pass ack to the |message-pump :: TODO: is it correct to (mix 1 bone) here?
:: ::
(run-message-pump (mix 1 bone.shut-packet) task)
:: +run-message-pump: process a $message-pump-task and its effects
::
++ run-message-pump
|= [=bone task=message-pump-task]
^+ peer-core
:: pass .task to the |message-pump and apply state mutations
::
=/ =message-pump-state
(fall (~(get by snd.peer-state) bone) *message-pump-state)
::
=/ message-pump (make-message-pump message-pump-state channel)
=^ pump-gifts message-pump-state (work:message-pump task) =^ pump-gifts message-pump-state (work:message-pump task)
=. snd.peer-state =. snd.peer-state (~(put by snd.peer-state) bone message-pump-state)
(~(put by snd.peer-state) bone.shut-packet message-pump-state)
:: ::
=/ client-duct=^duct =/ client-duct=^duct (~(got by by-bone.ossuary.peer-state) bone)
(~(got by by-bone.ossuary.peer-state) bone.shut-packet)
:: process effects from |message-pump :: process effects from |message-pump
:: ::
|- ^+ peer-core |^ ^+ peer-core
?~ pump-gifts peer-core ?~ pump-gifts peer-core
::
=* gift i.pump-gifts =* gift i.pump-gifts
=. peer-core =. peer-core
?- -.gift ?- -.gift
%ack-message %ack-message (process-ack-message [message-num ok]:gift)
?: ok.gift %send (process-send static-fragment.gift)
%wait (process-wait date.gift)
%rest (process-rest date.gift)
==
$(pump-gifts t.pump-gifts)
::
++ process-ack-message
|= [=message-num ok=?]
^+ peer-core
:: positive ack gets emitted trivially
::
?: ok
(emit client-duct %give %rest ~) (emit client-duct %give %rest ~)
:: nack; look up naxplanation or enqueue :: nack; look up naxplanation or enqueue
:: ::
=/ nax-key [bone message-num]:shut-packet =/ nax-key [bone message-num]
=/ naxplanation (~(get by nax.peer-state) nax-key) ::
?~ naxplanation ?~ naxplanation=(~(get by nax.peer-state) nax-key)
:: no naxplanation yet; enqueue :: no naxplanation yet; enqueue
:: ::
=. nax.peer-state (~(put by nax.peer-state) nax-key ~) =. nax.peer-state (~(put by nax.peer-state) nax-key ~)
@ -913,13 +972,19 @@
=. nax.peer-state (~(del by nax.peer-state) nax-key) =. nax.peer-state (~(del by nax.peer-state) nax-key)
(emit client-duct %give %rest u.naxplanation) (emit client-duct %give %rest u.naxplanation)
:: ::
%send ++ process-send
=/ pak=^shut-packet |= =static-fragment
^+ peer-core
:: encrypt and encode .static-fragment to .blob bitstream
::
:: XOR .bone with 1 just before sending. TODO: bone docs
::
=/ pak=shut-packet
:* our-life.channel :* our-life.channel
her-life.channel her-life.channel
(mix 1 bone.shut-packet) (mix 1 bone)
message-num.static-fragment.gift message-num.static-fragment
%& +.static-fragment.gift %& +.static-fragment
== ==
:: ::
=/ content (encrypt symmetric-key.channel pak) =/ content (encrypt symmetric-key.channel pak)
@ -947,19 +1012,20 @@
peer-core peer-core
$(rcvrs t.rcvrs) $(rcvrs t.rcvrs)
:: ::
%wait ++ process-wait
%- emit |= date=@da
:^ client-duct %pass ^+ peer-core
(pump-timer-wire her.channel bone.shut-packet)
[%b %wait date.gift]
:: ::
%rest =/ =wire (pump-timer-wire her.channel bone)
%- emit (emit client-duct %pass wire %b %wait date)
:^ client-duct %pass ::
(pump-timer-wire her.channel bone.shut-packet) ++ process-rest
[%b %rest date.gift] |= date=@da
== ^+ peer-core
$(pump-gifts t.pump-gifts) ::
=/ =wire (pump-timer-wire her.channel bone)
(emit client-duct %pass wire %b %rest date)
--
:: +on-hear-fragment: handle receipt of message fragment, from unix :: +on-hear-fragment: handle receipt of message fragment, from unix
:: ::
++ on-hear-fragment ++ on-hear-fragment
@ -991,6 +1057,15 @@
!! !!
== ==
$(still-gifts t.still-gifts) $(still-gifts t.still-gifts)
:: +on-west: handle request to send message
::
++ on-west
|= =message
^+ peer-core
::
=^ =bone ossuary.peer-state (get-bone ossuary.peer-state duct)
::
(run-message-pump bone %send message)
-- --
-- --
:: +make-message-pump: constructor for |message-pump :: +make-message-pump: constructor for |message-pump
@ -1516,6 +1591,19 @@
:: ::
!! !!
-- --
:: +get-bone: find or make new bone for .duct in .ossuary
::
++ get-bone
|= [=ossuary =duct]
^+ [next-bone.ossuary ossuary]
::
?^ existing=(~(get by by-duct.ossuary) duct)
[u.existing ossuary]
::
:- next-bone.ossuary
:+ (add 2 next-bone.ossuary)
(~(put by by-duct.ossuary) duct next-bone.ossuary)
(~(put by by-bone.ossuary) next-bone.ossuary duct)
:: ::
:: ::
++ pump-timer-wire ++ pump-timer-wire