diff --git a/desk/app/contacts.hoon b/desk/app/contacts.hoon index 02a345d..74c7b1f 100644 --- a/desk/app/contacts.hoon +++ b/desk/app/contacts.hoon @@ -1,4 +1,5 @@ -/+ default-agent, dbug, verb, neg=negotiate, activity +/- activity +/+ default-agent, dbug, verb, neg=negotiate /+ *contacts :: :: performance, keep warm @@ -103,7 +104,7 @@ ++ pass-activity |= [who=ship field=(pair @tas value)] ^- card - =/ =cage activity-action+!>([%add %contact who field]) + =/ =cage activity-action+!>(`action:activity`[%add %contact who field]) [%pass /activity %agent [our.bowl %activity] %poke cage] :: :: +pub: publication management @@ -377,6 +378,7 @@ ?~ val [(pass-activity who field) cards] ?< ?=(~ u.val) + ::NOTE currently shouldn't happen in practice ?. =(-.q.field -.u.val) cards ?: =(p.q.field p.u.val) cards ?. ?=(%set -.q.field) @@ -772,17 +774,17 @@ [%contact ~] si-abet:(si-take:(sub src.bowl) wire sign) :: - [%migrate ~] - ?> ?=(%poke-ack -.sign) - ?~ p.sign cor - %- (slog leaf/"{} failed" u.p.sign) + [%migrate ~] + ?> ?=(%poke-ack -.sign) + ?~ p.sign cor + %- (slog leaf/"{} failed" u.p.sign) cor :: - [%activity ~] - cor + [%activity ~] + cor :: - [%epic ~] - cor + [%epic ~] + cor == :: ++ arvo diff --git a/desk/lib/activity.hoon b/desk/lib/activity.hoon deleted file mode 100644 index 50e8dc3..0000000 --- a/desk/lib/activity.hoon +++ /dev/null @@ -1,375 +0,0 @@ -/- a=activity -|% -++ src - |% - ++ get-parents - |= =source:a - ^- (list source:a) - ?: ?=(%base -.source) ~ - ?< ?=(%base -.source) - =- (snoc - [%base ~]) - ^- (list source:a) - ?+ -.source ~ - %channel ~[[%group group.source]] - %dm-thread ~[[%dm whom.source]] - :: - %thread - :~ [%channel channel.source group.source] - [%group group.source] - == - == - :: - ++ get-parent - |= [=indices:a =source:a] - ^- (unit source:a) - ?: ?=(%base -.source) ~ - ?< ?=(%base -.source) - =/ parent - ?- -.source - %dm [%base ~] - %contact [%base ~] - %group [%base ~] - %channel [%group group.source] - %dm-thread [%dm whom.source] - %thread [%channel channel.source group.source] - == - ?. (~(has by indices) parent) ~ - `parent - ++ get-children :: direct children only - |= [=indices:a =source:a] - ^- (list source:a) - ?: ?=(?(%thread %dm-thread %contact) -.source) ~ - %+ skim - ~(tap in ~(key by indices)) - |= src=source:a - ?- -.source - %base ?=(?(%group %dm) -.src) - %group &(?=(%channel -.src) =(flag.source group.src)) - %channel &(?=(%thread -.src) =(nest.source channel.src)) - %dm &(?=(%dm-thread -.src) =(whom.source whom.src)) - == - :: - ++ get-order - |= =source:a - %. -.source - %~ got by - ^~ - %- my - :~ [%contact 7] - [%thread 6] - [%dm-thread 5] - [%channel 4] - [%group 3] - [%dm 2] - [%base 1] - == - ++ get-volumes - |= [vs=volume-settings:a =source:a] - ^- volume-map:a - =/ target (~(get by vs) source) - ?^ target u.target - ?- -.source - %base *volume-map:a - %group (get-volumes vs %base ~) - %dm (get-volumes vs %base ~) - %dm-thread (get-volumes vs %dm whom.source) - %channel (get-volumes vs %group group.source) - %thread (get-volumes vs %channel channel.source group.source) - %contact (get-volumes vs %base ~) - == - :: - ++ sort-sources - |= sources=(list source:a) - :: sort children first in order so we only have to make one pass - :: of summarization aka not repeatedly updating the same source - :: - %+ sort - sources - |= [asrc=source:a bsrc=source:a] - (gth (get-order:src asrc) (get-order:src bsrc)) - :: - -- -++ stm - |% - ++ get-reads - |= [=stream:a start=(unit time) end=(unit time) ignore-children=?] - %+ murn - %- tap:on-event:a - %^ lot:on-event:a stream - ?~(start ~ `(sub u.start 1)) - ?~(end ~ `(add u.end 1)) - |= [=time =event:a] - :: ignore child events if enabled - ?: &(ignore-children child.event) ~ - `[time ~] - :: - -- -++ idx - |_ =index:a - ++ find-floor - |= [orig=stream:a =reads:a] - ^- (unit time) - :: starting at the last-known first-unread location (floor), walk towards - :: the present, to find the new first-unread location (new floor) - :: - :: slice off the earlier part of the stream, for efficiency - :: - =/ =stream:a (lot:on-event:a orig `floor.reads ~) - =| new-floor=(unit time) - |- - ?~ stream new-floor - :: - =/ [[=time =event:a] rest=stream:a] (pop:on-event:a stream) - =; is-read=? - :: if we found something that's unread, we need look no further - :: - ?. is-read $(stream ~) - :: otherwise, continue our walk towards the present - :: - $(new-floor `time, stream rest) - :: treat all other events as read - ?+ -<.event & - ?(%dm-post %dm-reply %post %reply) - ?=(^ (get:on-read-items:a items.reads time)) - == - :: - -- -++ evt - |% - ++ source - |= event=incoming-event:a - ^- source:a - ?- -.event - %chan-init [%channel channel.event group.event] - %post [%channel channel.event group.event] - %reply [%thread parent.event channel.event group.event] - %dm-invite [%dm whom.event] - %dm-post [%dm whom.event] - %dm-reply [%dm-thread parent.event whom.event] - %group-invite [%group group.event] - %group-kick [%group group.event] - %group-join [%group group.event] - %group-role [%group group.event] - %group-ask [%group group.event] - %flag-post [%group group.event] - %flag-reply [%group group.event] - %contact [%contact who.event] - == - :: - ++ event-type - |= event=incoming-event:a - ^- event-type:a - ?+ -.event -.event - %post ?:(mention.event %post-mention %post) - %reply ?:(mention.event %reply-mention %reply) - %dm-post ?:(mention.event %dm-post-mention %dm-post) - %dm-reply ?:(mention.event %dm-reply-mention %dm-reply) - == - :: - ++ is-allowed - |= [allowed=notifications-allowed:a =incoming-event:a] - ?: ?=(%all allowed) & - ?: ?=(%none allowed) | - =/ type (event-type incoming-event) - ?+ type | - %post & - %reply & - %contact & - %dm-post & - %dm-reply & - %dm-invite & - %group-invite & - %post-mention & - %reply-mention & - %dm-post-mention & - %dm-reply-mention & - == - :: - ++ get-volume - |= [vs=volume-settings:a event=incoming-event:a] - ^- volume:a - =/ source (source:evt event) - =/ loudness=volume-map:a (get-volumes:src vs source) - (~(gut by loudness) (event-type event) [unreads=& notify=|]) - :: - -- -:: -++ urd - |_ [=indices:a =activity:a =volume-settings:a log=$-((trap tape) _same)] - ++ summarize-unreads - |= [=source:a =index:a] - ^- activity-summary:a - %- (log |.("summarizing unreads for: {}")) - =/ top=time -:(fall (ram:on-event:a stream.index) [*@da ~]) - =/ unread-stream=stream:a - :: all base's events are from children so we can ignore - ?: ?=(%base -.source) ~ - :: we don't need to take child events into account when summarizing - :: the activity, so we filter them out - :: TODO: measure performance vs gas+murn+tap+lot - =- -> - %^ (dip:on-event:a @) - (lot:on-event:a stream.index `floor.reads.index ~) - ~ - |= [st=@ =time-id:a =event:a] - :_ [%.n st] - ?: child.event ~ - `event - =/ children (get-children:src indices source) - %- (log |.("children: {}")) - (stream-to-unreads source index(stream unread-stream) children top) - ++ sum-children - |= children=(list source:a) - ^- activity-summary:a - %+ roll - children - |= [=source:a sum=activity-summary:a] - =/ =index:a (~(gut by indices) source *index:a) - =/ as=activity-summary:a - ?~ summary=(~(get by activity) source) - => (summarize-unreads source index) - .(children ~) - u.summary(children ~) - %= sum - count (add count.sum count.as) - notify |(notify.sum notify.as) - newest (max newest.as newest.sum) - notify-count (add notify-count.sum notify-count.as) - == - ++ stream-to-unreads - |= [=source:a =index:a children=(list source:a) top=time] - ^- activity-summary:a - =/ cs=activity-summary:a - (sum-children children) - %- (log |.("children summary: {}")) - =/ newest=time :(max newest.cs floor.reads.index bump.index top) - =/ total - :: if we're a channel, we only want thread notify counts, not totals - :: - ?: ?=(%channel -.source) - notify-count.cs - count.cs - =/ notify-count notify-count.cs - =/ main 0 - =/ notified=? notify.cs - =/ main-notified=? | - =* stream stream.index - =| last=(unit message-key:a) - :: for each event - :: update count and newest - :: if reply, update thread state - |- - ?~ stream - :* newest - total - notify-count - notified - ?~(last ~ `[u.last main main-notified]) - ?:(?=(%base -.source) ~ (sy children)) - ~ - == - =/ [[=time =event:a] rest=stream:a] (pop:on-event:a stream) - =/ volume (get-volume:evt volume-settings -.event) - ::TODO support other event types - =* is-msg ?=(?(%dm-post %dm-reply %post %reply) -<.event) - =* is-init ?=(?(%dm-invite %chan-init) -<.event) - =* is-flag ?=(?(%flag-post %flag-reply) -<.event) - =* is-group ?=(%group-ask -<.event) - =* supported |(is-msg is-init is-flag is-group) - ?. supported $(stream rest) - =? notified &(notify.volume notified.event) & - =? notify-count &(notify.volume notified.event) +(notify-count) - =. newest (max newest time) - ?. &(unreads.volume ?=(?(%dm-post %dm-reply %post %reply) -<.event)) - $(stream rest) - =. total +(total) - =. main +(main) - =? main-notified &(notify:volume notified.event) & - =. last - ?~ last `key.event - last - $(stream rest) - -- -++ convert-to - |% - ++ v4 - |% - ++ feed - |= =feed:a - ^- feed:v4:old:a - feed.feed - -- - ++ v3 - |% - ++ activity - |= =activity:a - ^- activity:v3:old:a - %- ~(run by activity) - |= as=activity-summary:a - (activity-summary as activity) - ++ activity-summary - |= [as=activity-summary:a =activity:a] - ^- activity-summary:v3:old:a - :* newest.as - count.as - notify-count.as - notify.as - unread.as - :: - ?: =(~ children.as) ~ - :- ~ - %- ~(gas by *activity:v3:old:a) - %+ turn - ~(tap in children.as) - |= =source:a - =/ sum (~(got by activity) source) - :- source - (activity-summary sum(children ~) ~) - :: - [*@da ~] - == - ++ update - |= [=update:a =activity:a] - ^- update:v3:old:a - ?+ -.update update - %activity !! - %read - [%read source.update (activity-summary activity-summary.update activity)] - == - -- - ++ v2 - |% - ++ activity - |= =activity:a - ^- activity:v2:old:a - %- ~(run by activity) - |= as=activity-summary:a - (activity-summary as activity) - ++ activity-summary - |= [as=activity-summary:a =activity:a] - ^- activity-summary:v2:old:a - :* newest.as - count.as - notify.as - unread.as - :: - :- ~ - %- ~(gas by *activity:v2:old:a) - %+ turn - ~(tap in children.as) - |= =source:a - =/ sum (~(got by activity) source) - :- source - (activity-summary sum(children ~) ~) - == - ++ update - |= [=update:a =activity:a] - ^- update:v2:old:a - ?+ -.update update - %activity !! - %read - [%read source.update (activity-summary activity-summary.update activity)] - == - -- - -- --- diff --git a/desk/lib/contacts.hoon b/desk/lib/contacts.hoon index 428f7d3..be6afe1 100644 --- a/desk/lib/contacts.hoon +++ b/desk/lib/contacts.hoon @@ -8,8 +8,8 @@ |= val=value ^- ? ?+ -.val | - %text =(0 (met 3 p.val)) - %look =(0 (met 3 p.val)) + %text =('' p.val) + %look =('' p.val) %set ?=(~ p.val) == :: +cy: contact map engine