Bitcore ======= [data:image/s3,"s3://crabby-images/9f7dd/9f7ddeb528d6e71b195d2bc4da7daec159dafb76" alt="NPM Package"](https://www.npmjs.org/package/bitcore) [data:image/s3,"s3://crabby-images/93d2d/93d2d219f406ef75cd17ddd70e9f7d77c24b382d" alt="Build Status"](https://travis-ci.org/bitpay/bitcore) [data:image/s3,"s3://crabby-images/c5fb8/c5fb82d64a73f2941103a17657cda5720b934d7e" alt="Coverage Status"](https://coveralls.io/r/bitpay/bitcore) A pure and powerful JavaScript Bitcoin library. ## Principles Bitcoin is a powerful new peer-to-peer platform for the next generation of financial technology. The decentralized nature of the Bitcoin network allows for highly resilient bitcoin infrastructure, and the developer community needs reliable, open-source tools to implement bitcoin apps and services. ## Get Started ``` npm install bitcore ``` Using it in Node.js: ```javascript var bitcore = require('bitcore'); assert(bitcore.Address.isValid('126vMmY1fyznpZiFTTnty3cm1Rw8wuheev')); var simpleTx = new bitcore.Transaction(); var simpleTx.from(unspent).to(address, amount); simpleTx.sign(privateKey); ``` ## Documentation The complete docs are hosted here: [bitcore documentation](http://bitcore.io/guide/). There's also a [bitcore API reference](http://bitcore.io/api/) available generated from the JSDocs of the project, where you'll find low-level details on each bitcore utility. - [Read the Developer Guide](http://bitcore.io/guide/) - [Read the API Reference](http://bitcore.io/api/) To get community assistance and ask for help with implementation questions, please use our [community forums](http://bitpaylabs.com/c/bitcore). ## Examples * [Generate a random address](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#generate-a-random-address) * [Generate a address from a SHA256 hash](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#generate-a-address-from-a-sha256-hash) * [Import an address via WIF](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#import-an-address-via-wif) * [Create a Transaction](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#create-a-transaction) * [Sign a Bitcoin message](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#sign-a-bitcoin-message) * [Verify a Bitcoin message](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#verify-a-bitcoin-message) * [Create an OP RETURN transaction](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#create-an-op-return-transaction) * [Create a 2-of-3 multisig P2SH address](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#create-a-2-of-3-multisig-p2sh-address) * [Spend from a 2-of-2 multisig P2SH address](https://github.com/bitpay/bitcore/blob/master/docs/examples.md#spend-from-a-2-of-2-multisig-p2sh-address) ## Modules This module provides bitcoin's core features. Other features and protocol extensions are built into separate modules. Here is a list of official bitcore modules: Module | Version | Building | Coverage -------|---------|----------|--------- <a href="http://github.com/bitpay/bitcore-payment-protocol"><img src="http://bitcore.io/css/images/bitcore-payment-protocol.svg" alt="bitcore-payment-protocol" height="28"></a> | [data:image/s3,"s3://crabby-images/72a6d/72a6deba636a28ae86cbc0b91ff9ee62b3499dc3" alt="NPM Package"](https://www.npmjs.org/package/bitcore-payment-protocol) | [data:image/s3,"s3://crabby-images/5ae64/5ae6495b9d2d59806a6bd354c10d1953c33e1372" alt="Build Status"](https://travis-ci.org/bitpay/bitcore-payment-protocol) | [data:image/s3,"s3://crabby-images/d13eb/d13eb2fd1a61df8adfc3f028c069f1c1e41f62e6" alt="Coverage Status"](https://coveralls.io/r/bitpay/bitcore-payment-protocol) <a href="http://github.com/bitpay/bitcore-p2p"><img src="http://bitcore.io/css/images/bitcore-p2p.svg" alt="bitcore-p2p" height="28"></a> | [data:image/s3,"s3://crabby-images/4a384/4a3841dcac0d40cf0d65b35218a8a76797cec04c" alt="NPM Package"](https://www.npmjs.org/package/bitcore-p2p) | [data:image/s3,"s3://crabby-images/a2c77/a2c77c5d9e522062abc89b6a9fbec76e80d4161e" alt="Build Status"](https://travis-ci.org/bitpay/bitcore-p2p) | [data:image/s3,"s3://crabby-images/4bbf8/4bbf866cee21334e1404e09c3bd0caa3726f2ac3" alt="Coverage Status"](https://coveralls.io/r/bitpay/bitcore-p2p?branch=master) <a href="http://github.com/bitpay/bitcore-mnemonic"><img src="http://bitcore.io/css/images/bitcore-mnemonic.svg" alt="bitcore-mnemonic" height="28"></a> | [data:image/s3,"s3://crabby-images/89d36/89d36faee784d75eb8f9b7c0c162450a6be000f5" alt="NPM Package"](https://www.npmjs.org/package/bitcore-mnemonic) | [data:image/s3,"s3://crabby-images/2ce86/2ce86d0b2c88cc9f7f604e0eef88abed01f046ca" alt="Build Status"](https://travis-ci.org/bitpay/bitcore-mnemonic) | [data:image/s3,"s3://crabby-images/105d6/105d6a2da7494b2f5e56324ee0b83365299d13b4" alt="Coverage Status"](https://coveralls.io/r/bitpay/bitcore-mnemonic) <a href="http://github.com/bitpay/bitcore-ecies"><img src="http://bitcore.io/css/images/bitcore-ecies.svg" alt="bitcore-ecies" height="25"></a> | [data:image/s3,"s3://crabby-images/e7e1f/e7e1f507e741d95ff3195f236f2b3560dd9dcbc8" alt="NPM Package"](https://www.npmjs.org/package/bitcore-ecies) | [data:image/s3,"s3://crabby-images/14c15/14c15f43dc9ae7ffe034135fc370a78aaf42864c" alt="Build Status"](https://travis-ci.org/bitpay/bitcore-ecies) | [data:image/s3,"s3://crabby-images/fab00/fab00edc0988a79afc8347ba2c67ed335922c3f0" alt="Coverage Status"](https://coveralls.io/r/bitpay/bitcore-ecies) <a href="http://github.com/bitpay/bitcore-channel"><img src="http://bitcore.io/css/images/bitcore-channel.svg" alt="bitcore-channel" height="28"></a> | [data:image/s3,"s3://crabby-images/1d71c/1d71cdb3957a1f5257cb9a8fd8148484771358fa" alt="NPM Package"](https://www.npmjs.org/package/bitcore-channel) | [data:image/s3,"s3://crabby-images/013ba/013bae12ee7671ab8918e1b92706dc445ecc665a" alt="Build Status"](https://travis-ci.org/bitpay/bitcore-channel) | [data:image/s3,"s3://crabby-images/7f9ae/7f9ae6d77d552dd59577cbe9b18d1075f5dfb641" alt="Coverage Status"](https://coveralls.io/r/bitpay/bitcore-channel) <a href="http://github.com/bitpay/bitcore-explorers"><img src="http://bitcore.io/css/images/bitcore-explorers.svg" alt="bitcore-explorers" height="28"></a> | [data:image/s3,"s3://crabby-images/ce2ce/ce2ced40418e8ee5da7e5289a83a9d38ab95eef0" alt="NPM Package"](https://www.npmjs.org/package/bitcore-explorers) | [data:image/s3,"s3://crabby-images/29fd8/29fd8be825b47abb103d2d673ccc73b6d3023f51" alt="Build Status"](https://travis-ci.org/bitpay/bitcore-explorers) | [data:image/s3,"s3://crabby-images/ade37/ade3725a23f151b6a2a2321ac181a09b43603f1c" alt="Coverage Status"](https://coveralls.io/r/bitpay/bitcore-explorers) <a href="http://github.com/bitpay/bitcore-message"><img src="http://bitcore.io/css/images/bitcore-message.svg" alt="bitcore-message" height="28"></a> | [data:image/s3,"s3://crabby-images/c5bfd/c5bfd8d2149f6e8369e35e4d0827510736a16acb" alt="NPM Package"](https://www.npmjs.org/package/bitcore-message) | [data:image/s3,"s3://crabby-images/5a24e/5a24ef005e98745b3610ed020820dc2de1164091" alt="Build Status"](https://travis-ci.org/bitpay/bitcore-message) | [data:image/s3,"s3://crabby-images/141a8/141a8fa368dc17ea62ff3ebbc2274143f2db5f9a" alt="Coverage Status"](https://coveralls.io/r/bitpay/bitcore-message) ## Security We're using Bitcore in production, as are [many others](http://bitcore.io#projects), but please use common sense when doing anything related to finances! We take no responsibility for your implementation decisions. If you find a security issue, please email security@bitpay.com. ## Contributing Please send pull requests for bug fixes, code optimization, and ideas for improvement. For more information on how to contribute, please refer to our [CONTRIBUTING](https://github.com/bitpay/bitcore/blob/master/CONTRIBUTING.md) file. ## Building the Browser Bundle To build bitcore full bundle for the browser: ```sh gulp browser ``` This will generate files named `bitcore.js` and `bitcore.min.js`. You can also use our pre-generated files, provided for each release along with a PGP signature by one of the project's maintainers. To get them, checkout a release commit (for example, https://github.com/bitpay/bitcore/commit/e33b6e3ba6a1e5830a079e02d949fce69ea33546 for v0.12.6). To verify signatures, use the following PGP keys: - @braydonf: https://pgp.mit.edu/pks/lookup?op=get&search=0x9BBF07CAC07A276D - @pnagurny: https://pgp.mit.edu/pks/lookup?op=get&search=0x0909B33F0AA53013 ## Tests Run all the tests: ```sh gulp test ``` You can also run just the NodeJS tests with `gulp test:node`, just the browser tests with `gulp test:browser` or create a test coverage report (you can open `coverage/lcov-report/index.html` to visualize it) with `gulp coverage`. ## License Code released under [the MIT license](https://github.com/bitpay/bitcore/blob/master/LICENSE). Copyright 2013-2015 BitPay, Inc. Bitcore is a trademark maintained by BitPay, Inc.