From 49aafbb39a539a9bfd828d39a7177cebd669566b Mon Sep 17 00:00:00 2001 From: Emanuele Bellocchia <54482000+ebellocchia@users.noreply.github.com> Date: Sat, 4 May 2024 20:42:56 +0200 Subject: [PATCH] Add Neo to Exodus example --- examples/exodus.py | 29 +++++++++++++++++++++++++++++ examples/exodus_ed25519.py | 31 ------------------------------- 2 files changed, 29 insertions(+), 31 deletions(-) create mode 100644 examples/exodus.py delete mode 100644 examples/exodus_ed25519.py diff --git a/examples/exodus.py b/examples/exodus.py new file mode 100644 index 00000000..992a5e02 --- /dev/null +++ b/examples/exodus.py @@ -0,0 +1,29 @@ +""" +Example of keys derivation for ed25519 or nist256p1 based coins in the same way of Exodus wallet. + +Basically, Exodus always uses the secp256k1 curve to derive the BIP44 path, even even for coins that are not based on secp256k1. +Then, for coins based on other curves (e.g. Algorand, Solana, Stellar, Neo ...), it uses the last derived private key as a master key to compute the public key and address. +It's not the only wallet doing this (Atomic Wallet does the same), because in this way the developers don't have to implement other derivation schemes beside secp256k1. +""" + +from bip_utils import Bip32Slip10Secp256k1, Bip39SeedGenerator, Bip44, Bip44Coins, Bip44ConfGetter + + +# Mnemonic +mnemonic = "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about" +# Generate seed from mnemonic +seed_bytes = Bip39SeedGenerator(mnemonic).Generate() + +# Example with Solana (ed25519-based coin) and Neo (nist256p1-based coin) +for coin_type in (Bip44Coins.SOLANA, Bip44Coins.NEO): + # Get coin index from configuration + coin_idx = Bip44ConfGetter.GetConfig(coin_type).CoinIndex() + + # Derive the standard BIP44 path using secp256k1 + bip32_ctx = Bip32Slip10Secp256k1.FromSeed(seed_bytes).DerivePath(f"m/44'/{coin_idx}'/0'/0/0") + priv_key_bytes = bip32_ctx.PrivateKey().Raw().ToBytes() + + # Use the last private key as a master key, we can use Bip44 to simplify the address computation + bip44_ctx = Bip44.FromPrivateKey(priv_key_bytes, coin_type) + # Same address of Exodus + print(f"Address for {coin_type}: {bip44_ctx.PublicKey().ToAddress()}") diff --git a/examples/exodus_ed25519.py b/examples/exodus_ed25519.py deleted file mode 100644 index 9d4ffb77..00000000 --- a/examples/exodus_ed25519.py +++ /dev/null @@ -1,31 +0,0 @@ -""" -Example of keys derivation for ed25519-based coins in the same way of Exodus wallet. - -Basically, the Exodus wallet uses the secp256k1 curve to derive the complete BIP44 path for all coins, even if they are not based on the secp256k1 curve. -Then, for the coins based on the ed25519 curve (e.g. Algorand, Solana, Stellar, ...), it uses the last derived private key as a ed25519 master key to compute the public key and address. -It's not the only wallet doing this (Atomic Wallet does the same), because in this way the developers don't have to implement other derivation schemes beside secp256k1. -""" - -from bip_utils import Bip32Slip10Secp256k1, Bip39SeedGenerator, Bip44, Bip44Coins, Bip44ConfGetter - - -# Coin that we want -coin_type = Bip44Coins.SOLANA - -# Mnemonic -mnemonic = "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about" - -# Generate seed from mnemonic -seed_bytes = Bip39SeedGenerator(mnemonic).Generate() - -# Get coin index from configuration -coin_idx = Bip44ConfGetter.GetConfig(coin_type).CoinIndex() - -# Derive the standard BIP44 path using secp256k1 -bip32_ctx = Bip32Slip10Secp256k1.FromSeed(seed_bytes).DerivePath(f"m/44'/{coin_idx}'/0'/0/0") -priv_key_bytes = bip32_ctx.PrivateKey().Raw().ToBytes() - -# Use the last private key as a ed25519 master key, we can use Bip44 to simplify the address computation -bip44_ctx = Bip44.FromPrivateKey(priv_key_bytes, coin_type) -# Same address of Exodus -print(f"Address: {bip44_ctx.PublicKey().ToAddress()}")