A crypto-currency address inspection/validation library.
Project description
CoinAddrValidator
Maintainer
Mohammad Aghamir - Maintainer of this repository - coinaddrvalidator
Fork Maintainer
Devmons s.r.o. - Maintainer of this fork - coinaddrng
See also the list of contributors who participated in this project.
Original Maintainer
Joe Black | me@joeblack.nyc | github
Introduction
A cryptocurrency address inspection/validation library for python.
Supported currencies
- binancecoin
- bitcoin
- bitcoin-sv
- bitcoin-cash
- boscoin
- cardano
- cosmos
- dashcoin
- decred
- dogecoin
- eos
- ethereum
- ethereum-classic
- ether-zero
- groestlcoin
- horizen
- kusama
- litecoin
- neocoin
- ontology
- polkadot
- ravencoin
- ripple
- stellar
- tezos
- tronix
- vechain
- zcash
Installation
pip3 install coinaddrvalidator
Usage
>>> import coinaddrvalidator
>>> coinaddrvalidator.validate('btc', b'1BoatSLRHtKNngkdXEeobR76b53LETtpyT')
ValidationResult(name='bitcoin', ticker='btc', address=b'1BoatSLRHtKNngkdXEeobR76b53LETtpyT', valid=True, network='main', is_extended=False, address_type='address')
ValidationResult returns coin name and ticker, address, if the address is valid or not. In case network prefix bytes are defined for the checked currency, then the network is returned, too. If the coin supports that and the address is an extended key, it returns if it is valid or not. For some coins the address type can be guessed based on its format, which is returned as address_type. If there's none, 'address' is being returned as a default.
Extending
Currencies
To add a new currency, simply instantiate a new coinaddr.currency.Currency
class. It will be automatically registered.
from coinaddrvalidator import Currency
Currency('decred', ticker='dcr', validator='DecredCheck',
networks=dict(
main=(0x073f,0x071a,0x02fda926), test=(0x0f21,0x0efc,0x043587d1)),
address_types=dict(
address=(0x073f,0x0f21), ticket=(0x071a,0x0efc),
xpubkey=(0x02fda926,0x043587d1)))
To override a default currency, simply instantiate a new currency with that name.
Validators
To add a new validator, simply create a subclass of coinaddr.validation.ValidatorBase
with your own implementation that implements the coinaddr.interfaces.IValidator
interface. It will be automatically registered.
from zope.interface import implementer
from coinaddr.interfaces import IValidator
from coinaddr import ValidatorBase
@implementer(IValidator)
class NewValidator(ValidatorBase):
name = 'New'
@property
def networks(self):
return 'testing'
def validate(self):
return True
To override a default validator, simply create a new validator with that name.
Changes
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
Built Distribution
File details
Details for the file coinaddrvalidator-1.1.1.tar.gz
.
File metadata
- Download URL: coinaddrvalidator-1.1.1.tar.gz
- Upload date:
- Size: 15.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | df82ffd574fc116893ec261686f61d642dc602f5fcc41e3bf8248cc9a8bfadb4 |
|
MD5 | 1768b0ee0211a3b8837c49546d07c95c |
|
BLAKE2b-256 | e4375c6665a7ac0e52d498d477875e30e0986c704d8f0cf0fc8d70b271bf1776 |
File details
Details for the file coinaddrvalidator-1.1.1-py2.py3-none-any.whl
.
File metadata
- Download URL: coinaddrvalidator-1.1.1-py2.py3-none-any.whl
- Upload date:
- Size: 25.2 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3ebde0b260b6b192e688e951e436cc93aaa0193b58a6a807058f6859c8efc3b9 |
|
MD5 | 68bcc04b268f334fa643c2edd0819c6d |
|
BLAKE2b-256 | 00b18ad9c27da4814699918408d0e4207e172045c3a69ae56c7d2a63e55aaba6 |