A bip39 implementation, with a collection of tools
Project description
Bip39
A Bip39 library, with a CLI and a collection of tools.
This project provides a full implementation of the Bip39 specs, along with a CLI that offers some mnemonic key management tools such as:
- generate and validate mnemonics;
- correct the last word according to the checksum (e.g. when a mnemonic is generated by rolling dices);
- transform (and restore) mnemonics, e.g. to create side-wallets hiding the original;
- hide or reveal a mnemonic in an image file, with a steganography algorithm.
For further details, please refer to the documentation folder.
For security reasons, it is highly recommended to run the CLI on an offline system, without any Internet or LAN connection.
Requirements
python 3.9+
Installation
This project is distributed on PyPI:
pip install tulliolo.bip39
Usage Examples
Here are some examples of using the library and CLI.
CLI
Generate a new 24 words mnemonic:
$ bip39-cli generate -s 24
******************
* bip39-cli v0.2 *
******************
generating a 24 words mnemonic...
generate success!
view fresh drink impulse doctor wise another smoke license collect unaware immense normal trick second owner subway bright chaos upper ribbon kite debris quote
Validate a mnemonic, fixing the checksum:
$ bip39-cli validate -f
******************
* bip39-cli v0.2 *
******************
enter a mnemonic:
₿ view fresh drink impulse doctor wise another smoke license collect unaware immense
invalid checksum | expected: 0 | obtained: c
validation success... with fixed checksum:
view fresh drink impulse doctor wise another smoke license collect unaware hybrid
Transform and restore a mnemonic with a negative (default) transformation:
$ bip39-cli transform
******************
* bip39-cli v0.2 *
******************
enter a mnemonic
₿ view fresh drink impulse doctor wise another smoke license collect unaware hybrid
applying negative transformation...
transformation success!
army permit rude miss sausage adjust wait creek learn sponsor bean mixed
$ bip39-cli transform
******************
* bip39-cli v0.2 *
******************
enter a mnemonic
₿ army permit rude miss sausage adjust wait creek learn sponsor bean mixed
applying negative transformation...
transformation success!
view fresh drink impulse doctor wise another smoke license collect unaware hybrid
Encrypt a mnemonic and hide it in an image with steganography:
$ bip39-cli steganography encode -i tests/data/test_image.jpg -o tests/data/output/
******************
* bip39-cli v0.2 *
******************
enter a mnemonic:
₿ view fresh drink impulse doctor wise another smoke license collect unaware hybrid
enter a password to encrypt the mnemonic (or leave blank):
₿
insert again...:
₿
encrypting mnemonic...
encoding image...
encoding success!
tests/data/output/test_image_horizontal_20230510-120631.png
Reveal a mnemonic from an image with steganography and decrypt it:
$ bip39-cli steganography decode -i tests/data/output/test_image_horizontal_20230510-120631.png
******************
* bip39-cli v0.2 *
******************
enter a password to decrypt the mnemonic (or leave blank):
₿
insert again...:
₿
decoding image...
decoding success!
decrypting mnemonic...
decrypting success!
view fresh drink impulse doctor wise another smoke license collect unaware hybrid
Library
Generate a 12 words mnemonic:
from tulliolo.bip39.mnemonic import Mnemonic
mnemonic = Mnemonic.generate(12)
print(" ".join(mnemonic.value))
absent deny citizen next velvet where mixture glimpse deposit sentence hat manual
Import a mnemonic and fix the checksum:
from tulliolo.bip39.mnemonic import Mnemonic
mnemonic = Mnemonic.from_value("view fresh drink impulse doctor wise another smoke license collect unaware immense", fix_checksum=True)
print(mnemonic.info)
{'entropy': 'f3eb990c391405f8c266668125b3b1b8', 'checksum': '0', 'value': {1: 'view', 2: 'fresh', 3: 'drink', 4: 'impulse', 5: 'doctor', 6: 'wise', 7: 'another', 8: 'smoke', 9: 'license', 10: 'collect', 11: 'unaware', 12: 'hybrid'}}
Generate the seed, that can be later used to generate bip32 wallets:
from tulliolo.bip39.mnemonic import Mnemonic
seed = Mnemonic.generate(24).encode(passphrase="my_optional_passphrase")
print(seed.hex())
d24027e4b7dae545b95dca96a7b8e539e0a0d7ae2ef6cd2247e346907f7b842bb93d2268ee3bd28eede481b0ddab0b44f04ed49b4a4904ee7882677dd2677ac2
Transform and restore a mnemonic with a mirror transformation:
from tulliolo.bip39.mnemonic import Mnemonic
from tulliolo.bip39.utils.transformation import Transformation
mnemonic_o = Mnemonic.from_value("view fresh drink impulse doctor wise another smoke license collect unaware hybrid")
mnemonic_t = mnemonic_o.transform(Transformation.MIRROR)
print(mnemonic_t.value)
('budget', 'hover', 'hard', 'actress', 'grid', 'canoe', 'leader', 'agree', 'order', 'luggage', 'invest', 'paddle')
mnemonic_t = mnemonic_t.transform(Transformation.MIRROR)
assert mnemonic_o == mnemonic_t
print(mnemonic_t.value)
('view', 'fresh', 'drink', 'impulse', 'doctor', 'wise', 'another', 'smoke', 'license', 'collect', 'unaware', 'hybrid')
Encrypt a mnemonic and hide it in an image with steganography:
import pathlib
from tulliolo.bip39.utils import encryption, steganography
words = "view fresh drink impulse doctor wise another smoke license collect unaware hybrid"
# encrypt words
words = encryption.encrypt(words, "my_password")
# create paths
input_file = pathlib.Path("tests/data/test_image.jpg")
output_path = pathlib.Path("tests/data/output")
# hide message
output_file = steganography.encode(words, input_file, output_path)
print(output_file)
tests/data/output/test_image_horizontal_20230513-103831.png
Reveal a mnemonic from an image with steganography and decrypt it:
import pathlib
from tulliolo.bip39.utils import encryption, steganography
# create path
input_file = pathlib.Path("tests/data/output/test_image_horizontal_20230513-103831.png")
# reveal message
message = steganography.decode(input_file)
# decrypt message
message = encryption.decrypt(message, "my_password").decode("utf-8")
print(message)
view fresh drink impulse doctor wise another smoke license collect unaware hybrid
Disclaimer
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file tulliolo.bip39-0.2.tar.gz
.
File metadata
- Download URL: tulliolo.bip39-0.2.tar.gz
- Upload date:
- Size: 645.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 16f116a1bf5b437fd96c63a05c15f66e14852f8aef806ca7f8ee4ba9b9807bf4 |
|
MD5 | 13f61626ed5aa4eed55caaed2d3d3c52 |
|
BLAKE2b-256 | 83e73d96ced4249adf9f1ead1e60f0c865ea2bf63530b09117bcd54cabf7d2d4 |
File details
Details for the file tulliolo.bip39-0.2-py3-none-any.whl
.
File metadata
- Download URL: tulliolo.bip39-0.2-py3-none-any.whl
- Upload date:
- Size: 31.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 11564efafb148676f3ef6b8ae9e19c41d5bfd70853c0c8d362d2dd38248460f3 |
|
MD5 | e0726a563dca35a581a1c35b33f84b53 |
|
BLAKE2b-256 | 2a7a344ffce297d61bdb7a3a628000f8d7c2279eebe2914ab783d3a98364efe4 |