2017-04-05 16:56:41 -04:00
ethers.js
=========
2016-07-16 00:34:40 -04:00
2017-10-20 15:44:54 -04:00
[![npm version ](https://badge.fury.io/js/ethers.svg )](https://badge.fury.io/js/ethers)
2016-08-05 03:53:29 -04:00
2018-06-20 21:14:56 -04:00
Complete Ethereum wallet implementation and utilities in JavaScript (and TypeScript).
2016-08-05 03:40:31 -04:00
**Features:**
2016-07-16 00:34:40 -04:00
2017-04-05 16:56:41 -04:00
- Keep your private keys in your client, **safe** and sound
2018-09-27 16:48:22 -04:00
- Import and export **JSON wallets** (Geth, Parity and crowdsale)
2018-06-20 21:19:08 -04:00
- 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)
2018-09-27 16:48:22 -04:00
- Meta-classes create JavaScript objects from any contract ABI, including **ABIv2** and **Human-Readable ABI**
2018-01-17 16:23:01 -05:00
- Connect to Ethereum nodes over [JSON-RPC ](https://github.com/ethereum/wiki/wiki/JSON-RPC ), [INFURA ](https://infura.io ), [Etherscan ](https://etherscan.io ), or [MetaMask ](https://metamask.io )
2018-09-27 16:48:22 -04:00
- **ENS names** are first-class citizens; they can be used anywhere an Ethereum addresses can be used
2018-06-20 21:19:08 -04:00
- **Tiny** (~84kb compressed; 270kb uncompressed)
2017-04-05 16:56:41 -04:00
- **Complete** functionality for all your Ethereum needs
2017-10-20 22:01:51 -04:00
- Extensive [documentation ](https://docs.ethers.io/ethers.js/html/ )
2018-09-27 16:48:22 -04:00
- Large collection of **test cases** which are maintained and added to
- Fully **TypeScript** ready, with definition files and full TypeScript source
2017-04-05 16:56:41 -04:00
- **MIT License** (including ALL dependencies); completely open source to do with as you please
2016-07-16 00:34:40 -04:00
2018-08-27 20:19:06 +02:00
Keep Updated
------------
2018-09-28 11:00:33 -04:00
For the latest news and advisories, please follow [@ethersproject ](https://twitter.com/ethersproject ) on Twitter as well as this GitHub project.
2018-08-27 20:19:06 +02:00
2016-08-05 03:53:29 -04:00
Installing
----------
To use in a browser:
```html
2017-10-20 22:59:30 -04:00
< script charset = "utf-8"
2018-09-27 16:48:22 -04:00
src="https://cdn.ethers.io/scripts/ethers-v4.min.js"
2017-10-20 22:59:30 -04:00
type="text/javascript">
2017-04-05 16:56:41 -04:00
< / script >
2016-08-05 03:53:29 -04:00
```
To use in [node.js ](https://nodejs.org/ ):
```
2017-04-05 16:56:41 -04:00
/Users/ethers/my-app> npm install --save ethers
2016-08-05 03:53:29 -04:00
```
2017-04-05 16:56:41 -04:00
Documentation
-------------
2016-07-23 03:27:14 -04:00
2017-10-20 23:01:08 -04:00
Browse the [API Documentation ](https://docs.ethers.io/ethers.js/html/ ) online.
2016-07-23 03:27:14 -04:00
2018-08-27 20:19:06 +02:00
To fork and submit pull requests to the documentation, please see the
[documentation repository ](https://github.com/ethers-io/documentation ).
Related Libraries
---------------
- [Command Line Interface ](https://github.com/ethers-io/ethers-cli ) - Command Line Tools for ethers
- [CryptoKitties ](https://github.com/ricmoo/ethers-meow ) - CryptoKitties utility libraries
- [ENS ](https://github.com/ethers-io/ethers-ens ) - ENS utility libraries for managing names
- [LedgerSigner ](https://github.com/ethers-io/ethers-ledger ) - Use a Ledger Hardware Wallet as an ethers Signer (supports HID (node.js) and U2F (browser); or specify your own transport)
- [Web3 Bridge ](https://github.com/ethers-io/ethers-web3-bridge ) - Use ethers as the backend for a Web3 front-end
2016-07-16 00:34:40 -04:00
2016-07-23 03:27:14 -04:00
2018-06-20 21:14:56 -04:00
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
2018-09-27 16:48:22 -04:00
- The library aims to be lean, so keep an eye on the `dist/ethers.min.js` file size before and after your changes
2018-06-20 21:14:56 -04:00
- 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
2018-09-27 16:48:22 -04:00
In general, **please start an issue before beginning a pull request** , so we can have a public discussion. :)
2018-06-20 21:14:56 -04:00
2016-07-23 03:27:14 -04:00
2017-05-10 19:09:58 -04:00
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`
2016-07-16 00:34:40 -04:00
License
-------
2017-04-05 16:56:41 -04:00
Completely MIT Licensed. Including ALL dependencies.