:: :::: /hoon/ask/app :: /? 310 /+ sole, womb [. sole] |% ++ card $% {$diff $sole-effect sole-effect} {$poke wire {ship $hood} $womb-invite {cord reference invite}:womb} == ++ invited ?($new $sent $ignored) ++ email @t -- !: |_ $: bow/bowl adr/(map email {time invited}) sos/(map bone sole-share) wom/(unit ship) admins/(set ship) == ++ prompt ^- sole-prompt ?~ wom [& %ask-ship ":womb-ship? ~"] =/ new new-adrs ?~ new [& %$ " (0) [l,a,i,w,?]"] [& %$ ": approve {}? ({<(lent new)>}) [y,n,l,a,i,w,?]"] :: ++ peer-sole |= path ^- (quip {bone card} +>) ~| [%not-in-whitelist src.bow] ?> |((~(has in admins) src.bow) =(our.bow src.bow)) :_ +>.$(sos (~(put by sos) ost.bow *sole-share)) =- [(effect %mor pro+prompt -)]~ =+ all=adrs [(render all) (turn all put-mail)] :: ++ render :: show list of invites |= a/(list {time email invited}) ^- sole-effect ?: =(~ a) txt+"~" tan+(flop (turn a message)) :: ++ adrs =- (sort - lor) %+ turn (~(tap by adr)) |=({a/email b/time c/invited} [tym=b ask=a inv=c]) :: ++ new-adrs (skim adrs |=({@ @ inv/invited} =(%new inv))) ++ ignored-adrs (skim adrs |=({@ @ inv/invited} =(%ignored inv))) ++ effect |=(fec/sole-effect [ost.bow %diff %sole-effect fec]) ++ message |= {now/time ask/@t inv/invited} ^- tank =. now (sub now (mod now ~s1)) leaf+"ask: {} {} {(trip ask)}" :: ++ put-mail |=({@ ask/@t inv/invited} =+(pax=(rash ask unix-path) [%sav pax `@t`inv])) ++ unix-path :: split into path of "name" and "extension" ;~ (glue dot) (cook crip (star ;~(less dot next))) ;~(plug (cook crip (star next)) (easy ~)) == :: ++ poke-ask-admins |= a/(set ship) ?> =(our.bow src.bow) `+>.$(admins a) :: ++ poke-ask-mail |= ask/@t ^- (quip {bone card} +>) ~| have-mail+ask ?< (~(has by adr) ask) =. adr (~(put by adr) ask now.bow %new) :: XX electroplating :_ +>.$ =/ new [now.bow ask %new] =+ [mez=[(message new)]~ pro=prompt sav=(put-mail new)] %+ turn (prey /sole bow) |=({ost/bone ^} (effect(ost.bow ost) %mor tan+mez pro+prompt sav ~)) :: ++ poke-sole-action |= act/sole-action ^- (quip {bone card} +>) =/ som (~(got by sos) ost.bow) ?- -.act $clr `+>.$ $ret ?^ wom [[(effect mor+help)]~ +>.$] :: show help ?: =(~ buf.som) [[(effect txt+"Please enter womb ship")]~ +>.$] =/ try (rose (tufa buf.som) fed:ag) ?. ?=({$& ^} try) [[(effect bel+~)]~ +>.$] => .(wom p.try) :: XX TMI (transmit set+~ pro+prompt ~) :: XX handle multiple links? :: $det :: reject all input =^ inv som (~(transceive sole som) +.act) =. sos (~(put by sos) ost.bow som) ?~ wom =/ try (rose (tufa buf.som) fed:ag) ?: -.try `+>.$ (transmit inv bel+~ ~) ?: =(`*`"?" buf.som) (transmit inv help) ?: =(`*`"a" buf.som) (transmit inv (render adrs) ~) ?: =(`*`"l" buf.som) (transmit inv (render new-adrs) ~) ?: =(`*`"i" buf.som) (transmit inv (render ignored-adrs) ~) ?: =(`*`"n" buf.som) =/ new new-adrs ?~ new (transmit inv bel+~ ~) =. inv.i.new %ignored =. adr (~(put by adr) ask.i.new [tym inv]:i.new) (transmit inv tan+[(message i.new)]~ pro+prompt ~) ?: =(`*`"y" buf.som) =/ new new-adrs ?~ new (transmit inv bel+~ ~) =. inv.i.new %sent :: XX pending =- [[(invite ask.i.new) -<] ->] =. adr (~(put by adr) ask.i.new [tym inv]:i.new) (transmit inv tan+[(message i.new)]~ pro+prompt ~) ?: =(`*`"w" buf.som) => .(wom ~) :: XX TMI (transmit inv pro+prompt ~) (transmit inv bel+~ ~) == ++ transmit |= {inv/sole-edit mor/(list sole-effect)} =/ som (~(got by sos) ost.bow) =^ det som (~(transmit sole som) inv) =. sos (~(put by sos) ost.bow som) [[(effect mor+[det+det mor])]~ +>.$] :: ++ help ^- (list sole-effect) =- (scan - (more (just '\0a') (stag %txt (star prn)))) %+ welp ?~ [new-adrs] "" """ y - invite current ask n - ignore current ask """ """ l - list new asks i - list ignored asks a - list all asks w - reset womb ship ? - print help """ :: ++ invite |= ask/email :- ost.bow ^- card :^ %poke /invite/(scot %t ask) [(need wom) %hood] :- %womb-invite ^- {cord reference invite}:womb =+ inv=(scot %uv (end 7 1 eny.bow)) [inv `&+our.bow [ask 1 0 "You have been invited to Urbit: {(trip inv)}" ""]] --