bitcoinjs-lib/README.md

178 lines
8 KiB
Markdown
Raw Normal View History

2014-07-01 12:30:14 -05:00
# BitcoinJS (bitcoinjs-lib)
2011-05-06 00:08:46 +01:00
2014-06-22 16:59:59 +02:00
[![Build Status](https://travis-ci.org/bitcoinjs/bitcoinjs-lib.png?branch=master)](https://travis-ci.org/bitcoinjs/bitcoinjs-lib)
2016-01-27 17:48:25 +11:00
[![NPM](https://img.shields.io/npm/v/bitcoinjs-lib.svg)](https://www.npmjs.org/package/bitcoinjs-lib)
[![tip for next commit](https://tip4commit.com/projects/735.svg)](http://tip4commit.com/projects/735)
2014-03-14 11:37:22 +08:00
[![js-standard-style](https://cdn.rawgit.com/feross/standard/master/badge.svg)](https://github.com/feross/standard)
2014-07-01 22:27:58 -05:00
2014-07-01 12:30:14 -05:00
The pure JavaScript Bitcoin library for node.js and browsers.
2016-02-25 18:23:00 +11:00
Used by over a million wallet users and the backbone for almost all Bitcoin web wallets in production today.
2014-07-01 12:30:14 -05:00
## Features
2014-04-24 01:36:46 +10:00
2014-07-01 12:30:14 -05:00
- Clean: Pure JavaScript, concise code, easy to read.
- Tested: Coverage > 90%, third-party integration tests.
- Careful: Two person approval process for small, focused pull requests.
- Compatible: Works on Node.js and all modern browsers.
- Powerful: Support for advanced features, such as multi-sig, HD Wallets.
- Secure: Strong random number generation, PGP signed releases, trusted developers.
- Principled: No support for browsers with crap RNG (IE < 11)
- Standardized: Node community coding style, Browserify, Node's stdlib and Buffers.
- Fast: Optimized code, uses typed arrays instead of byte arrays for performance.
- Experiment-friendly: Bitcoin Mainnet and Testnet support.
- Altcoin-ready: Capable of working with bitcoin-derived cryptocurrencies (such as Dogecoin).
2014-03-08 15:08:08 -06:00
2014-07-01 12:30:14 -05:00
## Should I use this in production?
2016-04-27 16:35:22 +10:00
If you are thinking of using the master branch of this library in production, **stop**.
Master is not stable; it is our development branch, and [only tagged releases may be classified as stable](https://github.com/bitcoinjs/bitcoinjs-lib/tags).
2011-05-06 00:08:46 +01:00
2014-03-08 15:08:08 -06:00
## Installation
2011-12-20 12:47:50 +01:00
2014-03-01 14:03:37 +01:00
`npm install bitcoinjs-lib`
2014-03-18 23:10:39 -04:00
## Setup
2014-03-08 15:08:08 -06:00
### Node.js
var bitcoin = require('bitcoinjs-lib')
2014-03-08 15:08:08 -06:00
### Browser
If you're familiar with how to use browserify, ignore this and proceed normally.
These steps are advisory only and allow you to use the API to its full extent.
[Browserify](https://github.com/substack/node-browserify) is assumed to be installed for these steps.
From your repository, create a `foobar.js` file
2014-07-01 18:02:52 -05:00
``` javascript
var foobar = {
base58: require('bs58'),
bitcoin: require('bitcoinjs-lib'),
ecurve: require('ecurve'),
BigInteger: require('bigi'),
Buffer: require('buffer')
}
module.exports = foobar
```
Each of these included packages are seperate to `bitcoinjs-lib`, and must be installed separately.
They are however used in the bitcoinjs-lib public API.
Using browserify, compile `foo.js` for use in the browser:
$ browserify foo.js -s foobar > bar.js
You will then be able to load `bar.js` into your browser, with each of the dependencies above accessible from the global `foobar` object.
2014-03-01 14:03:37 +01:00
**NOTE**: See our package.json for the currently supported version of browserify used by this repository.
2015-04-10 10:46:59 +10:00
**NOTE**: When uglifying the javascript, you must exclude the following variable names from being mangled: `Array`, `BigInteger`, `Boolean`, `Buffer`, `ECPair`, `Function`, `Number`, `Point` and `Script`.
This is because of the function-name-duck-typing used in [typeforce](https://github.com/dcousens/typeforce).
2016-04-08 11:45:28 +10:00
Example:
``` bash
uglifyjs ... --mangle --reserved 'Array,BigInteger,Boolean,Buffer,ECPair,Function,Number,Point'
```
## Examples
2014-03-18 23:10:39 -04:00
2014-11-29 12:48:27 +11:00
The below examples are implemented as integration tests, they should be very easy to understand. Otherwise, pull requests are appreciated.
2014-03-18 23:10:39 -04:00
- [Generate a random address](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/basic.js#L9)
2014-11-25 14:32:47 +11:00
- [Generate a address from a SHA256 hash](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/basic.js#L20)
- [Generate a address and WIF for Litecoin](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/basic.js#L30)
- [Import an address via WIF](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/basic.js#L44)
- [Create a Transaction](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/basic.js#L51)
- [Sign a Bitcoin message](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/advanced.js#L8)
- [Verify a Bitcoin message](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/advanced.js#L16)
2014-12-08 11:58:46 +11:00
- [Create an OP RETURN transaction](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/advanced.js#L24)
- [Create a 2-of-3 multisig P2SH address](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/multisig.js#L9)
- [Spend from a 2-of-4 multisig P2SH address](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/multisig.js#L25)
- [Generate a single-key stealth address](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/crypto.js#L14)
- [Generate a dual-key stealth address](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/crypto.js#L53)
- [Recover a BIP32 parent private key from the parent public key and a derived non-hardened child private key](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/crypto.js#L55)
- [Recover a Private key from duplicate R values in a signature](https://github.com/bitcoinjs/bitcoinjs-lib/blob/master/test/integration/crypto.js#L102)
2014-07-10 13:48:54 +10:00
2015-10-27 15:39:34 +11:00
If you have a use case that you feel could be listed here, please [ask for it](https://github.com/bitcoinjs/bitcoinjs-lib/issues/new)!
2014-07-10 13:48:54 +10:00
2014-07-01 18:02:52 -05:00
## Projects utilizing BitcoinJS
2014-03-01 14:03:37 +01:00
2014-07-01 18:02:52 -05:00
- [BitAddress](https://www.bitaddress.org)
- [Blockchain.info](https://blockchain.info/wallet)
2015-03-10 20:04:52 +11:00
- [Blocktrail](https://www.blocktrail.com/)
2014-07-01 12:30:14 -05:00
- [Brainwallet](https://brainwallet.github.io)
- [Coinkite](https://coinkite.com)
- [Coinpunk](https://coinpunk.com)
2014-07-01 18:02:52 -05:00
- [Dark Wallet](https://darkwallet.unsystem.net)
2015-02-24 12:33:55 +11:00
- [DecentralBank](http://decentralbank.com/)
2014-07-01 18:02:52 -05:00
- [Dogechain Wallet](https://dogechain.info)
2016-02-05 14:44:43 +11:00
- [EI8HT Wallet](http://ei8.ht/)
2014-07-01 18:02:52 -05:00
- [GreenAddress](https://greenaddress.it)
- [Hive Wallet](https://www.hivewallet.com)
2014-10-14 13:04:27 +11:00
- [QuickCoin](https://wallet.quickcoin.co)
- [Robocoin](https://wallet.robocoin.com)
- [Skyhook ATM](http://projectskyhook.com)
2014-10-14 13:04:27 +11:00
2014-07-01 18:02:52 -05:00
## Contributors
Stefan Thomas is the inventor and creator of this project. His pioneering work made Bitcoin web wallets possible.
2016-04-27 16:33:59 +10:00
Daniel Cousens, Wei Lu, JP Richardson and Kyle Drake lead the major refactor of the library from 0.1.3 to 1.0.0.
2014-07-01 18:02:52 -05:00
Since then, many people have contributed. [Click here](https://github.com/bitcoinjs/bitcoinjs-lib/graphs/contributors) to see the comprehensive list.
2014-09-05 15:45:39 +10:00
2014-03-18 23:10:39 -04:00
## Contributing
2015-11-09 15:37:12 +11:00
We are always accepting of pull requests, but we do adhere to specific standards in regards to coding style, test driven development and commit messages.
2014-03-18 23:10:39 -04:00
Please make your best effort to adhere to these when contributing to save on trivial corrections.
2014-03-18 23:10:39 -04:00
### Running the test suite
2014-03-18 23:10:39 -04:00
$ npm test
2014-07-01 12:30:14 -05:00
$ npm run-script coverage
2014-03-18 23:10:39 -04:00
2014-07-01 18:02:52 -05:00
## Complementing Libraries
- [BIP21](https://github.com/bitcoinjs/bip21) - A BIP21 compatible URL encoding utility library
- [BIP38](https://github.com/bitcoinjs/bip38) - Passphrase-protected private keys
- [BIP39](https://github.com/bitcoinjs/bip39) - Mnemonic generation for deterministic keys
- [BIP32-Utils](https://github.com/bitcoinjs/bip32-utils) - A set of utilities for working with BIP32
- [BIP32-Wallet](https://github.com/bitcoinjs/bip32-wallet) - A BIP32 Wallet backed by bitcoinjs-lib, lite on features but heavily tested
- [BIP66](https://github.com/bitcoinjs/bip66) - Strict DER signature decoding
- [BIP69](https://github.com/bitcoinjs/bip69) - Mnemonic generation for deterministic keys
- [Base58](https://github.com/cryptocoinjs/bs58) - Base58 encoding/decoding
- [Base58 Check](https://github.com/bitcoinjs/bs58check) - Base58 check encoding/decoding
2014-07-01 18:02:52 -05:00
- [BCoin](https://github.com/indutny/bcoin) - BIP37 / Bloom Filters / SPV client
- [insight](https://github.com/bitpay/insight) - A bitcoin blockchain API for web wallets.
## Alternatives
2014-03-01 14:03:37 +01:00
2014-03-08 15:08:08 -06:00
- [Bitcore](https://github.com/bitpay/bitcore)
- [Cryptocoin](https://github.com/cryptocoinjs/cryptocoin)
2016-01-27 17:45:55 +11:00
## LICENSE [MIT](LICENSE)
2012-07-30 19:09:21 +02:00
2014-03-08 15:08:08 -06:00
## Copyright
2012-07-30 19:09:21 +02:00
2015-12-17 16:23:46 +11:00
BitcoinJS (c) 2011-2016 bitcoinjs-lib contributors
2014-03-01 14:03:37 +01:00
Released under MIT license