File: //usr/local/CyberCP/lib/python3.10/site-packages/validators/crypto_addresses/bsc_address.py
"""BSC Address."""
# standard
import re
# local
from validators.utils import validator
@validator
def bsc_address(value: str, /):
    """Return whether or not given value is a valid binance smart chain address.
    Full validation is implemented for BSC addresses.
    Examples:
        >>> bsc_address('0x4e5acf9684652BEa56F2f01b7101a225Ee33d23f')
        # Output: True
        >>> bsc_address('0x4g5acf9684652BEa56F2f01b7101a225Eh33d23z')
        # Output: ValidationError(func=bsc_address, args=...)
    Args:
        value:
            BSC address string to validate.
    Returns:
        (Literal[True]): If `value` is a valid bsc address.
        (ValidationError): If `value` is an invalid bsc address.
    """
    if not value:
        return False
    if not re.fullmatch(r"0x[a-fA-F0-9]{40}", value):
        return False
    return True