|% :: +move: output effect :: +$ move [bone card] :: +card: output effect payload :: +$ card $% [%connect wire [(unit @t) (list @t)] %server] [%wait wire @da] [%http-response =raw-http-response:light] == -- :: utilities: :: |% :: ++ parse-request-line |= url=@t ^- [[(unit @ta) site=(list @t)] args=(list [key=@t value=@t])] (fall (rush url ;~(plug apat:de-purl:html yque:de-purl:html)) [[~ ~] ~]) :: +hello: :: ++ hello |= name=@t ^- octs %- as-octs:mimes:html %- crip %- en-xml:html ;html ;head ;title:"Hello, {<(trip name)>}" == ;body ;h1:"Hello, {<(trip name)>}" == == :: helper library that lets an app handle an EventSource. :: :: TODO: This doesn't even attempt to deal with sequence numbers. :: ++ event-source |_ m=(map =bone last-id=@ud) ++ abet m :: +start-session: called by app to start a session and send first event :: :: This creates a new session where we :: ++ start-session |= [session=@ud =bone data=wall] ^- [(list move) _m] :: :- :~ :* bone %http-response %start 200 :~ ['content-type' 'text/event-stream'] ['cache-control' 'no-cache'] == (wall-to-output data) complete=%.n == == (~(put by m) bone 0) :: +session-stopped: external notification that a session ended :: ++ session-stopped |= =bone ^- _m :: (~(del by m) bone) :: +send-message: sends a message based on the continuation :: ++ send-message |= [=bone data=wall] ^- [(list move) _m] :- [bone %http-response %continue (wall-to-output data) complete=%.n]~ (~(jab by m) bone |=(a=@ud +(a))) :: +wall-to-output: changes our raw text lines to a text/event-stream :: ++ wall-to-output |= =wall ^- (unit octs) :- ~ %- as-octs:mimes:html %- crip %- zing %+ weld %+ turn wall |= t=tape "data: {t}\0a" :: [`tape`['\0a' ~] ~] -- :: ++ part1 ^- octs %- as-octs:mimes:html %- crip "
Time is
" :: %- trip ''' ''' :: "" == -- |% :: +$ state $: events=(map =bone last-id=@ud) == -- :: |_ [bow=bowl:gall state] :: ++ this . :: ++ prep |= old=(unit state) ^- (quip move _this) ~& %prep :- [`move`[ost.bow [%connect / [~ /'~server'] %server]] ~] ?~ old this this(+<+ u.old) :: alerts us that we were bound. we need this because the vane calls back. :: ++ bound |= [wir=wire success=? binding=binding:light] ~& [%bound success] [~ this] :: ++ handle-start-stream |= =inbound-request:light ^- (quip move _this) :: Start a session sending the current time :: =^ moves events (~(start-session event-source events) 0 ost.bow ["{