Package Exports
- @bsv/sdk
- @bsv/sdk/auth
- @bsv/sdk/auth/Peer
- @bsv/sdk/auth/SessionManager
- @bsv/sdk/auth/certificate
- @bsv/sdk/auth/certificates/Certificate
- @bsv/sdk/auth/certificates/MasterCertificate
- @bsv/sdk/auth/certificates/VerifiableCertificate
- @bsv/sdk/auth/certificates/__tests/CompletedProtoWallet
- @bsv/sdk/auth/certificates/index
- @bsv/sdk/auth/clients/AuthFetch
- @bsv/sdk/auth/clients/index
- @bsv/sdk/auth/index
- @bsv/sdk/auth/transports/SimplifiedFetchTransport
- @bsv/sdk/auth/transports/index
- @bsv/sdk/auth/types
- @bsv/sdk/auth/utils/createNonce
- @bsv/sdk/auth/utils/getVerifiableCertificates
- @bsv/sdk/auth/utils/index
- @bsv/sdk/auth/utils/validateCertificates
- @bsv/sdk/auth/utils/verifyNonce
- @bsv/sdk/compat
- @bsv/sdk/compat/BSM
- @bsv/sdk/compat/ECIES
- @bsv/sdk/compat/HD
- @bsv/sdk/compat/Mnemonic
- @bsv/sdk/compat/Utxo
- @bsv/sdk/compat/bip-39-wordlist-en
- @bsv/sdk/compat/index
- @bsv/sdk/messages
- @bsv/sdk/messages/EncryptedMessage
- @bsv/sdk/messages/SignedMessage
- @bsv/sdk/messages/index
- @bsv/sdk/overlay-tools
- @bsv/sdk/overlay-tools/LookupResolver
- @bsv/sdk/overlay-tools/OverlayAdminTokenTemplate
- @bsv/sdk/overlay-tools/SHIPBroadcaster
- @bsv/sdk/overlay-tools/index
- @bsv/sdk/primitives
- @bsv/sdk/primitives/AESGCM
- @bsv/sdk/primitives/BasePoint
- @bsv/sdk/primitives/BigNumber
- @bsv/sdk/primitives/Curve
- @bsv/sdk/primitives/DRBG
- @bsv/sdk/primitives/ECDSA
- @bsv/sdk/primitives/Hash
- @bsv/sdk/primitives/JacobianPoint
- @bsv/sdk/primitives/K256
- @bsv/sdk/primitives/Mersenne
- @bsv/sdk/primitives/MontgomoryMethod
- @bsv/sdk/primitives/Point
- @bsv/sdk/primitives/Polynomial
- @bsv/sdk/primitives/PrivateKey
- @bsv/sdk/primitives/PublicKey
- @bsv/sdk/primitives/Random
- @bsv/sdk/primitives/ReductionContext
- @bsv/sdk/primitives/Schnorr
- @bsv/sdk/primitives/Signature
- @bsv/sdk/primitives/SymmetricKey
- @bsv/sdk/primitives/TransactionSignature
- @bsv/sdk/primitives/index
- @bsv/sdk/primitives/utils
- @bsv/sdk/script
- @bsv/sdk/script/LockingScript
- @bsv/sdk/script/OP
- @bsv/sdk/script/Script
- @bsv/sdk/script/ScriptChunk
- @bsv/sdk/script/ScriptTemplate
- @bsv/sdk/script/ScriptTemplateUnlock
- @bsv/sdk/script/Spend
- @bsv/sdk/script/UnlockingScript
- @bsv/sdk/script/index
- @bsv/sdk/script/templates
- @bsv/sdk/script/templates/P2PKH
- @bsv/sdk/script/templates/PushDrop
- @bsv/sdk/script/templates/RPuzzle
- @bsv/sdk/script/templates/index
- @bsv/sdk/totp
- @bsv/sdk/totp/index
- @bsv/sdk/totp/totp
- @bsv/sdk/transaction
- @bsv/sdk/transaction/Beef
- @bsv/sdk/transaction/BeefParty
- @bsv/sdk/transaction/BeefTx
- @bsv/sdk/transaction/Broadcaster
- @bsv/sdk/transaction/ChainTracker
- @bsv/sdk/transaction/FeeModel
- @bsv/sdk/transaction/MerklePath
- @bsv/sdk/transaction/Transaction
- @bsv/sdk/transaction/TransactionInput
- @bsv/sdk/transaction/TransactionOutput
- @bsv/sdk/transaction/broadcaster
- @bsv/sdk/transaction/broadcasters/ARC
- @bsv/sdk/transaction/broadcasters/DefaultBroadcaster
- @bsv/sdk/transaction/broadcasters/WhatsOnChainBroadcaster
- @bsv/sdk/transaction/broadcasters/index
- @bsv/sdk/transaction/chaintrackers
- @bsv/sdk/transaction/chaintrackers/DefaultChainTracker
- @bsv/sdk/transaction/chaintrackers/WhatsOnChain
- @bsv/sdk/transaction/chaintrackers/index
- @bsv/sdk/transaction/fee-model
- @bsv/sdk/transaction/fee-models/SatoshisPerKilobyte
- @bsv/sdk/transaction/fee-models/index
- @bsv/sdk/transaction/http
- @bsv/sdk/transaction/http/DefaultHttpClient
- @bsv/sdk/transaction/http/FetchHttpClient
- @bsv/sdk/transaction/http/HttpClient
- @bsv/sdk/transaction/http/NodejsHttpClient
- @bsv/sdk/transaction/http/index
- @bsv/sdk/transaction/index
- @bsv/sdk/umd
- @bsv/sdk/wallet
- @bsv/sdk/wallet/CachedKeyDeriver
- @bsv/sdk/wallet/KeyDeriver
- @bsv/sdk/wallet/ProtoWallet
- @bsv/sdk/wallet/Wallet.interfaces
- @bsv/sdk/wallet/WalletClient
- @bsv/sdk/wallet/WalletError
- @bsv/sdk/wallet/index
- @bsv/sdk/wallet/substrates
- @bsv/sdk/wallet/substrates/HTTPWalletJSON
- @bsv/sdk/wallet/substrates/HTTPWalletWire
- @bsv/sdk/wallet/substrates/WalletWire
- @bsv/sdk/wallet/substrates/WalletWireCalls
- @bsv/sdk/wallet/substrates/WalletWireProcessor
- @bsv/sdk/wallet/substrates/WalletWireTransceiver
- @bsv/sdk/wallet/substrates/XDM
- @bsv/sdk/wallet/substrates/index
- @bsv/sdk/wallet/substrates/window.CWI
Readme
BSV SDK
BSV BLOCKCHAIN | Software Development Kit for JavaScript and TypeScript
Welcome to the BSV Blockchain Libraries Project, the comprehensive TypeScript SDK designed to provide an updated and unified layer for developing scalable applications on the BSV Blockchain. This SDK addresses the limitations of previous tools by offering a fresh, peer-to-peer approach, adhering to SPV, and ensuring privacy and scalability.
Table of Contents
- Objective
- Getting Started
- Features & Deliverables
- Documentation
- Contribution Guidelines
- Support & Contacts
Objective
The BSV Blockchain Libraries Project aims to structure and maintain a middleware layer of the BSV Blockchain technology stack. By facilitating the development and maintenance of core libraries, it serves as an essential toolkit for developers looking to build on the BSV Blockchain.
Getting Started
Installation
To install the SDK, run:
npm install @bsv/sdkBasic Usage
Here's a simple example of using the SDK to create and sign a transaction:
import { PrivateKey, P2PKH, Transaction, ARC } from '@bsv/sdk'
const privKey = PrivateKey.fromWif('L5EY1SbTvvPNSdCYQe1EJHfXCBBT4PmnF6CDbzCm9iifZptUvDGB')
const sourceTransaction = Transaction.fromHex('0200000001849c6419aec8b65d747cb72282cc02f3fc26dd018b46962f5de48957fac50528020000006a473044022008a60c611f3b48eaf0d07b5425d75f6ce65c3730bd43e6208560648081f9661b0220278fa51877100054d0d08e38e069b0afdb4f0f9d38844c68ee2233ace8e0de2141210360cd30f72e805be1f00d53f9ccd47dfd249cbb65b0d4aee5cfaf005a5258be37ffffffff03d0070000000000001976a914acc4d7c37bc9d0be0a4987483058a2d842f2265d88ac75330100000000001976a914db5b7964eecb19fcab929bf6bd29297ec005d52988ac809f7c09000000001976a914c0b0a42e92f062bdbc6a881b1777eed1213c19eb88ac00000000')
const version = 1
const input = {
  sourceTransaction,
  sourceOutputIndex: 0,
  unlockingScriptTemplate: new P2PKH().unlock(privKey),
}
const output = {
  lockingScript: new P2PKH().lock(privKey.toAddress()),
  change: true
}
const tx = new Transaction(version, [input], [output])
await tx.fee()
await tx.sign()
await tx.broadcast()For a more detailed tutorial and advanced examples, check our Documentation.
Features & Deliverables
- Sound Cryptographic Primitives: Secure key management, signature computations, and encryption protocols. 
- Script Level Constructs: Network-compliant script interpreter with support for custom scripts and serialization formats. 
- Transaction Construction and Signing: Comprehensive transaction builder API, ensuring versatile and secure transaction creation. 
- Transaction Broadcast Management: Mechanisms to send transactions to both miners and overlays, ensuring extensibility and future-proofing. 
- Merkle Proof Verification: Tools for representing and verifying merkle proofs, adhering to various serialization standards. 
- Serializable SPV Structures: Structures and interfaces for full SPV verification. 
- Secure Encryption and Signed Messages: Enhanced mechanisms for encryption and digital signatures, replacing outdated methods. 
Documentation
The Docs are available here on Github pages.
Example code is available over on our gitbook.  
The SDK is richly documented with code-level annotations. This should show up well within editors like VSCode.
Contribution Guidelines
We're always looking for contributors to help us improve the SDK. Whether it's bug reports, feature requests, or pull requests - all contributions are welcome.
- Fork & Clone: Fork this repository and clone it to your local machine.
- Set Up: Run npm installto install all dependencies.
- Make Changes: Create a new branch and make your changes.
- Test: Ensure all tests pass by running npm test.
- Commit: Commit your changes and push to your fork.
- Pull Request: Open a pull request from your fork to this repository. For more details, check the contribution guidelines.
For information on past releases, check out the changelog. For future plans, check the roadmap!
Support & Contacts
Project Owners: Thomas Giacomo and Darren Kellenschwiler
Development Team Lead: Ty Everett
For questions, bug reports, or feature requests, please open an issue on GitHub or contact us directly.
License
The license for the code in this repository is the Open BSV License. Refer to LICENSE.txt for the license text.
Thank you for being a part of the BSV Blockchain Libraries Project. Let's build the future of BSV Blockchain together!