/gep/hart.js long-poll utils factored out

This commit is contained in:
Anton Dyudin 2014-09-04 14:37:29 -07:00 committed by Anton Dyudin
parent 2d15399137
commit d83db302f6

View File

@ -139,8 +139,7 @@
hen=duct :: event trace hen=duct :: event trace
som=seam :: logical request som=seam :: logical request
pez=pest :: request state pez=pest :: request state
vaz=(list ,[p=cord q=tape]) :: variables sip=marl :: injected scripts
sip=(list manx) :: scripts in result
== :: == ::
++ rote :: remote server ++ rote :: remote server
$: cnt=@ud :: number served $: cnt=@ud :: number served
@ -152,6 +151,7 @@
[%aph p=ship q=@ud r=@ud s=json] :: app heartbeat [%aph p=ship q=@ud r=@ud s=json] :: app heartbeat
[%apg p=term q=ship r=mark s=path] :: app get/start [%apg p=term q=ship r=mark s=path] :: app get/start
[%apm p=ship q=@ud r=@ud s=hasp t=json] :: message send [%apm p=ship q=@ud r=@ud s=hasp t=json] :: message send
[%app p=ship q=(unit ,@ud)] :: script by port
[%aps p=ship q=@ud s=hasp t=path] :: subscribe [%aps p=ship q=@ud s=hasp t=path] :: subscribe
[%apu p=ship q=@ud s=hasp t=path] :: unsubscribe [%apu p=ship q=@ud s=hasp t=path] :: unsubscribe
[%cog p=@ud q=@ud] :: console get [%cog p=@ud q=@ud] :: console get
@ -315,30 +315,6 @@
=+ rep=:(welp p.hop scr q.q.hop) =+ rep=:(welp p.hop scr q.q.hop)
[%mid p.luv (tact rep)] [%mid p.luv (tact rep)]
== ==
++ lofe :: variables in head
|= [vaz=(list ,[p=cord q=tape]) sip=(list manx) luv=love]
%- lofa
:_ luv
%- flop
^- (list manx)
:_ sip
^- manx
:- [%script ~]
:- :/ "window.urb = \{};\0a"
(turn vaz |=([a=cord b=tape] :/("window.urb.{(trip a)}={b};\0a")))
::
++ lofi :: XX unused
|= [mog=(list manx) luv=love]
^- love
?: =(~ mog) luv
?+ -.luv luv
%mid
?. =(/text/html p.luv) luv
=+ str=(trip q.q.luv)
=+ scr=|-(^-(tape ?~(mog "</body>" (xmlt & i.mog $(mog t.mog)))))
=+ rep=(need (repg "</body>" str scr))
[%mid p.luv (tact rep)]
==
:: ::
++ loft :: love to response ++ loft :: love to response
|= luv=love |= luv=love
@ -610,7 +586,7 @@
=+ cyz=(need (~(get by wup.sef) ses)) =+ cyz=(need (~(get by wup.sef) ses))
~(. ya [our ses] sef cyz) ~(. ya [our ses] sef cyz)
:: ::
++ galt ++ galt ::
|= [our=ship ses=hole num=@ud mez=(each bead (list tank))] |= [our=ship ses=hole num=@ud mez=(each bead (list tank))]
^+ +> ^+ +>
=+ suf=(~(get by own) our) =+ suf=(~(get by own) our)
@ -920,116 +896,115 @@
|= [our=ship whu=(unit ship) rul=tape ruf=tape] |= [our=ship whu=(unit ship) rul=tape ruf=tape]
^- manx ^- manx
=+ ^= sic ^- manx =+ ^= sic ^- manx
;script ;script:'''
; var seal = {
; var seal = { who: goal,
; who: goal, url: burl,
; url: burl, pas: null
; pas: null }
; } var hist = []
; var hist = [] var hind = 0
; var hind = 0 $(
; $( function() {
; function() { $input = $('#input .line')
; $input = $('#input .line') $prompt = $('#input .prompt')
; $prompt = $('#input .prompt') $prompt.addClass('prefix')
; $prompt.addClass('prefix') $output = $('#output')
; $output = $('#output') $input.focus()
; $input.focus() $('body').click(function() { $input.focus() })
; $('body').click(function() { $input.focus() }) ctrl = false;
; ctrl = false;
; start = function(ship) {
; start = function(ship) { $prompt.text('vessel: ~')
; $prompt.text('vessel: ~') $input.attr('placeholder', 'ship-name')
; $input.attr('placeholder', 'ship-name') if(ship) {
; if(ship) { $input.val(ship)
; $input.val(ship) }
; } }
; }
; ident = function() {
; ident = function() { seal.who = $input.val()
; seal.who = $input.val()
; if( (seal.who.length != 13) &&
; if( (seal.who.length != 13) && (seal.who.length != 6) &&
; (seal.who.length != 6) && (seal.who.length != 3) )
; (seal.who.length != 3) ) {
; { $output.text('not a ship name - try again.');
; $output.text('not a ship name - try again.'); return false;
; return false; }
; }
; if(seal.who !== host) {
; if(seal.who !== host) { var foreign = {oth: host, ses: session};
; var foreign = {oth: host, ses: session}; var all = $.extend({}, seal, foreign);
; var all = $.extend({}, seal, foreign);
; console.log('redirect')
; console.log('redirect') window.location="http://"+seal.who+".urbit.org/gul"
; window.location="http://"+seal.who+".urbit.org/gul" + $.params(all);
; + $.params(all); return false;
; return false; }
; }
; $output.text($prompt.text() + " " + seal.who)
; $output.text($prompt.text() + " " + seal.who) $input.val('')
; $input.val('') $input.attr('placeholder', 'ronber-bacnub-hanmev-labnyd')
; $input.attr('placeholder', 'ronber-bacnub-hanmev-labnyd') $prompt.text('secret: ~')
; $prompt.text('secret: ~')
; return true;
; return true; }
; }
; login = function() {
; login = function() { seal.pas = $input.val()
; seal.pas = $input.val()
; output = $output.html()
; output = $output.html() console.log($output.html())
; console.log($output.html()) $output.html(output.replace('sorry. please try again.<br>',''))
; $output.html(output.replace('sorry. please try again.<br>',''))
; $.post(form, seal, function(data,xhr,status) {
; $.post(form, seal, function(data,xhr,status) { console.log(data);
; console.log(data); if(data.ok == true) {
; if(data.ok == true) { document.location = data.next;
; document.location = data.next; } else {
; } else { $output.prepend('sorry. please try again.<br>')
; $output.prepend('sorry. please try again.<br>') }
; } })
; }) }
; }
; steps = [ident,login]
; steps = [ident,login] step = 0
; step = 0 start(seal.who)
; start(seal.who) if(seal.who) {
; if(seal.who) { ident()
; ident() step++
; step++ }
; }
; $input.on('keydown', function(e) {
; $input.on('keydown', function(e) { if(e.keyCode == 17) {
; if(e.keyCode == 17) { ctrl = true
; ctrl = true return;
; return; }
; }
; if(e.keyCode == 68 &&
; if(e.keyCode == 68 && ctrl == true &&
; ctrl == true && step == 1) {
; step == 1) { $output.text('')
; $output.text('') step = 0
; step = 0 start(null)
; start(null) return;
; return; }
; }
; if(e.keyCode == 13) {
; if(e.keyCode == 13) { if(steps[step]() && step < steps.length-1)
; if(steps[step]() && step < steps.length-1) step++
; step++ return;
; return; }
; } });
; });
; $input.on('keyup', function(e) {
; $input.on('keyup', function(e) { if(e.keyCode == 17) {
; if(e.keyCode == 17) { ctrl = false
; ctrl = false }
; } });
; }); })
; }) '''
==
=+ ^= cof =+ ^= cof
;= ;=
; var host = '{(trip (rsh 3 1 (scot %p our)))}'; ; var host = '{(trip (rsh 3 1 (scot %p our)))}';
@ -1043,32 +1018,32 @@
;head ;head
;title: urbit login ;title: urbit login
;script(type "text/javascript", src jqu); ;script(type "text/javascript", src jqu);
;style ;style:'''
; body { body {
; margin: 60px 120px; margin: 60px 120px;
; font: normal 12px "Menlo" monospace; font: normal 12px "Menlo" monospace;
; background-color: #000; background-color: #000;
; color: #fff; color: #fff;
; } }
;
; #output { #output {
;
; } }
;
; #input .prompt { #input .prompt {
; display: inline-block; display: inline-block;
; margin-right: 12px; margin-right: 12px;
; } }
;
; #input .line { #input .line {
; outline: none; outline: none;
; width: 80%; width: 80%;
; border: 0; border: 0;
; background-color: transparent; background-color: transparent;
; color: #fff; color: #fff;
; font: normal 12px "Menlo" monospace; font: normal 12px "Menlo" monospace;
; } }
== '''
== ==
=+ ^= bod ^- manx =+ ^= bod ^- manx
;body ;body
@ -1150,30 +1125,21 @@
?> ?=(%way pez.u.pup) ?> ?=(%way pez.u.pup)
$(yov t.yov, q.rey (~(put by q.rey) i.yov u.pup(pez noz))) $(yov t.yov, q.rey (~(put by q.rey) i.yov u.pup(pez noz)))
:: ::
++ duti :: heartbeat script ++ duty |= [our=ship nap=@ud you=ship orx=oryx] :: interface script
;script:''' ^- cord
window.urb.seqn_h = 0 %^ cat 3
window.urb.heartbeat = function() { %- crip
this.poll({ =- "window.urb = {(pojo (jobe -))}\0a"
type:"heb", :~
ship:this.ship, [%ship (jape |1:<our>)]
dely:30000, [%port (jone nap)]
seqn:function() { [%auto %b %&]
return window.urb.seqn_h [%user (jape |1:<you>)]
}, [%oryx %s orx]
incs:function() { ==
window.urb.seqn_h = window.urb.seqn_h+1
}
},function() {
console.log('heartbeat.')
})
}
window.urb.heartbeat()
''' '''
::
++ duty
;script:'''
window.urb.seqn_u = 0 window.urb.seqn_u = 0
window.urb.seqn_h = 0
window.urb.dely = 0 window.urb.dely = 0
window.urb.puls = 0 window.urb.puls = 0
window.urb.cabs = {} window.urb.cabs = {}
@ -1312,6 +1278,23 @@
} }
window.urb.poll(param) window.urb.poll(param)
} }
window.urb.heartbeat = function() {
this.poll({
type:"heb",
ship:this.ship,
dely:30000,
seqn:function() {
return window.urb.seqn_h
},
incs:function() {
window.urb.seqn_h = window.urb.seqn_h+1
}
},function() {
console.log('heartbeat.')
})
}
window.urb.heartbeat()
''' '''
:: ::
++ fape :: dispatch %ape ++ fape :: dispatch %ape
@ -1365,6 +1348,18 @@
(need (eccu orx.ced moh)) (need (eccu orx.ced moh))
== ==
:: ::
++ fapp
|= [fur=(unit term) you=@p paw=path]
?> ?=([~ %js] fur)
?> ?=(?([%hart ~] [@ %hart ~]) paw)
:- ~
:* %app
you
?~ t.paw
~
(some (slav %ui (cat 3 '0i' i.paw)))
==
::
++ faps :: dispatch %aps ++ faps :: dispatch %aps
|= [fur=(unit term) you=@p paw=path moh=moth] |= [fur=(unit term) you=@p paw=path moh=moth]
^- (unit seam) ^- (unit seam)
@ -1612,6 +1607,7 @@
%r :: app response %r :: app response
%s :: app subscribe %s :: app subscribe
%h :: app heartbeat %h :: app heartbeat
%p :: app script by port
%n :: now %n :: now
%u :: app unsubscribe %u :: app unsubscribe
%z :: app version %z :: app version
@ -1642,6 +1638,7 @@
%l (fool r.pul) %l (fool r.pul)
%g (fapg p.q.pul yun paw) %g (fapg p.q.pul yun paw)
%e (fape p.q.pul yun paw) %e (fape p.q.pul yun paw)
%p (fapp p.q.pul yun paw)
== ==
:: ::
%p %p
@ -1727,7 +1724,6 @@
*seam *seam
`pest`[%raw pul moh] `pest`[%raw pul moh]
~ ~
~
== ==
== ==
:: ::
@ -1798,6 +1794,10 @@
:: ~& [%wink-apm +.som.pip] :: ~& [%wink-apm +.som.pip]
:- [~ pip(pez %way)] :- [~ pip(pez %way)]
(yokm num +.som.pip) (yokm num +.som.pip)
::
%app :: script by port
:: ~& [%wink-app +.som.pip]
(yokp num +.som.pip)
:: ::
%aps :: subscribe %aps :: subscribe
:: ~& [%wink-aps +.som.pip] :: ~& [%wink-aps +.som.pip]
@ -1913,7 +1913,7 @@
:+ 500 :+ 500
~[content-type/'text/html'] ~[content-type/'text/html']
[~ (tact (xmlt | mad ~))] [~ (tact (xmlt | mad ~))]
& [%fin (lofe vaz.pip mog (lopo q.p.p.pez.pip))] & [%fin (lofa mog (lopo q.p.p.pez.pip))]
== ==
== ==
:: ::
@ -1969,6 +1969,17 @@
?~ yon (bust 204 num) ?~ yon (bust 204 num)
abet:(post:u.yon cnt num hap jon) abet:(post:u.yon cnt num hap jon)
:: ::
++ yokp :: script by port
|= [num=@ud you=ship nup=(unit ,@ud)]
^- [(unit pimp) _+>]
?~ nup
$(nup [~ num], +> ~(harp yo num you *sink))
=+ yon=(yolk u.nup)
?~ yon
=+ err=(bust 204 num)
[`(need (~(get by q.rey.err) num)) err]
[- abet:+]:(hark:u.yon num)
::
++ yoks :: subscribe ++ yoks :: subscribe
|= [num=@ud you=ship nap=@ud hap=hasp pax=path] |= [num=@ud you=ship nap=@ud hap=hasp pax=path]
=+ yon=(yolk nap) =+ yon=(yolk nap)
@ -2022,6 +2033,18 @@
=. +>.$ (hear:(yule %bet) ~ %& %json !>((joba %a-ok %b %&))) =. +>.$ (hear:(yule %bet) ~ %& %json !>((joba %a-ok %b %&)))
[`(need (~(get by q.rey) num)) +>.$] [`(need (~(get by q.rey) num)) +>.$]
:: ::
++ hark
|= num=@ud
^- [(unit pimp) _+>]
=. +>.$ abet:(busk:(yule %nil) num _@ ~ %& %js !>((duty our nap you orx.ced)))
[`(need (~(get by q.rey) num)) +>.$]
::
++ harp
%_ abet
tim.bet.siq now
num.sub.siq 1
==
::
++ hoop :: request path ++ hoop :: request path
|= can=(unit ,@ud) |= can=(unit ,@ud)
^- path ^- path
@ -2117,22 +2140,17 @@
== ==
=+ pip=u.pup =+ pip=u.pup
=+ ^= sip =+ ^= sip
?. =(%apg -.som.pip) sip.pip ?. ?=(%apg -.som.pip) sip.pip
[duty duti sip.pip] =* his q.som.pip
=+ mef=?:(=(our his) "gop" "gip/{|1:<his>}")
[;script(src "/{mef}/{(pojo (jone nap))}/hart.js"); sip.pip]
?~ huq +>.$(..yo (bust 404 num)) ?~ huq +>.$(..yo (bust 404 num))
%= +>.$ %= +>.$
q.rey q.rey
%+ ~(put by q.rey) num %+ ~(put by q.rey) num
^- pimp ^- pimp
=+ quo=|=(a=cord :(weld "\"" (trip a) "\""))
%= pip %= pip
pez %new pez %new
vaz :~ [%ship (quo (rsh 3 1 (scot %p our)))]
[%port (trip (rsh 3 2 (scot %ui nap)))]
[%auto "true"]
[%oryx (quo orx.ced)]
[%user (quo (rsh 3 1 (scot %p you)))]
==
sip sip sip sip
som ^- seam som ^- seam
:+ %sil :+ %sil