2019-11-19 07:36:21 +03:00
|
|
|
!: :: %gall, agent execution
|
2019-08-29 21:44:37 +03:00
|
|
|
!? 163
|
|
|
|
!:
|
|
|
|
::::
|
|
|
|
|= pit=vase
|
2019-11-19 07:36:21 +03:00
|
|
|
=, gall
|
2020-04-22 08:37:12 +03:00
|
|
|
=>
|
2019-08-29 21:44:37 +03:00
|
|
|
|%
|
2020-04-22 08:37:12 +03:00
|
|
|
:: +move: Arvo-level move
|
|
|
|
::
|
|
|
|
+$ move [=duct move=(wind note-arvo gift-arvo)]
|
|
|
|
:: +state-5: overall gall state, versioned
|
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
+$ state-5 [%5 state]
|
2020-04-22 08:37:12 +03:00
|
|
|
:: +state: overall gall state
|
|
|
|
::
|
|
|
|
:: system-duct: TODO document
|
|
|
|
:: outstanding: outstanding request queue
|
|
|
|
:: contacts: other ships we're in communication with
|
|
|
|
:: yokes: running agents
|
|
|
|
:: blocked: moves to agents that haven't been started yet
|
|
|
|
::
|
|
|
|
+$ state
|
|
|
|
$: system-duct=duct
|
|
|
|
outstanding=(map [wire duct] (qeu remote-request))
|
|
|
|
contacts=(set ship)
|
|
|
|
yokes=(map term yoke)
|
|
|
|
blocked=(map term (qeu blocked-move))
|
|
|
|
==
|
|
|
|
:: +watches: subscribers and publications
|
|
|
|
::
|
|
|
|
:: TODO: rename this, to $ties?
|
|
|
|
:: TODO: rename $boat and $bitt and document
|
|
|
|
::
|
|
|
|
+$ watches [inbound=bitt outbound=boat]
|
|
|
|
:: +routes: new cuff; TODO: document
|
|
|
|
::
|
|
|
|
+$ routes
|
|
|
|
$: disclosing=(unit (set ship))
|
|
|
|
attributing=ship
|
|
|
|
==
|
|
|
|
:: +yoke: agent runner state
|
|
|
|
::
|
|
|
|
:: control-duct: TODO document
|
|
|
|
:: live: is this agent running? TODO document better
|
|
|
|
:: stats: TODO document
|
|
|
|
:: watches: incoming and outgoing subscription state
|
|
|
|
:: agent: agent core
|
|
|
|
:: beak: compilation source
|
2020-04-30 09:00:57 +03:00
|
|
|
:: marks: mark conversion requests
|
2020-04-22 08:37:12 +03:00
|
|
|
::
|
|
|
|
+$ yoke
|
|
|
|
$: control-duct=duct
|
|
|
|
live=?
|
|
|
|
=stats
|
|
|
|
=watches
|
|
|
|
=agent
|
|
|
|
=beak
|
|
|
|
marks=(map duct mark)
|
|
|
|
==
|
|
|
|
:: +blocked-move: enqueued move to an agent
|
|
|
|
::
|
|
|
|
+$ blocked-move [=duct =routes =deal]
|
|
|
|
:: +stats: statistics
|
|
|
|
::
|
|
|
|
:: change: how many moves this agent has processed
|
|
|
|
:: eny: entropy
|
|
|
|
:: time: date of current event processing
|
|
|
|
::
|
|
|
|
+$ stats [change=@ud eny=@uvJ time=@da]
|
2019-10-30 23:12:57 +03:00
|
|
|
:: +ames-response: network response message (%boon)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
:: %d: fact
|
2019-10-30 23:12:57 +03:00
|
|
|
:: %x: quit
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
+$ ames-response
|
2019-10-30 23:12:57 +03:00
|
|
|
$% [%d =mark noun=*]
|
2019-08-29 21:44:37 +03:00
|
|
|
[%x ~]
|
|
|
|
==
|
2019-10-30 23:12:57 +03:00
|
|
|
:: +ames-request: network request (%plea)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
:: %m: poke
|
2019-11-20 00:03:07 +03:00
|
|
|
:: %l: watch-as
|
|
|
|
:: %s: watch
|
|
|
|
:: %u: leave
|
2019-10-30 23:12:57 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
+$ ames-request
|
2019-10-30 23:12:57 +03:00
|
|
|
$% [%m =mark noun=*]
|
2019-08-29 21:44:37 +03:00
|
|
|
[%l =mark =path]
|
|
|
|
[%s =path]
|
|
|
|
[%u ~]
|
|
|
|
==
|
2019-11-20 00:03:07 +03:00
|
|
|
:: +remote-request: kinds of agent actions that can cross the network
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
:: Used in wires to identify the kind of remote request we made.
|
|
|
|
:: Bijective with the tags of $ames-request.
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
+$ remote-request
|
2019-11-07 09:19:32 +03:00
|
|
|
$? %watch
|
2019-11-09 04:26:47 +03:00
|
|
|
%watch-as
|
2019-08-29 21:44:37 +03:00
|
|
|
%poke
|
2019-11-07 09:19:32 +03:00
|
|
|
%leave
|
2020-02-14 04:48:33 +03:00
|
|
|
%missing
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
--
|
2020-04-30 09:00:57 +03:00
|
|
|
=| state=state-5
|
2020-04-22 08:37:12 +03:00
|
|
|
|= [our=ship now=@da eny=@uvJ ski=sley]
|
2019-11-19 07:36:21 +03:00
|
|
|
~% %gall-top ..is ~
|
2019-08-29 21:44:37 +03:00
|
|
|
|%
|
2019-11-19 07:36:21 +03:00
|
|
|
:: +gall-payload: gall payload
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-19 07:36:21 +03:00
|
|
|
++ gall-payload +
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo: Arvo-level move handling
|
|
|
|
::
|
|
|
|
:: An outer core responsible for routing moves to and from Arvo; it calls
|
|
|
|
:: an inner core, +ap, to route internal moves to and from agents.
|
|
|
|
::
|
|
|
|
++ mo
|
2019-11-19 07:36:21 +03:00
|
|
|
~% %gall-mo +> ~
|
2020-04-22 08:37:12 +03:00
|
|
|
|_ [hen=duct moves=(list move)]
|
|
|
|
:: +mo-abed: initialise state with the provided duct
|
|
|
|
:: +mo-abet: finalize, reversing moves
|
|
|
|
:: +mo-pass: prepend a standard %pass to the current list of moves
|
|
|
|
:: +mo-give: prepend a standard %give to the current list of moves
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
++ mo-core .
|
|
|
|
++ mo-abed |=(hun=duct mo-core(hen hun))
|
|
|
|
++ mo-abet [(flop moves) gall-payload]
|
|
|
|
++ mo-pass |=(p=[wire note-arvo] mo-core(moves [[hen pass+p] moves]))
|
|
|
|
++ mo-give |=(g=gift:able mo-core(moves [[hen give+g] moves]))
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-boot: ask %ford to build us a core for the specified agent.
|
|
|
|
::
|
|
|
|
++ mo-boot
|
2020-04-22 08:37:12 +03:00
|
|
|
|= [dap=term =ship =desk]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
|
|
|
=/ =case [%da now]
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ =wire /sys/cor/[dap]/(scot %p ship)/[desk]/(scot case)
|
2020-04-22 12:27:36 +03:00
|
|
|
(mo-pass wire %c %warp ship desk ~ %sing %a case /app/[dap]/hoon)
|
2019-11-10 03:47:41 +03:00
|
|
|
:: +mo-reboot: ask %ford to rebuild the specified agent
|
|
|
|
::
|
|
|
|
++ mo-reboot
|
2020-04-22 08:37:12 +03:00
|
|
|
|= [dap=term =ship]
|
2019-11-10 03:47:41 +03:00
|
|
|
^+ mo-core
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ gent (~(got by yokes.state) dap)
|
2019-11-10 03:47:41 +03:00
|
|
|
=* desk q.beak.gent
|
2020-04-22 08:37:12 +03:00
|
|
|
(mo-boot:(mo-abed control-duct.gent) dap ship desk)
|
2019-11-10 03:47:41 +03:00
|
|
|
:: +mo-goad: rebuild agent(s)
|
|
|
|
::
|
|
|
|
++ mo-goad
|
2020-04-22 08:37:12 +03:00
|
|
|
|= agent=(unit dude)
|
2019-11-10 03:47:41 +03:00
|
|
|
^+ mo-core
|
|
|
|
?^ agent
|
|
|
|
~| goad-gone+u.agent
|
2020-04-22 08:37:12 +03:00
|
|
|
(mo-reboot u.agent our)
|
|
|
|
=/ agents=(list term) ~(tap in ~(key by yokes.state))
|
2019-11-10 03:47:41 +03:00
|
|
|
|- ^+ mo-core
|
2020-04-22 08:37:12 +03:00
|
|
|
?~ agents mo-core
|
|
|
|
$(agents t.agents, mo-core (mo-reboot i.agents our))
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-receive-core: receives an app core built by %ford.
|
|
|
|
::
|
|
|
|
:: Presuming we receive a good core, we first check to see if the agent
|
2019-11-19 07:36:21 +03:00
|
|
|
:: is already running. If so, we update its beak in %gall's state,
|
2019-08-29 21:44:37 +03:00
|
|
|
:: initialise an +ap core for the agent, install the core we got from
|
|
|
|
:: %ford, and then resolve any moves associated with it.
|
|
|
|
::
|
|
|
|
:: If we're dealing with a new agent, we create one using the result we
|
2019-11-19 07:36:21 +03:00
|
|
|
:: got from %ford, add it to the collection of agents %gall is keeping
|
2019-08-29 21:44:37 +03:00
|
|
|
:: track of, and then do more or less the same procedure as we did for the
|
|
|
|
:: running agent case.
|
|
|
|
::
|
|
|
|
++ mo-receive-core
|
|
|
|
~/ %mo-receive-core
|
2020-04-24 07:13:19 +03:00
|
|
|
|= [dap=term bek=beak =cage]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
?. =(%vase p.cage)
|
2020-04-24 07:13:19 +03:00
|
|
|
(mo-give %onto |+[leaf+"gall: bad mark {<p.cage>} for agent {<dap>}"]~)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ maybe-new-agent (mule |.(!<(agent !<(vase q.cage))))
|
|
|
|
?: ?=(%| -.maybe-new-agent)
|
|
|
|
=/ err [[%leaf "{<dap>}: not valid agent"] p.maybe-new-agent]
|
|
|
|
(mo-give %onto %.n err)
|
|
|
|
=/ =agent p.maybe-new-agent
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
?^ existing=(~(get by yokes.state) dap)
|
|
|
|
=. yokes.state
|
|
|
|
(~(put by yokes.state) dap u.existing(beak bek))
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ =routes [disclosing=~ attributing=our]
|
2020-04-22 01:50:47 +03:00
|
|
|
=/ ap-core (ap-abed:ap dap routes)
|
2020-04-22 08:37:12 +03:00
|
|
|
=. ap-core (ap-reinstall:ap-core agent)
|
2020-04-22 01:50:47 +03:00
|
|
|
ap-abet:ap-core
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=. yokes.state
|
|
|
|
%+ ~(put by yokes.state) dap
|
|
|
|
=/ default-yoke *yoke
|
|
|
|
default-yoke(control-duct hen, beak bek, agent agent)
|
2020-04-22 01:50:47 +03:00
|
|
|
::
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ old mo-core
|
|
|
|
=/ wag
|
|
|
|
=/ =routes [disclosing=~ attributing=our]
|
2020-04-22 01:50:47 +03:00
|
|
|
=/ ap-core (ap-abed:ap dap routes)
|
|
|
|
(ap-upgrade-state:ap-core ~)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
=/ maybe-tang -.wag
|
2020-04-22 01:50:47 +03:00
|
|
|
=/ ap-core +.wag
|
2019-08-29 21:44:37 +03:00
|
|
|
?^ maybe-tang
|
|
|
|
=. mo-core old
|
|
|
|
(mo-give %onto %.n u.maybe-tang)
|
|
|
|
::
|
2020-04-22 01:50:47 +03:00
|
|
|
=. mo-core ap-abet:ap-core
|
|
|
|
=. mo-core (mo-clear-queue dap)
|
|
|
|
=/ =suss [dap %boot now]
|
2019-08-29 21:44:37 +03:00
|
|
|
(mo-give %onto [%.y suss])
|
2020-04-24 07:13:19 +03:00
|
|
|
:: +mo-subscribe-to-agent-builds: request agent update notices
|
|
|
|
::
|
|
|
|
++ mo-subscribe-to-agent-builds
|
|
|
|
|= date=@da
|
|
|
|
^+ mo-core
|
|
|
|
=. mo-core (mo-abed system-duct.state)
|
|
|
|
=/ =wire /sys/lyv :: TODO: add $aeon to wire as sanity check
|
|
|
|
=. mo-core (mo-pass /sys/lyv %c %warp our %home ~)
|
|
|
|
=/ =mool:clay
|
|
|
|
:- da+date
|
|
|
|
%- ~(gas in *(set [care:clay path]))
|
|
|
|
%+ turn ~(tap in ~(key by yokes.state))
|
|
|
|
|= dap=term
|
|
|
|
^- [care:clay path]
|
|
|
|
[%a /app/[dap]/hoon]
|
|
|
|
(mo-pass wire %c %warp our %home ~ %mult mool)
|
2019-11-20 00:03:07 +03:00
|
|
|
:: +mo-send-foreign-request: handle local request to .ship
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
++ mo-send-foreign-request
|
|
|
|
~/ %mo-send-foreign-request
|
2019-11-20 00:03:07 +03:00
|
|
|
|= [=ship foreign-agent=term =deal]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
=. mo-core (mo-track-ship ship)
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
?< ?=(?(%raw-poke %poke-as) -.deal)
|
2019-10-30 23:12:57 +03:00
|
|
|
=/ =ames-request
|
2019-11-09 04:26:47 +03:00
|
|
|
?- -.deal
|
|
|
|
%poke [%m p.cage.deal q.q.cage.deal]
|
|
|
|
%leave [%u ~]
|
|
|
|
%watch-as [%l deal]
|
|
|
|
%watch [%s path.deal]
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
=/ wire
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
/sys/way/(scot %p ship)/[foreign-agent]
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
=/ =note-arvo
|
2019-11-01 22:06:09 +03:00
|
|
|
=/ =path /ge/[foreign-agent]
|
2019-10-30 23:12:57 +03:00
|
|
|
[%a %plea ship %g path ames-request]
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=. outstanding.state
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
=/ stand
|
2020-04-22 08:37:12 +03:00
|
|
|
(~(gut by outstanding.state) [wire hen] *(qeu remote-request))
|
|
|
|
(~(put by outstanding.state) [wire hen] (~(put to stand) -.deal))
|
2019-11-03 03:52:48 +03:00
|
|
|
(mo-pass wire note-arvo)
|
2019-11-04 04:35:45 +03:00
|
|
|
:: +mo-track-ship: subscribe to ames and jael for notices about .ship
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
++ mo-track-ship
|
2019-10-30 23:12:57 +03:00
|
|
|
|= =ship
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
2019-10-30 23:12:57 +03:00
|
|
|
:: if already contacted, no-op
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
?: (~(has in contacts.state) ship)
|
2019-11-05 07:19:08 +03:00
|
|
|
mo-core
|
2019-11-04 04:35:45 +03:00
|
|
|
:: first contact; update state and subscribe to notifications
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=. contacts.state (~(put in contacts.state) ship)
|
2019-11-04 04:35:45 +03:00
|
|
|
:: ask ames to track .ship's connectivity
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=. moves [[system-duct.state %pass /sys/lag %a %heed ship] moves]
|
2019-11-04 04:35:45 +03:00
|
|
|
:: ask jael to track .ship's breaches
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
=/ =note-arvo [%j %public-keys (silt ship ~)]
|
|
|
|
=. moves
|
2020-04-22 08:37:12 +03:00
|
|
|
[[system-duct.state %pass /sys/era note-arvo] moves]
|
2019-10-30 23:12:57 +03:00
|
|
|
mo-core
|
2019-11-04 04:35:45 +03:00
|
|
|
:: +mo-untrack-ship: cancel subscriptions to ames and jael for .ship
|
2019-11-05 07:19:08 +03:00
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
++ mo-untrack-ship
|
2019-11-05 07:19:08 +03:00
|
|
|
|= =ship
|
|
|
|
^+ mo-core
|
2019-10-30 23:12:57 +03:00
|
|
|
:: if already canceled, no-op
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
?. (~(has in contacts.state) ship)
|
2019-10-30 23:12:57 +03:00
|
|
|
mo-core
|
2019-11-04 04:35:45 +03:00
|
|
|
:: delete .ship from state and kill subscriptions
|
2019-10-30 23:12:57 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=. contacts.state (~(del in contacts.state) ship)
|
2019-11-04 04:35:45 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=. moves [[system-duct.state %pass /sys/lag %a %jilt ship] moves]
|
2019-11-04 04:35:45 +03:00
|
|
|
::
|
2019-11-05 07:19:08 +03:00
|
|
|
=/ =note-arvo [%j %nuke (silt ship ~)]
|
|
|
|
=. moves
|
2020-04-22 08:37:12 +03:00
|
|
|
[[system-duct.state %pass /sys/era note-arvo] moves]
|
2019-11-05 07:19:08 +03:00
|
|
|
mo-core
|
|
|
|
:: +mo-breach: ship breached, so forget about them
|
|
|
|
::
|
|
|
|
++ mo-breach
|
|
|
|
|= =ship
|
|
|
|
^+ mo-core
|
2019-11-04 04:35:45 +03:00
|
|
|
=. mo-core (mo-untrack-ship ship)
|
2020-04-22 08:37:12 +03:00
|
|
|
=. mo-core (mo-filter-queue ship)
|
|
|
|
=/ agents=(list [name=term =yoke]) ~(tap by yokes.state)
|
2019-11-05 07:19:08 +03:00
|
|
|
|- ^+ mo-core
|
|
|
|
?~ agents
|
|
|
|
mo-core
|
|
|
|
=. mo-core
|
|
|
|
=/ =routes [disclosing=~ attributing=ship]
|
|
|
|
=/ app (ap-abed:ap name.i.agents routes)
|
|
|
|
ap-abet:(ap-breach:app ship)
|
|
|
|
$(agents t.agents)
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-handle-sys: handle a +sign incoming over /sys.
|
|
|
|
::
|
|
|
|
:: (Note that /sys implies the +sign should be routed to a vane.)
|
|
|
|
::
|
|
|
|
++ mo-handle-sys
|
|
|
|
~/ %mo-handle-sys
|
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
::
|
|
|
|
?+ -.path !!
|
2020-04-24 07:13:19 +03:00
|
|
|
%lyv (mo-handle-sys-lyv path sign-arvo)
|
2019-11-04 04:35:45 +03:00
|
|
|
%era (mo-handle-sys-era path sign-arvo)
|
|
|
|
%cor (mo-handle-sys-cor path sign-arvo)
|
|
|
|
%lag (mo-handle-sys-lag path sign-arvo)
|
|
|
|
%pel (mo-handle-sys-pel path sign-arvo)
|
|
|
|
%rep (mo-handle-sys-rep path sign-arvo)
|
|
|
|
%req (mo-handle-sys-req path sign-arvo)
|
|
|
|
%val (mo-handle-sys-val path sign-arvo)
|
|
|
|
%way (mo-handle-sys-way path sign-arvo)
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
2019-11-04 04:35:45 +03:00
|
|
|
:: +mo-handle-sys-era: receive update about contact
|
2019-11-05 07:19:08 +03:00
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
++ mo-handle-sys-era
|
2019-11-05 07:19:08 +03:00
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
?> ?=([%j %public-keys *] sign-arvo)
|
2019-11-20 00:03:07 +03:00
|
|
|
?> ?=([%era ~] path)
|
2019-11-05 07:19:08 +03:00
|
|
|
?. ?=(%breach -.public-keys-result.sign-arvo)
|
|
|
|
mo-core
|
|
|
|
(mo-breach who.public-keys-result.sign-arvo)
|
2020-04-24 07:13:19 +03:00
|
|
|
:: +mo-handle-sys-cor: receive a built agent from %clay
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
++ mo-handle-sys-cor
|
2019-08-29 21:44:37 +03:00
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
?> ?=([%cor @ @ @ @ ~] path)
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ [dap=term her=@ta desk=@ta dat=@ta ~] t.path
|
2020-04-24 07:13:19 +03:00
|
|
|
=/ tim (slav da+dat)
|
|
|
|
=/ =beak [(slav %p her) desk da+tim]
|
2020-04-22 08:37:12 +03:00
|
|
|
?> ?=([?(%b %c) %writ *] sign-arvo)
|
|
|
|
?^ p.sign-arvo
|
2020-04-24 07:13:19 +03:00
|
|
|
=. mo-core (mo-receive-core dap beak r.u.p.sign-arvo)
|
|
|
|
(mo-subscribe-to-agent-builds tim)
|
2020-04-22 08:37:12 +03:00
|
|
|
(mo-give %onto |+[leaf+"gall: failed to build agent {<dap>}"]~)
|
2020-04-24 07:13:19 +03:00
|
|
|
::
|
|
|
|
::
|
|
|
|
++ mo-handle-sys-lyv
|
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
?> ?=([%lyv ~] path)
|
|
|
|
?> ?=([?(%b %c) %wris *] sign-arvo)
|
|
|
|
=/ bek=beak [our %home p.sign-arvo]
|
|
|
|
=/ nex=(list [=care:clay =^path]) ~(tap in q.sign-arvo)
|
|
|
|
=; cor (mo-subscribe-to-agent-builds:cor p.p.sign-arvo)
|
|
|
|
%+ roll nex
|
|
|
|
|= [[=care:clay =^path] cor=_mo-core]
|
|
|
|
^+ cor
|
|
|
|
?> =(%a care)
|
|
|
|
=/ dap dap:;;([%app dap=@tas %hoon ~] path)
|
|
|
|
=/ cage (need (need (ski [%141 %noun] ~ %ca bek (flop path))))
|
|
|
|
(mo-receive-core:cor dap bek cage)
|
2019-11-04 04:35:45 +03:00
|
|
|
:: +mo-handle-sys-lag: handle an ames %clog notification
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
++ mo-handle-sys-lag
|
2019-08-29 21:44:37 +03:00
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
?> ?=([%lag ~] path)
|
|
|
|
?> ?=([%a %clog *] sign-arvo)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ agents=(list term) ~(tap in ~(key by yokes.state))
|
2019-11-04 04:35:45 +03:00
|
|
|
|- ^+ mo-core
|
|
|
|
?~ agents mo-core
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
=. mo-core
|
|
|
|
=/ =routes [disclosing=~ attributing=our]
|
|
|
|
=/ app (ap-abed:ap i.agents routes)
|
|
|
|
ap-abet:(ap-clog:app ship.sign-arvo)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
$(agents t.agents)
|
2019-05-13 10:40:50 +03:00
|
|
|
:: +mo-handle-sys-pel: translated peer.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
:: Validates a received %ford result and %gives an internal
|
|
|
|
:: %fact.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-05-13 10:40:50 +03:00
|
|
|
++ mo-handle-sys-pel
|
2019-08-29 21:44:37 +03:00
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
?> ?=([%pel @ ~] path)
|
2020-04-30 09:00:57 +03:00
|
|
|
?> ?=([%f %made *] sign-arvo)
|
|
|
|
::
|
|
|
|
?- result.sign-arvo
|
|
|
|
[%incomplete *]
|
|
|
|
(mo-give %unto %poke-ack `tang.result.sign-arvo)
|
|
|
|
::
|
|
|
|
[%complete %error *]
|
|
|
|
(mo-give %unto %poke-ack `message.build-result.result.sign-arvo)
|
|
|
|
::
|
|
|
|
[%complete %success *]
|
|
|
|
(mo-give %unto %fact (result-to-cage:ford build-result.result.sign-arvo))
|
|
|
|
==
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-handle-sys-rep: reverse request.
|
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
:: On receipt of a valid +sign from %ford, sets state to the
|
2019-11-07 09:19:32 +03:00
|
|
|
:: appropriate duct and gives an internal %fact
|
2019-09-12 05:55:31 +03:00
|
|
|
:: containing the +sign payload.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
++ mo-handle-sys-rep
|
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
?> ?=([%rep ~] path)
|
2019-08-29 21:44:37 +03:00
|
|
|
?> ?=([%f %made *] sign-arvo)
|
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
?- result.sign-arvo
|
|
|
|
[%incomplete *]
|
|
|
|
(mo-give %done `[%gall-fail tang.result.sign-arvo])
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
[%complete %error *]
|
|
|
|
(mo-give %done `[%gall-fail message.build-result.result.sign-arvo])
|
|
|
|
::
|
|
|
|
[%complete %success *]
|
2019-11-20 00:03:07 +03:00
|
|
|
(mo-give %unto %fact (result-to-cage:ford build-result.result.sign-arvo))
|
2019-10-30 23:12:57 +03:00
|
|
|
==
|
|
|
|
:: +mo-handle-sys-req: TODO description
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
:: TODO: what should we do if the remote nacks our %pull?
|
2019-08-29 21:44:37 +03:00
|
|
|
++ mo-handle-sys-req
|
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
::
|
2019-11-03 03:52:48 +03:00
|
|
|
?> ?=([%req @ @ ~] path)
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ him (slav %p i.t.path)
|
|
|
|
=/ dap i.t.t.path
|
|
|
|
::
|
2019-11-21 00:22:36 +03:00
|
|
|
?> ?=([?(%g %b) %unto *] sign-arvo)
|
2019-11-09 10:31:11 +03:00
|
|
|
=/ =sign:agent +>.sign-arvo
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-09 10:31:11 +03:00
|
|
|
?- -.sign
|
2019-09-12 05:55:31 +03:00
|
|
|
%poke-ack
|
2019-10-30 23:12:57 +03:00
|
|
|
=/ err=(unit error:ames)
|
2019-11-20 00:03:07 +03:00
|
|
|
?~ p.sign ~
|
|
|
|
`[%poke-ack u.p.sign]
|
2019-10-30 23:12:57 +03:00
|
|
|
(mo-give %done err)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-07 09:19:32 +03:00
|
|
|
%fact
|
2019-11-20 00:03:07 +03:00
|
|
|
=+ [mark noun]=[p q.q]:cage.sign
|
2019-11-01 23:18:51 +03:00
|
|
|
(mo-give %boon %d mark noun)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-07 09:19:32 +03:00
|
|
|
%kick
|
2019-11-01 23:18:51 +03:00
|
|
|
(mo-give %boon %x ~)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-07 09:19:32 +03:00
|
|
|
%watch-ack
|
2019-10-30 23:12:57 +03:00
|
|
|
=/ err=(unit error:ames)
|
2019-11-20 00:03:07 +03:00
|
|
|
?~ p.sign ~
|
2019-11-27 05:18:44 +03:00
|
|
|
`[%watch-ack u.p.sign]
|
2019-10-30 23:12:57 +03:00
|
|
|
(mo-give %done err)
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
:: +mo-handle-sys-val: inbound validate.
|
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
:: Validates an incoming +sign from %ford and applies it to the
|
|
|
|
:: specified agent.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
++ mo-handle-sys-val
|
|
|
|
|= [=path =sign-arvo]
|
|
|
|
^+ mo-core
|
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
?> ?=([%val @ @ ~] path)
|
2019-08-29 21:44:37 +03:00
|
|
|
?> ?=([%f %made *] sign-arvo)
|
|
|
|
=/ =ship (slav %p i.t.path)
|
|
|
|
=/ =term i.t.t.path
|
|
|
|
?: ?=([%incomplete *] result.sign-arvo)
|
|
|
|
=/ err (some tang.result.sign-arvo)
|
2019-09-12 05:55:31 +03:00
|
|
|
(mo-give %unto %poke-ack err)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
=/ build-result build-result.result.sign-arvo
|
|
|
|
?: ?=([%error *] build-result)
|
|
|
|
=/ err (some message.build-result)
|
2019-09-12 05:55:31 +03:00
|
|
|
(mo-give %unto %poke-ack err)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
=/ =routes [disclosing=~ attributing=ship]
|
|
|
|
=/ =cage (result-to-cage:ford build-result)
|
2019-11-09 04:26:47 +03:00
|
|
|
=/ =deal [%poke cage]
|
|
|
|
(mo-apply term routes deal)
|
2019-10-30 23:12:57 +03:00
|
|
|
:: +mo-handle-sys-way: handle response to outgoing remote request
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
++ mo-handle-sys-way
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
|= [=wire =sign-arvo]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
?> ?=([%way @ @ $@(~ [@ ~])] wire)
|
|
|
|
=/ =ship (slav %p i.t.wire)
|
|
|
|
=/ foreign-agent i.t.t.wire
|
2019-10-30 23:12:57 +03:00
|
|
|
::
|
|
|
|
?+ sign-arvo !!
|
|
|
|
[%a %done *]
|
2020-04-22 08:37:12 +03:00
|
|
|
=^ remote-request outstanding.state
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
?~ t.t.t.wire
|
2020-02-14 02:12:07 +03:00
|
|
|
=/ full-wire sys+wire
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
=/ stand
|
2020-04-22 08:37:12 +03:00
|
|
|
%+ ~(gut by outstanding.state) [full-wire hen]
|
2020-02-14 02:51:29 +03:00
|
|
|
:: default is do nothing; should only hit if cleared queue
|
|
|
|
:: in +load 3-to-4
|
|
|
|
::
|
2020-02-14 04:48:33 +03:00
|
|
|
(~(put to *(qeu remote-request)) %missing)
|
2020-04-22 08:37:12 +03:00
|
|
|
~| [full-wire=full-wire hen=hen stand=stand outs=outstanding.state]
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
=^ rr stand ~(get to stand)
|
2020-04-22 08:37:12 +03:00
|
|
|
[rr (~(put by outstanding.state) [full-wire hen] stand)]
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
:: non-null case of wire is old, remove on next breach after
|
|
|
|
:: 2019/12
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
[;;(remote-request i.t.t.t.wire) outstanding.state]
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
=/ err=(unit tang)
|
|
|
|
?~ error=error.sign-arvo
|
|
|
|
~
|
|
|
|
`[[%leaf (trip tag.u.error)] tang.u.error]
|
2019-06-29 04:13:32 +03:00
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
?- remote-request
|
|
|
|
%watch-as (mo-give %unto %watch-ack err)
|
|
|
|
%watch (mo-give %unto %watch-ack err)
|
|
|
|
%poke (mo-give %unto %poke-ack err)
|
|
|
|
%leave mo-core
|
2020-02-14 04:48:33 +03:00
|
|
|
%missing (mo-give:(mo-give %unto %watch-ack err) %unto %poke-ack err)
|
2016-12-16 09:34:01 +03:00
|
|
|
==
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
[%a %boon *]
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
?^ t.t.t.wire
|
|
|
|
:: kill subscriptions which use the old wire format
|
|
|
|
::
|
|
|
|
!!
|
2019-10-30 23:12:57 +03:00
|
|
|
=/ =ames-response ;;(ames-response payload.sign-arvo)
|
2019-11-04 04:35:45 +03:00
|
|
|
(mo-handle-ames-response ames-response)
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
[%a %lost *]
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
:: note this should only happen on reverse bones, so only facts
|
|
|
|
:: and kicks
|
|
|
|
::
|
|
|
|
=/ sys-wire [%sys wire]
|
2019-11-20 00:03:07 +03:00
|
|
|
:: TODO: %drip %kick so app crash can't kill the remote %pull
|
2019-08-28 06:12:56 +03:00
|
|
|
::
|
2019-11-04 04:35:45 +03:00
|
|
|
=. mo-core (mo-pass sys-wire %a %plea ship %g /ge/[foreign-agent] %u ~)
|
2019-12-03 00:35:05 +03:00
|
|
|
=. mo-core (mo-give %unto %kick ~)
|
2019-10-30 23:12:57 +03:00
|
|
|
mo-core
|
2016-11-24 07:25:07 +03:00
|
|
|
==
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-handle-use: handle a typed +sign incoming on /use.
|
|
|
|
::
|
|
|
|
:: (Note that /use implies the +sign should be routed to an agent.)
|
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
:: Initialises the specified agent and then performs an agent-level
|
|
|
|
:: +take on the supplied +sign.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
++ mo-handle-use
|
|
|
|
~/ %mo-handle-use
|
|
|
|
|= [=path hin=(hypo sign-arvo)]
|
|
|
|
^+ mo-core
|
|
|
|
::
|
2019-09-06 04:18:31 +03:00
|
|
|
?. ?=([@ @ *] path)
|
2019-08-29 21:44:37 +03:00
|
|
|
~& [%mo-handle-use-bad-path path]
|
|
|
|
!!
|
|
|
|
::
|
|
|
|
=/ =sign-arvo q.hin
|
2019-11-21 00:22:36 +03:00
|
|
|
?. ?=([?(%g %b) %unto *] sign-arvo)
|
2019-11-08 01:46:06 +03:00
|
|
|
=/ app
|
|
|
|
=/ =term i.path
|
|
|
|
=/ =ship (slav %p i.t.path)
|
|
|
|
=/ =routes [disclosing=~ attributing=ship]
|
|
|
|
(ap-abed:ap term routes)
|
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
=. app (ap-generic-take:app t.t.path sign-arvo)
|
2019-08-29 21:44:37 +03:00
|
|
|
ap-abet:app
|
2019-11-09 10:31:11 +03:00
|
|
|
=/ =sign:agent +>.sign-arvo
|
2019-11-08 01:46:06 +03:00
|
|
|
=/ app
|
|
|
|
?> ?=([%out @ @ *] t.t.path)
|
|
|
|
=/ =term i.path
|
|
|
|
=/ =ship (slav %p i.t.t.t.path)
|
|
|
|
=/ =routes [disclosing=~ attributing=ship]
|
|
|
|
(ap-abed:ap term routes)
|
2019-09-06 04:18:31 +03:00
|
|
|
=. app
|
2019-11-09 10:31:11 +03:00
|
|
|
(ap-specific-take:app t.t.path sign)
|
2019-09-06 04:18:31 +03:00
|
|
|
ap-abet:app
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-clear-queue: clear blocked tasks from the specified running agent.
|
|
|
|
::
|
|
|
|
++ mo-clear-queue
|
2020-04-22 08:37:12 +03:00
|
|
|
|= dap=term
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
2020-04-22 08:37:12 +03:00
|
|
|
?. (~(has by yokes.state) dap)
|
2019-08-29 21:44:37 +03:00
|
|
|
mo-core
|
2020-04-22 08:37:12 +03:00
|
|
|
?~ maybe-blocked=(~(get by blocked.state) dap)
|
2019-08-29 21:44:37 +03:00
|
|
|
mo-core
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ blocked=(qeu blocked-move) u.maybe-blocked
|
2019-08-29 21:44:37 +03:00
|
|
|
|- ^+ mo-core
|
|
|
|
?: =(~ blocked)
|
2020-04-22 08:37:12 +03:00
|
|
|
=. blocked.state (~(del by blocked.state) dap)
|
|
|
|
mo-core
|
|
|
|
=^ [=duct =routes =deal] blocked ~(get to blocked)
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ move
|
|
|
|
=/ =sock [attributing.routes our]
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ card [%slip %g %deal sock dap deal]
|
2019-08-29 21:44:37 +03:00
|
|
|
[duct card]
|
|
|
|
$(moves [move moves])
|
2020-04-22 08:37:12 +03:00
|
|
|
:: +mo-filter-queue: remove all blocked tasks from ship.
|
|
|
|
::
|
|
|
|
++ mo-filter-queue
|
|
|
|
|= =ship
|
|
|
|
=/ agents=(list [name=term blocked=(qeu blocked-move)])
|
|
|
|
~(tap by blocked.state)
|
|
|
|
=| new-agents=(map term (qeu blocked-move))
|
|
|
|
|- ^+ mo-core
|
|
|
|
?~ agents
|
|
|
|
mo-core(blocked.state new-agents)
|
|
|
|
=| new-blocked=(qeu blocked-move)
|
|
|
|
|- ^+ mo-core
|
|
|
|
?: =(~ blocked.i.agents)
|
|
|
|
?~ new-blocked
|
|
|
|
^$(agents t.agents)
|
|
|
|
%= ^$
|
|
|
|
agents t.agents
|
|
|
|
new-agents (~(put by new-agents) name.i.agents new-blocked)
|
|
|
|
==
|
|
|
|
=^ mov=blocked-move blocked.i.agents ~(get to blocked.i.agents)
|
|
|
|
=? new-blocked !=(ship attributing.routes.mov)
|
|
|
|
(~(put to new-blocked) mov)
|
|
|
|
$
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-beak: assemble a beak for the specified agent.
|
|
|
|
::
|
|
|
|
++ mo-beak
|
2020-04-22 08:37:12 +03:00
|
|
|
|= dap=term
|
2019-08-29 21:44:37 +03:00
|
|
|
^- beak
|
2020-04-22 08:37:12 +03:00
|
|
|
?^ yoke=(~(get by yokes.state) dap)
|
|
|
|
beak.u.yoke
|
|
|
|
:: XX this fallback is necessary, as .term could be either the source
|
|
|
|
:: or the destination app. ie, it might not exist locally ...
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
[our %home %da now]
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-peek: call to +ap-peek (which is not accessible outside of +mo).
|
|
|
|
::
|
|
|
|
++ mo-peek
|
|
|
|
~/ %mo-peek
|
2020-04-22 08:37:12 +03:00
|
|
|
|= [dap=term =routes care=term =path]
|
2019-08-29 21:44:37 +03:00
|
|
|
^- (unit (unit cage))
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ app (ap-abed:ap dap routes)
|
2020-04-22 13:49:23 +03:00
|
|
|
(ap-peek:app care path)
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +mo-apply: apply the supplied action to the specified agent.
|
|
|
|
::
|
|
|
|
++ mo-apply
|
2020-04-22 12:27:36 +03:00
|
|
|
|= [dap=term =routes =deal]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
2020-04-22 08:37:12 +03:00
|
|
|
:: TODO: Remove this horrific hack when ford pinto comes!
|
|
|
|
=> |%
|
|
|
|
+$ serial @uvH
|
|
|
|
::
|
|
|
|
+$ letter
|
|
|
|
$% [%text text=cord]
|
|
|
|
[%url url=cord]
|
|
|
|
[%code expression=cord output=(list tank)]
|
|
|
|
[%me narrative=cord]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ envelope
|
|
|
|
$: uid=serial
|
|
|
|
number=@
|
|
|
|
author=ship
|
|
|
|
when=time
|
|
|
|
=letter
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ config
|
|
|
|
$: length=@
|
|
|
|
read=@
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ mailbox
|
|
|
|
$: =config
|
|
|
|
envelopes=(list envelope)
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ inbox (map path mailbox)
|
|
|
|
::
|
|
|
|
+$ chat-configs (map path config)
|
|
|
|
::
|
|
|
|
+$ chat-base
|
|
|
|
$% [%create =path]
|
|
|
|
[%delete =path]
|
|
|
|
[%message =path =envelope]
|
|
|
|
[%read =path]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ chat-action
|
|
|
|
$% :: %messages: append a list of messages to mailbox
|
|
|
|
::
|
|
|
|
[%messages =path envelopes=(list envelope)]
|
|
|
|
chat-base
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ chat-update
|
|
|
|
$% [%keys keys=(set path)]
|
|
|
|
[%config =path =config]
|
|
|
|
[%messages =path start=@ud end=@ud envelopes=(list envelope)]
|
|
|
|
chat-base
|
|
|
|
==
|
|
|
|
--
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 12:27:36 +03:00
|
|
|
=/ =path /sys/val/(scot %p attributing.routes)/[dap]
|
|
|
|
=/ [=ship =desk] [p q]:(mo-beak dap)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-09 04:26:47 +03:00
|
|
|
?: ?=(%raw-poke -.deal)
|
2020-04-22 08:37:12 +03:00
|
|
|
:: TODO: Remove this horrific hack when ford pinto comes!
|
|
|
|
?+ mark.deal
|
2020-04-22 12:27:36 +03:00
|
|
|
=/ =schematic:ford [%vale ship^desk +.deal]
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ =note-arvo [%f %build live=%.n schematic]
|
|
|
|
(mo-pass path note-arvo)
|
|
|
|
::
|
|
|
|
%chat-action
|
|
|
|
=/ chat-act=(unit chat-action) ((soft chat-action) noun.deal)
|
|
|
|
?~ chat-act
|
2020-04-22 12:27:36 +03:00
|
|
|
~& gall-raw-chat-poke-failed+[dap attributing.routes]
|
2020-04-22 08:37:12 +03:00
|
|
|
mo-core
|
|
|
|
=/ =cage [%chat-action !>(u.chat-act)]
|
|
|
|
=/ new-deal=^deal [%poke cage]
|
2020-04-22 12:27:36 +03:00
|
|
|
=/ app (ap-abed:ap dap routes)
|
2020-04-22 08:37:12 +03:00
|
|
|
=. app (ap-apply:app new-deal)
|
|
|
|
ap-abet:app
|
|
|
|
==
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-09 04:26:47 +03:00
|
|
|
?: ?=(%poke-as -.deal)
|
2020-04-22 12:27:36 +03:00
|
|
|
=/ =schematic:ford [%cast ship^desk mark.deal [%$ cage.deal]]
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ =note-arvo [%f %build live=%.n schematic]
|
|
|
|
(mo-pass path note-arvo)
|
|
|
|
::
|
2020-04-22 12:27:36 +03:00
|
|
|
=/ app (ap-abed:ap dap routes)
|
2019-11-09 04:26:47 +03:00
|
|
|
=. app (ap-apply:app deal)
|
2019-08-29 21:44:37 +03:00
|
|
|
ap-abet:app
|
|
|
|
:: +mo-handle-local: handle locally.
|
|
|
|
::
|
2019-11-09 04:26:47 +03:00
|
|
|
:: If the agent is running or blocked, assign it the supplied +deal.
|
2019-08-29 21:44:37 +03:00
|
|
|
:: Otherwise simply apply the action to the agent.
|
|
|
|
::
|
|
|
|
++ mo-handle-local
|
2020-04-30 09:00:57 +03:00
|
|
|
|= [=ship agent=term =deal]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
|
|
|
::
|
|
|
|
=/ =routes [disclosing=~ attributing=ship]
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ is-running (~(has by yokes.state) agent)
|
|
|
|
=/ is-blocked (~(has by blocked.state) agent)
|
|
|
|
::
|
|
|
|
?: |(!is-running is-blocked)
|
|
|
|
=/ blocked=(qeu blocked-move)
|
|
|
|
=/ waiting (~(get by blocked.state) agent)
|
|
|
|
=/ deals (fall waiting *(qeu blocked-move))
|
|
|
|
=/ deal [hen routes deal]
|
|
|
|
(~(put to deals) deal)
|
|
|
|
::
|
|
|
|
%- (slog leaf+"gall: not running {<agent>} yet, got {<-.deal>}" ~)
|
|
|
|
%_ mo-core
|
|
|
|
blocked.state (~(put by blocked.state) agent blocked)
|
|
|
|
==
|
|
|
|
(mo-apply agent routes deal)
|
2019-11-20 00:03:07 +03:00
|
|
|
:: +mo-handle-ames-request: handle %ames request message.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
++ mo-handle-ames-request
|
2020-04-30 09:00:57 +03:00
|
|
|
|= [=ship agent-name=term =ames-request]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
2019-11-20 00:03:07 +03:00
|
|
|
:: %u/%leave gets automatically acked
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-27 01:56:20 +03:00
|
|
|
=. mo-core (mo-track-ship ship)
|
2019-11-03 03:52:48 +03:00
|
|
|
=? mo-core ?=(%u -.ames-request) (mo-give %done ~)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ =wire /sys/req/(scot %p ship)/[agent-name]
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
=/ =deal
|
2019-10-30 23:12:57 +03:00
|
|
|
?- -.ames-request
|
2019-11-20 00:03:07 +03:00
|
|
|
%m [%raw-poke [mark noun]:ames-request]
|
|
|
|
%l [%watch-as [mark path]:ames-request]
|
|
|
|
%s [%watch path.ames-request]
|
|
|
|
%u [%leave ~]
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
2020-04-30 09:00:57 +03:00
|
|
|
(mo-pass wire %g %deal [ship our] agent-name deal)
|
2019-11-20 00:03:07 +03:00
|
|
|
:: +mo-handle-ames-response: handle ames response message.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
++ mo-handle-ames-response
|
2019-11-04 04:35:45 +03:00
|
|
|
|= =ames-response
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ mo-core
|
2019-10-30 23:12:57 +03:00
|
|
|
?- -.ames-response
|
|
|
|
:: %d: diff; ask ford to validate .noun as .mark
|
|
|
|
::
|
2019-08-29 21:44:37 +03:00
|
|
|
%d
|
2019-11-04 04:35:45 +03:00
|
|
|
=/ =wire /sys/rep
|
|
|
|
:: agents load their code from the %home desk, including marks
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
=/ =note-arvo
|
2019-11-04 04:35:45 +03:00
|
|
|
=/ =disc:ford [our %home]
|
2019-10-30 23:12:57 +03:00
|
|
|
[%f %build live=%.n %vale disc [mark noun]:ames-response]
|
2019-11-08 01:46:06 +03:00
|
|
|
(mo-pass wire note-arvo)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
:: %x: kick; tell agent the publisher canceled the subscription
|
2019-10-30 23:12:57 +03:00
|
|
|
::
|
2019-08-29 21:44:37 +03:00
|
|
|
%x
|
2019-11-20 00:03:07 +03:00
|
|
|
(mo-give %unto %kick ~)
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
:: +ap: agent engine
|
|
|
|
::
|
|
|
|
:: An inner, agent-level core. The sample refers to the agent we're
|
|
|
|
:: currently focused on.
|
|
|
|
::
|
|
|
|
++ ap
|
2019-11-19 07:36:21 +03:00
|
|
|
~% %gall-ap +> ~
|
2020-04-30 09:00:57 +03:00
|
|
|
|_ $: agent-name=term
|
|
|
|
agent-routes=routes
|
|
|
|
agent-duct=duct
|
|
|
|
agent-moves=(list move)
|
|
|
|
agent-config=(list (each suss tang))
|
|
|
|
current-agent=yoke
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
++ ap-core .
|
|
|
|
:: +ap-abed: initialise state for an agent, with the supplied routes.
|
|
|
|
::
|
2019-11-19 07:36:21 +03:00
|
|
|
:: The agent must already be running in +gall -- here we simply update
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap's state to focus on it.
|
|
|
|
::
|
|
|
|
++ ap-abed
|
|
|
|
~/ %ap-abed
|
2020-04-22 13:49:23 +03:00
|
|
|
|= [dap=term =routes]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ ap-core
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ =yoke
|
2020-04-22 13:49:23 +03:00
|
|
|
=/ running (~(got by yokes.state) dap)
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ =stats
|
|
|
|
:+ +(change.stats.running)
|
2020-04-22 13:49:23 +03:00
|
|
|
(shaz (mix (add dap change.stats.running) eny))
|
2019-08-29 21:44:37 +03:00
|
|
|
now
|
|
|
|
running(stats stats)
|
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
=. agent-name dap
|
|
|
|
=. agent-routes routes
|
|
|
|
=. current-agent yoke
|
|
|
|
=. agent-duct hen
|
2019-09-12 05:55:31 +03:00
|
|
|
ap-core
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap-abet: resolve moves.
|
|
|
|
::
|
|
|
|
++ ap-abet
|
|
|
|
^+ mo-core
|
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ running (~(put by yokes.state) agent-name current-agent)
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ moves
|
|
|
|
=/ giver |=(report=(each suss tang) [hen %give %onto report])
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ from-suss (turn agent-config giver)
|
|
|
|
:(weld agent-moves from-suss moves)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
%_ mo-core
|
2020-04-22 08:37:12 +03:00
|
|
|
yokes.state running
|
|
|
|
moves moves
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
:: +ap-from-internal: internal move to move.
|
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
:: We convert from cards to duct-indexed moves when resolving
|
|
|
|
:: them in Arvo.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
++ ap-from-internal
|
|
|
|
~/ %ap-from-internal
|
2019-11-09 04:26:47 +03:00
|
|
|
|= card=(wind neat gift:agent)
|
2020-04-30 09:00:57 +03:00
|
|
|
^- (list move)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
?- -.card
|
|
|
|
%slip !!
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
%give
|
|
|
|
=/ =gift:agent p.card
|
2019-11-08 00:17:13 +03:00
|
|
|
?: ?=(%kick -.gift)
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ ducts=(list duct) (ap-ducts-from-paths paths.gift ship.gift)
|
|
|
|
%+ turn ducts
|
2019-11-08 00:17:13 +03:00
|
|
|
|= =duct
|
2020-04-30 09:00:57 +03:00
|
|
|
~? &(=(duct system-duct.state) !=(agent-name %hood))
|
|
|
|
[%agent-giving-on-system-duct agent-name -.gift]
|
2019-11-09 04:26:47 +03:00
|
|
|
[duct %give %unto %kick ~]
|
2019-11-08 01:46:06 +03:00
|
|
|
::
|
2019-11-07 09:19:32 +03:00
|
|
|
?. ?=(%fact -.gift)
|
2020-04-30 09:00:57 +03:00
|
|
|
[agent-duct %give %unto gift]~
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ ducts=(list duct) (ap-ducts-from-paths paths.gift ~)
|
2019-09-12 05:55:31 +03:00
|
|
|
=/ =cage cage.gift
|
2020-04-30 09:00:57 +03:00
|
|
|
%+ turn ducts
|
|
|
|
|= =duct
|
|
|
|
~? &(=(duct system-duct.state) !=(agent-name %hood))
|
|
|
|
[%agent-giving-on-system-duct agent-name -.gift]
|
|
|
|
^- move
|
|
|
|
=/ =mark
|
|
|
|
(~(gut by marks.current-agent) duct p.cage)
|
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
?: =(mark p.cage)
|
2020-04-30 09:00:57 +03:00
|
|
|
[duct %give %unto %fact cage.gift]
|
|
|
|
=/ =path /sys/pel/[agent-name]
|
|
|
|
=/ =note-arvo
|
|
|
|
=/ =schematic:ford
|
|
|
|
=/ =beak (mo-beak agent-name)
|
|
|
|
[%cast [p q]:beak mark [%$ cage]]
|
|
|
|
[%f %build live=%.n schematic]
|
|
|
|
::
|
|
|
|
[duct %pass path note-arvo]
|
2019-09-12 05:55:31 +03:00
|
|
|
::
|
|
|
|
%pass
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ =duct system-duct.state
|
2019-09-29 07:44:31 +03:00
|
|
|
=/ =wire p.card
|
2020-04-22 01:50:47 +03:00
|
|
|
=/ =neat q.card
|
2019-09-29 07:44:31 +03:00
|
|
|
=. wire
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
?: ?=(%agent -.neat)
|
|
|
|
:: remove `our` in next breach after 2019/12 and reflect in
|
|
|
|
:: +mo-handle-use (non-unto case)
|
|
|
|
::
|
|
|
|
:- (scot %p our)
|
|
|
|
[%out (scot %p ship.neat) name.neat wire]
|
2020-04-30 09:00:57 +03:00
|
|
|
[(scot %p attributing.agent-routes) wire]
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
=. wire
|
2020-04-30 09:00:57 +03:00
|
|
|
[%use agent-name wire]
|
2019-09-12 05:55:31 +03:00
|
|
|
=/ =note-arvo
|
2020-04-22 01:50:47 +03:00
|
|
|
?- -.neat
|
|
|
|
%arvo note-arvo.neat
|
|
|
|
%agent [%g %deal [our ship.neat] [name deal]:neat]
|
2019-09-12 05:55:31 +03:00
|
|
|
==
|
2020-04-30 09:00:57 +03:00
|
|
|
[duct %pass wire note-arvo]~
|
2019-09-12 05:55:31 +03:00
|
|
|
==
|
2019-11-05 07:19:08 +03:00
|
|
|
:: +ap-breach: ship breached, so forget about them
|
|
|
|
::
|
|
|
|
++ ap-breach
|
|
|
|
|= =ship
|
|
|
|
^+ ap-core
|
|
|
|
=/ in=(list [=duct =^ship =path])
|
2020-04-30 09:00:57 +03:00
|
|
|
~(tap by inbound.watches.current-agent)
|
2019-11-05 07:19:08 +03:00
|
|
|
|- ^+ ap-core
|
|
|
|
?^ in
|
|
|
|
=? ap-core =(ship ship.i.in)
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ core ap-load-delete(agent-duct duct.i.in)
|
|
|
|
core(agent-duct agent-duct)
|
2019-11-05 07:19:08 +03:00
|
|
|
$(in t.in)
|
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
=/ out=(list [[=wire =^ship =term] ? =path])
|
2020-04-30 09:00:57 +03:00
|
|
|
~(tap by outbound.watches.current-agent)
|
2019-11-05 07:19:08 +03:00
|
|
|
|- ^+ ap-core
|
|
|
|
?~ out
|
|
|
|
ap-core
|
|
|
|
=? ap-core =(ship ship.i.out)
|
|
|
|
=/ core
|
2020-04-30 09:00:57 +03:00
|
|
|
=. agent-duct system-duct.state
|
2019-12-03 10:46:15 +03:00
|
|
|
=/ way [%out (scot %p ship) term.i.out wire.i.out]
|
|
|
|
(ap-specific-take way %kick ~)
|
2020-04-30 09:00:57 +03:00
|
|
|
core(agent-duct agent-duct)
|
2019-11-05 07:19:08 +03:00
|
|
|
$(out t.out)
|
2019-11-04 04:35:45 +03:00
|
|
|
:: +ap-clog: handle %clog notification from ames
|
|
|
|
::
|
|
|
|
:: Kills subscriptions from .ship in both directions:
|
|
|
|
:: - notifies local app that subscription is dead
|
|
|
|
:: - gives remote %quit to notify subscriber ship
|
|
|
|
:: TODO: %drip local app notification for error isolation
|
|
|
|
::
|
|
|
|
++ ap-clog
|
|
|
|
|= =ship
|
|
|
|
^+ ap-core
|
|
|
|
::
|
2019-11-20 00:03:07 +03:00
|
|
|
=/ in=(list [=duct =^ship =path])
|
2020-04-30 09:00:57 +03:00
|
|
|
~(tap by inbound.watches.current-agent)
|
2019-11-04 04:35:45 +03:00
|
|
|
|- ^+ ap-core
|
|
|
|
?~ in ap-core
|
|
|
|
::
|
|
|
|
=? ap-core =(ship ship.i.in)
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ core ap-kill-up(agent-duct duct.i.in)
|
|
|
|
core(agent-duct agent-duct)
|
2019-11-04 04:35:45 +03:00
|
|
|
$(in t.in)
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap-agent-core: agent core with current bowl and state
|
|
|
|
::
|
|
|
|
++ ap-agent-core
|
2020-04-30 09:00:57 +03:00
|
|
|
~(. agent.current-agent ap-construct-bowl)
|
2019-12-22 23:12:28 +03:00
|
|
|
:: +ap-ducts-from-paths: get ducts subscribed to paths
|
|
|
|
::
|
|
|
|
++ ap-ducts-from-paths
|
|
|
|
|= [target-paths=(list path) target-ship=(unit ship)]
|
|
|
|
^- (list duct)
|
|
|
|
?: &(?=(~ target-paths) ?=(~ target-ship))
|
2020-04-30 09:00:57 +03:00
|
|
|
~[agent-duct]
|
2019-12-22 23:12:28 +03:00
|
|
|
%- zing
|
|
|
|
%+ turn target-paths
|
|
|
|
|= =path
|
|
|
|
(ap-ducts-from-path `path target-ship)
|
2019-09-12 05:55:31 +03:00
|
|
|
:: +ap-ducts-from-path: get ducts subscribed to path
|
|
|
|
::
|
|
|
|
++ ap-ducts-from-path
|
2019-09-24 06:46:59 +03:00
|
|
|
|= [target-path=(unit path) target-ship=(unit ship)]
|
2019-09-12 05:55:31 +03:00
|
|
|
^- (list duct)
|
2019-09-24 06:46:59 +03:00
|
|
|
?: &(?=(~ target-path) ?=(~ target-ship))
|
2020-04-30 09:00:57 +03:00
|
|
|
~[agent-duct]
|
|
|
|
%+ murn ~(tap by inbound.watches.current-agent)
|
2019-09-12 05:55:31 +03:00
|
|
|
|= [=duct =ship =path]
|
|
|
|
^- (unit ^duct)
|
2019-09-24 06:46:59 +03:00
|
|
|
?~ target-ship
|
|
|
|
?: =(target-path `path)
|
|
|
|
`duct
|
|
|
|
~
|
|
|
|
?~ target-path
|
|
|
|
?: =(target-ship `ship)
|
|
|
|
`duct
|
|
|
|
~
|
|
|
|
?: &(=(target-path `path) =(target-ship `ship))
|
2019-09-12 05:55:31 +03:00
|
|
|
`duct
|
|
|
|
~
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap-apply: apply effect.
|
|
|
|
::
|
|
|
|
++ ap-apply
|
2019-11-09 04:26:47 +03:00
|
|
|
|= =deal
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ ap-core
|
2019-11-09 04:26:47 +03:00
|
|
|
?- -.deal
|
|
|
|
%watch-as (ap-subscribe-as +.deal)
|
|
|
|
%poke (ap-poke +.deal)
|
|
|
|
%watch (ap-subscribe +.deal)
|
|
|
|
%raw-poke !!
|
|
|
|
%poke-as !!
|
|
|
|
%leave ap-load-delete
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
:: +ap-peek: peek.
|
|
|
|
::
|
|
|
|
++ ap-peek
|
|
|
|
~/ %ap-peek
|
2020-04-22 13:49:23 +03:00
|
|
|
|= [care=term tyl=path]
|
2019-08-29 21:44:37 +03:00
|
|
|
^- (unit (unit cage))
|
2020-04-22 13:49:23 +03:00
|
|
|
:: strip trailing mark off path for %x scrys
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 13:49:23 +03:00
|
|
|
=? tyl ?=(%x care) (flop (tail (flop tyl)))
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ peek-result=(each (unit (unit cage)) tang)
|
2020-04-22 13:49:23 +03:00
|
|
|
(ap-mule-peek |.((on-peek:ap-agent-core [care tyl])))
|
2019-08-29 21:44:37 +03:00
|
|
|
?- -.peek-result
|
|
|
|
%& p.peek-result
|
|
|
|
%| ((slog leaf+"peek bad result" p.peek-result) [~ ~])
|
2019-09-04 22:48:36 +03:00
|
|
|
==
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap-update-subscription: update subscription.
|
|
|
|
::
|
|
|
|
++ ap-update-subscription
|
|
|
|
~/ %ap-update-subscription
|
2019-09-29 07:44:31 +03:00
|
|
|
|= [is-ok=? =other=ship other-agent=term =wire]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ ap-core
|
|
|
|
?: is-ok
|
|
|
|
ap-core
|
2019-11-20 00:03:07 +03:00
|
|
|
(ap-kill-down wire [other-ship other-agent])
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap-give: return result.
|
|
|
|
::
|
|
|
|
++ ap-give
|
2019-09-12 05:55:31 +03:00
|
|
|
|= =gift:agent
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ ap-core
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ internal-moves
|
|
|
|
(weld (ap-from-internal %give gift) agent-moves)
|
|
|
|
ap-core(agent-moves internal-moves)
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap-construct-bowl: set up bowl.
|
|
|
|
::
|
|
|
|
++ ap-construct-bowl
|
|
|
|
^- bowl
|
|
|
|
:* :* our :: host
|
2020-04-30 09:00:57 +03:00
|
|
|
attributing.agent-routes :: guest
|
|
|
|
agent-name :: agent
|
2019-08-29 21:44:37 +03:00
|
|
|
== ::
|
2020-04-30 09:00:57 +03:00
|
|
|
:* wex=outbound.watches.current-agent :: outgoing
|
|
|
|
sup=inbound.watches.current-agent :: incoming
|
2019-08-29 21:44:37 +03:00
|
|
|
== ::
|
2020-04-30 09:00:57 +03:00
|
|
|
:* act=change.stats.current-agent :: tick
|
|
|
|
eny=eny.stats.current-agent :: nonce
|
|
|
|
now=time.stats.current-agent :: time
|
|
|
|
byk=beak.current-agent :: source
|
2019-08-29 21:44:37 +03:00
|
|
|
== ==
|
2020-04-30 09:00:57 +03:00
|
|
|
:: +ap-pass: request action.
|
|
|
|
::
|
|
|
|
++ ap-pass
|
|
|
|
|= [=path =neat]
|
|
|
|
^+ ap-core
|
|
|
|
=/ internal-moves
|
|
|
|
(ap-from-internal %pass path neat)
|
|
|
|
ap-core(agent-moves (weld internal-moves agent-moves))
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap-reinstall: reinstall.
|
|
|
|
::
|
|
|
|
++ ap-reinstall
|
|
|
|
~/ %ap-reinstall
|
2020-04-22 08:37:12 +03:00
|
|
|
|= =agent
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ ap-core
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ old-state=vase ~(on-save agent.current-agent ap-construct-bowl)
|
2020-04-22 08:37:12 +03:00
|
|
|
=^ error ap-core
|
2020-04-30 09:00:57 +03:00
|
|
|
(ap-install(agent.current-agent agent) `old-state)
|
2020-04-22 08:37:12 +03:00
|
|
|
?~ error
|
2019-08-29 21:44:37 +03:00
|
|
|
ap-core
|
2020-04-22 08:37:12 +03:00
|
|
|
(ap-error %load-failed u.error)
|
2019-11-09 04:26:47 +03:00
|
|
|
:: +ap-subscribe-as: apply %watch-as.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-09 04:26:47 +03:00
|
|
|
++ ap-subscribe-as
|
2019-08-29 21:44:37 +03:00
|
|
|
|= [=mark =path]
|
|
|
|
^+ ap-core
|
2020-04-30 09:00:57 +03:00
|
|
|
=. marks.current-agent (~(put by marks.current-agent) agent-duct mark)
|
2019-09-12 05:55:31 +03:00
|
|
|
(ap-subscribe path)
|
2019-11-07 09:19:32 +03:00
|
|
|
:: +ap-subscribe: apply %watch.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
++ ap-subscribe
|
|
|
|
~/ %ap-subscribe
|
2019-08-29 21:44:37 +03:00
|
|
|
|= pax=path
|
|
|
|
^+ ap-core
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ incoming [attributing.agent-routes pax]
|
|
|
|
=. inbound.watches.current-agent
|
|
|
|
(~(put by inbound.watches.current-agent) agent-duct incoming)
|
2019-08-29 21:44:37 +03:00
|
|
|
=^ maybe-tang ap-core
|
2019-11-07 09:19:32 +03:00
|
|
|
%+ ap-ingest %watch-ack |.
|
|
|
|
(on-watch:ap-agent-core pax)
|
2019-08-29 21:44:37 +03:00
|
|
|
?^ maybe-tang
|
|
|
|
ap-silent-delete
|
|
|
|
ap-core
|
|
|
|
:: +ap-poke: apply %poke.
|
|
|
|
::
|
|
|
|
++ ap-poke
|
|
|
|
~/ %ap-poke
|
|
|
|
|= =cage
|
|
|
|
^+ ap-core
|
|
|
|
=^ maybe-tang ap-core
|
2019-09-12 05:55:31 +03:00
|
|
|
%+ ap-ingest %poke-ack |.
|
2019-11-07 09:19:32 +03:00
|
|
|
(on-poke:ap-agent-core cage)
|
2019-08-29 21:44:37 +03:00
|
|
|
ap-core
|
2019-09-12 05:55:31 +03:00
|
|
|
:: +ap-error: pour error.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
++ ap-error
|
2019-08-29 21:44:37 +03:00
|
|
|
|= [=term =tang]
|
|
|
|
^+ ap-core
|
|
|
|
=/ form |=(=tank [%rose [~ "! " ~] tank ~])
|
2019-08-29 22:57:33 +03:00
|
|
|
=^ maybe-tang ap-core
|
|
|
|
%+ ap-ingest ~ |.
|
2019-11-07 09:19:32 +03:00
|
|
|
(on-fail:ap-agent-core term (turn tang form))
|
2019-08-29 21:44:37 +03:00
|
|
|
ap-core
|
|
|
|
:: +ap-generic-take: generic take.
|
|
|
|
::
|
|
|
|
++ ap-generic-take
|
|
|
|
~/ %ap-generic-take
|
2019-09-12 05:55:31 +03:00
|
|
|
|= [=wire =sign-arvo]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ ap-core
|
|
|
|
=^ maybe-tang ap-core
|
|
|
|
%+ ap-ingest ~ |.
|
2019-11-07 09:19:32 +03:00
|
|
|
(on-arvo:ap-agent-core wire sign-arvo)
|
2019-08-29 21:44:37 +03:00
|
|
|
?^ maybe-tang
|
2019-09-12 05:55:31 +03:00
|
|
|
(ap-error %arvo-response u.maybe-tang)
|
2019-08-29 21:44:37 +03:00
|
|
|
ap-core
|
|
|
|
:: +ap-specific-take: specific take.
|
|
|
|
::
|
|
|
|
++ ap-specific-take
|
2019-11-09 04:26:47 +03:00
|
|
|
|= [=wire =sign:agent]
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ ap-core
|
2019-09-29 07:44:31 +03:00
|
|
|
~| wire=wire
|
|
|
|
?> ?=([%out @ @ *] wire)
|
|
|
|
=/ other-ship (slav %p i.t.wire)
|
|
|
|
=/ other-agent i.t.t.wire
|
2019-10-01 06:53:02 +03:00
|
|
|
=/ =dock [other-ship other-agent]
|
2019-09-29 07:44:31 +03:00
|
|
|
=/ agent-wire t.t.t.wire
|
2019-10-01 06:53:02 +03:00
|
|
|
:: if subscription ack or close, handle before calling user code
|
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
=? outbound.watches.current-agent ?=(%kick -.sign)
|
|
|
|
%- ~(del by outbound.watches.current-agent)
|
2019-11-08 05:25:19 +03:00
|
|
|
[agent-wire dock]
|
2019-11-09 04:26:47 +03:00
|
|
|
?: ?& ?=(%watch-ack -.sign)
|
2020-04-30 09:00:57 +03:00
|
|
|
!(~(has by outbound.watches.current-agent) [agent-wire dock])
|
2019-11-06 06:55:51 +03:00
|
|
|
==
|
|
|
|
%- %: slog
|
2020-04-30 09:00:57 +03:00
|
|
|
leaf+"{<agent-name>}: got ack for nonexistent subscription"
|
2019-11-06 06:55:51 +03:00
|
|
|
leaf+"{<dock>}: {<agent-wire>}"
|
2019-11-08 05:25:19 +03:00
|
|
|
>wire=wire<
|
2020-04-30 09:00:57 +03:00
|
|
|
>out=outbound.watches.current-agent<
|
2019-11-06 06:55:51 +03:00
|
|
|
~
|
|
|
|
==
|
|
|
|
ap-core
|
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
=? outbound.watches.current-agent ?=(%watch-ack -.sign)
|
2019-11-09 04:26:47 +03:00
|
|
|
?^ p.sign
|
2020-04-30 09:00:57 +03:00
|
|
|
%- ~(del by outbound.watches.current-agent)
|
2019-11-27 05:18:44 +03:00
|
|
|
[agent-wire dock]
|
2020-04-30 09:00:57 +03:00
|
|
|
%+ ~(jab by outbound.watches.current-agent) [agent-wire dock]
|
2019-10-01 06:53:02 +03:00
|
|
|
|= [acked=? =path]
|
2019-12-10 11:21:03 +03:00
|
|
|
=. .
|
|
|
|
?. acked
|
|
|
|
.
|
|
|
|
%- =/ =tape
|
2020-04-30 09:00:57 +03:00
|
|
|
"{<agent-name>}: received 2nd watch-ack on {<wire dock path>}"
|
2019-12-10 11:21:03 +03:00
|
|
|
(slog leaf+tape ~)
|
|
|
|
.
|
2019-10-01 06:53:02 +03:00
|
|
|
[& path]
|
|
|
|
::
|
2019-08-29 21:44:37 +03:00
|
|
|
=^ maybe-tang ap-core
|
|
|
|
%+ ap-ingest ~ |.
|
2019-11-09 04:26:47 +03:00
|
|
|
(on-agent:ap-agent-core agent-wire sign)
|
2019-12-10 11:21:03 +03:00
|
|
|
:: if failed %fact handling, kill subscription
|
2019-10-01 06:53:02 +03:00
|
|
|
::
|
2019-11-09 04:26:47 +03:00
|
|
|
=? ap-core ?=(%fact -.sign)
|
2019-10-01 06:53:02 +03:00
|
|
|
(ap-update-subscription =(~ maybe-tang) p.dock q.dock agent-wire)
|
2019-08-29 21:44:37 +03:00
|
|
|
?^ maybe-tang
|
2019-11-09 04:26:47 +03:00
|
|
|
(ap-error -.sign leaf/"closing subscription" u.maybe-tang)
|
2019-08-29 21:44:37 +03:00
|
|
|
ap-core
|
|
|
|
:: +ap-install: install wrapper.
|
|
|
|
::
|
|
|
|
++ ap-install
|
2020-04-22 08:37:12 +03:00
|
|
|
|= old-agent-state=(unit vase)
|
2019-08-29 21:44:37 +03:00
|
|
|
^- [(unit tang) _ap-core]
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
=^ maybe-tang ap-core (ap-upgrade-state old-agent-state)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
=. agent-config
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ =term ?~(old-agent-state %boot %bump)
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ possibly-suss
|
|
|
|
?~ maybe-tang
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ =suss [agent-name term now]
|
2019-08-29 21:44:37 +03:00
|
|
|
[%.y suss]
|
|
|
|
[%.n u.maybe-tang]
|
2020-04-30 09:00:57 +03:00
|
|
|
[possibly-suss agent-config]
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
[maybe-tang ap-core]
|
2019-09-12 05:55:31 +03:00
|
|
|
:: +ap-upgrade-state: low-level install.
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-09-12 05:55:31 +03:00
|
|
|
++ ap-upgrade-state
|
|
|
|
~/ %ap-upgrade-state
|
2019-08-29 21:44:37 +03:00
|
|
|
|= maybe-vase=(unit vase)
|
|
|
|
^- [(unit tang) _ap-core]
|
|
|
|
::
|
|
|
|
=^ maybe-tang ap-core
|
|
|
|
%+ ap-ingest ~
|
|
|
|
?~ maybe-vase
|
2019-11-07 09:19:32 +03:00
|
|
|
|. on-init:ap-agent-core
|
|
|
|
|. (on-load:ap-agent-core u.maybe-vase)
|
2019-08-29 21:44:37 +03:00
|
|
|
[maybe-tang ap-core]
|
|
|
|
:: +ap-silent-delete: silent delete.
|
|
|
|
::
|
|
|
|
++ ap-silent-delete
|
|
|
|
^+ ap-core
|
|
|
|
::
|
2019-11-01 23:18:51 +03:00
|
|
|
%= ap-core
|
2020-04-30 09:00:57 +03:00
|
|
|
inbound.watches.current-agent
|
|
|
|
(~(del by inbound.watches.current-agent) agent-duct)
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
:: +ap-load-delete: load delete.
|
|
|
|
::
|
|
|
|
++ ap-load-delete
|
|
|
|
^+ ap-core
|
|
|
|
::
|
|
|
|
=/ maybe-incoming
|
2020-04-30 09:00:57 +03:00
|
|
|
(~(get by inbound.watches.current-agent) agent-duct)
|
2019-08-29 21:44:37 +03:00
|
|
|
?~ maybe-incoming
|
|
|
|
ap-core
|
|
|
|
::
|
|
|
|
=/ incoming u.maybe-incoming
|
2020-04-30 09:00:57 +03:00
|
|
|
=. inbound.watches.current-agent
|
|
|
|
(~(del by inbound.watches.current-agent) agent-duct)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
=^ maybe-tang ap-core
|
|
|
|
%+ ap-ingest ~ |.
|
2019-11-07 09:19:32 +03:00
|
|
|
(on-leave:ap-agent-core q.incoming)
|
2019-08-29 21:44:37 +03:00
|
|
|
?^ maybe-tang
|
2019-11-07 09:19:32 +03:00
|
|
|
(ap-error %leave u.maybe-tang)
|
2019-08-29 21:44:37 +03:00
|
|
|
ap-core
|
2019-09-29 07:44:31 +03:00
|
|
|
:: +ap-kill-up: 2-sided kill from publisher side
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-09-29 07:44:31 +03:00
|
|
|
++ ap-kill-up
|
2019-08-29 21:44:37 +03:00
|
|
|
^+ ap-core
|
|
|
|
::
|
|
|
|
=> ap-load-delete
|
2019-11-07 09:19:32 +03:00
|
|
|
(ap-give %kick ~ ~)
|
2019-09-29 07:44:31 +03:00
|
|
|
:: +ap-kill-down: 2-sided kill from subscriber side
|
|
|
|
::
|
2019-11-21 00:22:36 +03:00
|
|
|
:: Must process leave first in case kick handler rewatches.
|
|
|
|
::
|
2019-09-29 07:44:31 +03:00
|
|
|
++ ap-kill-down
|
|
|
|
|= [=wire =dock]
|
|
|
|
^+ ap-core
|
|
|
|
::
|
|
|
|
=. ap-core
|
2019-11-21 00:22:36 +03:00
|
|
|
(ap-pass wire %agent dock %leave ~)
|
|
|
|
=/ way [%out (scot %p p.dock) q.dock wire]
|
|
|
|
(ap-pass way %arvo %b %huck !>([%unto %kick ~]))
|
2019-11-22 01:45:56 +03:00
|
|
|
:: +ap-mule: run virtualized with intercepted scry, preserving type
|
|
|
|
::
|
|
|
|
:: Compare +mute and +mule. Those pass through scry, which
|
|
|
|
:: doesn't allow us to catch crashes due to blocking scry. If
|
|
|
|
:: you intercept scry, you can't preserve the type
|
|
|
|
:: polymorphically. By monomorphizing, we are able to do so
|
|
|
|
:: safely.
|
|
|
|
::
|
|
|
|
++ ap-mule
|
|
|
|
|= run=_^?(|.(*step:agent))
|
|
|
|
^- (each step:agent tang)
|
|
|
|
=/ res (mock [run %9 2 %0 1] (sloy ski))
|
|
|
|
?- -.res
|
|
|
|
%0 [%& !<(step:agent [-:!>(*step:agent) p.res])]
|
|
|
|
%1 [%| (turn p.res |=(a=* (smyt (path a))))]
|
|
|
|
%2 [%| p.res]
|
|
|
|
==
|
|
|
|
:: +ap-mule-peek: same as +ap-mule but for (unit (unit cage))
|
|
|
|
::
|
|
|
|
++ ap-mule-peek
|
|
|
|
|= run=_^?(|.(*(unit (unit cage))))
|
|
|
|
^- (each (unit (unit cage)) tang)
|
|
|
|
=/ res (mock [run %9 2 %0 1] (sloy ski))
|
|
|
|
?- -.res
|
|
|
|
%0 [%& !<((unit (unit cage)) [-:!>(*(unit (unit cage))) p.res])]
|
|
|
|
%1 [%| (turn p.res |=(a=* (smyt (path a))))]
|
|
|
|
%2 [%| p.res]
|
|
|
|
==
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +ap-ingest: call agent arm
|
|
|
|
::
|
|
|
|
:: Handle acks here because they need to be emitted before the
|
|
|
|
:: rest of the moves.
|
|
|
|
::
|
|
|
|
++ ap-ingest
|
2019-11-07 09:19:32 +03:00
|
|
|
|= [ack=?(%poke-ack %watch-ack ~) run=_^?(|.(*step:agent))]
|
2019-08-29 21:44:37 +03:00
|
|
|
^- [(unit tang) _ap-core]
|
2019-11-22 01:45:56 +03:00
|
|
|
=/ result (ap-mule run)
|
2019-11-08 03:30:45 +03:00
|
|
|
=^ new-moves ap-core (ap-handle-result result)
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ maybe-tang=(unit tang)
|
2019-09-04 22:48:36 +03:00
|
|
|
?: ?=(%& -.result)
|
2019-08-29 21:44:37 +03:00
|
|
|
~
|
2019-09-04 22:48:36 +03:00
|
|
|
`p.result
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ ack-moves=(list move)
|
|
|
|
%- zing
|
|
|
|
%- turn :_ ap-from-internal
|
|
|
|
^- (list card:agent)
|
2019-08-29 21:44:37 +03:00
|
|
|
?- ack
|
2020-04-30 09:00:57 +03:00
|
|
|
~ ~
|
|
|
|
%poke-ack [%give %poke-ack maybe-tang]~
|
|
|
|
%watch-ack [%give %watch-ack maybe-tang]~
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
2020-04-30 09:00:57 +03:00
|
|
|
::
|
|
|
|
=. agent-moves
|
|
|
|
:(weld (flop new-moves) ack-moves agent-moves)
|
2019-08-29 21:44:37 +03:00
|
|
|
[maybe-tang ap-core]
|
|
|
|
:: +ap-handle-result: handle result.
|
|
|
|
::
|
|
|
|
++ ap-handle-result
|
|
|
|
~/ %ap-handle-result
|
2019-09-04 22:48:36 +03:00
|
|
|
|= result=(each step:agent tang)
|
2019-11-08 03:30:45 +03:00
|
|
|
^- [(list move) _ap-core]
|
2019-08-29 21:44:37 +03:00
|
|
|
?: ?=(%| -.result)
|
2019-09-04 22:48:36 +03:00
|
|
|
`ap-core
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
=. agent.current-agent +.p.result
|
|
|
|
=/ moves (zing (turn -.p.result ap-from-internal))
|
|
|
|
=. inbound.watches.current-agent
|
2019-11-08 03:30:45 +03:00
|
|
|
(ap-handle-kicks moves)
|
|
|
|
(ap-handle-peers moves)
|
2020-04-22 08:37:12 +03:00
|
|
|
:: +ap-handle-kicks: handle cancels of inbound.watches
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-08 03:30:45 +03:00
|
|
|
++ ap-handle-kicks
|
|
|
|
~/ %ap-handle-kicks
|
|
|
|
|= moves=(list move)
|
2019-08-29 21:44:37 +03:00
|
|
|
^- bitt
|
2019-09-12 05:55:31 +03:00
|
|
|
=/ quits=(list duct)
|
2019-11-08 03:30:45 +03:00
|
|
|
%+ murn moves
|
|
|
|
|= =move
|
|
|
|
^- (unit duct)
|
|
|
|
?. ?=([* %give %unto %kick *] move)
|
2019-08-29 21:44:37 +03:00
|
|
|
~
|
2019-11-08 03:30:45 +03:00
|
|
|
`duct.move
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
=/ quit-map=bitt
|
2019-09-12 05:55:31 +03:00
|
|
|
(malt (turn quits |=(=duct [duct *[ship path]])))
|
2020-04-30 09:00:57 +03:00
|
|
|
(~(dif by inbound.watches.current-agent) quit-map)
|
2020-04-22 08:37:12 +03:00
|
|
|
:: +ap-handle-peers: handle new outbound.watches
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-01 06:53:02 +03:00
|
|
|
++ ap-handle-peers
|
|
|
|
~/ %ap-handle-peers
|
2019-11-08 03:30:45 +03:00
|
|
|
|= moves=(list move)
|
|
|
|
^- [(list move) _ap-core]
|
|
|
|
=| new-moves=(list move)
|
|
|
|
|- ^- [(list move) _ap-core]
|
2019-10-01 06:53:02 +03:00
|
|
|
?~ moves
|
2019-11-08 03:30:45 +03:00
|
|
|
[(flop new-moves) ap-core]
|
|
|
|
=/ =move i.moves
|
2019-11-19 07:36:21 +03:00
|
|
|
?: ?=([* %pass * %g %deal * * %leave *] move)
|
2019-11-08 03:30:45 +03:00
|
|
|
=/ =wire p.move.move
|
2019-11-08 05:25:19 +03:00
|
|
|
?> ?=([%use @ @ %out @ @ *] wire)
|
|
|
|
=/ short-wire t.t.t.t.t.t.wire
|
2019-11-08 03:30:45 +03:00
|
|
|
=/ =dock [q.p q]:q.move.move
|
2020-04-30 09:00:57 +03:00
|
|
|
=. outbound.watches.current-agent
|
|
|
|
(~(del by outbound.watches.current-agent) [short-wire dock])
|
2019-11-08 03:30:45 +03:00
|
|
|
$(moves t.moves, new-moves [move new-moves])
|
2019-11-19 07:36:21 +03:00
|
|
|
?. ?=([* %pass * %g %deal * * %watch *] move)
|
2019-11-08 03:30:45 +03:00
|
|
|
$(moves t.moves, new-moves [move new-moves])
|
|
|
|
=/ =wire p.move.move
|
2019-11-08 05:25:19 +03:00
|
|
|
?> ?=([%use @ @ %out @ @ *] wire)
|
|
|
|
=/ short-wire t.t.t.t.t.t.wire
|
2019-11-08 03:30:45 +03:00
|
|
|
=/ =dock [q.p q]:q.move.move
|
|
|
|
=/ =path path.r.q.move.move
|
2020-04-30 09:00:57 +03:00
|
|
|
?: (~(has by outbound.watches.current-agent) short-wire dock)
|
2019-11-05 07:19:08 +03:00
|
|
|
=. ap-core
|
2019-10-01 06:53:02 +03:00
|
|
|
=/ =tang
|
2020-04-30 09:00:57 +03:00
|
|
|
~[leaf+"subscribe wire not unique" >agent-name< >short-wire< >dock<]
|
|
|
|
%- (slog >out=outbound.watches.current-agent< tang)
|
2019-11-27 05:18:44 +03:00
|
|
|
(ap-error %watch-not-unique tang)
|
2019-10-01 06:53:02 +03:00
|
|
|
$(moves t.moves)
|
2020-04-30 09:00:57 +03:00
|
|
|
=. outbound.watches.current-agent
|
|
|
|
(~(put by outbound.watches.current-agent) [short-wire dock] [| path])
|
2019-11-08 03:30:45 +03:00
|
|
|
$(moves t.moves, new-moves [move new-moves])
|
2019-08-29 21:44:37 +03:00
|
|
|
--
|
|
|
|
--
|
|
|
|
:: +call: request
|
|
|
|
::
|
|
|
|
++ call
|
2019-11-19 07:36:21 +03:00
|
|
|
~% %gall-call +> ~
|
2020-02-11 01:03:03 +03:00
|
|
|
|= [=duct dud=(unit goof) hic=(hypo (hobo task:able))]
|
2019-11-19 07:36:21 +03:00
|
|
|
^- [(list move) _gall-payload]
|
2020-02-25 01:10:59 +03:00
|
|
|
?^ dud
|
|
|
|
~|(%gall-call-dud (mean tang.u.dud))
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-19 07:36:21 +03:00
|
|
|
~| [%gall-call-failed duct q.hic]
|
2020-01-21 02:01:36 +03:00
|
|
|
=/ =task:able ((harden task:able) q.hic)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 01:50:47 +03:00
|
|
|
=/ mo-core (mo-abed:mo duct)
|
2019-08-29 21:44:37 +03:00
|
|
|
?- -.task
|
2020-04-22 01:50:47 +03:00
|
|
|
%conf mo-abet:(mo-boot:mo-core dap.task our %home)
|
2019-11-09 04:26:47 +03:00
|
|
|
%deal
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ [=sock =term =deal] [p q r]:task
|
2019-08-29 21:44:37 +03:00
|
|
|
?. =(q.sock our)
|
|
|
|
?> =(p.sock our)
|
2020-04-22 01:50:47 +03:00
|
|
|
mo-abet:(mo-send-foreign-request:mo-core q.sock term deal)
|
|
|
|
mo-abet:(mo-handle-local:mo-core p.sock term deal)
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
%goad mo-abet:(mo-goad:mo-core agent.task)
|
|
|
|
%init [~ gall-payload(system-duct.state duct)]
|
2019-10-30 23:12:57 +03:00
|
|
|
%plea
|
|
|
|
=/ =ship ship.task
|
2019-11-01 22:06:09 +03:00
|
|
|
=/ =path path.plea.task
|
|
|
|
=/ =noun payload.plea.task
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
~| [ship=ship plea-path=path]
|
|
|
|
?> ?=([%ge @ ~] path)
|
2020-04-30 09:00:57 +03:00
|
|
|
=/ agent-name i.t.path
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
=/ =ames-request ;;(ames-request noun)
|
2020-04-30 09:00:57 +03:00
|
|
|
=> (mo-handle-ames-request:mo-core ship agent-name ames-request)
|
2019-08-29 21:44:37 +03:00
|
|
|
mo-abet
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
%sear mo-abet:(mo-filter-queue:mo-core ship.task)
|
|
|
|
%trim [~ gall-payload]
|
|
|
|
%vega [~ gall-payload]
|
2019-08-29 21:44:37 +03:00
|
|
|
%wegh
|
|
|
|
=/ blocked
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ queued (~(run by blocked.state) |=((qeu blocked-move) [%.y +<]))
|
2019-08-29 21:44:37 +03:00
|
|
|
(sort ~(tap by queued) aor)
|
|
|
|
::
|
|
|
|
=/ running
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ active (~(run by yokes.state) |=(yoke [%.y +<]))
|
2019-08-29 21:44:37 +03:00
|
|
|
(sort ~(tap by active) aor)
|
|
|
|
::
|
|
|
|
=/ =mass
|
2019-11-19 07:36:21 +03:00
|
|
|
:+ %gall %.n
|
2020-04-22 08:37:12 +03:00
|
|
|
:~ [%foreign %.y contacts.state]
|
2019-08-29 21:44:37 +03:00
|
|
|
[%blocked %.n blocked]
|
|
|
|
[%active %.n running]
|
|
|
|
[%dot %.y state]
|
|
|
|
==
|
|
|
|
::
|
2019-10-30 23:12:57 +03:00
|
|
|
[[duct %give %mass mass]~ gall-payload]
|
2019-08-29 21:44:37 +03:00
|
|
|
==
|
|
|
|
:: +load: recreate vane
|
|
|
|
::
|
|
|
|
++ load
|
2019-12-02 14:20:34 +03:00
|
|
|
|^
|
|
|
|
|= =all-state
|
2019-11-19 07:36:21 +03:00
|
|
|
^+ gall-payload
|
2019-09-10 06:00:56 +03:00
|
|
|
::
|
2019-12-02 14:20:34 +03:00
|
|
|
=? all-state ?=(%0 -.all-state)
|
|
|
|
(state-0-to-1 all-state)
|
|
|
|
::
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
=? all-state ?=(%1 -.all-state)
|
|
|
|
(state-1-to-2 all-state)
|
|
|
|
::
|
2019-12-22 23:12:28 +03:00
|
|
|
=? all-state ?=(%2 -.all-state)
|
|
|
|
(state-2-to-3 all-state)
|
|
|
|
::
|
2020-02-14 02:51:29 +03:00
|
|
|
=? all-state ?=(%3 -.all-state)
|
|
|
|
(state-3-to-4 all-state)
|
|
|
|
::
|
2020-04-22 01:50:47 +03:00
|
|
|
=? all-state ?=(%4 -.all-state)
|
|
|
|
(state-4-to-5 all-state)
|
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
?> ?=(%5 -.all-state)
|
2019-12-02 14:20:34 +03:00
|
|
|
gall-payload(state all-state)
|
|
|
|
::
|
|
|
|
:: +all-state: upgrade path
|
|
|
|
::
|
2020-04-30 09:00:57 +03:00
|
|
|
++ all-state $%(state-0 state-1 state-2 state-3 state-4 state-5)
|
2020-04-22 01:50:47 +03:00
|
|
|
::
|
|
|
|
++ state-4-to-5
|
|
|
|
|= =state-4
|
2020-04-22 08:37:12 +03:00
|
|
|
^- state-5
|
2020-04-22 01:50:47 +03:00
|
|
|
%= state-4
|
|
|
|
- %5
|
|
|
|
running.agents-4
|
2020-04-22 08:37:12 +03:00
|
|
|
(~(run by running.agents-4.state-4) |=(yoke-3 +<+))
|
2020-04-22 01:50:47 +03:00
|
|
|
==
|
|
|
|
::
|
|
|
|
++ state-4
|
|
|
|
$: %4
|
|
|
|
agents-4=agents-3 :: agents-3 is unchanged in state-4
|
|
|
|
==
|
2020-02-14 02:51:29 +03:00
|
|
|
::
|
|
|
|
++ state-3-to-4
|
|
|
|
|= =state-3
|
2020-04-22 01:50:47 +03:00
|
|
|
^- state-4
|
2020-02-14 02:51:29 +03:00
|
|
|
%= state-3
|
|
|
|
- %4
|
2020-04-22 01:50:47 +03:00
|
|
|
outstanding.agents-3 ~
|
2020-02-14 02:51:29 +03:00
|
|
|
==
|
|
|
|
::
|
|
|
|
++ state-3
|
|
|
|
$: %3
|
2020-04-22 01:50:47 +03:00
|
|
|
=agents-3
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ agents-3
|
|
|
|
$: system-duct=duct
|
|
|
|
outstanding=(map [wire duct] (qeu remote-request))
|
|
|
|
contacts=(set ship)
|
2020-04-22 08:37:12 +03:00
|
|
|
running=(map term yoke-3)
|
|
|
|
blocked=(map term (qeu blocked-move))
|
2020-04-22 01:50:47 +03:00
|
|
|
==
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
++ yoke-3
|
2020-04-22 01:50:47 +03:00
|
|
|
$: cache=worm
|
|
|
|
control-duct=duct
|
|
|
|
live=?
|
|
|
|
=stats
|
2020-04-22 08:37:12 +03:00
|
|
|
=watches
|
2020-04-22 01:50:47 +03:00
|
|
|
=agent
|
|
|
|
=beak
|
|
|
|
marks=(map duct mark)
|
2020-02-14 02:51:29 +03:00
|
|
|
==
|
2019-12-22 23:12:28 +03:00
|
|
|
::
|
|
|
|
++ state-2-to-3
|
|
|
|
|= =state-2
|
2020-02-14 02:51:29 +03:00
|
|
|
^- state-3
|
2019-12-22 23:12:28 +03:00
|
|
|
%= state-2
|
|
|
|
- %3
|
|
|
|
running.agents-2
|
|
|
|
%- ~(run by running.agents-2.state-2)
|
2020-04-22 08:37:12 +03:00
|
|
|
|= =yoke-2
|
|
|
|
^- yoke-3
|
|
|
|
%= yoke-2
|
|
|
|
agent-2 (agent-2-to-3 agent-2.yoke-2)
|
2019-12-22 23:12:28 +03:00
|
|
|
==
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ agent-2-to-3
|
|
|
|
|= =agent-2
|
|
|
|
^- agent
|
|
|
|
=> |%
|
|
|
|
++ cards-2-to-3
|
|
|
|
|= cards=(list card:^agent-2)
|
|
|
|
^- (list card:agent)
|
|
|
|
%+ turn cards
|
|
|
|
|= =card:^agent-2
|
|
|
|
^- card:agent
|
|
|
|
?. ?=([%give ?(%fact %kick) *] card) card
|
|
|
|
%=(card path.p (drop path.p.card))
|
|
|
|
--
|
|
|
|
|_ =bowl:gall
|
|
|
|
+* this .
|
|
|
|
pass ~(. agent-2 bowl)
|
|
|
|
++ on-init
|
|
|
|
=^ cards agent-2 on-init:pass
|
|
|
|
[(cards-2-to-3 cards) this]
|
|
|
|
::
|
|
|
|
++ on-save
|
|
|
|
on-save:pass
|
|
|
|
::
|
|
|
|
++ on-load
|
|
|
|
|= old-state=vase
|
|
|
|
=^ cards agent-2 (on-load:pass old-state)
|
|
|
|
[(cards-2-to-3 cards) this]
|
|
|
|
::
|
|
|
|
++ on-poke
|
|
|
|
|= [=mark =vase]
|
|
|
|
=^ cards agent-2 (on-poke:pass mark vase)
|
|
|
|
[(cards-2-to-3 cards) this]
|
|
|
|
::
|
|
|
|
++ on-watch
|
|
|
|
|= =path
|
|
|
|
=^ cards agent-2 (on-watch:pass path)
|
|
|
|
[(cards-2-to-3 cards) this]
|
|
|
|
::
|
|
|
|
++ on-leave
|
|
|
|
|= =path
|
|
|
|
=^ cards agent-2 (on-leave:pass path)
|
|
|
|
[(cards-2-to-3 cards) this]
|
|
|
|
::
|
|
|
|
++ on-peek
|
|
|
|
|= =path
|
|
|
|
(on-peek:pass path)
|
|
|
|
::
|
|
|
|
++ on-agent
|
|
|
|
|= [=wire =sign:agent:gall]
|
|
|
|
=^ cards agent-2 (on-agent:pass wire sign)
|
|
|
|
[(cards-2-to-3 cards) this]
|
|
|
|
::
|
|
|
|
++ on-arvo
|
|
|
|
|= [=wire =sign-arvo]
|
|
|
|
=^ cards agent-2 (on-arvo:pass wire sign-arvo)
|
|
|
|
[(cards-2-to-3 cards) this]
|
|
|
|
::
|
|
|
|
++ on-fail
|
|
|
|
|= [=term =tang]
|
|
|
|
=^ cards agent-2 (on-fail:pass term tang)
|
|
|
|
[(cards-2-to-3 cards) this]
|
|
|
|
--
|
|
|
|
::
|
|
|
|
++ state-2
|
|
|
|
$: %2
|
|
|
|
=agents-2
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ agents-2
|
|
|
|
$: system-duct=duct
|
|
|
|
outstanding=(map [wire duct] (qeu remote-request))
|
|
|
|
contacts=(set ship)
|
2020-04-22 08:37:12 +03:00
|
|
|
running=(map term yoke-2)
|
|
|
|
blocked=(map term (qeu blocked-move))
|
2019-12-22 23:12:28 +03:00
|
|
|
==
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
++ yoke-2
|
2019-12-22 23:12:28 +03:00
|
|
|
$: cache=worm
|
|
|
|
control-duct=duct
|
|
|
|
live=?
|
|
|
|
=stats
|
2020-04-22 08:37:12 +03:00
|
|
|
=watches
|
2019-12-22 23:12:28 +03:00
|
|
|
=agent-2
|
|
|
|
=beak
|
|
|
|
marks=(map duct mark)
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ agent-2
|
|
|
|
=< form
|
|
|
|
|%
|
|
|
|
+$ step (quip card form)
|
|
|
|
+$ card (wind note gift)
|
|
|
|
+$ note note:agent
|
|
|
|
+$ task task:agent
|
|
|
|
+$ sign sign:agent
|
|
|
|
+$ gift
|
|
|
|
$% [%fact path=(unit path) =cage]
|
|
|
|
[%kick path=(unit path) ship=(unit ship)]
|
|
|
|
[%watch-ack p=(unit tang)]
|
|
|
|
[%poke-ack p=(unit tang)]
|
|
|
|
==
|
|
|
|
++ form
|
|
|
|
$_ ^|
|
|
|
|
|_ bowl
|
|
|
|
++ on-init
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-save
|
|
|
|
*vase
|
|
|
|
::
|
|
|
|
++ on-load
|
|
|
|
|~ old-state=vase
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-poke
|
|
|
|
|~ [mark vase]
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-watch
|
|
|
|
|~ path
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-leave
|
|
|
|
|~ path
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-peek
|
|
|
|
|~ path
|
|
|
|
*(unit (unit cage))
|
|
|
|
::
|
|
|
|
++ on-agent
|
|
|
|
|~ [wire sign]
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-arvo
|
|
|
|
|~ [wire sign-arvo]
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-fail
|
|
|
|
|~ [term tang]
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
--
|
|
|
|
--
|
2019-12-02 14:20:34 +03:00
|
|
|
::
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
++ state-1-to-2
|
|
|
|
|= =state-1
|
2019-12-22 23:12:28 +03:00
|
|
|
^- state-2
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
%= state-1
|
|
|
|
- %2
|
|
|
|
+.agents-1 [~ +.agents-1.state-1]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ state-1
|
|
|
|
$: %1
|
|
|
|
=agents-1
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ agents-1
|
|
|
|
$: system-duct=duct
|
|
|
|
contacts=(set ship)
|
2020-04-22 08:37:12 +03:00
|
|
|
running=(map term yoke-2)
|
|
|
|
blocked=(map term (qeu blocked-move))
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
==
|
|
|
|
::
|
2019-12-02 14:20:34 +03:00
|
|
|
++ state-0-to-1
|
|
|
|
|= =state-0
|
gall: remove message type from wire
%leave over the network didn't work because we included the message type
in the wire from gall, so the duct for the initial %watch and the %leave
were different. We need to know the message type so we can route the
acknowledgment as %poke-ack, %watch-ack, or no-op.
This moves this piece of information to a piece of state, where we queue
up the message types per [duct wire]. Ames guarantees that
acknowledgments will come in order.
This also includes an easy state adapter. The more interesting part of
the upgrade is that we likely have outstanding subscriptions with the
old wire format. The disadvantage of storing information in wires is
that it can't be upgraded in +load. So, here we listen for updates on
the old wire format, and when we get them we kill the old subscription,
so that it will be recreated with the new wire format.
As an aside, this is a good example of what we mean when we say
subscriptions may be killed at any time, so apps must handle this case.
Finally, this fixes the "attributing" ship to ~zod for agent requests.
This information was ignored for agent requests, but including it causes
spurious duct mismatches.
2019-12-10 04:52:53 +03:00
|
|
|
^- state-1
|
2019-12-02 14:20:34 +03:00
|
|
|
%= state-0
|
|
|
|
- %1
|
|
|
|
running.agents-0
|
|
|
|
%- ~(run by running.agents-0.state-0)
|
2020-04-22 08:37:12 +03:00
|
|
|
|= =yoke-0
|
|
|
|
^- yoke-2
|
|
|
|
%= yoke-0
|
|
|
|
agent-0 (agent-0-to-1 agent-0.yoke-0)
|
2019-12-02 14:20:34 +03:00
|
|
|
==
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ agent-0-to-1
|
|
|
|
|= =agent-0
|
2019-12-22 23:12:28 +03:00
|
|
|
^- agent-2
|
2019-12-02 14:20:34 +03:00
|
|
|
|_ =bowl:gall
|
|
|
|
+* this .
|
|
|
|
pass ~(. agent-0 bowl)
|
|
|
|
++ on-init
|
|
|
|
=^ cards agent-0 on-init:pass
|
|
|
|
[cards this]
|
|
|
|
::
|
|
|
|
++ on-save
|
|
|
|
on-save:pass
|
|
|
|
::
|
|
|
|
++ on-load
|
|
|
|
|= old-state=vase
|
|
|
|
=^ cards agent-0 (on-load:pass old-state)
|
|
|
|
[cards this]
|
|
|
|
::
|
|
|
|
++ on-poke
|
|
|
|
|= [=mark =vase]
|
|
|
|
=^ cards agent-0 (on-poke:pass mark vase)
|
|
|
|
[cards this]
|
|
|
|
::
|
|
|
|
++ on-watch
|
|
|
|
|= =path
|
|
|
|
=^ cards agent-0 (on-watch:pass path)
|
|
|
|
[cards this]
|
|
|
|
::
|
|
|
|
++ on-leave
|
|
|
|
|= =path
|
|
|
|
=^ cards agent-0 (on-leave:pass path)
|
|
|
|
[cards this]
|
|
|
|
::
|
|
|
|
++ on-peek
|
|
|
|
|= =path
|
|
|
|
(on-peek:pass path)
|
|
|
|
::
|
|
|
|
++ on-agent
|
|
|
|
|= [=wire =sign:agent:gall]
|
|
|
|
=^ cards agent-0 (on-agent:pass wire sign)
|
|
|
|
[cards this]
|
|
|
|
::
|
|
|
|
++ on-arvo
|
|
|
|
|= [=wire =sign-arvo]
|
|
|
|
?< ?=([%d %pack *] sign-arvo)
|
|
|
|
=^ cards agent-0 (on-arvo:pass wire `sign-arvo-0`sign-arvo)
|
|
|
|
[cards this]
|
|
|
|
::
|
|
|
|
++ on-fail
|
|
|
|
|= [=term =tang]
|
|
|
|
=^ cards agent-0 (on-fail:pass term tang)
|
|
|
|
[cards this]
|
|
|
|
--
|
|
|
|
::
|
|
|
|
++ state-0
|
|
|
|
$: %0
|
|
|
|
=agents-0
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ agents-0
|
|
|
|
$: system-duct=duct
|
|
|
|
contacts=(set ship)
|
2020-04-22 08:37:12 +03:00
|
|
|
running=(map term yoke-0)
|
|
|
|
blocked=(map term (qeu blocked-move))
|
2019-12-02 14:20:34 +03:00
|
|
|
==
|
|
|
|
::
|
2020-04-22 08:37:12 +03:00
|
|
|
++ yoke-0
|
2019-12-02 14:20:34 +03:00
|
|
|
$: cache=worm
|
|
|
|
control-duct=duct
|
|
|
|
live=?
|
|
|
|
=stats
|
2020-04-22 08:37:12 +03:00
|
|
|
=watches
|
2019-12-02 14:20:34 +03:00
|
|
|
=agent-0
|
|
|
|
=beak
|
|
|
|
marks=(map duct mark)
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ agent-0
|
|
|
|
=< form
|
|
|
|
|%
|
|
|
|
+$ step (quip card form)
|
|
|
|
+$ card (wind note gift)
|
|
|
|
+$ note note:agent
|
|
|
|
+$ task task:agent
|
2019-12-22 23:12:28 +03:00
|
|
|
+$ gift gift:agent-2
|
2019-12-02 14:20:34 +03:00
|
|
|
+$ sign sign:agent
|
|
|
|
++ form
|
|
|
|
$_ ^|
|
|
|
|
|_ bowl
|
|
|
|
++ on-init
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-save
|
|
|
|
*vase
|
|
|
|
::
|
|
|
|
++ on-load
|
|
|
|
|~ old-state=vase
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-poke
|
|
|
|
|~ [mark vase]
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-watch
|
|
|
|
|~ path
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-leave
|
|
|
|
|~ path
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-peek
|
|
|
|
|~ path
|
|
|
|
*(unit (unit cage))
|
|
|
|
::
|
|
|
|
++ on-agent
|
|
|
|
|~ [wire sign]
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-arvo
|
|
|
|
|~ [wire sign-arvo-0]
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
::
|
|
|
|
++ on-fail
|
|
|
|
|~ [term tang]
|
|
|
|
*(quip card _^|(..on-init))
|
|
|
|
--
|
|
|
|
--
|
|
|
|
::
|
|
|
|
++ sign-arvo-0
|
|
|
|
$% {$a gift:able:ames}
|
|
|
|
$: $b
|
|
|
|
$% gift:able:behn
|
2020-04-24 07:13:19 +03:00
|
|
|
$>(%wris gift:able:clay)
|
|
|
|
$>(%writ gift:able:clay)
|
2019-12-02 14:20:34 +03:00
|
|
|
$>(%mere gift:able:clay)
|
|
|
|
$>(%unto gift:able:gall)
|
|
|
|
==
|
|
|
|
==
|
|
|
|
{$c gift:able:clay}
|
|
|
|
{$d $<(%pack gift:able:dill)}
|
|
|
|
{$f gift:able:ford}
|
|
|
|
[%e gift:able:eyre]
|
|
|
|
{$g gift:able:gall}
|
|
|
|
[%i gift:able:iris]
|
|
|
|
{$j gift:able:jael}
|
|
|
|
==
|
|
|
|
--
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +scry: standard scry
|
|
|
|
::
|
|
|
|
++ scry
|
2019-11-19 07:36:21 +03:00
|
|
|
~/ %gall-scry
|
2020-04-22 08:37:12 +03:00
|
|
|
|= [fur=(unit (set monk)) care=term =shop dap=desk =coin =path]
|
2019-08-29 21:44:37 +03:00
|
|
|
^- (unit (unit cage))
|
|
|
|
?. ?=(%.y -.shop)
|
|
|
|
~
|
|
|
|
=/ =ship p.shop
|
2020-04-22 08:37:12 +03:00
|
|
|
?: ?& =(%u care)
|
2019-08-29 21:44:37 +03:00
|
|
|
=(~ path)
|
|
|
|
=([%$ %da now] coin)
|
|
|
|
=(our ship)
|
|
|
|
==
|
2020-04-22 08:37:12 +03:00
|
|
|
[~ ~ noun+!>((~(has by yokes.state) dap))]
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
|
|
|
?. =(our ship)
|
|
|
|
~
|
|
|
|
?. =([%$ %da now] coin)
|
|
|
|
~
|
2020-04-22 08:37:12 +03:00
|
|
|
?. (~(has by yokes.state) dap)
|
|
|
|
[~ ~]
|
2019-08-29 21:44:37 +03:00
|
|
|
?. ?=(^ path)
|
|
|
|
~
|
|
|
|
=/ =routes [~ ship]
|
2020-04-22 08:37:12 +03:00
|
|
|
(mo-peek:mo dap routes care path)
|
2019-08-29 21:44:37 +03:00
|
|
|
:: +stay: save without cache
|
|
|
|
::
|
|
|
|
++ stay state
|
|
|
|
:: +take: response
|
|
|
|
::
|
|
|
|
++ take
|
2019-11-19 07:36:21 +03:00
|
|
|
~/ %gall-take
|
2020-02-11 01:03:03 +03:00
|
|
|
|= [=wire =duct dud=(unit goof) hin=(hypo sign-arvo)]
|
2019-11-19 07:36:21 +03:00
|
|
|
^- [(list move) _gall-payload]
|
2020-02-25 01:10:59 +03:00
|
|
|
?^ dud
|
2020-04-24 07:13:19 +03:00
|
|
|
~&(%gall-take-dud ((slog tang.u.dud) [~ gall-payload]))
|
2019-08-29 21:44:37 +03:00
|
|
|
::
|
2019-11-19 07:36:21 +03:00
|
|
|
~| [%gall-take-failed wire]
|
2019-10-30 23:12:57 +03:00
|
|
|
::
|
2019-08-29 21:44:37 +03:00
|
|
|
?> ?=([?(%sys %use) *] wire)
|
2020-04-22 08:37:12 +03:00
|
|
|
=/ mo-core (mo-abed:mo duct)
|
2019-08-29 21:44:37 +03:00
|
|
|
=/ =sign-arvo q.hin
|
2019-09-29 07:44:31 +03:00
|
|
|
=> ?- i.wire
|
2020-04-22 08:37:12 +03:00
|
|
|
%sys (mo-handle-sys:mo-core t.wire sign-arvo)
|
|
|
|
%use (mo-handle-use:mo-core t.wire hin)
|
2019-09-29 07:44:31 +03:00
|
|
|
==
|
2019-08-29 21:44:37 +03:00
|
|
|
mo-abet
|
|
|
|
--
|