A tool for attempting to recover Ethereum addresses from incorrectly input seed phrases.
- Attempts to compare an entered seed phrase against detected possible spelling errors.
- Generates accounts for each valid seed phrase variation up to a defined depth.
- Checks for accounts with any ethereum balance in that depth.
- If an account with a balance is found, the valid mnemonic is returned.
- The module is an event emitter for easy introspection into its attempt cycle.
const Guesser = require('hd-seed-phrase-guesser')
const Eth = require('ethjs')
const eth = new Eth(new Eth.HttpProvider('https://mainnet.infura.io'))
const input = ' travel funny ocean erupt srader whale mandate timber scoter escout actress elbow'
const getBalance = eth.getBalance.bind(eth)
const guesser = new Guesser({
phrase: input,
getBalance: getBalance,
})
guesser.guess()
.then((mnemonic) => {
// Successful recovery!
})
.catch((reason) => {
// Failed to recover :()
})
// Track events!
guesser.on('trying', (mnemonic) => {
// The guesser is checking balances on this mnemonic
})
One detail: You'll have to remove the line of node_modules/spell/spell.js
that references readFileSync
, since that is not available in browser.
After you npm install
, assuming you have browserify installed globally (npm install browserify -g
) you should be able to build with npm run build
.