urbit/lib/btc-wallet-store.hoon

95 lines
2.5 KiB
Plaintext
Raw Normal View History

2020-10-31 14:25:32 +03:00
::
::
2020-10-30 14:45:38 +03:00
/- *btc-wallet-store
/+ bip32, btc
=, secp:crypto
=+ ecc=secp256k1
|%
++ default-max-gap 20
:: xpub
:: wilt
:: bipt: BIP44/49/84
:: next: next index to generate address for in non-change/change accounts respectively
:: scanned: whether the wallet's addresses have been checked for prior activity
:: if unscanned, 'next' values won't be valid
:: scan-to
:: max-gap
::
++ walt
2020-10-31 14:25:32 +03:00
|_ [=wilt =bipt =wach =nixt scanned=? scan-to=scon max-gap=@]
2020-10-31 12:41:00 +03:00
+* this .
::
2020-10-30 14:45:38 +03:00
++ from-xpub
2020-10-31 14:25:32 +03:00
|= [=xpub:btc scan-to=(unit scon) max-gap=(unit @)]
2020-10-31 12:41:00 +03:00
^- _this
%= this
wilt (from-extended:bip32 (trip xpub))
2020-10-30 14:45:38 +03:00
bipt (xpub-type:btc xpub)
wach *^wach
2020-10-31 14:25:32 +03:00
nixt [0 0]
2020-10-30 14:45:38 +03:00
scanned %.n
scan-to (fall scan-to *scon)
max-gap (fall max-gap default-max-gap)
==
2020-10-31 18:03:00 +03:00
:: generate an address; add it to wach (i.e. treat it as used and out in the wild)
::
++ gen-address
|= =chyg
^- (pair address:btc _this)
=/ addr=address:btc
(mk-address chyg (get-nixt chyg))
:- addr
%= this
wach (~(put by wach) addr [chyg (get-nixt chyg) *(set utxo:btc)])
nixt (bump-nixt chyg)
==
::
2020-10-31 14:25:32 +03:00
++ mk-address
|= [=chyg =idx]
2020-10-30 14:45:38 +03:00
^- address:btc
=/ pubkey=@ux
%- compress-point:ecc
2020-10-31 14:25:32 +03:00
pub:(derive-public:(derive-public:wilt (@ chyg)) idx)
2020-10-30 14:45:38 +03:00
?: ?=(%bip84 bipt)
(need (encode-pubkey:bech32:btc %main pubkey))
~|("legacy addresses not supported yet" !!)
2020-10-31 14:25:32 +03:00
:: insert a new address; update "nixt" free address if this one was it
::
++ insert-address
|= [a=address:btc =addi]
^- _this
=? nixt (is-nixt addi)
(bump-nixt chyg.addi)
this(wach (~(put by wach) a addi))
:: update an address if it's in our wach (we're watching it already)
2020-10-31 12:41:00 +03:00
::
++ update-address
2020-10-31 14:25:32 +03:00
|= [a=address:btc utxos=(set utxo:btc)]
2020-10-31 12:41:00 +03:00
^- _this
=/ adi=(unit addi)
(~(get by wach) a)
?~ adi this
2020-10-31 14:25:32 +03:00
this(wach (~(put by wach) a u.adi(utxos utxos)))
::
++ is-nixt
|= =addi ^- ?
?: ?=(%0 chyg.addi)
=(idx.addi p.nixt)
=(idx.addi q.nixt)
:: Returns the next unused index in the (non-)change account
2020-10-31 12:41:00 +03:00
::
2020-10-31 14:25:32 +03:00
++ bump-nixt
|= =chyg ^- ^nixt
=/ new-idx=idx (add 1 (get-nixt chyg))
|- ?> (lte new-idx max-index)
?. (~(has by wach) (mk-address chyg new-idx))
(set-nixt chyg new-idx)
$(new-idx +(new-idx))
++ get-nixt
|= =chyg ?:(?=(%0 chyg) p.nixt q.nixt)
++ set-nixt
|= [=chyg idx=@] ^- ^nixt
?:(?=(%0 chyg) [idx q.nixt] [p.nixt idx])
2020-10-30 14:45:38 +03:00
--
--