/- lens /+ *server, base64 /= lens-mark /: /===/mar/lens/command /!noun/ =, format |% :: +move: output effect :: +$ move [bone card] :: +card: output effect payload :: +$ card $% [%connect wire binding:eyre term] [%http-response =http-event:http] [%peer wire dock path] [%peel wire dock mark path] [%poke wire dock poke] [%pull wire dock ~] == :: +$ poke $% [%lens-command command:lens] == :: +$ state $% $: %0 job=(unit [=bone com=command:lens]) == == :: -- :: |_ [bow=bowl:gall state=state] :: ++ this . :: ++ prep |= old=(unit *) ^- (quip move _this) [~ this] :: :: alerts us that we were bound. we need this because the vane calls back. :: ++ bound |= [wir=wire success=? binding=binding:eyre] ^- (quip move _this) [~ this] :: ++ poke-handle-http-request %- (require-authorization:app ost.bow move this) |= =inbound-request:eyre ^- (quip move _this) ~& %poke-handle-http-request-lens ?^ job.state :_ this [ost.bow %http-response %start [%500 ~] ~ %.y]~ :: =/ request-line (parse-request-line url.request.inbound-request) =/ site (flop site.request-line) :: =/ jon=json (need (de-json:html q:(need body.request.inbound-request))) =/ com=command:lens (json:grab:lens-mark jon) :_ this(job.state (some [ost.bow com])) :: ?: ?=(%export -.source.com) :: todo: send export commands ~& [%export app.source.com] [ost.bow %peer /export [our.bow app.source.com] /export]~ [ost.bow %peel /sole [our.bow %dojo] %lens-json /sole]~ :: ++ diff-lens-json |= [=wire jon=json] ^- (quip move _this) ?~ jon [~ this] ~& [%json jon] ?> ?=(^ job.state) :_ this(job.state ~) [bone.u.job.state %http-response (json-response:app (json-to-octs jon))]~ :: ++ diff-export |= [=wire data=*] ^- (quip move _this) :: ?> ?=(^ job.state) :: TOOD: the following isn't really good enough. :: :: herb will do whatever we tell it to, so by convention have it write to :: an app name based on the file name. :: ?> ?=(%export -.source.com.u.job.state) =/ app-name=tape (trip app.source.com.u.job.state) =/ output=@t (crip "/{app-name}/jam") :: =/ jon=json =/ =atom (jam data) =/ =octs [(met 3 atom) atom] =/ enc (en:base64 octs) (pairs:enjs:format file+s+output data+s+enc ~) :: :_ this(job.state ~) [bone.u.job.state %http-response (json-response:app (json-to-octs jon))]~ :: ++ quit |= =wire ^- (quip move _this) ~& [%quit wire] [~ this] :: ++ reap |= [=wire saw=(unit tang)] ^- (quip move _this) ~& [%reap wire] ?: =([%export ~] wire) [~ this] :: ?^ saw [((slog u.saw) ~) this] ?> ?=(^ job.state) :_ this :~ [ost.bow %poke /sole [our.bow %dojo] %lens-command com.u.job.state] [ost.bow %pull /sole [our.bow %dojo] ~] == :: ++ coup |= [=wire saw=(unit tang)] ^- (quip move _this) ~& [%coup wire] ?^ saw [((slog u.saw) ~) this] [~ this] :: :: +poke-handle-http-cancel: received when a connection was killed :: ++ poke-handle-http-cancel |= =inbound-request:eyre ^- (quip move _this) :: the only long lived connections we keep state about are the stream ones. :: [~ this] :: ++ poke-noun |= a=* ^- (quip move _this) ~& poke+a [~ this] :: --