Complete Ethereum library and wallet implementation in JavaScript.
Go to file
2018-07-03 16:44:05 -04:00
contracts Added eslint for promises. (#189) 2018-07-03 16:44:05 -04:00
dist Added eslint for promises. (#189) 2018-07-03 16:44:05 -04:00
providers Added eslint for promises. (#189) 2018-07-03 16:44:05 -04:00
src.browser Added no implicit any for TypeScript checking. 2018-06-22 20:30:50 -04:00
src.ts Added eslint for promises. (#189) 2018-07-03 16:44:05 -04:00
tests Use block polling rather than exponential backoff when possible. Added transactionHash to errors on failed transactions. 2018-07-03 15:48:37 -04:00
utils Added eslint for promises. (#189) 2018-07-03 16:44:05 -04:00
wallet Added eslint for promises. (#189) 2018-07-03 16:44:05 -04:00
wordlists Updated dist files for wordlists. 2018-06-24 05:34:57 -04:00
_version.js Added version to TypeScript library output. 2018-06-24 05:31:24 -04:00
.eslintrc.js Added eslint for promises. (#189) 2018-07-03 16:44:05 -04:00
.gitignore Fixed TypeScript definition file generation. 2018-06-24 04:03:21 -04:00
.npmignore Add tsconfig to npmignore. 2018-06-21 21:15:28 -04:00
.travis.yml Added node 10 to Travis CI testing. 2018-06-24 21:43:29 -04:00
CODE_OF_CONDUCT.md Adding default code of conduct 2017-11-04 02:03:41 -05:00
gulpfile.js Fixed TypeScript definition file generation. 2018-06-24 04:03:21 -04:00
index.js Added version to TypeScript library output. 2018-06-24 05:31:24 -04:00
LICENSE Creating license file in GitHub UI 2017-11-03 14:53:11 -05:00
package-lock.json Added deployed to contract and abstracted polling into web. 2018-06-30 23:05:22 -04:00
package.json Added deployed to contract and abstracted polling into web. 2018-06-30 23:05:22 -04:00
README.md Updated readme. 2018-06-20 21:19:08 -04:00
thirdparty.d.ts Added no implicit any for TypeScript checking. 2018-06-22 20:30:50 -04:00
tsconfig.json Added no implicit any for TypeScript checking. 2018-06-22 20:30:50 -04:00

ethers.js

npm version

Complete Ethereum wallet implementation and utilities in JavaScript (and TypeScript).

Features:

  • Keep your private keys in your client, safe and sound
  • Import and export JSON wallets (Geth, Parity and crowdsale) and brain wallets
  • Import and export BIP 39 mnemonic phrases (12 word backup phrases) and HD Wallets (English, Italian, Japanese, Korean, Simplified Chinese, Traditional Chinese; more coming soon)
  • Meta-classes create JavaScript objects from any contract ABI
  • Connect to Ethereum nodes over JSON-RPC, INFURA, Etherscan, or MetaMask
  • ENS names are first-class citizens; they can be used anywhere an Ethereum addresses can be
  • Tiny (~84kb compressed; 270kb uncompressed)
  • Complete functionality for all your Ethereum needs
  • Extensive documentation
  • Large collection of test cases which are maintained and added to
  • Fully TypeScript ready, with definition files and full TypeScript source
  • MIT License (including ALL dependencies); completely open source to do with as you please

Installing

To use in a browser:

<script charset="utf-8"
        src="https://cdn.ethers.io/scripts/ethers-v4.min.js"
        type="text/javascript">
</script>

To use in node.js:

/Users/ethers/my-app> npm install --save ethers

Documentation

Browse the API Documentation online.

Documentation is generated using Sphinx and can be browsed locally from the /docs/build/html directory.

Hacking and Contributing

The JavaScript code is now generated from TypeScript, so make sure you modify the TypeScript and compile it, rather than modifying the JavaScript directly. To start auto-compiling the TypeScript code, you may use:

/home/ethers> npm run auto-build

A very important part of ethers is its exhaustive test cases, so before making any bug fix, please add a test case that fails prior to the fix, and succeeds after the fix. All regression tests must pass.

Pull requests are always welcome, but please keep a few points in mind:

  • Compatibility-breaking changes will not be accepted; they may be considered for the next major version
  • Security is important; adding dependencies require fairly convincing arguments
  • The library aims to be lean, so keep an eye on the dist/ethers.min.js filesize before and after your changes
  • Add test cases for both expected and unexpected input
  • Any new features need to be supported by us (issues, documentation, testing), so anything that is overly complicated or specific may not be accepted

If in doubt, please start an issue, and we can have a nice public discussion. :)

Donations

I do this because I love it, but if you want to buy me a coffee, I won't say no. :o)

Ethereum: 0xEA517D5a070e6705Cc5467858681Ed953d285Eb9

License

Completely MIT Licensed. Including ALL dependencies.