mirror of
https://github.com/ilyakooo0/urbit.git
synced 2024-12-13 11:45:45 +03:00
WIP: pend/fail tables
This commit is contained in:
parent
d4725c7280
commit
236745444e
@ -1,20 +1,31 @@
|
||||
:: btc-wallet-hook.hoon
|
||||
::
|
||||
:: Subscriptions:
|
||||
:: Subscribes to:
|
||||
:: btc-provider:
|
||||
:: connection status
|
||||
:: RPC call results/errors
|
||||
:: To Subscribers:
|
||||
:: - connection status
|
||||
:: - RPC call results/errors
|
||||
::
|
||||
:: btc-wallet-store
|
||||
:: - requests for address info
|
||||
:: - updates to existing address info
|
||||
::
|
||||
:: Sends updates to:
|
||||
:: none
|
||||
::
|
||||
/- *btc-wallet-hook
|
||||
/+ shoe, dbug, default-agent
|
||||
/- *btc, *btc-wallet-hook, bws=btc-wallet-store
|
||||
/+ shoe, dbug, default-agent, lib-bws=btc-wallet-store
|
||||
|%
|
||||
+$ versioned-state
|
||||
$% state-0
|
||||
==
|
||||
:: provdider: maybe ship if provider is set
|
||||
::
|
||||
+$ state-0 [%0 provider=(unit ship)]
|
||||
+$ state-0
|
||||
$: %0
|
||||
provider=(unit [host=ship works=?])
|
||||
pend=back
|
||||
fail=back
|
||||
==
|
||||
::
|
||||
+$ card card:shoe
|
||||
+$ command
|
||||
@ -45,8 +56,10 @@
|
||||
++ on-init
|
||||
^- (quip card _this)
|
||||
~& > '%btc-wallet-hook initialized'
|
||||
:: sub to wallet-store
|
||||
`this
|
||||
:_ this
|
||||
:~ [%pass /r/[(scot %da now.bowl)] %agent [our.bowl %btc-wallet-store] %watch /requests]
|
||||
[%pass /u/[(scot %da now.bowl)] %agent [our.bowl %btc-wallet-store] %watch /updates]
|
||||
==
|
||||
++ on-save
|
||||
^- vase
|
||||
!>(state)
|
||||
@ -74,8 +87,17 @@
|
||||
?+ -.sign (on-agent:def wire sign)
|
||||
%watch-ack
|
||||
?: ?=(%set-provider -.wire)
|
||||
`this(provider.state `src.bowl)
|
||||
`this(provider.state `[src.bowl %.y])
|
||||
`this
|
||||
%fact
|
||||
=^ cards state
|
||||
?+ p.cage.sign `state
|
||||
%btc-provider-response
|
||||
`state
|
||||
%btc-wallet-store-request
|
||||
(handle-request:hc !<(request:bws q.cage.sign))
|
||||
==
|
||||
[cards this]
|
||||
==
|
||||
++ on-arvo on-arvo:def
|
||||
++ on-fail on-fail:def
|
||||
@ -92,17 +114,35 @@
|
||||
|= act=action
|
||||
^- (quip card _state)
|
||||
?- -.act
|
||||
%get-balance
|
||||
~& > %get-balance
|
||||
~& > addresses.act
|
||||
`state
|
||||
::
|
||||
%set-provider
|
||||
:_ state
|
||||
[[%pass /set-provider %agent [provider.act %btc-provider] %watch /clients]]~
|
||||
::
|
||||
%add-xpub
|
||||
~& > xpub.act
|
||||
`state
|
||||
:: TODO %+ weld
|
||||
:: ?~(provider *(list card) ~[[%pass /leave-prov %agent [host.u.provider %btc-provider] %leave ~]])
|
||||
~[[%pass /set-prov %agent [provider.act %btc-provider] %watch /clients]]
|
||||
==
|
||||
++ handle-request
|
||||
|= req=request:bws
|
||||
^- (quip card _state)
|
||||
?- -.req
|
||||
%scan-address
|
||||
?~ provider ~|("provider not set" !!)
|
||||
=/ ri=req-id (mk-req-id +.req)
|
||||
=/ a=address *address
|
||||
:: TODO (~(mk-address (from-xpub:walt:lib-bws xpub.req) chyg.req) idx.req)
|
||||
:- ~[(get-address-info host.u.provider a)]
|
||||
state(pend (~(put by pend) ri +.req))
|
||||
==
|
||||
::
|
||||
++ get-address-info
|
||||
|= [host=ship a=address] ^- card
|
||||
:* %pass /[(scot %da now.bowl)] %agent [host %btc-provider]
|
||||
%poke %btc-provider-action !>([%get-address-info a])
|
||||
==
|
||||
::
|
||||
++ mk-req-id
|
||||
|= [=xpub =chyg:bws =idx:bws] ^- req-id
|
||||
=/ chygidx=@ (cat 3 ?:(=(%0 chyg) '0' '1') idx)
|
||||
=/ dat=@ (cat 3 xpub chygidx)
|
||||
%- ripemd-160:ripemd:crypto
|
||||
[(met 3 dat) dat]
|
||||
--
|
||||
|
@ -1,9 +1,11 @@
|
||||
:: btc-wallet-store.hoon
|
||||
:: Manages wallet pubkeys
|
||||
::
|
||||
:: Subscriptions: none
|
||||
:: To Subscribers:
|
||||
:: watched address updates
|
||||
:: Subscribes to: none
|
||||
::
|
||||
:: Sends updates on:
|
||||
:: - /requests: to request data about addresses
|
||||
:: - /updates: new data about one of our addresses
|
||||
::
|
||||
/- *btc-wallet-store
|
||||
/+ dbug, default-agent, *btc-wallet-store, btc, bip32
|
||||
@ -62,8 +64,12 @@
|
||||
|= pax=path
|
||||
^- (quip card _this)
|
||||
?> (team:title our.bowl src.bowl)
|
||||
?> ?=([%wallets *] pax)
|
||||
`this
|
||||
?+ pax (on-watch:def pax)
|
||||
[%requests *]
|
||||
`this
|
||||
[%updates *]
|
||||
`this
|
||||
==
|
||||
++ on-leave on-leave:def
|
||||
++ on-peek on-peek:def
|
||||
++ on-agent on-agent:def
|
||||
@ -89,6 +95,13 @@
|
||||
%update-address
|
||||
`state
|
||||
==
|
||||
:: Wallet-scan algorithm:
|
||||
:: Initiate a batch for each chyg, with max-gap idxs in it
|
||||
:: Send that to /requests subscribers to call out to providers and get the info
|
||||
:: Whenever a %watch-address result comes back
|
||||
:: - remove that idx from todo.batch
|
||||
:: - do run-scan to check whether that chyg is done
|
||||
:: - if it isn't, refill it with idxs to scan
|
||||
::
|
||||
++ req-scan
|
||||
|= [b=batch =xpub =chyg]
|
||||
@ -161,10 +174,7 @@
|
||||
^- (quip card _state)
|
||||
=/ s0 (scan-status xpub %0)
|
||||
=/ s1 (scan-status xpub %1)
|
||||
~& >> s0
|
||||
~& >> s1
|
||||
?: ?&(empty.s0 done.s0 empty.s1 done.s1)
|
||||
~& > "ending scan"
|
||||
`(end-scan xpub)
|
||||
=/ [cards0=(list card) batch0=batch]
|
||||
(bump-batch xpub %0)
|
||||
|
@ -42,4 +42,3 @@
|
||||
--
|
||||
|
||||
--
|
||||
|
||||
|
@ -1,9 +1,13 @@
|
||||
/- *btc
|
||||
/- *btc, bws=btc-wallet-store
|
||||
|%
|
||||
+$ xpub tape
|
||||
:: req-id: hash of [xpub chyg idx]
|
||||
:: addo: wallet index to send result of request to
|
||||
:: back: lookup table of req-id -> addo
|
||||
::
|
||||
+$ req-id @ux
|
||||
+$ addo [=xpub =chyg:bws =idx:bws]
|
||||
+$ back (map req-id addo)
|
||||
+$ action
|
||||
$% [%get-balance addresses=(set address)]
|
||||
[%set-provider provider=ship]
|
||||
[%add-xpub xpub=tape]
|
||||
$% [%set-provider provider=ship]
|
||||
==
|
||||
--
|
||||
|
Loading…
Reference in New Issue
Block a user