urbit/pkg/arvo/lib/hood/helm.hoon

248 lines
6.7 KiB
Plaintext
Raw Normal View History

/+ pill
2020-06-16 10:29:17 +03:00
=* card card:agent:gall
|%
2021-08-11 19:23:36 +03:00
+$ state state-1
+$ any-state
$~ *state
$% state-1
state-0
==
+$ state-1
$: %1
mass-timer=[way=wire nex=@da tim=@dr]
==
+$ state-0 [%0 hoc=(map bone session-0)]
+$ session-0
$: say=*
mud=*
mass-timer=[way=wire nex=@da tim=@dr]
2020-06-16 10:29:17 +03:00
==
2019-11-14 21:39:50 +03:00
::
++ state-0-to-1
|= s=state-0
^- state
[%1 mass-timer:(~(got by hoc.s) 0)]
--
2021-08-18 01:16:48 +03:00
|= [=bowl:gall sat=state]
2020-06-16 10:29:17 +03:00
=| moz=(list card)
|%
++ this .
+$ state ^state :: proxy
+$ any-state ^any-state :: proxy
++ abet [(flop moz) sat]
2020-06-16 10:29:17 +03:00
++ flog |=(=flog:dill (emit %pass /di %arvo %d %flog flog))
++ emit |=(card this(moz [+< moz]))
:: +emil: emit multiple cards
2019-11-14 21:39:50 +03:00
::
2020-06-16 10:29:17 +03:00
++ emil
|= caz=(list card)
^+ this
?~(caz this $(caz t.caz, this (emit i.caz)))
2015-09-02 01:20:17 +03:00
::
++ on-load
2020-07-18 02:58:28 +03:00
|= [hood-version=@ud old=any-state]
=< abet
=? old ?=(%0 -.old) (state-0-to-1 old)
?> ?=(%1 -.old)
this(sat old)
::
++ poke-rekey :: rotate private keys
|= des=@t
2020-12-08 03:47:06 +03:00
=/ sed=(unit seed:jael)
%+ biff
(bind (slaw %uw des) cue)
2020-12-08 03:47:06 +03:00
(soft seed:jael)
=< abet
?~ sed
~& %invalid-private-key
2020-06-16 10:29:17 +03:00
this
?. =(our.bowl who.u.sed)
~& [%wrong-private-key-ship who.u.sed]
2020-06-16 10:29:17 +03:00
this
2019-11-14 21:39:50 +03:00
(emit %pass / %arvo %j %rekey lyf.u.sed key.u.sed)
::
++ ames-secret
^- @t
=; pax (crip +:<.^(@p %j pax)>)
/(scot %p our.bowl)/code/(scot %da now.bowl)/(scot %p our.bowl)
::
++ poke-sec-atom
|= [hot=host:eyre dat=@]
?> ?=(%& -.hot)
=. p.hot (scag 2 p.hot) :: ignore subdomain
=. dat (scot %uw (en:crub:crypto ames-secret dat))
=- abet:(emit %pass /write %arvo %c %info -)
2020-12-06 12:03:12 +03:00
=/ byk=path (en-beam byk.bowl(r da+now.bowl) ~)
=+ .^(=tube:clay cc+(welp byk /mime/atom))
=/ =cage atom+(tube !>([/ (as-octs:mimes:html dat)]))
(foal:space:userlib :(welp byk sec+p.hot /atom) cage)
::
++ poke-moon :: rotate moon keys
2020-12-08 03:47:06 +03:00
|= sed=(unit [=ship =udiff:point:jael])
=< abet
?~ sed
2020-06-16 10:29:17 +03:00
this
2019-11-14 21:39:50 +03:00
(emit %pass / %arvo %j %moon u.sed)
2015-09-02 01:20:17 +03:00
::
++ poke-code
|= act=?(~ %reset)
=< abet
?~ act
this
(emit %pass / %arvo %j %step ~)
::
2015-09-02 01:20:17 +03:00
++ poke-mass
2018-03-19 07:18:20 +03:00
|= ~ =< abet
(emit %pass /heft %arvo %d %flog %heft ~)
2015-09-02 01:20:17 +03:00
::
++ poke-automass
|= recur=@dr
=. mass-timer.sat
[/helm/automass (add now.bowl recur) recur]
abet:(emit %pass way.mass-timer.sat %arvo %b %wait nex.mass-timer.sat)
2019-01-30 03:25:47 +03:00
::
++ poke-cancel-automass
|= ~
abet:(emit %pass way.mass-timer.sat %arvo %b %rest nex.mass-timer.sat)
::
++ poke-meld
|= ~ =< abet
(emit %pass /pack %arvo %d %flog %meld ~)
::
2019-11-23 04:24:42 +03:00
++ poke-pack
|= ~ =< abet
(emit %pass /pack %arvo %d %flog %pack ~)
2019-02-16 12:34:38 +03:00
::
2020-11-10 09:26:13 +03:00
++ poke-pass
|= =note-arvo =< abet
2020-11-17 23:53:05 +03:00
(emit %pass /helm/pass %arvo note-arvo)
2020-11-10 09:26:13 +03:00
::
++ take-wake-automass
2019-04-13 01:48:22 +03:00
|= [way=wire error=(unit tang)]
?^ error
%- (slog u.error)
~& %helm-wake-automass-fail
abet
=. nex.mass-timer.sat (add now.bowl tim.mass-timer.sat)
=< abet
%- emil
2019-11-14 21:39:50 +03:00
:~ [%pass /heft %arvo %d %flog %crud %hax-heft ~]
[%pass way.mass-timer.sat %arvo %b %wait nex.mass-timer.sat]
==
::
++ poke-send-hi
|= [her=ship mes=(unit tape)] =< abet
2019-11-14 21:39:50 +03:00
%- emit
:* %pass /helm/hi/(scot %p her)
%agent [her %hood] %poke
%helm-hi !>(?~(mes '' (crip u.mes)))
==
2015-09-02 01:20:17 +03:00
::
::
++ poke-hi
|= mes=@t
2017-10-10 06:39:08 +03:00
~| %poke-hi-fail
?: =(%fail mes)
~& %poke-hi-fail
!!
abet:(flog %text "< {<src.bowl>}: {(trip mes)}")
2017-10-10 06:39:08 +03:00
::
++ poke-atom
|= ato=@
=+ len=(scow %ud (met 3 ato))
=+ gum=(scow %p (mug ato))
=< abet
(flog %text "< {<src.bowl>}: atom: {len} bytes, mug {gum}")
::
2015-09-02 01:20:17 +03:00
++ coup-hi
|= [pax=path cop=(unit tang)] =< abet
?> ?=([@t ~] pax)
2019-11-14 21:39:50 +03:00
(flog %text "hi {(trip i.pax)} {?~(cop "" "un")}successful")
2015-09-02 01:20:17 +03:00
::
++ poke-trim
|= pri=@ud =< abet
(emit %pass /pack %arvo %d %flog %crop pri)
::
2015-09-02 01:20:17 +03:00
++ poke-verb :: toggle verbose
2018-03-19 07:18:20 +03:00
|= ~ =< abet
2019-11-14 21:39:50 +03:00
(flog %verb ~)
2015-09-02 01:20:17 +03:00
::
++ poke-ames-sift
|= ships=(list ship) =< abet
(emit %pass /helm %arvo %a %sift ships)
::
2019-12-03 02:54:01 +03:00
++ poke-ames-verb
|= veb=(list verb:ames) =< abet
(emit %pass /helm %arvo %a %spew veb)
::
++ poke-ames-wake
|= ~ =< abet
(emit %pass /helm %arvo %a %stir '')
::
++ poke-knob
|= [error-tag=@tas level=?(%hush %soft %loud)] =< abet
2019-11-14 21:39:50 +03:00
(emit %pass /helm %arvo %d %knob error-tag level)
2017-12-12 23:23:00 +03:00
::
2018-10-11 01:26:51 +03:00
++ poke-serve
|= [=binding:eyre =generator:eyre] =< abet
2019-11-14 21:39:50 +03:00
(emit %pass /helm/serv %arvo %e %serve binding generator)
::
++ poke-cors-approve
|= =origin:eyre
=< abet
(emit %pass /helm/cors/approve %arvo %e %approve-origin origin)
::
++ poke-cors-reject
|= =origin:eyre
=< abet
(emit %pass /helm/cors/reject %arvo %e %reject-origin origin)
::
2019-11-14 21:39:50 +03:00
++ poke
|= [=mark =vase]
?+ mark ~|([%poke-helm-bad-mark mark] !!)
2020-06-16 10:29:17 +03:00
%helm-ames-sift =;(f (f !<(_+<.f vase)) poke-ames-sift)
%helm-ames-verb =;(f (f !<(_+<.f vase)) poke-ames-verb)
%helm-ames-wake =;(f (f !<(_+<.f vase)) poke-ames-wake)
%helm-atom =;(f (f !<(_+<.f vase)) poke-atom)
%helm-automass =;(f (f !<(_+<.f vase)) poke-automass)
%helm-cancel-automass =;(f (f !<(_+<.f vase)) poke-cancel-automass)
%helm-code =;(f (f !<(_+<.f vase)) poke-code)
%helm-cors-approve =;(f (f !<(_+<.f vase)) poke-cors-approve)
%helm-cors-reject =;(f (f !<(_+<.f vase)) poke-cors-reject)
2019-11-14 21:39:50 +03:00
%helm-hi =;(f (f !<(_+<.f vase)) poke-hi)
2020-06-16 10:29:17 +03:00
%helm-knob =;(f (f !<(_+<.f vase)) poke-knob)
2019-11-14 21:39:50 +03:00
%helm-mass =;(f (f !<(_+<.f vase)) poke-mass)
%helm-meld =;(f (f !<(_+<.f vase)) poke-meld)
2020-06-16 10:29:17 +03:00
%helm-moon =;(f (f !<(_+<.f vase)) poke-moon)
%helm-pack =;(f (f !<(_+<.f vase)) poke-pack)
2020-11-10 09:26:13 +03:00
%helm-pass =;(f (f !<(_+<.f vase)) poke-pass)
2020-06-16 10:29:17 +03:00
%helm-rekey =;(f (f !<(_+<.f vase)) poke-rekey)
2019-11-14 21:39:50 +03:00
%helm-send-hi =;(f (f !<(_+<.f vase)) poke-send-hi)
%helm-serve =;(f (f !<(_+<.f vase)) poke-serve)
%helm-trim =;(f (f !<(_+<.f vase)) poke-trim)
2020-06-16 10:29:17 +03:00
%helm-verb =;(f (f !<(_+<.f vase)) poke-verb)
%helm-write-sec-atom =;(f (f !<(_+<.f vase)) poke-sec-atom)
2019-11-14 21:39:50 +03:00
==
::
++ take-agent
2019-11-19 07:36:21 +03:00
|= [=wire =sign:agent:gall]
2019-11-14 21:39:50 +03:00
?+ wire ~|([%helm-bad-take-agent wire -.sign] !!)
2021-07-17 02:54:20 +03:00
[%hi *] ?> ?=(%poke-ack -.sign)
(coup-hi t.wire p.sign)
2019-11-14 21:39:50 +03:00
==
2018-10-11 01:26:51 +03:00
::
++ take-bound
|= [wir=wire success=? binding=binding:eyre] =< abet
2019-11-14 21:39:50 +03:00
(flog %text "bound: {<success>}")
::
2020-06-16 10:29:17 +03:00
++ take-arvo
2019-11-14 21:39:50 +03:00
|= [=wire =sign-arvo]
?+ wire ~|([%helm-bad-take-wire wire +<.sign-arvo] !!)
[%automass *] %+ take-wake-automass t.wire
?>(?=(%wake +<.sign-arvo) +>.sign-arvo)
[%serv *] %+ take-bound t.wire
?>(?=(%bound +<.sign-arvo) +>.sign-arvo)
[%pass *] abet
2019-11-14 21:39:50 +03:00
==
2015-05-11 20:53:47 +03:00
--