Improvement Proposals
ℹ️
While this document and some proposals are a work-in-progress, it can be used in production in agreement with wallets implementing the standard. The thinking behind this is to use, test, and iterate on proposals in a real-world environment. There should not be a burden of waiting for some ratification criteria or 100% consensus.
Motivation for WBIPs
tl;dr Make it easier for developers to build BTC enabled experiences!
- Single interface for BTC and L2s, without the need for new interfaces in the future
window.WalletProvider
as the location for the global interface- Use namespaces in method strings to denote L2s (e.g. "lbtc*" for Liquid wrapped Bitcoin, "ln*" for lightning, "stx*" for Stacks)
.request
API which is future proof, without needing new specs or updates on the provider implementation- Standardized JSON API for alternatives communication channels (e.g. WalletConnect)
- Simple and dynamic interface (i.e. not static methods, but rather dynamic strings and JSON objects)
- Removal of bloat observed in other systems
- e.g. Ethereum's web3.js (with its reliance on many dependencies to initialize)
- e.g. Stacks Connect (with its outdated success/error callbacks, unnecessary JWT wrapping and parameters)
- The user (via the wallet interface) should have more control over the actions than the web-app
- e.g. the user should also be able to choose the network/chain/nonce, not the web-app alone
Goals
- Get the community to come together as a working group on single JS API standard
- Alby
- Unisat
- WebBTC
- Leather
- Xverse
- Marketplaces (OpenOrdex, etc.)
- Bifrost wallet
- Reduce extisting methods to essentials (for new API styles)
- Add WBIPs solving existing issues users/wallets/applications face