# Ethereum JavaScript API This is the Ethereum compatible [JavaScript API](https://github.com/ethereum/wiki/wiki/JavaScript-API) which implements the [Generic JSON RPC](https://github.com/ethereum/wiki/wiki/JSON-RPC) spec. It's available on npm as a node module, for bower and component as an embeddable js and as a meteor.js package. [![NPM version][npm-image]][npm-url] [![Build Status][travis-image]][travis-url] [![dependency status][dep-image]][dep-url] [![dev dependency status][dep-dev-image]][dep-dev-url][![Coverage Status][coveralls-image]][coveralls-url] <!-- [![browser support](https://ci.testling.com/ethereum/ethereum.js.png)](https://ci.testling.com/ethereum/ethereum.js) --> You need to run a local ethrereum node to use this library. [Documentation](https://github.com/ethereum/wiki/wiki/JavaScript-API) ## Installation ### Node.js $ npm install ethereum.js ### Meteor.js $ meteor add ethereum:js ### As Browser module Bower $ bower install ethereum.js Component $ component install ethereum/ethereum.js * Include `ethereum.min.js` in your html file. (not required for the meteor package) * Include [bignumber.js](https://github.com/MikeMcl/bignumber.js/) (not required for the meteor package) ## Usage Require the library (not required for the meteor package): var web3 = require('web3'); Set a provider (QtSyncProvider, HttpProvider) web3.setProvider(new web3.providers.HttpProvider('http://localhost:8545')); There you go, now you can use it: ``` var coinbase = web3.eth.coinbase; var balance = web3.eth.getBalance(coinbase); ``` For another example see `example/index.html`. ## Contribute! ### Requirements * Node.js * npm ```bash sudo apt-get update sudo apt-get install nodejs sudo apt-get install npm sudo apt-get install nodejs-legacy ``` ### Building (gulp) ```bash npm run-script build ``` ### Testing (mocha) ```bash npm test ``` ### Testing (karma) Karma allows testing within one or several browsers. ```bash npm run-script karma # default browsers are Chrome and Firefox npm run-script karma -- --browsers="Chrome,Safari" # custom browsers ``` **Please note this repo is in it's early stage.** If you'd like to run a Http ethereum node check out [cpp-ethereum](https://github.com/ethereum/cpp-ethereum). Install ethereum and spawn a node: ``` eth -j ``` [npm-image]: https://badge.fury.io/js/ethereum.js.png [npm-url]: https://npmjs.org/package/ethereum.js [travis-image]: https://travis-ci.org/ethereum/ethereum.js.svg [travis-url]: https://travis-ci.org/ethereum/ethereum.js [dep-image]: https://david-dm.org/ethereum/ethereum.js.svg [dep-url]: https://david-dm.org/ethereum/ethereum.js [dep-dev-image]: https://david-dm.org/ethereum/ethereum.js/dev-status.svg [dep-dev-url]: https://david-dm.org/ethereum/ethereum.js#info=devDependencies [coveralls-image]: https://coveralls.io/repos/ethereum/ethereum.js/badge.svg?branch=master [coveralls-url]: https://coveralls.io/r/ethereum/ethereum.js?branch=master