ecash-wallet
v4.0.1
Published
An ecash wallet class. Manage keys, build and broadcast txs. Includes support for tokens and agora.
Downloads
2,405
Maintainers
Readme
ecash-wallet
A production-ready wallet class for building and broadcasting eCash (XEC) txs
Use
Install with npm (when published).
npm i ecash-wallet
Import. Create your Wallet and use methods.
import { Wallet } from "ecash-wallet";
const mnemonic = 'morning average minor stable parrot refuse credit exercise february mirror just begin',
const wallet = Wallet.fromMnemonic(mnemonic, chronik);See tests for detailed methods.
Roadmap
ecash-wallet is engineered to be a drop-in wallet lib for any ecash application that needs wallet functionality. The first milestone demonstrating minimal fulfillment of this requirement will be the integration of ecash-wallet into Cashtab.
Phase One, Cashtab feature parity
XEC actions [x] Send XEC to one recipient [x] Send XEC to many recipients
GENESIS, MINT, SEND, and BURN for all token types [x] SLP_TOKEN_TYPE_FUNGIBLE [x] ALP_TOKEN_TYPE_STANDARD [x] SLP_TOKEN_TYPE_MINT_VAULT SEND and BURN actions
[x] SLP_TOKEN_TYPE_NFT1_GROUP [x] SLP_TOKEN_TYPE_NFT1_CHILD (Mint NFTs) [x] DataAction for ALP_TOKEN_TYPE_STANDARD txs [X] BURN txs for arbitrary amounts using BURN method (intentional burn, not SEND) [X] One-step mints for SLP NFTsAgora actions (PARTIAL and ONESHOT) [] SLP (requires "chained" txs) [] ALP
Phase Two, extended functionality
[x] Support for chained XEC txs, i.e. handling an Action that requires more than one tx due to the 100,000 byte tx size restriction [x] Support for chained token txs, i.e. handling an Action that requires more than one tx due to token protocol per-tx output limits
Phase Three, wishlist
[] HD wallets [] Fine-grained utxo control, avalanche proofs [] SLP_TOKEN_TYPE_MINT_VAULT GENESIS and MINT actions
Change log
- 0.0.0 Init with constructor and
syncmethod D17773 - 0.0.1 Add utxo getter methods
getFuelUtxosandgetSpendableCoinbaseUtxosD17779
1.0.0
D17822 Add support for building and broadcasting txs, including ALP and SLP token txs. Update methods and syntax. Add preliminary support for Postage protocol.
D18384 Add fromMnemonic constructor, make Wallet a normal export (not uniquely a default export), call broadcastTx using hex rawTx to facilitate testing with mock-chronik-client (practical improvements from implementing ecash-wallet in cashtab-faucet)
D18390 Patch the main entry in package.json to point to dist/index.js
1.0.1
D18391 Patch README
1.1.0
D18398 Accept addresses in the transaction ouputs
1.2.0
D18548 Support GENESIS, SEND, and BURN for SLP_TOKEN_TYPE_MINT_VAULT
1.3.0
D18551 Support GENESIS, SEND, MINT, and BURN for SLP_TOKEN_TYPE_NFT1_GROUP
1.4.0
D18558 Support GENESIS, SEND, and BURN for SLP_TOKEN_TYPE_NFT1_CHILD
1.5.0
D18585 Support DataAction for ALP token sends
2.0.0
- Support intentional SLP burns for arbitrary amounts with a chained tx.
- Support automatic updating of determined wallet utxo set on tx build() (unless user opts out, e.g. for running tests) (NB does not apply to PostageTx)
- BREAKING CHANGE the
.broadcast()method no longer throws, returns asuccesskey with more information - Patch issue where SLP burns are not invalidated for including specified outputs
2.0.1
- Type errors uncovered when using
ecash-walletas a dep inecash-agora
2.1.0
- Support chained txs for minting SLP NFTs without requiring a "fan-out" tx
2.1.1
- Patch type issue in returning
SelectUtxosResult
2.1.2
- Export the
BuiltActionclass to support the user ofWalletin theecash-agoraAgoraOffertakemethod
2.1.3
- Return sats selection strategy used to select utxos with
SelectUtxosResult
2.2.0
- Update the
PostageTxclass to support client/server postage interactions
2.3.0
- Support chained txs to handle XEC-only Actions that would exceed MAX_TX_SERSIZE if built in a single tx
2.3.1
- Prevent
addFuelAndSignfrom adding unnecessary postage
2.3.2
- Automatically remove consumed postage utxos from the postage wallet in
addFuelAndSignmethod
2.3.3
- Tolerate token outputs without the
isMintBatonkey, but always classify such inputs as if they wereisMintBaton: false
2.3.4
- Publish to catch updated
chronik-clientdep
2.3.5
- Publish to catch updated
chronik-clientdep
2.3.6
2.3.7
- Publish to catch updated
chronik-clientdep
2.3.8
- Add stub methods for HD support (not a functional wallet, but could be used to derive different accounts)
2.3.9
- Add methods for getting receive and change addresses for HD wallets
3.0.0 BREAKING CHANGE
- Add
sync()support for the HD wallet - Introduce new
WalletUtxotype with includedaddresskey, which will help match utxos with keypairs for HD transaction signing (breaking change)
3.1.0
- Add
balanceSatsas wallet property that updates onsync()
3.2.0
- Support for msg signing and txs from HD wallets
- Similar to non-HD, we also "auto-update" the wallet's utxo set after txs are built
- For a consistent API, we introduce methods that return different addresses/scripts depending on whether or not the wallet is HD
3.2.1
- For ALP burns, if we do not have an exact qty utxo, we infer a SEND action for change
- Introduce action preprocessing and typed error,
ExactAtomsNotFoundError, to support this inferrence
3.3.0
- Support for chained token txs
3.4.0
- Add
maxSendSatsmethod for determining how many sats we can send to leave no balance remaining in the wallet
3.5.0
- If broadcasting a tx fails due to
bad-txns-inputs-missingorspentortxn-mempool-conflict, resync the utxo set and try again
3.5.1
- Update method name
updateBalanceinstead ofupdateBalances
3.6.0
- Add
addReceivedTxmethod to support updating the utxo set and balance of a wallet with an incoming tx, including processing inputs to remove spent UTXOs
3.6.1
- Make
addReceivedTxrobust against txs with non-standard address types
3.6.2
- If broadcasting a tx fails due to
finalized-tx-conflict, resync the utxo set and try again
3.7.0
- Add a
WalletAction.inspect()method that can't be broadcasted and won't update the utxos. This can be used to inspect the tx and compute the fees without impacting the wallet.
3.8.0
- Add a
Wallet.isWalletAddress()method to check if an address belongs to the wallet. - Add a
Wallet.getTxAmounts()to get all the balance changes introduced by a transaction from the wallet history.
3.9.0
- Add a new class
WatchOnlyWalletto support watch only wallets (both HD and single-address)
3.10.0
- Add support for wallets using a custom prefix
4.0.0 BREAKING CHANGE
- Add support for building token postage aka "swap" txs (partially signed txs with token outputs that require added token inputs)
- Changes the API as
satsStrategyis no longer its own param, now part ofSelectUtxosConfig
4.0.1
- Add a memory limit on iterations for attempts to determine exact atom available in utxo set to prevent OOM crashes
