npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

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

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 NFTs

  • Agora 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 sync method D17773
  • 0.0.1 Add utxo getter methods getFuelUtxos and getSpendableCoinbaseUtxos D17779

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

D18627

  • 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 a success key with more information
  • Patch issue where SLP burns are not invalidated for including specified outputs

2.0.1

D18673

  • Type errors uncovered when using ecash-wallet as a dep in ecash-agora

2.1.0

D18834

  • Support chained txs for minting SLP NFTs without requiring a "fan-out" tx

2.1.1

D18839

  • Patch type issue in returning SelectUtxosResult

2.1.2

D18840

  • Export the BuiltAction class to support the user of Wallet in the ecash-agora AgoraOffer take method

2.1.3

D18841

  • Return sats selection strategy used to select utxos with SelectUtxosResult

2.2.0

D18837

  • Update the PostageTx class to support client/server postage interactions

2.3.0

D18867

  • Support chained txs to handle XEC-only Actions that would exceed MAX_TX_SERSIZE if built in a single tx

2.3.1

D18920

  • Prevent addFuelAndSign from adding unnecessary postage

2.3.2

D18924

  • Automatically remove consumed postage utxos from the postage wallet in addFuelAndSign method

2.3.3

D18932

  • Tolerate token outputs without the isMintBaton key, but always classify such inputs as if they were isMintBaton: false

2.3.4

D18975

  • Publish to catch updated chronik-client dep

2.3.5

D18994

  • Publish to catch updated chronik-client dep

2.3.6

D19051

2.3.7

  • Publish to catch updated chronik-client dep

D19139

2.3.8

  • Add stub methods for HD support (not a functional wallet, but could be used to derive different accounts)

D19233

2.3.9

  • Add methods for getting receive and change addresses for HD wallets

D19245

3.0.0 BREAKING CHANGE

  • Add sync() support for the HD wallet
  • Introduce new WalletUtxo type with included address key, which will help match utxos with keypairs for HD transaction signing (breaking change)

D19249

3.1.0

  • Add balanceSats as wallet property that updates on sync()

D19266

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

D19271

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

D19301

3.3.0

  • Support for chained token txs

D19316

3.4.0

  • Add maxSendSats method for determining how many sats we can send to leave no balance remaining in the wallet

D19349

3.5.0

  • If broadcasting a tx fails due to bad-txns-inputs-missingorspent or txn-mempool-conflict, resync the utxo set and try again

D19348

3.5.1

  • Update method name updateBalance instead of updateBalances

D19352

3.6.0

  • Add addReceivedTx method to support updating the utxo set and balance of a wallet with an incoming tx, including processing inputs to remove spent UTXOs

D19351

3.6.1

  • Make addReceivedTx robust against txs with non-standard address types

D19371

3.6.2

  • If broadcasting a tx fails due to finalized-tx-conflict, resync the utxo set and try again

D19376

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.

D19390

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.

D19390 D19403

3.9.0

  • Add a new class WatchOnlyWallet to support watch only wallets (both HD and single-address)

D19406

3.10.0

  • Add support for wallets using a custom prefix

D19441

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 satsStrategy is no longer its own param, now part of SelectUtxosConfig

D19476

4.0.1

  • Add a memory limit on iterations for attempts to determine exact atom available in utxo set to prevent OOM crashes

D19556