Skip to main content

Neo N3 Python Wallet Library with BIP-39 mnemonic support, HD wallet derivation, and complete key management

Project description

neo-n3-wallet

The Python wallet library for Neo N3 — with BIP-39 mnemonic support, HD key derivation, and full key management. Filling the gap that Rust and neon-js filled for other languages.

Aligned with Neo-CLI v3.10.0's expanded BIP-39 support (12 and 24-word phrases).

pip install neo-n3-wallet

Features

Feature Details
BIP-39 Mnemonics 12 / 15 / 18 / 21 / 24 words, 8 languages
HD Derivation BIP-32 over secp256r1 (NIST P-256), BIP-44 path m/44'/888'/0'/0/0
NEP-2 Encryption scrypt + AES-256-ECB passphrase-protected private keys
NEP-6 Wallets Save / load standard Neo wallet JSON files
WIF Wallet Import Format encode / decode
Signing secp256r1 sign & verify

Quick Start

from neo_n3_wallet import Wallet, MnemonicManager, Account, KeyPair

# --- Create a brand-new HD wallet (24-word mnemonic) ---
wallet = Wallet.create(word_count=24)
print(wallet.mnemonic)   # 24 BIP-39 words

# Derive the first account (m/44'/888'/0'/0/0)
account = wallet.derive_account(index=0)
print(account.address)   # NXxx...  Neo N3 address

# Derive 5 accounts at once
accounts = wallet.derive_accounts(count=5)

# Save as NEP-6 JSON (accounts are encrypted with the passphrase)
wallet.save("my_wallet.json", passphrase="s3cur3!")

# --- Restore a wallet from an existing mnemonic ---
wallet2 = Wallet.from_mnemonic(
    "abandon abandon abandon ... art",
    passphrase=""          # optional BIP-39 passphrase
)

# --- Load a NEP-6 file ---
loaded = Wallet.load("my_wallet.json", passphrase="s3cur3!")
print(loaded.accounts[0].address)

Mnemonic Management

from neo_n3_wallet import MnemonicManager

m = MnemonicManager()                # default: English
phrase = m.generate(24)              # 24-word mnemonic
assert m.validate(phrase)            # True

seed = m.to_seed(phrase)             # 64-byte BIP-39 seed
entropy = m.to_entropy(phrase)       # recover original entropy
restored = m.from_entropy(entropy)   # back to phrase

# Other languages
m_jp = MnemonicManager("japanese")
phrase_jp = m_jp.generate(12)

Key Pair & Accounts

from neo_n3_wallet import KeyPair, Account

# Random key pair
kp = KeyPair.generate()
print(kp.address)          # Neo N3 address
print(kp.public_key_hex)   # 33-byte compressed public key
print(kp.to_wif())         # WIF-encoded private key

# From WIF
kp2 = KeyPair.from_wif("KwdMAjGmer...")

# Sign & verify
sig = kp.sign(b"my message")
assert kp.verify(b"my message", sig)

# Account with NEP-2 encryption
acct = Account.from_private_key(bytes.fromhex("..."))
nep2 = acct.encrypt("my-passphrase")   # encrypt in-place
acct.lock()                             # wipe key from memory
acct.unlock("my-passphrase")           # restore it

HD Derivation Paths

Neo N3 uses SLIP-0044 coin type 888 and secp256r1:

m / 44' / 888' / account' / change / index
Wallet.derivation_path(account=0, change=0, index=0)
# → "m/44'/888'/0'/0/0"

Running Tests

python -m pytest tests/ -v --no-cov   # fast
python -m pytest tests/ -v            # with coverage

Project Layout

neo_n3_wallet/
├── __init__.py      public API
├── wallet.py        Wallet (HD + NEP-6)
├── account.py       Account (NEP-2 lock/unlock)
├── key_pair.py      KeyPair (sign / verify)
├── mnemonic.py      BIP-39 MnemonicManager
├── hd.py            BIP-32 derivation (secp256r1)
├── nep2.py          NEP-2 encrypt / decrypt
├── wif.py           WIF encode / decode
├── address.py       Neo N3 address utilities
├── crypto.py        secp256r1 primitives
├── constants.py     Neo N3 constants
└── exceptions.py    Custom exceptions

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

neo_n3_wallet-0.1.0.tar.gz (23.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

neo_n3_wallet-0.1.0-py3-none-any.whl (18.4 kB view details)

Uploaded Python 3

File details

Details for the file neo_n3_wallet-0.1.0.tar.gz.

File metadata

  • Download URL: neo_n3_wallet-0.1.0.tar.gz
  • Upload date:
  • Size: 23.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.6

File hashes

Hashes for neo_n3_wallet-0.1.0.tar.gz
Algorithm Hash digest
SHA256 03b55ff9e9f3c2322452e1d3da5776ed1453d8edb95ebc5590cef922371e011a
MD5 83bd147e2615d6140fd9209cc9285fbd
BLAKE2b-256 74b165514e1589c78dcc255a104123cb77408092afb11013cf5846ecdd1fc4e5

See more details on using hashes here.

File details

Details for the file neo_n3_wallet-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: neo_n3_wallet-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 18.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.6

File hashes

Hashes for neo_n3_wallet-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 149d6546a69b4cc9741136655272a1cdc50d233a9847c1c35b259f730038d097
MD5 05a7fe5cfe557a71d260415becf5f9dd
BLAKE2b-256 7e21f230ac3c087b3e3bdb8cd388228c775bf1524e2ae5d96329e9c3fddc4117

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page