ethers.jsとは
公式ドキュメントでは以下のように書かれています。
https://docs.ethers.io/ethers.js/html/
This library is designed to make it easier to write client-side JavaScript based wallets, keeping the private key on the owners machine at all times.
また、下記ブログではこんなことも書かれています。
https://medium.com/l4-media/announcing-ethers-js-a-web3-alternative-6f134fdd06f3
In short, ethers.js is an alternative to web3, the most commonly used library for ethereum applications.
特徴
以下のような特徴を持っています。
- ノードから独立したwallet機能をもつ。クライアント側に閉じた状態でアドレスの生成・復元などができる。
- web3でできることは基本的に全てできる(らしい)ので、webの代替となる。
- ライブラリ単体でBIP39&BIP32に対応したウォレットを作成できる。
- Fallback Provider、ENSの設定などをデフォルトでサポートしている。
ウォレットの生成方法
以下の5つの方法でウォレットが生成できます。
- Private Key
- 既存のPrivate Keyから復元したウォレット。
- Mnemonic Phrase
- 既存のMnemonicから復元したウォレット。
- Random Wallet
- cryptoモジュールのrandomBytesを用いてランダムに生成されるウォレット。
- Secret Storage Wallet (e.g. Geth or Parity)
- ノードで生成されるkeystoreより復元されるウォレット
- Brain Wallet
- 任意のidとパスワードからハッシュを作成してPrivate Keyとするウォレット。クラックされる危険性があるため非推奨とされている。
実装方法
web3.jsとehters.jsの実装方法を比べてみます。
(TypeScriptで必要最低限の実装をしています。)
1. web3.jsの場合
import Web3 from 'web3';
import { default as contract } from 'truffle-contract';
export class Web3Service {
private web3: Web3;
// 初期化
constructor() {
this.web3 = new Web3(new Web3.providers.HttpProvider('https://mainnet.infura.io/<your-api-key>'));
// or
// this.web3 = new Web3(window.web3.currentProvider);
}
// コントラクト取得
public getContract(abi: any, address: string): any {
return new this.web3.eth.Contract(abi, address);
}
// ウォレット作成(ランダム)
getNewWallet(): any {
return this.web3.eth.accounts.create();
}
}
2. ehrers.jsの場合
import * as ethers from 'ethers';
declare const web3: any;
export class EthersService {
private currentProvider: any;
// 初期化
constructor() {
const providers = ethers.providers;
const network = providers.networks['mainnet'];
const web3Provider = new providers.Web3Provider(web3.currentProvider, network);
const infuraProvider = new providers.InfuraProvider(network, '<your-api-key>');
this.currentProvider = new providers.FallbackProvider([ web3Provider, infuraProvider ]);
}
// コントラクト取得
getContract(abi: any, address: string): any {
return new ethers.Contract(address, abi, this.currentProvider);
}
// ウォレット作成(ランダム)
getNewWallet(): any {
return ethers.Wallet.createRandom();
}
}
懸念点
- その他ライブラリでweb3に依存しているものが存在する場合は、ethers.jsだけでは完結できず結局web.jsが必要になるのでは。
- WebSoketモードで起動しているノードに対応していない。(issueには上がっている。)
<参考>
https://medium.com/@julien.m./what-is-an-ethereum-keystore-file-86c8c5917b97
https://security.srad.jp/story/16/02/16/0641240/