/core-decrypt

Tool for recovering Bitcoin Core wallet passwords

Primary LanguageC++

core-decrypt

Tool for recovering Bitcoin Core wallet passwords. Requires an OpenCL device.

Note: Please test against some of the sample wallets to verify the program works properly. Each vendor has a different OpenCL implementation, and I am unable to test all of them

Usage:

core-decrypt [OPTIONS] [ENCRYPTED_MASTER_KEY] [WORD FILES ..]

--list-devices	List devices then exit
--device NUM    Use device NUM
--start NUM     Specify where in the password space to start

Reading the encrypted master key

Run the walletinfo.py script on the wallet file. The output contains the encrypted master key, number of iterations, and salt.

# python walletinfo.py wallet.dat
ec01bd09d2befa62ec34609fa2e19316063a9a688aef03494ab9a4d8ba67e24c414609b1ce5abb850002ecc0

Recovering the password

Pass the output to the core-decrypt program

# core-decrypt.exe ec01bd09d2befa62ec34609fa2e19316063a9a688aef03494ab9a4d8ba67e24c414609b1ce5abb850002ecc0  dictionary.txt

The dictionaries contain one password per line. The program will try each password until it finds the correct one or exhausts the list.

More complex passwords

Multiple dictionaries can be combined together to form complex password combinations

For example, if you know the password consists of two words and a number, you might use

# core-decrypt <encrypted key> words1.txt words2.txt 0_to_9.txt

This will try all combinations of passwords in the form,

[word from words1.txt][word from words2.txt][number]

Sample wallets

There are some sample wallets for testing. The file name of the wallet is the password.

TODO List:

  • Multi-GPU support
  • Password rules
  • Allow more performance tuning by user
  • Better word lists