2019-10-03 23:33:07 +03:00
|
|
|
:: chat-store: data store that holds linear sequences of chat messages
|
|
|
|
::
|
2019-10-08 23:44:20 +03:00
|
|
|
/+ *chat-json, *chat-eval
|
2019-10-01 02:25:25 +03:00
|
|
|
|%
|
|
|
|
+$ move [bone card]
|
|
|
|
::
|
|
|
|
+$ card
|
|
|
|
$% [%diff diff]
|
|
|
|
[%quit ~]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ state
|
|
|
|
$% [%0 state-zero]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ state-zero
|
|
|
|
$: =inbox
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ diff
|
|
|
|
$% [%chat-initial inbox]
|
|
|
|
[%chat-configs chat-configs]
|
|
|
|
[%chat-update chat-update]
|
|
|
|
==
|
|
|
|
--
|
|
|
|
::
|
|
|
|
|_ [bol=bowl:gall state]
|
|
|
|
::
|
|
|
|
++ this .
|
|
|
|
::
|
|
|
|
++ prep
|
|
|
|
|= old=(unit state)
|
|
|
|
^- (quip move _this)
|
2019-10-07 21:16:47 +03:00
|
|
|
[~ ?~(old this this(+<+ u.old))]
|
2019-10-01 02:25:25 +03:00
|
|
|
::
|
|
|
|
++ peek-x-all
|
|
|
|
|= pax=path
|
|
|
|
^- (unit (unit [%noun (map path mailbox)]))
|
|
|
|
[~ ~ %noun inbox]
|
|
|
|
::
|
|
|
|
++ peek-x-configs
|
|
|
|
|= pax=path
|
|
|
|
^- (unit (unit [%noun chat-configs]))
|
|
|
|
:^ ~ ~ %noun
|
|
|
|
(inbox-to-configs inbox)
|
|
|
|
::
|
|
|
|
++ peek-x-keys
|
|
|
|
|= pax=path
|
|
|
|
^- (unit (unit [%noun (set path)]))
|
|
|
|
[~ ~ %noun ~(key by inbox)]
|
|
|
|
::
|
|
|
|
++ peek-x-mailbox
|
|
|
|
|= pax=path
|
|
|
|
^- (unit (unit [%noun (unit mailbox)]))
|
2019-10-07 21:16:47 +03:00
|
|
|
?~ pax ~
|
2019-10-01 02:25:25 +03:00
|
|
|
=/ mailbox=(unit mailbox) (~(get by inbox) pax)
|
|
|
|
[~ ~ %noun mailbox]
|
|
|
|
::
|
|
|
|
++ peek-x-config
|
|
|
|
|= pax=path
|
|
|
|
^- (unit (unit [%noun config]))
|
2019-10-07 21:16:47 +03:00
|
|
|
?~ pax ~
|
2019-10-01 02:25:25 +03:00
|
|
|
=/ mailbox (~(get by inbox) pax)
|
2019-10-07 21:16:47 +03:00
|
|
|
?~ mailbox ~
|
2019-10-01 02:25:25 +03:00
|
|
|
:^ ~ ~ %noun
|
|
|
|
config.u.mailbox
|
|
|
|
::
|
|
|
|
++ peek-x-envelopes
|
|
|
|
|= pax=path
|
|
|
|
^- (unit (unit [%noun (list envelope)]))
|
2019-10-07 21:16:47 +03:00
|
|
|
?+ pax ~
|
2019-10-01 02:25:25 +03:00
|
|
|
[@ @ *]
|
|
|
|
=/ mail-path t.t.pax
|
|
|
|
=/ mailbox (~(get by inbox) mail-path)
|
|
|
|
?~ mailbox
|
|
|
|
[~ ~ %noun ~]
|
|
|
|
=* envelopes envelopes.u.mailbox
|
|
|
|
=/ sign-test=[?(%neg %pos) @]
|
|
|
|
%- need
|
|
|
|
%+ rush i.pax
|
|
|
|
;~ pose
|
|
|
|
%+ cook
|
|
|
|
|= n=@
|
|
|
|
[%neg n]
|
|
|
|
;~(pfix hep dem:ag)
|
|
|
|
::
|
|
|
|
%+ cook
|
|
|
|
|= n=@
|
|
|
|
[%pos n]
|
|
|
|
dem:ag
|
|
|
|
==
|
|
|
|
=* length length.config.u.mailbox
|
|
|
|
=* start +.sign-test
|
|
|
|
?: =(-.sign-test %neg)
|
|
|
|
?: (gth start length)
|
|
|
|
[~ ~ %noun envelopes]
|
|
|
|
[~ ~ %noun (swag [(sub length start) start] envelopes)]
|
|
|
|
::
|
|
|
|
=/ end (slav %ud i.t.pax)
|
|
|
|
?. (lte start end)
|
|
|
|
~
|
|
|
|
=. end ?:((lth end length) end length)
|
|
|
|
[~ ~ %noun (swag [start (sub end start)] envelopes)]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ peer-keys
|
|
|
|
|= pax=path
|
|
|
|
^- (quip move _this)
|
2019-10-03 00:58:38 +03:00
|
|
|
?> (team:title our.bol src.bol)
|
2019-10-01 02:25:25 +03:00
|
|
|
:: we send the list of keys then send events when they change
|
|
|
|
:_ this
|
|
|
|
[ost.bol %diff %chat-update [%keys ~(key by inbox)]]~
|
|
|
|
::
|
|
|
|
++ peer-all
|
|
|
|
|= pax=path
|
|
|
|
^- (quip move _this)
|
2019-10-03 00:58:38 +03:00
|
|
|
?> (team:title our.bol src.bol)
|
2019-10-01 02:25:25 +03:00
|
|
|
:_ this
|
|
|
|
[ost.bol %diff %chat-initial inbox]~
|
|
|
|
::
|
|
|
|
++ peer-configs
|
|
|
|
|= pax=path
|
|
|
|
^- (quip move _this)
|
2019-10-03 00:58:38 +03:00
|
|
|
?> (team:title our.bol src.bol)
|
2019-10-01 02:25:25 +03:00
|
|
|
:_ this
|
|
|
|
[ost.bol %diff %chat-configs (inbox-to-configs inbox)]~
|
|
|
|
::
|
|
|
|
++ peer-updates
|
|
|
|
|= pax=path
|
|
|
|
^- (quip move _this)
|
2019-10-03 00:58:38 +03:00
|
|
|
?> (team:title our.bol src.bol)
|
2019-10-01 02:25:25 +03:00
|
|
|
:: we now proxy all events to this path
|
|
|
|
[~ this]
|
|
|
|
::
|
|
|
|
++ peer-mailbox
|
|
|
|
|= pax=path
|
|
|
|
^- (quip move _this)
|
2019-10-03 00:58:38 +03:00
|
|
|
?> (team:title our.bol src.bol)
|
2019-10-07 21:16:47 +03:00
|
|
|
?> (~(has by inbox) pax)
|
|
|
|
=^ =ship pax
|
|
|
|
?> ?=([* ^] pax)
|
|
|
|
[(slav %p i.pax) t.pax]
|
|
|
|
:_ this
|
|
|
|
[ost.bol %diff %chat-update [%create ship pax]]~
|
|
|
|
::
|
2019-10-01 02:25:25 +03:00
|
|
|
++ poke-json
|
|
|
|
|= jon=json
|
|
|
|
^- (quip move _this)
|
2019-10-03 00:58:38 +03:00
|
|
|
?> (team:title our.bol src.bol)
|
2019-10-01 02:25:25 +03:00
|
|
|
(poke-chat-action (json-to-action jon))
|
|
|
|
::
|
|
|
|
++ poke-chat-action
|
|
|
|
|= action=chat-action
|
|
|
|
^- (quip move _this)
|
2019-10-03 00:58:38 +03:00
|
|
|
?> (team:title our.bol src.bol)
|
2019-10-01 02:25:25 +03:00
|
|
|
?- -.action
|
2019-11-14 03:53:47 +03:00
|
|
|
%create (handle-create action)
|
|
|
|
%delete (handle-delete action)
|
|
|
|
%message (handle-message action)
|
|
|
|
%messages (handle-messages action)
|
|
|
|
%read (handle-read action)
|
2019-10-01 02:25:25 +03:00
|
|
|
==
|
|
|
|
::
|
|
|
|
++ handle-create
|
|
|
|
|= act=chat-action
|
|
|
|
^- (quip move _this)
|
|
|
|
?> ?=(%create -.act)
|
2019-10-07 21:16:47 +03:00
|
|
|
=/ pax [(scot %p ship.act) path.act]
|
|
|
|
?: (~(has by inbox) pax)
|
2019-10-01 02:25:25 +03:00
|
|
|
[~ this]
|
2019-10-07 21:16:47 +03:00
|
|
|
:- (send-diff pax act)
|
|
|
|
this(inbox (~(put by inbox) pax *mailbox))
|
2019-10-01 02:25:25 +03:00
|
|
|
::
|
|
|
|
++ handle-delete
|
|
|
|
|= act=chat-action
|
|
|
|
^- (quip move _this)
|
|
|
|
?> ?=(%delete -.act)
|
|
|
|
=/ mailbox=(unit mailbox) (~(get by inbox) path.act)
|
|
|
|
?~ mailbox
|
|
|
|
[~ this]
|
2019-10-07 21:16:47 +03:00
|
|
|
:- (send-diff path.act act)
|
|
|
|
this(inbox (~(del by inbox) path.act))
|
2019-10-01 02:25:25 +03:00
|
|
|
::
|
|
|
|
++ handle-message
|
|
|
|
|= act=chat-action
|
|
|
|
^- (quip move _this)
|
|
|
|
?> ?=(%message -.act)
|
|
|
|
=/ mailbox=(unit mailbox) (~(get by inbox) path.act)
|
|
|
|
?~ mailbox
|
|
|
|
[~ this]
|
2019-11-15 23:27:35 +03:00
|
|
|
=. letter.envelope.act (evaluate-letter letter.envelope.act)
|
|
|
|
=. u.mailbox (append-envelope u.mailbox envelope.act)
|
2019-10-16 01:51:56 +03:00
|
|
|
:- (send-diff path.act act)
|
|
|
|
this(inbox (~(put by inbox) path.act u.mailbox))
|
2019-10-01 02:25:25 +03:00
|
|
|
::
|
2019-11-14 03:53:47 +03:00
|
|
|
++ handle-messages
|
|
|
|
|= act=chat-action
|
|
|
|
^- (quip move _this)
|
|
|
|
?> ?=(%messages -.act)
|
|
|
|
=/ mailbox=(unit mailbox) (~(get by inbox) path.act)
|
|
|
|
?~ mailbox
|
|
|
|
[~ this]
|
2019-11-15 23:27:35 +03:00
|
|
|
=/ evaluated-envelopes=(list envelope) ~
|
|
|
|
|- ^- (quip move _this)
|
|
|
|
?~ envelopes.act
|
|
|
|
:_ this(inbox (~(put by inbox) path.act u.mailbox))
|
|
|
|
%+ send-diff path.act
|
2019-11-14 03:53:47 +03:00
|
|
|
:* %messages
|
|
|
|
path.act
|
2019-11-15 23:27:35 +03:00
|
|
|
(sub length.config.u.mailbox (lent evaluated-envelopes))
|
|
|
|
length.config.u.mailbox
|
|
|
|
evaluated-envelopes
|
2019-11-14 03:53:47 +03:00
|
|
|
==
|
2019-11-15 23:27:35 +03:00
|
|
|
=. letter.i.envelopes.act (evaluate-letter letter.i.envelopes.act)
|
|
|
|
=. evaluated-envelopes (snoc evaluated-envelopes i.envelopes.act)
|
|
|
|
=. u.mailbox (append-envelope u.mailbox i.envelopes.act)
|
2019-11-14 03:53:47 +03:00
|
|
|
$(envelopes.act t.envelopes.act)
|
|
|
|
::
|
2019-10-01 02:25:25 +03:00
|
|
|
++ handle-read
|
|
|
|
|= act=chat-action
|
|
|
|
^- (quip move _this)
|
|
|
|
?> ?=(%read -.act)
|
|
|
|
=/ mailbox=(unit mailbox) (~(get by inbox) path.act)
|
|
|
|
?~ mailbox
|
|
|
|
[~ this]
|
2019-10-16 01:51:56 +03:00
|
|
|
=. read.config.u.mailbox length.config.u.mailbox
|
|
|
|
:- (send-diff path.act act)
|
|
|
|
this(inbox (~(put by inbox) path.act u.mailbox))
|
2019-10-01 02:25:25 +03:00
|
|
|
::
|
2019-11-15 23:27:35 +03:00
|
|
|
++ evaluate-letter
|
|
|
|
|= =letter
|
|
|
|
^- ^letter
|
|
|
|
=? letter &(?=(%code -.letter) ?=(~ output.letter))
|
|
|
|
=/ =hoon (ream expression.letter)
|
|
|
|
letter(output (eval bol hoon))
|
|
|
|
letter
|
|
|
|
::
|
|
|
|
++ append-envelope
|
|
|
|
|= [=mailbox =envelope]
|
|
|
|
^- ^mailbox
|
|
|
|
=. number.envelope +(length.config.mailbox)
|
|
|
|
=: length.config.mailbox +(length.config.mailbox)
|
|
|
|
envelopes.mailbox (snoc envelopes.mailbox envelope)
|
|
|
|
==
|
|
|
|
mailbox
|
|
|
|
::
|
2019-10-03 00:58:38 +03:00
|
|
|
++ update-subscribers
|
2019-11-14 03:53:47 +03:00
|
|
|
|= [pax=path upd=chat-update]
|
2019-10-03 00:58:38 +03:00
|
|
|
^- (list move)
|
|
|
|
%+ turn (prey:pubsub:userlib pax bol)
|
|
|
|
|= [=bone *]
|
2019-11-14 03:53:47 +03:00
|
|
|
[bone %diff %chat-update upd]
|
2019-10-03 00:58:38 +03:00
|
|
|
::
|
2019-10-01 02:25:25 +03:00
|
|
|
++ send-diff
|
2019-11-14 03:53:47 +03:00
|
|
|
|= [pax=path upd=chat-update]
|
2019-10-01 02:25:25 +03:00
|
|
|
^- (list move)
|
2019-10-03 00:58:38 +03:00
|
|
|
%- zing
|
2019-11-14 03:53:47 +03:00
|
|
|
:~ (update-subscribers /all upd)
|
|
|
|
(update-subscribers /updates upd)
|
|
|
|
(update-subscribers [%mailbox pax] upd)
|
|
|
|
?. |(|(=(%read -.upd) =(%message -.upd)) =(%messages -.upd))
|
2019-10-03 00:58:38 +03:00
|
|
|
~
|
2019-11-14 03:53:47 +03:00
|
|
|
(update-subscribers /configs upd)
|
|
|
|
?. |(=(%create -.upd) =(%delete -.upd))
|
2019-10-03 00:58:38 +03:00
|
|
|
~
|
2019-11-14 03:53:47 +03:00
|
|
|
(update-subscribers /keys upd)
|
2019-10-01 02:25:25 +03:00
|
|
|
==
|
|
|
|
::
|
|
|
|
--
|