The enchanted vault is a tool to manage your encrypted wallet in an airgapped environment. It is a simple cli tool that allows you to create a new wallet, get its address and sign transactions.
Generate a new random mnemonic
python enchanted_vault/run.py --generate
Generate an encrypted wallet with interactive password prompt
python enchanted_vault/run.py --initialize
or with a password as an argument
python enchanted_vault/run.py --initialize -p <your password>
python enchanted_vault/run.py --address
python enchanted_vault/run.py --sign-transaction <transaction_data_json>
or if you want to read the transaction data json from a file
python enchanted_vault/run.py --sign-transaction --input-file <inputfile>
Use --password
to provide the password as an argument and --output-file
to write the signed transaction to the given file.
All the commands can also be run using the container image (ghcr.io/doerfli/airgapped-wallet/enchanted_vault
).
Instead of python enchanted_vault/run.py
use
docker run -it ghcr.io/doerfli/airgapped-wallet/enchanted_vault:main <command>
The other arguments are the same as when running the script directly. To provide an existing wallet file (or have access to a newly created one), mount the file to the container
docker run -it -v <path to data directory>:/data ghcr.io/doerfli/airgapped-wallet/enchanted_vault:main <command>
Don't forget to log into the ghcr.io registry before pulling the image.
python forger.py
docker build -t forger .
docker run -rm forger
python enchanter.py <your password>
or
cat << EOF | python enchanter.py
<your password>
EOF
docker build -t enchanter .
docker run -rm enchanter <your password>
or
docker run -i -rm enchanter
<your password><EOF>
cat << EOF | python address_weaver.py
<your mnemonic>
EOF
or
python address_weaver.py <your mnemonic>
python address_weaver/enchanted_address_weaver.py <your encrypted key> <your password>
docker build -t address_weaver .
docker run -rm address_weaver <your mnemonic>
or
docker run -i -rm address_weaver
<your mnemonic><EOF>
Initialize the virtual environment with pipenv
pipenv shell
https://docs.ethers.org/v6/api/wordlists/
https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki
https://github.com/trezor/python-mnemonic https://eth-account.readthedocs.io/en/stable/ https://web3py.readthedocs.io/en/stable/