PHP WebShell

Текущая директория: /opt/BitGoJS/modules/statics/dist/src

Просмотр файла: account.js

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.Sip10Token = exports.FiatCoin = exports.AptNFTCollection = exports.AptCoin = exports.SuiCoin = exports.XrpCoin = exports.BeraERC20Token = exports.ZkethERC20Token = exports.OpethERC20Token = exports.ArbethERC20Token = exports.PolygonERC20Token = exports.AvaxERC20Token = exports.AdaCoin = exports.SolCoin = exports.EosCoin = exports.AlgoCoin = exports.HederaToken = exports.HederaCoin = exports.StellarCoin = exports.BscCoin = exports.CeloCoin = exports.Erc20CompatibleAccountCoin = exports.TronErc20Coin = exports.Erc1155Coin = exports.Erc721Coin = exports.Erc20Coin = exports.Base58ContractAddressDefinedToken = exports.NFTCollectionIdDefinedToken = exports.ContractAddressDefinedToken = exports.GasTankAccountCoin = exports.AccountCoinToken = exports.AccountCoin = void 0;
exports.account = account;
exports.gasTankAccount = gasTankAccount;
exports.erc20 = erc20;
exports.terc20 = terc20;
exports.erc721 = erc721;
exports.terc721 = terc721;
exports.nonstandardToken = nonstandardToken;
exports.erc1155 = erc1155;
exports.terc1155 = terc1155;
exports.erc20CompatibleAccountCoin = erc20CompatibleAccountCoin;
exports.celoToken = celoToken;
exports.tceloToken = tceloToken;
exports.bscToken = bscToken;
exports.tbscToken = tbscToken;
exports.stellarToken = stellarToken;
exports.tstellarToken = tstellarToken;
exports.tronToken = tronToken;
exports.ttronToken = ttronToken;
exports.hederaCoin = hederaCoin;
exports.hederaToken = hederaToken;
exports.algoToken = algoToken;
exports.talgoToken = talgoToken;
exports.eosToken = eosToken;
exports.teosToken = teosToken;
exports.solToken = solToken;
exports.tsolToken = tsolToken;
exports.adaToken = adaToken;
exports.tadaToken = tadaToken;
exports.avaxErc20 = avaxErc20;
exports.tavaxErc20 = tavaxErc20;
exports.polygonErc20 = polygonErc20;
exports.tpolygonErc20 = tpolygonErc20;
exports.arbethErc20 = arbethErc20;
exports.tarbethErc20 = tarbethErc20;
exports.opethErc20 = opethErc20;
exports.topethErc20 = topethErc20;
exports.zkethErc20 = zkethErc20;
exports.tzkethErc20 = tzkethErc20;
exports.beraErc20 = beraErc20;
exports.tberaErc20 = tberaErc20;
exports.xrpToken = xrpToken;
exports.txrpToken = txrpToken;
exports.suiToken = suiToken;
exports.tsuiToken = tsuiToken;
exports.aptToken = aptToken;
exports.aptNFTCollection = aptNFTCollection;
exports.taptToken = taptToken;
exports.taptNFTCollection = taptNFTCollection;
exports.fiat = fiat;
exports.sip10Token = sip10Token;
exports.tsip10Token = tsip10Token;
const base_1 = require("./base");
const constants_1 = require("./constants");
const errors_1 = require("./errors");
const networks_1 = require("./networks");
/**
 * Account based coins, such as Ethereum, Stellar, or XRP.
 *
 * These types of coins maintain an "account balance" for each address on the network,
 * as opposed to the unspent transaction output model which maintains a record of all
 * "pieces" of coin which belong to an address.
 */
class AccountCoin extends base_1.BaseCoin {
    constructor(options) {
        super({
            ...options,
            kind: base_1.CoinKind.CRYPTO,
        });
        this.network = options.network;
    }
    requiredFeatures() {
        return new Set([base_1.CoinFeature.ACCOUNT_MODEL]);
    }
    disallowedFeatures() {
        return new Set([base_1.CoinFeature.UNSPENT_MODEL]);
    }
    static getFeaturesExcluding(excludedFeatures) {
        return AccountCoin.DEFAULT_FEATURES.filter((feature) => !excludedFeatures.includes(feature));
    }
}
exports.AccountCoin = AccountCoin;
AccountCoin.DEFAULT_FEATURES = [
    base_1.CoinFeature.ACCOUNT_MODEL,
    base_1.CoinFeature.REQUIRES_BIG_NUMBER,
    base_1.CoinFeature.VALUELESS_TRANSFER,
    base_1.CoinFeature.TRANSACTION_DATA,
    base_1.CoinFeature.CUSTODY,
    base_1.CoinFeature.CUSTODY_BITGO_TRUST,
    base_1.CoinFeature.CUSTODY_BITGO_MENA_FZE,
    base_1.CoinFeature.CUSTODY_BITGO_CUSTODY_MENA_FZE,
    base_1.CoinFeature.CUSTODY_BITGO_SINGAPORE,
    base_1.CoinFeature.CUSTODY_BITGO_KOREA,
    base_1.CoinFeature.CUSTODY_BITGO_EUROPE_APS,
    base_1.CoinFeature.CUSTODY_BITGO_FRANKFURT,
];
// Need to gate some high risk coin from SINGAPORE trust
AccountCoin.DEFAULT_FEATURES_EXCLUDE_SINGAPORE = AccountCoin.DEFAULT_FEATURES.filter((feature) => feature !== base_1.CoinFeature.CUSTODY_BITGO_SINGAPORE);
class AccountCoinToken extends AccountCoin {
    constructor(options) {
        super({
            ...options,
        });
    }
}
exports.AccountCoinToken = AccountCoinToken;
class GasTankAccountCoin extends AccountCoin {
    constructor(options) {
        super({
            ...options,
        });
        this.gasTankLowBalanceAlertFactor = options.gasTankLowBalanceAlertFactor;
        this.gasTankMinBalanceRecommendationFactor = options.gasTankMinBalanceRecommendationFactor;
    }
}
exports.GasTankAccountCoin = GasTankAccountCoin;
/**
 * Some blockchains support tokens which are defined by an address at which they have a smart contract deployed.
 * Examples are ERC20 tokens, and the equivalent on other chains.
 */
class ContractAddressDefinedToken extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        // valid ERC 20 contract addresses are "0x" followed by 40 lowercase hex characters
        // do not use a valid address format for generic tokens because they not have onchain addresses
        if (!options.contractAddress.match(/^0x[a-f0-9]{40}$/) && !options.features.includes(base_1.CoinFeature.GENERIC_TOKEN)) {
            throw new errors_1.InvalidContractAddressError(options.name, options.contractAddress);
        }
        this.contractAddress = options.contractAddress;
    }
}
exports.ContractAddressDefinedToken = ContractAddressDefinedToken;
/**
 * Used for blockchains that support NFT collections.
 */
class NFTCollectionIdDefinedToken extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.nftCollectionId = options.nftCollectionId;
    }
}
exports.NFTCollectionIdDefinedToken = NFTCollectionIdDefinedToken;
/**
 * ERC20 token addresses are Base58 formatted on some blockchains.
 */
class Base58ContractAddressDefinedToken extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        if (!/^[1-9A-HJ-NP-Za-km-z]{34}$/.test(options.contractAddress)) {
            throw new errors_1.InvalidContractAddressError(options.name, options.contractAddress);
        }
        this.contractAddress = options.contractAddress;
    }
}
exports.Base58ContractAddressDefinedToken = Base58ContractAddressDefinedToken;
/**
 * ERC 20 is a token standard for the Ethereum blockchain. They are similar to other account coins, but have a
 * contract address property which identifies the smart contract which defines the token.
 */
class Erc20Coin extends ContractAddressDefinedToken {
}
exports.Erc20Coin = Erc20Coin;
/**
 * ERC 721 is the non fungible token standard for the Ethereum blockchain.
 *
 * {@link https://eips.ethereum.org/EIPS/eip-721 EIP721}
 */
class Erc721Coin extends ContractAddressDefinedToken {
}
exports.Erc721Coin = Erc721Coin;
/**
 * ERC 1155 is the multi token standard for the Ethereum blockchain.
 *
 * {@link https://eips.ethereum.org/EIPS/eip-1155 EIP1155}
 */
class Erc1155Coin extends ContractAddressDefinedToken {
}
exports.Erc1155Coin = Erc1155Coin;
/**
 * The TRON blockchain supports tokens of the ERC20 standard similar to ETH ERC20 tokens.
 */
class TronErc20Coin extends Base58ContractAddressDefinedToken {
}
exports.TronErc20Coin = TronErc20Coin;
/**
 * Some blockchains have native coins which also support the ERC20 interface such as CELO.
 */
class Erc20CompatibleAccountCoin extends ContractAddressDefinedToken {
    constructor(options) {
        super({
            ...options,
            // These coins should not be classified as tokens as they are not children of other coins
            isToken: false,
        });
    }
}
exports.Erc20CompatibleAccountCoin = Erc20CompatibleAccountCoin;
/**
 * The CELO blockchain supports tokens of the ERC20 standard similar to ETH ERC20 tokens.
 */
class CeloCoin extends ContractAddressDefinedToken {
}
exports.CeloCoin = CeloCoin;
/**
 * The BSC blockchain supports tokens of the ERC20 standard similar to ETH ERC20 tokens.
 */
class BscCoin extends ContractAddressDefinedToken {
}
exports.BscCoin = BscCoin;
/**
 * The Stellar network supports tokens (non-native assets)
 * XLM is also known as the native asset.
 * Stellar tokens work similar to XLM, but the token name is determined by the chain,
 * the token code and the issuer account in the form: (t)xlm:<token>-<issuer>
 */
class StellarCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        if (options.domain !== '' && !options.domain.match(constants_1.DOMAIN_PATTERN)) {
            throw new errors_1.InvalidDomainError(options.name, options.domain);
        }
        this.domain = options.domain;
    }
}
exports.StellarCoin = StellarCoin;
/**
 * The Hedera coin needs a client set with the node account Id.
 * It's an account based coin that needs the node account ID
 * where the transaction will be sent.
 *
 */
class HederaCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.nodeAccountId = options.nodeAccountId;
    }
}
exports.HederaCoin = HederaCoin;
/**
 * The Hedera network supports tokens.
 * Hedera tokens work similar to native Hedera coin,
 * but the token is determined by the tokenId on the node
 *
 */
class HederaToken extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.nodeAccountId = options.nodeAccountId;
        this.tokenId = options.contractAddress;
        this.contractAddress = options.contractAddress;
    }
}
exports.HederaToken = HederaToken;
/**
 * The Algo network supports tokens (assets)
 * Algo tokens work similar to native ALGO coin, but the token name is determined by
 * unique asset id on the chain. Internally, BitGo uses token identifiers of the format: (t)algo:<assetId>
 *
 */
class AlgoCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
    }
}
exports.AlgoCoin = AlgoCoin;
/**
 * The Eos network supports tokens
 * Eos tokens work similar to native Eos coin, but the token name is determined by
 * the contractName on the chain.
 *
 */
class EosCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.contractName = options.contractAddress;
        this.contractAddress = options.contractAddress;
    }
}
exports.EosCoin = EosCoin;
/**
 * The Sol network supports tokens
 * Sol tokens work similar to native SOL coin, but the token name is determined by
 * the tokenAddress on the chain.
 *
 */
class SolCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.tokenAddress = options.contractAddress;
        this.contractAddress = options.contractAddress;
    }
}
exports.SolCoin = SolCoin;
/**
 * The Ada network supports tokens
 * Ada tokens are identified by their policy ID and asset name
 *
 */
class AdaCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.policyId = options.policyId;
        this.assetName = options.assetName;
    }
}
exports.AdaCoin = AdaCoin;
/**
 * The AVAX C Chain network support tokens
 * AVAX C Chain Tokens are ERC20 coins
 */
class AvaxERC20Token extends ContractAddressDefinedToken {
    constructor(options) {
        super(options);
    }
}
exports.AvaxERC20Token = AvaxERC20Token;
/**
 * The Polygon Chain network support tokens
 * Polygon Chain Tokens are ERC20 coins
 */
class PolygonERC20Token extends ContractAddressDefinedToken {
    constructor(options) {
        super(options);
    }
}
exports.PolygonERC20Token = PolygonERC20Token;
/**
 * The Arbitrum Chain network support tokens
 * Arbitrum Chain Tokens are ERC20 tokens
 */
class ArbethERC20Token extends ContractAddressDefinedToken {
    constructor(options) {
        super(options);
    }
}
exports.ArbethERC20Token = ArbethERC20Token;
/**
 * The Optimism Chain network support tokens
 * Optimism Chain Tokens are ERC20 tokens
 */
class OpethERC20Token extends ContractAddressDefinedToken {
    constructor(options) {
        super(options);
    }
}
exports.OpethERC20Token = OpethERC20Token;
/**
 * The zkSync network support tokens
 * zkSync Tokens are ERC20 tokens
 */
class ZkethERC20Token extends ContractAddressDefinedToken {
    constructor(options) {
        super(options);
    }
}
exports.ZkethERC20Token = ZkethERC20Token;
/**
 * The Bera Chain network support tokens
 * Bera Chain Tokens are ERC20 tokens
 */
class BeraERC20Token extends ContractAddressDefinedToken {
    constructor(options) {
        super(options);
    }
}
exports.BeraERC20Token = BeraERC20Token;
/**
 * The Xrp network supports tokens
 * Xrp tokens are identified by their issuer address
 * Naming format is similar to XLM
 * <network>:<token>-<issuer>
 */
class XrpCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        if (options.domain !== '' && !options.domain.match(constants_1.DOMAIN_PATTERN)) {
            throw new errors_1.InvalidDomainError(options.name, options.domain);
        }
        this.domain = options.domain;
        this.issuerAddress = options.contractAddress.split('::')[0];
        this.currencyCode = options.contractAddress.split('::')[1];
        this.contractAddress = options.contractAddress;
    }
}
exports.XrpCoin = XrpCoin;
class SuiCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.packageId = options.packageId;
        this.module = options.module;
        this.symbol = options.symbol;
        this.contractAddress = options.contractAddress;
    }
}
exports.SuiCoin = SuiCoin;
/**
 * The Apt network supports tokens
 * Apt tokens work similar to native Apt coin, but the token name is determined by
 * the tokenAddress on the chain.
 *
 */
class AptCoin extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.assetId = options.assetId;
    }
}
exports.AptCoin = AptCoin;
/**
 * The Apt network supports non-fungible tokens (Digital Asset Standard)
 * Every NFT belongs to an NFT collection.
 */
class AptNFTCollection extends NFTCollectionIdDefinedToken {
}
exports.AptNFTCollection = AptNFTCollection;
/**
 * Fiat currencies, such as USD, EUR, or YEN.
 */
class FiatCoin extends base_1.BaseCoin {
    constructor(options) {
        super({ ...options, kind: base_1.CoinKind.FIAT });
        this.network = options.network;
    }
    requiredFeatures() {
        return new Set([base_1.CoinFeature.ACCOUNT_MODEL]);
    }
    disallowedFeatures() {
        return new Set([base_1.CoinFeature.UNSPENT_MODEL]);
    }
}
exports.FiatCoin = FiatCoin;
FiatCoin.DEFAULT_FEATURES = [...AccountCoin.DEFAULT_FEATURES];
/**
 * The Stacks network supports tokens
 * Stx tokens work similar to native Stx coin, but the token name is determined by
 * the contractName on the chain.
 */
class Sip10Token extends AccountCoinToken {
    constructor(options) {
        super({
            ...options,
        });
        this.assetId = options.assetId;
    }
}
exports.Sip10Token = Sip10Token;
/**
 * Factory function for account coin instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the coin
 * @param fullName Complete human-readable name of the coin
 * @param network Network object for this coin
 * @param decimalPlaces Number of decimal places this coin supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve? The elliptic curve for this chain/token
 * @param prefix? Optional coin prefix. Defaults to empty string
 * @param suffix? Optional coin suffix. Defaults to coin name.
 * @param isToken? Whether or not this account coin is a token of another coin
 */
function account(id, name, fullName, network, decimalPlaces, asset, baseUnit, features = AccountCoin.DEFAULT_FEATURES, primaryKeyCurve = base_1.KeyCurve.Secp256k1, prefix = '', suffix = name.toUpperCase(), isToken = false) {
    return Object.freeze(new AccountCoin({
        id,
        name,
        fullName,
        network,
        prefix,
        suffix,
        baseUnit,
        features,
        decimalPlaces,
        isToken,
        asset,
        primaryKeyCurve,
    }));
}
/**
 * Factory function for gas tank account coin instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the coin
 * @param fullName Complete human-readable name of the coin
 * @param network Network object for this coin
 * @param decimalPlaces Number of decimal places this coin supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param baseUnit
 * @param features Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 * @param gasTankLowBalanceAlertFactor Low gas tank balance alert threshold = (feeEstimate x gasTankLowBalanceAlertFactor)
 * @param gasTankMinBalanceRecommendationFactor Min gas tank balance recommendation = (feeEstimate x gasTankMinBalanceRecommendationFactor)
 * @param prefix Optional coin prefix. Defaults to empty string
 * @param suffix Optional coin suffix. Defaults to coin name.
 * @param isToken Whether or not this account coin is a token of another coin
 */
function gasTankAccount(id, name, fullName, network, decimalPlaces, asset, baseUnit, features = AccountCoin.DEFAULT_FEATURES, primaryKeyCurve = base_1.KeyCurve.Secp256k1, gasTankLowBalanceAlertFactor = 2, gasTankMinBalanceRecommendationFactor = 10, prefix = '', suffix = name.toUpperCase(), isToken = false) {
    return Object.freeze(new GasTankAccountCoin({
        id,
        name,
        fullName,
        network,
        prefix,
        suffix,
        baseUnit,
        features,
        decimalPlaces,
        isToken,
        asset,
        primaryKeyCurve,
        gasTankLowBalanceAlertFactor,
        gasTankMinBalanceRecommendationFactor,
    }));
}
/**
 * Factory function for erc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Ethereum main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function erc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.BULK_TRANSACTION], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.ethereum, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new Erc20Coin({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for testnet erc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the Kovan test network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 */
function terc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.BULK_TRANSACTION], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.kovan) {
    return erc20(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network);
}
/**
 * Factory function for erc721 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param contractAddress Contract address of this token
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Ethereum main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function erc721(id, name, fullName, contractAddress, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.ethereum, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new Erc721Coin({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces: 0,
        asset: base_1.UnderlyingAsset.ERC721,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for testnet erc721 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param contractAddress Contract address of this token
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Holesky test network.
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function terc721(id, name, fullName, contractAddress, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.holesky, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return erc721(id, name, fullName, contractAddress, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for nonstandard token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param contractAddress Contract address of this token
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Ethereum main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function nonstandardToken(id, name, fullName, contractAddress, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.ethereum, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new ContractAddressDefinedToken({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces: 0,
        asset: base_1.UnderlyingAsset.NONSTANDARD,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for erc1155 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param contractAddress Contract address of this token
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Ethereum main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function erc1155(id, name, fullName, contractAddress, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.ethereum, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new Erc1155Coin({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces: 0,
        asset: base_1.UnderlyingAsset.ERC1155,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for testnet erc1155 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param contractAddress Contract address of this token
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Holesky test network.
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function terc1155(id, name, fullName, contractAddress, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.holesky, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return erc1155(id, name, fullName, contractAddress, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for ERC20-compatible account coin instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param network Network object for this coin
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function erc20CompatibleAccountCoin(id, name, fullName, network, decimalPlaces, contractAddress, asset, baseUnit, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new Erc20CompatibleAccountCoin({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: false,
        primaryKeyCurve,
        baseUnit,
    }));
}
/**
 * Factory function for celo token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to CELO main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function celoToken(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.celo, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new CeloCoin({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for testnet celo token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the testnet CELO network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 */
function tceloToken(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.celo) {
    return celoToken(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network);
}
/**
 * Factory function for celo token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to BSC main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function bscToken(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.bsc, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new BscCoin({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.BSC,
    }));
}
/**
 * Factory function for testnet bsc token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the testnet BSC network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 */
function tbscToken(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.bsc) {
    return bscToken(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network);
}
/**
 * Factory function for Stellar token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param domain Domain of the token issuer (used to access token information from the issuer's stellar.toml file)
 * See https://www.stellar.org/developers/guides/concepts/stellar-toml.html
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Stellar mainnet.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function stellarToken(id, name, fullName, decimalPlaces, asset, domain = '', features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.stellar, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new StellarCoin({
        id,
        name,
        fullName,
        decimalPlaces,
        asset,
        domain,
        features,
        prefix,
        suffix,
        network,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.XLM,
    }));
}
/**
 * Factory function for testnet Stellar token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param domain Domain of the token issuer (used to access token information from the issuer's stellar.toml file)
 * See https://www.stellar.org/developers/guides/concepts/stellar-toml.html
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Stellar testnet.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 */
function tstellarToken(id, name, fullName, decimalPlaces, asset, domain = '', features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.stellar) {
    return stellarToken(id, name, fullName, decimalPlaces, asset, domain, features, prefix, suffix, network);
}
/**
 * Factory function for tron token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to TRON main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function tronToken(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.trx, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new TronErc20Coin({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.TRX,
    }));
}
/**
 * Factory function for testnet tron token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the testnet TRON network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function ttronToken(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.trx, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return tronToken(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for Hedera coin instances
 *
 * @param id uuid v4
 * @param name unique identifier of the coin
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param nodeAccountId node account Id from which the transaction will be sent
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Hedera mainnet.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function hederaCoin(id, name, fullName, network, decimalPlaces, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new HederaCoin({
        id,
        name,
        fullName,
        decimalPlaces,
        asset,
        nodeAccountId: constants_1.HEDERA_NODE_ACCCOUNT_ID,
        features,
        prefix,
        suffix,
        network,
        isToken: false,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.HBAR,
    }));
}
/**
 * Factory function for Hedera token instances
 *
 * @param id uuid v4
 * @param name unique identifier of the coin
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param nodeAccountId node account Id from which the transaction will be sent
 * @param tokenId The unique identifier of this token
 * @param contractAddress Contract address of this token, same as tokenId
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Hedera mainnet.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function hederaToken(id, name, fullName, network, decimalPlaces, asset, tokenId, contractAddress, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new HederaToken({
        id,
        name,
        fullName,
        decimalPlaces,
        asset,
        nodeAccountId: constants_1.HEDERA_NODE_ACCCOUNT_ID,
        tokenId,
        contractAddress,
        features,
        prefix,
        suffix,
        network,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.HBAR,
    }));
}
/**
 * Factory function for ALGO token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token

 * @param alias (optional) alternative identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * See https://developer.algorand.org/docs/reference/transactions/#url
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to ALGO mainnet.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function algoToken(id, name, alias, fullName, decimalPlaces, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.algorand, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new AlgoCoin({
        id,
        name,
        alias,
        fullName,
        decimalPlaces,
        asset,
        features,
        prefix,
        suffix,
        network,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ALGO,
    }));
}
/**
 * Factory function for testnet ALGO token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param alias (optional) alternative identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * See https://developer.algorand.org/docs/reference/transactions/#url
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Algo testnet.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 */
function talgoToken(id, name, alias, fullName, decimalPlaces, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.algorand) {
    return algoToken(id, name, alias, fullName, decimalPlaces, asset, features, prefix, suffix, network);
}
/**
 * Factory function for eos token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractName Contract address of this token
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to EOS main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function eosToken(id, name, fullName, decimalPlaces, contractName, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.eos, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new EosCoin({
        id,
        name,
        fullName,
        network,
        contractName,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.EOS,
    }));
}
/**
 * Factory function for testnet eos token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractName Contract address of this token
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the testnet EOS network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 */
function teosToken(id, name, fullName, decimalPlaces, contractName, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.eos) {
    return eosToken(id, name, fullName, decimalPlaces, contractName, contractAddress, asset, features, prefix, suffix, network);
}
/**
 * Factory function for sol token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param tokenAddress Token address of this token
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to SOL main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function solToken(id, name, fullName, decimalPlaces, tokenAddress, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.REQUIRES_RESERVE], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.sol, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new SolCoin({
        id,
        name,
        fullName,
        network,
        tokenAddress,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.SOL,
    }));
}
/**
 * Factory function for testnet solana token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param tokenAddress Token address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the testnet Solana network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`
 */
function tsolToken(id, name, fullName, decimalPlaces, tokenAddress, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.REQUIRES_RESERVE], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.sol) {
    return solToken(id, name, fullName, decimalPlaces, tokenAddress, contractAddress, asset, features, prefix, suffix, network);
}
/**
 * Factory function for ada token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param tokenSymbol Token symbol of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Cardano main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function adaToken(id, name, fullName, decimalPlaces, policyId, assetName, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.REQUIRES_RESERVE], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.ada, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new AdaCoin({
        id,
        name,
        fullName,
        network,
        policyId,
        assetName,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ADA,
    }));
}
/**
 * Factory function for testnet cardano token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param tokenSymbol Token symbol of this token i.e: AUSD
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the testnet Cardano network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`
 */
function tadaToken(id, name, fullName, decimalPlaces, policyId, assetName, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.REQUIRES_RESERVE], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.ada) {
    return adaToken(id, name, fullName, decimalPlaces, policyId, assetName, asset, features, prefix, suffix, network);
}
/**
 * Factory function for avaxErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to AvalancheC main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function avaxErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.avalancheC, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new AvaxERC20Token({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for testnet avaxErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the AvalancheC test network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function tavaxErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.avalancheC, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return avaxErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for polygonErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Polygon main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function polygonErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.EIP1559], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.polygon, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new PolygonERC20Token({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for Amoy testnet polygonErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the Polygon test network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function tpolygonErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.polygon, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return polygonErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for arbethErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Arbitrum main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function arbethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.EIP1559], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.arbitrum, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new ArbethERC20Token({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for Arbitrum Sepolia testnet arbethErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the Arbitrum test network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function tarbethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.arbitrum, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return arbethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for opethErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Optimism main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function opethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.EIP1559, base_1.CoinFeature.BULK_TRANSACTION], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.optimism, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new OpethERC20Token({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for Optimism Sepolia testnet opethErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the Optimism test network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function topethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.BULK_TRANSACTION], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.optimism, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return opethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for zkethErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to zkSync mainnet network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function zkethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.zkSync, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new ZkethERC20Token({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for zkSync Sepolia testnet zkethErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the zkSync sepolia test network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function tzkethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.zkSync, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return zkethErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for beraErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to bera mainnet network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function beraErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = [...AccountCoin.DEFAULT_FEATURES, base_1.CoinFeature.EIP1559], prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.bera, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new BeraERC20Token({
        id,
        name,
        fullName,
        network,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.ETH,
    }));
}
/**
 * Factory function for zkSync Sepolia testnet beraErc20 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param contractAddress Contract address of this token
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the bera test network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function tberaErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.bera, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return beraErc20(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for xrp token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param issuerAddress: The address of the issuer of the token,
 * @param currencyCode The token symbol. Example: USD, BTC, ETH, etc.
 * @param contractAddress Contract address of this token formed with `issuerAddress::currencyCode`
 * @param domain? the domain of the issuer of the token,
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Cardano main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function xrpToken(id, name, fullName, decimalPlaces, issuerAddress, currencyCode, contractAddress, domain = '', asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.xrp, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new XrpCoin({
        id,
        name,
        fullName,
        network,
        issuerAddress,
        currencyCode,
        contractAddress,
        domain,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.XRP,
    }));
}
/**
 * Factory function for testnet cardano token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param issuerAddress: The address of the issuer of the token,
 * @param currencyCode The token symbol. Example: USD, BTC, ETH, etc.
 * @param contractAddress Contract address of this token formed with `issuerAddress::currencyCode`
 * @param domain? the domain of the issuer of the token,
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the testnet Cardano network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 */
function txrpToken(id, name, fullName, decimalPlaces, issuerAddress, currencyCode, contractAddress, domain = '', asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.xrp) {
    return xrpToken(id, name, fullName, decimalPlaces, issuerAddress, currencyCode, contractAddress, domain, asset, features, prefix, suffix, network);
}
/**
 * Factory function for sui token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param packageId PackageId of this token
 * @param module The module of the package with id `packageId`
 * @param symbol Identifies the coin defined in the module `module` of the package with id `packageId`
 * @param contractAddress Contract address of this token formed with `packageId::module::symbol`
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to SUI main network.
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function suiToken(id, name, fullName, decimalPlaces, packageId, module, symbol, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.sui, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new SuiCoin({
        id,
        name,
        fullName,
        network,
        packageId,
        module,
        symbol,
        contractAddress,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.SUI,
    }));
}
/**
 * Factory function for testnet sui token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param packageId PackageId of this token
 * @param module The module of the package with id `packageId`
 * @param symbol Identifies the coin defined in the module `module` of the package with id `packageId`
 * @param contractAddress Contract address of this token formed with `packageId::module::symbol`
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to SUI test network.
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function tsuiToken(id, name, fullName, decimalPlaces, packageId, module, symbol, contractAddress, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.sui, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return suiToken(id, name, fullName, decimalPlaces, packageId, module, symbol, contractAddress, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for apt token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param assetId Asset Id of this token i.e. the unique identifier of the token for all tokens - fungible, non-fungible and legacy
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix Optional token prefix. Defaults to empty string
 * @param suffix Optional token suffix. Defaults to token name.
 * @param network Optional token network. Defaults to APT main network.
 * @param features Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function aptToken(id, name, fullName, decimalPlaces, assetId, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.apt, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new AptCoin({
        id,
        name,
        fullName,
        network,
        assetId,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.APT,
    }));
}
/**
 * Factory function for Apt NFT collections.
 *
 * @param id uuid v4
 * @param name unique identifier of the NFT collection
 * @param fullName Complete human-readable name of the NFT collection
 * @param nftCollectionId collection ID of the non-fungible tokens (NFTs)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix Optional token prefix. Defaults to empty string
 * @param suffix Optional token suffix. Defaults to token name.
 * @param network Optional token network. Defaults to APT main network.
 * @param features Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function aptNFTCollection(id, name, fullName, nftCollectionId, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.apt, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return Object.freeze(new AptNFTCollection({
        id,
        name,
        fullName,
        network,
        nftCollectionId,
        prefix,
        suffix,
        features,
        decimalPlaces: 0,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.APT,
    }));
}
/**
 * Factory function for testnet apt token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param assetId Asset Id of this token i.e. the unique identifier of the token for all tokens - fungible, non-fungible and legacy
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix Optional token prefix. Defaults to empty string
 * @param suffix Optional token suffix. Defaults to token name.
 * @param network Optional token network. Defaults to the testnet APT network.
 * @param features Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function taptToken(id, name, fullName, decimalPlaces, assetId, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.apt, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return aptToken(id, name, fullName, decimalPlaces, assetId, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for testnet Apt NFT collections.
 *
 * @param id uuid v4
 * @param name unique identifier of the NFT collection
 * @param fullName Complete human-readable name of the NFT collection
 * @param nftCollectionId collection ID of the non-fungible tokens (NFTs)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix Optional token prefix. Defaults to empty string
 * @param suffix Optional token suffix. Defaults to token name.
 * @param network Optional token network. Defaults to APT test network.
 * @param features Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function taptNFTCollection(id, name, fullName, nftCollectionId, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = 't', suffix = name.toUpperCase(), network = networks_1.Networks.test.apt, primaryKeyCurve = base_1.KeyCurve.Ed25519) {
    return aptNFTCollection(id, name, fullName, nftCollectionId, asset, features, prefix, suffix, network, primaryKeyCurve);
}
/**
 * Factory function for fiat coin instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the coin, should start with 'fiat' or 'tfiat' followed by the 3-char ISO-4217 alphabetical code
 * @param fullName Complete human-readable name of the coin
 * @param network Network object for this coin
 * @param decimalPlaces Number of decimal places this coin supports (divisibility exponent)
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `FiatCoin`
 * @param primaryKeyCurve? The elliptic curve for this chain/token
 * @param prefix? Optional coin prefix. Defaults to empty string
 * @param suffix? Optional coin suffix. Defaults to coin name.
 * @param isToken? Whether or not this coin is a token of another coin
 */
function fiat(id, name, fullName, network, decimalPlaces, asset, features = FiatCoin.DEFAULT_FEATURES, primaryKeyCurve = base_1.KeyCurve.Secp256k1, prefix = '', suffix = name.toUpperCase(), isToken = false) {
    return Object.freeze(new FiatCoin({
        id,
        name,
        fullName,
        network,
        prefix,
        suffix,
        features,
        decimalPlaces,
        isToken,
        asset,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.FIAT,
    }));
}
/**
 * Factory function for sip10 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param assetId A unique identifier for a token, which is in the form of contractAddress.contractName::tokenName
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to Stacks main network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 * @param primaryKeyCurve The elliptic curve for this chain/token
 */
function sip10Token(id, name, fullName, decimalPlaces, assetId, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.main.stx, primaryKeyCurve = base_1.KeyCurve.Secp256k1) {
    return Object.freeze(new Sip10Token({
        id,
        name,
        fullName,
        network,
        assetId,
        prefix,
        suffix,
        features,
        decimalPlaces,
        asset,
        isToken: true,
        primaryKeyCurve,
        baseUnit: base_1.BaseUnit.STX,
    }));
}
/**
 * Factory function for testnet sip10 token instances.
 *
 * @param id uuid v4
 * @param name unique identifier of the token
 * @param fullName Complete human-readable name of the token
 * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)
 * @param assetId A unique identifier for a token, which is in the form of contractAddress.contractName::tokenName
 * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.
 * @param prefix? Optional token prefix. Defaults to empty string
 * @param suffix? Optional token suffix. Defaults to token name.
 * @param network? Optional token network. Defaults to the testnet Stacks network.
 * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`
 */
function tsip10Token(id, name, fullName, decimalPlaces, assetId, asset, features = AccountCoin.DEFAULT_FEATURES, prefix = '', suffix = name.toUpperCase(), network = networks_1.Networks.test.stx) {
    return sip10Token(id, name, fullName, decimalPlaces, assetId, asset, features, prefix, suffix, network);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"account.js","sourceRoot":"","sources":["../../src/account.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin, BaseUnit, CoinFeature, CoinKind, KeyCurve, UnderlyingAsset } from './base';\nimport { DOMAIN_PATTERN, HEDERA_NODE_ACCCOUNT_ID } from './constants';\nimport { InvalidContractAddressError, InvalidDomainError } from './errors';\nimport { AccountNetwork, BaseNetwork, EthereumNetwork, Networks, TronNetwork } from './networks';\n\nexport interface AccountConstructorOptions {\n  id: string;\n  fullName: string;\n  name: string;\n  alias?: string;\n  network: AccountNetwork;\n  asset: UnderlyingAsset;\n  baseUnit: BaseUnit;\n  features: CoinFeature[];\n  decimalPlaces: number;\n  isToken: boolean;\n  prefix?: string;\n  suffix?: string;\n  primaryKeyCurve: KeyCurve;\n}\n\n/**\n * Account based coins, such as Ethereum, Stellar, or XRP.\n *\n * These types of coins maintain an \"account balance\" for each address on the network,\n * as opposed to the unspent transaction output model which maintains a record of all\n * \"pieces\" of coin which belong to an address.\n */\nexport class AccountCoin extends BaseCoin {\n  public static readonly DEFAULT_FEATURES = [\n    CoinFeature.ACCOUNT_MODEL,\n    CoinFeature.REQUIRES_BIG_NUMBER,\n    CoinFeature.VALUELESS_TRANSFER,\n    CoinFeature.TRANSACTION_DATA,\n    CoinFeature.CUSTODY,\n    CoinFeature.CUSTODY_BITGO_TRUST,\n    CoinFeature.CUSTODY_BITGO_MENA_FZE,\n    CoinFeature.CUSTODY_BITGO_CUSTODY_MENA_FZE,\n    CoinFeature.CUSTODY_BITGO_SINGAPORE,\n    CoinFeature.CUSTODY_BITGO_KOREA,\n    CoinFeature.CUSTODY_BITGO_EUROPE_APS,\n    CoinFeature.CUSTODY_BITGO_FRANKFURT,\n  ];\n\n  // Need to gate some high risk coin from SINGAPORE trust\n  public static readonly DEFAULT_FEATURES_EXCLUDE_SINGAPORE = AccountCoin.DEFAULT_FEATURES.filter(\n    (feature) => feature !== CoinFeature.CUSTODY_BITGO_SINGAPORE\n  );\n\n  public readonly network: AccountNetwork;\n\n  constructor(options: AccountConstructorOptions) {\n    super({\n      ...options,\n      kind: CoinKind.CRYPTO,\n    });\n\n    this.network = options.network;\n  }\n\n  protected requiredFeatures(): Set<CoinFeature> {\n    return new Set<CoinFeature>([CoinFeature.ACCOUNT_MODEL]);\n  }\n\n  protected disallowedFeatures(): Set<CoinFeature> {\n    return new Set<CoinFeature>([CoinFeature.UNSPENT_MODEL]);\n  }\n\n  public static getFeaturesExcluding(excludedFeatures: CoinFeature[]): CoinFeature[] {\n    return AccountCoin.DEFAULT_FEATURES.filter((feature) => !excludedFeatures.includes(feature));\n  }\n}\n\nexport interface GasTankAccountConstructorOptions extends AccountConstructorOptions {\n  // low gas tank balance alert threshold is calculated as (feeEstimate x gasTankLowBalanceAlertFactor)\n  gasTankLowBalanceAlertFactor: number;\n  // min gas tank balance recommendation is calculated as (feeEstimate x gasTankMinBalanceRecommendationFactor)\n  gasTankMinBalanceRecommendationFactor: number;\n}\n\nexport interface Erc20ConstructorOptions extends AccountConstructorOptions {\n  contractAddress: string;\n}\n\nexport interface NFTCollectionIdConstructorOptions extends AccountConstructorOptions {\n  nftCollectionId: string;\n}\n\nexport interface StellarCoinConstructorOptions extends AccountConstructorOptions {\n  domain: string;\n}\n\nexport interface HederaCoinConstructorOptions extends AccountConstructorOptions {\n  nodeAccountId: string;\n}\n\nexport interface HederaTokenConstructorOptions extends AccountConstructorOptions {\n  nodeAccountId: string;\n  tokenId: string;\n  contractAddress: string;\n}\n\nexport interface EosCoinConstructorOptions extends AccountConstructorOptions {\n  contractName: string;\n  contractAddress: string;\n}\n\nexport interface SolCoinConstructorOptions extends AccountConstructorOptions {\n  tokenAddress: string;\n  contractAddress: string;\n}\n\nexport interface AdaCoinConstructorOptions extends AccountConstructorOptions {\n  policyId: string;\n  assetName: string;\n}\n\nexport interface XrpCoinConstructorOptions extends AccountConstructorOptions {\n  issuerAddress: string;\n  currencyCode: string;\n  domain: string;\n  contractAddress: string;\n}\n\nexport interface SuiCoinConstructorOptions extends AccountConstructorOptions {\n  packageId: string;\n  module: string;\n  symbol: string;\n  contractAddress: string;\n}\n\nexport interface AptCoinConstructorOptions extends AccountConstructorOptions {\n  assetId: string;\n}\n\ntype FiatCoinName = `fiat${string}` | `tfiat${string}`;\nexport interface FiatCoinConstructorOptions extends AccountConstructorOptions {\n  name: FiatCoinName;\n}\n\nexport interface Sip10TokenConstructorOptions extends AccountConstructorOptions {\n  assetId: string;\n}\n\nexport interface ContractAddress extends String {\n  __contractaddress_phantom__: never;\n}\n\nexport class AccountCoinToken extends AccountCoin {\n  constructor(options: AccountConstructorOptions) {\n    super({\n      ...options,\n    });\n  }\n}\n\nexport class GasTankAccountCoin extends AccountCoin {\n  public gasTankLowBalanceAlertFactor: number;\n  public gasTankMinBalanceRecommendationFactor: number;\n  constructor(options: GasTankAccountConstructorOptions) {\n    super({\n      ...options,\n    });\n    this.gasTankLowBalanceAlertFactor = options.gasTankLowBalanceAlertFactor;\n    this.gasTankMinBalanceRecommendationFactor = options.gasTankMinBalanceRecommendationFactor;\n  }\n}\n\n/**\n * Some blockchains support tokens which are defined by an address at which they have a smart contract deployed.\n * Examples are ERC20 tokens, and the equivalent on other chains.\n */\nexport class ContractAddressDefinedToken extends AccountCoinToken {\n  public contractAddress: ContractAddress;\n\n  constructor(options: Erc20ConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    // valid ERC 20 contract addresses are \"0x\" followed by 40 lowercase hex characters\n    // do not use a valid address format for generic tokens because they not have onchain addresses\n    if (!options.contractAddress.match(/^0x[a-f0-9]{40}$/) && !options.features.includes(CoinFeature.GENERIC_TOKEN)) {\n      throw new InvalidContractAddressError(options.name, options.contractAddress);\n    }\n\n    this.contractAddress = options.contractAddress as unknown as ContractAddress;\n  }\n}\n\n/**\n * Used for blockchains that support NFT collections.\n */\nexport class NFTCollectionIdDefinedToken extends AccountCoinToken {\n  public nftCollectionId: string;\n\n  constructor(options: NFTCollectionIdConstructorOptions) {\n    super({\n      ...options,\n    });\n    this.nftCollectionId = options.nftCollectionId;\n  }\n}\n\n/**\n * ERC20 token addresses are Base58 formatted on some blockchains.\n */\nexport class Base58ContractAddressDefinedToken extends AccountCoinToken {\n  public contractAddress: ContractAddress;\n\n  constructor(options: Erc20ConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    if (!/^[1-9A-HJ-NP-Za-km-z]{34}$/.test(options.contractAddress)) {\n      throw new InvalidContractAddressError(options.name, options.contractAddress);\n    }\n\n    this.contractAddress = options.contractAddress as unknown as ContractAddress;\n  }\n}\n\n/**\n * ERC 20 is a token standard for the Ethereum blockchain. They are similar to other account coins, but have a\n * contract address property which identifies the smart contract which defines the token.\n */\nexport class Erc20Coin extends ContractAddressDefinedToken {}\n\n/**\n * ERC 721 is the non fungible token standard for the Ethereum blockchain.\n *\n * {@link https://eips.ethereum.org/EIPS/eip-721 EIP721}\n */\nexport class Erc721Coin extends ContractAddressDefinedToken {}\n\n/**\n * ERC 1155 is the multi token standard for the Ethereum blockchain.\n *\n * {@link https://eips.ethereum.org/EIPS/eip-1155 EIP1155}\n */\nexport class Erc1155Coin extends ContractAddressDefinedToken {}\n\n/**\n * The TRON blockchain supports tokens of the ERC20 standard similar to ETH ERC20 tokens.\n */\nexport class TronErc20Coin extends Base58ContractAddressDefinedToken {}\n\n/**\n * Some blockchains have native coins which also support the ERC20 interface such as CELO.\n */\nexport class Erc20CompatibleAccountCoin extends ContractAddressDefinedToken {\n  constructor(options: Erc20ConstructorOptions) {\n    super({\n      ...options,\n      // These coins should not be classified as tokens as they are not children of other coins\n      isToken: false,\n    });\n  }\n}\n\n/**\n * The CELO blockchain supports tokens of the ERC20 standard similar to ETH ERC20 tokens.\n */\nexport class CeloCoin extends ContractAddressDefinedToken {}\n\n/**\n * The BSC blockchain supports tokens of the ERC20 standard similar to ETH ERC20 tokens.\n */\nexport class BscCoin extends ContractAddressDefinedToken {}\n\n/**\n * The Stellar network supports tokens (non-native assets)\n * XLM is also known as the native asset.\n * Stellar tokens work similar to XLM, but the token name is determined by the chain,\n * the token code and the issuer account in the form: (t)xlm:<token>-<issuer>\n */\nexport class StellarCoin extends AccountCoinToken {\n  public domain: string;\n\n  constructor(options: StellarCoinConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    if (options.domain !== '' && !options.domain.match(DOMAIN_PATTERN)) {\n      throw new InvalidDomainError(options.name, options.domain);\n    }\n\n    this.domain = options.domain as string;\n  }\n}\n\n/**\n * The Hedera coin needs a client set with the node account Id.\n * It's an account based coin that needs the node account ID\n * where the transaction will be sent.\n *\n */\nexport class HederaCoin extends AccountCoinToken {\n  public nodeAccountId: string;\n\n  constructor(options: HederaCoinConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    this.nodeAccountId = options.nodeAccountId;\n  }\n}\n\n/**\n * The Hedera network supports tokens.\n * Hedera tokens work similar to native Hedera coin,\n * but the token is determined by the tokenId on the node\n *\n */\nexport class HederaToken extends AccountCoinToken {\n  public nodeAccountId: string;\n  public tokenId: string;\n  public contractAddress: string;\n\n  constructor(options: HederaTokenConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    this.nodeAccountId = options.nodeAccountId;\n    this.tokenId = options.contractAddress;\n    this.contractAddress = options.contractAddress;\n  }\n}\n\n/**\n * The Algo network supports tokens (assets)\n * Algo tokens work similar to native ALGO coin, but the token name is determined by\n * unique asset id on the chain. Internally, BitGo uses token identifiers of the format: (t)algo:<assetId>\n *\n */\nexport class AlgoCoin extends AccountCoinToken {\n  constructor(options: AccountConstructorOptions) {\n    super({\n      ...options,\n    });\n  }\n}\n\n/**\n * The Eos network supports tokens\n * Eos tokens work similar to native Eos coin, but the token name is determined by\n * the contractName on the chain.\n *\n */\nexport class EosCoin extends AccountCoinToken {\n  public contractName: string;\n  public contractAddress: string;\n  constructor(options: EosCoinConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    this.contractName = options.contractAddress;\n    this.contractAddress = options.contractAddress;\n  }\n}\n\n/**\n * The Sol network supports tokens\n * Sol tokens work similar to native SOL coin, but the token name is determined by\n * the tokenAddress on the chain.\n *\n */\nexport class SolCoin extends AccountCoinToken {\n  public tokenAddress: string;\n  public contractAddress: string;\n  constructor(options: SolCoinConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    this.tokenAddress = options.contractAddress;\n    this.contractAddress = options.contractAddress;\n  }\n}\n\n/**\n * The Ada network supports tokens\n * Ada tokens are identified by their policy ID and asset name\n *\n */\nexport class AdaCoin extends AccountCoinToken {\n  public policyId: string;\n  public assetName: string;\n  constructor(options: AdaCoinConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    this.policyId = options.policyId;\n    this.assetName = options.assetName;\n  }\n}\n\n/**\n * The AVAX C Chain network support tokens\n * AVAX C Chain Tokens are ERC20 coins\n */\nexport class AvaxERC20Token extends ContractAddressDefinedToken {\n  constructor(options: Erc20ConstructorOptions) {\n    super(options);\n  }\n}\n\n/**\n * The Polygon Chain network support tokens\n * Polygon Chain Tokens are ERC20 coins\n */\nexport class PolygonERC20Token extends ContractAddressDefinedToken {\n  constructor(options: Erc20ConstructorOptions) {\n    super(options);\n  }\n}\n\n/**\n * The Arbitrum Chain network support tokens\n * Arbitrum Chain Tokens are ERC20 tokens\n */\nexport class ArbethERC20Token extends ContractAddressDefinedToken {\n  constructor(options: Erc20ConstructorOptions) {\n    super(options);\n  }\n}\n\n/**\n * The Optimism Chain network support tokens\n * Optimism Chain Tokens are ERC20 tokens\n */\nexport class OpethERC20Token extends ContractAddressDefinedToken {\n  constructor(options: Erc20ConstructorOptions) {\n    super(options);\n  }\n}\n\n/**\n * The zkSync network support tokens\n * zkSync Tokens are ERC20 tokens\n */\nexport class ZkethERC20Token extends ContractAddressDefinedToken {\n  constructor(options: Erc20ConstructorOptions) {\n    super(options);\n  }\n}\n\n/**\n * The Bera Chain network support tokens\n * Bera Chain Tokens are ERC20 tokens\n */\nexport class BeraERC20Token extends ContractAddressDefinedToken {\n  constructor(options: Erc20ConstructorOptions) {\n    super(options);\n  }\n}\n\n/**\n * The Xrp network supports tokens\n * Xrp tokens are identified by their issuer address\n * Naming format is similar to XLM\n * <network>:<token>-<issuer>\n */\nexport class XrpCoin extends AccountCoinToken {\n  public issuerAddress: string;\n  public currencyCode: string;\n  public domain: string;\n  public contractAddress: string;\n  constructor(options: XrpCoinConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    if (options.domain !== '' && !options.domain.match(DOMAIN_PATTERN)) {\n      throw new InvalidDomainError(options.name, options.domain);\n    }\n\n    this.domain = options.domain as string;\n    this.issuerAddress = options.contractAddress.split('::')[0];\n    this.currencyCode = options.contractAddress.split('::')[1];\n    this.contractAddress = options.contractAddress;\n  }\n}\n\nexport class SuiCoin extends AccountCoinToken {\n  public packageId: string;\n  public module: string;\n  public symbol: string;\n  public contractAddress: string;\n\n  constructor(options: SuiCoinConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    this.packageId = options.packageId;\n    this.module = options.module;\n    this.symbol = options.symbol;\n    this.contractAddress = options.contractAddress;\n  }\n}\n\n/**\n * The Apt network supports tokens\n * Apt tokens work similar to native Apt coin, but the token name is determined by\n * the tokenAddress on the chain.\n *\n */\nexport class AptCoin extends AccountCoinToken {\n  public assetId: string;\n  constructor(options: AptCoinConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    this.assetId = options.assetId;\n  }\n}\n\n/**\n * The Apt network supports non-fungible tokens (Digital Asset Standard)\n * Every NFT belongs to an NFT collection.\n */\nexport class AptNFTCollection extends NFTCollectionIdDefinedToken {}\n\n/**\n * Fiat currencies, such as USD, EUR, or YEN.\n */\nexport class FiatCoin extends BaseCoin {\n  public static readonly DEFAULT_FEATURES = [...AccountCoin.DEFAULT_FEATURES];\n\n  public readonly network: BaseNetwork;\n\n  constructor(options: FiatCoinConstructorOptions) {\n    super({ ...options, kind: CoinKind.FIAT });\n\n    this.network = options.network;\n  }\n\n  protected requiredFeatures(): Set<CoinFeature> {\n    return new Set<CoinFeature>([CoinFeature.ACCOUNT_MODEL]);\n  }\n\n  protected disallowedFeatures(): Set<CoinFeature> {\n    return new Set<CoinFeature>([CoinFeature.UNSPENT_MODEL]);\n  }\n}\n\n/**\n * The Stacks network supports tokens\n * Stx tokens work similar to native Stx coin, but the token name is determined by\n * the contractName on the chain.\n */\nexport class Sip10Token extends AccountCoinToken {\n  public assetId: string;\n  constructor(options: Sip10TokenConstructorOptions) {\n    super({\n      ...options,\n    });\n\n    this.assetId = options.assetId;\n  }\n}\n\n/**\n * Factory function for account coin instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the coin\n * @param fullName Complete human-readable name of the coin\n * @param network Network object for this coin\n * @param decimalPlaces Number of decimal places this coin supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve? The elliptic curve for this chain/token\n * @param prefix? Optional coin prefix. Defaults to empty string\n * @param suffix? Optional coin suffix. Defaults to coin name.\n * @param isToken? Whether or not this account coin is a token of another coin\n */\nexport function account(\n  id: string,\n  name: string,\n  fullName: string,\n  network: AccountNetwork,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  baseUnit: BaseUnit,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  isToken = false\n) {\n  return Object.freeze(\n    new AccountCoin({\n      id,\n      name,\n      fullName,\n      network,\n      prefix,\n      suffix,\n      baseUnit,\n      features,\n      decimalPlaces,\n      isToken,\n      asset,\n      primaryKeyCurve,\n    })\n  );\n}\n\n/**\n * Factory function for gas tank account coin instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the coin\n * @param fullName Complete human-readable name of the coin\n * @param network Network object for this coin\n * @param decimalPlaces Number of decimal places this coin supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param baseUnit\n * @param features Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n * @param gasTankLowBalanceAlertFactor Low gas tank balance alert threshold = (feeEstimate x gasTankLowBalanceAlertFactor)\n * @param gasTankMinBalanceRecommendationFactor Min gas tank balance recommendation = (feeEstimate x gasTankMinBalanceRecommendationFactor)\n * @param prefix Optional coin prefix. Defaults to empty string\n * @param suffix Optional coin suffix. Defaults to coin name.\n * @param isToken Whether or not this account coin is a token of another coin\n */\nexport function gasTankAccount(\n  id: string,\n  name: string,\n  fullName: string,\n  network: AccountNetwork,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  baseUnit: BaseUnit,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1,\n  gasTankLowBalanceAlertFactor = 2,\n  gasTankMinBalanceRecommendationFactor = 10,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  isToken = false\n) {\n  return Object.freeze(\n    new GasTankAccountCoin({\n      id,\n      name,\n      fullName,\n      network,\n      prefix,\n      suffix,\n      baseUnit,\n      features,\n      decimalPlaces,\n      isToken,\n      asset,\n      primaryKeyCurve,\n      gasTankLowBalanceAlertFactor,\n      gasTankMinBalanceRecommendationFactor,\n    })\n  );\n}\n\n/**\n * Factory function for erc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Ethereum main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function erc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.BULK_TRANSACTION],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.main.ethereum,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new Erc20Coin({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for testnet erc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the Kovan test network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n */\nexport function terc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.BULK_TRANSACTION],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.test.kovan\n) {\n  return erc20(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network);\n}\n\n/**\n * Factory function for erc721 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param contractAddress Contract address of this token\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Ethereum main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function erc721(\n  id: string,\n  name: string,\n  fullName: string,\n  contractAddress: string,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.main.ethereum,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new Erc721Coin({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces: 0,\n      asset: UnderlyingAsset.ERC721,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for testnet erc721 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param contractAddress Contract address of this token\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Holesky test network.\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function terc721(\n  id: string,\n  name: string,\n  fullName: string,\n  contractAddress: string,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.test.holesky,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return erc721(id, name, fullName, contractAddress, features, prefix, suffix, network, primaryKeyCurve);\n}\n\n/**\n * Factory function for nonstandard token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param contractAddress Contract address of this token\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Ethereum main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function nonstandardToken(\n  id: string,\n  name: string,\n  fullName: string,\n  contractAddress: string,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.main.ethereum,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new ContractAddressDefinedToken({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces: 0,\n      asset: UnderlyingAsset.NONSTANDARD,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for erc1155 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param contractAddress Contract address of this token\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Ethereum main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function erc1155(\n  id: string,\n  name: string,\n  fullName: string,\n  contractAddress: string,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.main.ethereum,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new Erc1155Coin({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces: 0,\n      asset: UnderlyingAsset.ERC1155,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for testnet erc1155 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param contractAddress Contract address of this token\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Holesky test network.\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function terc1155(\n  id: string,\n  name: string,\n  fullName: string,\n  contractAddress: string,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.test.holesky,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return erc1155(id, name, fullName, contractAddress, features, prefix, suffix, network, primaryKeyCurve);\n}\n\n/**\n * Factory function for ERC20-compatible account coin instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param network Network object for this coin\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function erc20CompatibleAccountCoin(\n  id: string,\n  name: string,\n  fullName: string,\n  network: EthereumNetwork,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  baseUnit: BaseUnit,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new Erc20CompatibleAccountCoin({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: false,\n      primaryKeyCurve,\n      baseUnit,\n    })\n  );\n}\n\n/**\n * Factory function for celo token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to CELO main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function celoToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.main.celo,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new CeloCoin({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for testnet celo token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the testnet CELO network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n */\nexport function tceloToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.test.celo\n) {\n  return celoToken(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network);\n}\n\n/**\n * Factory function for celo token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to BSC main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function bscToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.main.bsc,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new BscCoin({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.BSC,\n    })\n  );\n}\n\n/**\n * Factory function for testnet bsc token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the testnet BSC network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n */\nexport function tbscToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: EthereumNetwork = Networks.test.bsc\n) {\n  return bscToken(id, name, fullName, decimalPlaces, contractAddress, asset, features, prefix, suffix, network);\n}\n\n/**\n * Factory function for Stellar token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param domain Domain of the token issuer (used to access token information from the issuer's stellar.toml file)\n * See https://www.stellar.org/developers/guides/concepts/stellar-toml.html\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Stellar mainnet.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function stellarToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  domain = '',\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.stellar,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return Object.freeze(\n    new StellarCoin({\n      id,\n      name,\n      fullName,\n      decimalPlaces,\n      asset,\n      domain,\n      features,\n      prefix,\n      suffix,\n      network,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.XLM,\n    })\n  );\n}\n\n/**\n * Factory function for testnet Stellar token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param domain Domain of the token issuer (used to access token information from the issuer's stellar.toml file)\n * See https://www.stellar.org/developers/guides/concepts/stellar-toml.html\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Stellar testnet.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n */\nexport function tstellarToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  domain = '',\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.stellar\n) {\n  return stellarToken(id, name, fullName, decimalPlaces, asset, domain, features, prefix, suffix, network);\n}\n\n/**\n * Factory function for tron token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to TRON main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function tronToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: TronNetwork = Networks.main.trx,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new TronErc20Coin({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.TRX,\n    })\n  );\n}\n\n/**\n * Factory function for testnet tron token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the testnet TRON network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function ttronToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: TronNetwork = Networks.test.trx,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return tronToken(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for Hedera coin instances\n *\n * @param id uuid v4\n * @param name unique identifier of the coin\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param nodeAccountId node account Id from which the transaction will be sent\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Hedera mainnet.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function hederaCoin(\n  id: string,\n  name: string,\n  fullName: string,\n  network: AccountNetwork,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return Object.freeze(\n    new HederaCoin({\n      id,\n      name,\n      fullName,\n      decimalPlaces,\n      asset,\n      nodeAccountId: HEDERA_NODE_ACCCOUNT_ID,\n      features,\n      prefix,\n      suffix,\n      network,\n      isToken: false,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.HBAR,\n    })\n  );\n}\n\n/**\n * Factory function for Hedera token instances\n *\n * @param id uuid v4\n * @param name unique identifier of the coin\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param nodeAccountId node account Id from which the transaction will be sent\n * @param tokenId The unique identifier of this token\n * @param contractAddress Contract address of this token, same as tokenId\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Hedera mainnet.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function hederaToken(\n  id: string,\n  name: string,\n  fullName: string,\n  network: AccountNetwork,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  tokenId: string,\n  contractAddress: string,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return Object.freeze(\n    new HederaToken({\n      id,\n      name,\n      fullName,\n      decimalPlaces,\n      asset,\n      nodeAccountId: HEDERA_NODE_ACCCOUNT_ID,\n      tokenId,\n      contractAddress,\n      features,\n      prefix,\n      suffix,\n      network,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.HBAR,\n    })\n  );\n}\n\n/**\n * Factory function for ALGO token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n\n * @param alias (optional) alternative identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * See https://developer.algorand.org/docs/reference/transactions/#url\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to ALGO mainnet.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function algoToken(\n  id: string,\n  name: string,\n  alias: string | undefined,\n  fullName: string,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.algorand,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n): Readonly<AlgoCoin> {\n  return Object.freeze(\n    new AlgoCoin({\n      id,\n      name,\n      alias,\n      fullName,\n      decimalPlaces,\n      asset,\n      features,\n      prefix,\n      suffix,\n      network,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ALGO,\n    })\n  );\n}\n\n/**\n * Factory function for testnet ALGO token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param alias (optional) alternative identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * See https://developer.algorand.org/docs/reference/transactions/#url\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Algo testnet.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n */\nexport function talgoToken(\n  id: string,\n  name: string,\n  alias: string | undefined,\n  fullName: string,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.algorand\n): Readonly<AlgoCoin> {\n  return algoToken(id, name, alias, fullName, decimalPlaces, asset, features, prefix, suffix, network);\n}\n\n/**\n * Factory function for eos token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractName Contract address of this token\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to EOS main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function eosToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractName: string,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.eos,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new EosCoin({\n      id,\n      name,\n      fullName,\n      network,\n      contractName,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.EOS,\n    })\n  );\n}\n\n/**\n * Factory function for testnet eos token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractName Contract address of this token\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the testnet EOS network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n */\nexport function teosToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractName: string,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.eos\n) {\n  return eosToken(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    contractName,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network\n  );\n}\n\n/**\n * Factory function for sol token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param tokenAddress Token address of this token\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to SOL main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function solToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  tokenAddress: string,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.REQUIRES_RESERVE],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.sol,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return Object.freeze(\n    new SolCoin({\n      id,\n      name,\n      fullName,\n      network,\n      tokenAddress,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.SOL,\n    })\n  );\n}\n\n/**\n * Factory function for testnet solana token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param tokenAddress Token address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the testnet Solana network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`\n */\nexport function tsolToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  tokenAddress: string,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.REQUIRES_RESERVE],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.sol\n) {\n  return solToken(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    tokenAddress,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network\n  );\n}\n\n/**\n * Factory function for ada token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param tokenSymbol Token symbol of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Cardano main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function adaToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  policyId: string,\n  assetName: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.REQUIRES_RESERVE],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.ada,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return Object.freeze(\n    new AdaCoin({\n      id,\n      name,\n      fullName,\n      network,\n      policyId,\n      assetName,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ADA,\n    })\n  );\n}\n\n/**\n * Factory function for testnet cardano token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param tokenSymbol Token symbol of this token i.e: AUSD\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the testnet Cardano network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`\n */\nexport function tadaToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  policyId: string,\n  assetName: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.REQUIRES_RESERVE],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.ada\n) {\n  return adaToken(id, name, fullName, decimalPlaces, policyId, assetName, asset, features, prefix, suffix, network);\n}\n\n/**\n * Factory function for avaxErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to AvalancheC main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function avaxErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.avalancheC,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new AvaxERC20Token({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for testnet avaxErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the AvalancheC test network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function tavaxErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.avalancheC,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return avaxErc20(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for polygonErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Polygon main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function polygonErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.EIP1559],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.polygon,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new PolygonERC20Token({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for Amoy testnet polygonErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the Polygon test network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function tpolygonErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.polygon,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return polygonErc20(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for arbethErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Arbitrum main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function arbethErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.EIP1559],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.arbitrum,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new ArbethERC20Token({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for Arbitrum Sepolia testnet arbethErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the Arbitrum test network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function tarbethErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.arbitrum,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return arbethErc20(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for opethErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Optimism main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function opethErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.EIP1559, CoinFeature.BULK_TRANSACTION],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.optimism,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new OpethERC20Token({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for Optimism Sepolia testnet opethErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the Optimism test network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function topethErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.BULK_TRANSACTION],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.optimism,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return opethErc20(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for zkethErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to zkSync mainnet network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function zkethErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.zkSync,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new ZkethERC20Token({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for zkSync Sepolia testnet zkethErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the zkSync sepolia test network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function tzkethErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.zkSync,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return zkethErc20(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for beraErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to bera mainnet network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function beraErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = [...AccountCoin.DEFAULT_FEATURES, CoinFeature.EIP1559],\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.bera,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new BeraERC20Token({\n      id,\n      name,\n      fullName,\n      network,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.ETH,\n    })\n  );\n}\n\n/**\n * Factory function for zkSync Sepolia testnet beraErc20 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param contractAddress Contract address of this token\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the bera test network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function tberaErc20(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.bera,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return beraErc20(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for xrp token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param issuerAddress: The address of the issuer of the token,\n * @param currencyCode The token symbol. Example: USD, BTC, ETH, etc.\n * @param contractAddress Contract address of this token formed with `issuerAddress::currencyCode`\n * @param domain? the domain of the issuer of the token,\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Cardano main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function xrpToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  issuerAddress: string,\n  currencyCode: string,\n  contractAddress: string,\n  domain = '',\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.xrp,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new XrpCoin({\n      id,\n      name,\n      fullName,\n      network,\n      issuerAddress,\n      currencyCode,\n      contractAddress,\n      domain,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.XRP,\n    })\n  );\n}\n\n/**\n * Factory function for testnet cardano token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param issuerAddress: The address of the issuer of the token,\n * @param currencyCode The token symbol. Example: USD, BTC, ETH, etc.\n * @param contractAddress Contract address of this token formed with `issuerAddress::currencyCode`\n * @param domain? the domain of the issuer of the token,\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the testnet Cardano network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n */\nexport function txrpToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  issuerAddress: string,\n  currencyCode: string,\n  contractAddress: string,\n  domain = '',\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.xrp\n) {\n  return xrpToken(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    issuerAddress,\n    currencyCode,\n    contractAddress,\n    domain,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network\n  );\n}\n\n/**\n * Factory function for sui token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param packageId PackageId of this token\n * @param module The module of the package with id `packageId`\n * @param symbol Identifies the coin defined in the module `module` of the package with id `packageId`\n * @param contractAddress Contract address of this token formed with `packageId::module::symbol`\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to SUI main network.\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function suiToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  packageId: string,\n  module: string,\n  symbol: string,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.sui,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n): Readonly<SuiCoin> {\n  return Object.freeze(\n    new SuiCoin({\n      id,\n      name,\n      fullName,\n      network,\n      packageId,\n      module,\n      symbol,\n      contractAddress,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.SUI,\n    })\n  );\n}\n\n/**\n * Factory function for testnet sui token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param packageId PackageId of this token\n * @param module The module of the package with id `packageId`\n * @param symbol Identifies the coin defined in the module `module` of the package with id `packageId`\n * @param contractAddress Contract address of this token formed with `packageId::module::symbol`\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to SUI test network.\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\n\nexport function tsuiToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  packageId: string,\n  module: string,\n  symbol: string,\n  contractAddress: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.sui,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n): Readonly<SuiCoin> {\n  return suiToken(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    packageId,\n    module,\n    symbol,\n    contractAddress,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for apt token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param assetId Asset Id of this token i.e. the unique identifier of the token for all tokens - fungible, non-fungible and legacy\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix Optional token prefix. Defaults to empty string\n * @param suffix Optional token suffix. Defaults to token name.\n * @param network Optional token network. Defaults to APT main network.\n * @param features Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function aptToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  assetId: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.apt,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return Object.freeze(\n    new AptCoin({\n      id,\n      name,\n      fullName,\n      network,\n      assetId,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.APT,\n    })\n  );\n}\n\n/**\n * Factory function for Apt NFT collections.\n *\n * @param id uuid v4\n * @param name unique identifier of the NFT collection\n * @param fullName Complete human-readable name of the NFT collection\n * @param nftCollectionId collection ID of the non-fungible tokens (NFTs)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix Optional token prefix. Defaults to empty string\n * @param suffix Optional token suffix. Defaults to token name.\n * @param network Optional token network. Defaults to APT main network.\n * @param features Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function aptNFTCollection(\n  id: string,\n  name: string,\n  fullName: string,\n  nftCollectionId: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.apt,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return Object.freeze(\n    new AptNFTCollection({\n      id,\n      name,\n      fullName,\n      network,\n      nftCollectionId,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces: 0,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.APT,\n    })\n  );\n}\n\n/**\n * Factory function for testnet apt token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param assetId Asset Id of this token i.e. the unique identifier of the token for all tokens - fungible, non-fungible and legacy\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix Optional token prefix. Defaults to empty string\n * @param suffix Optional token suffix. Defaults to token name.\n * @param network Optional token network. Defaults to the testnet APT network.\n * @param features Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function taptToken(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  assetId: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.apt,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return aptToken(\n    id,\n    name,\n    fullName,\n    decimalPlaces,\n    assetId,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for testnet Apt NFT collections.\n *\n * @param id uuid v4\n * @param name unique identifier of the NFT collection\n * @param fullName Complete human-readable name of the NFT collection\n * @param nftCollectionId collection ID of the non-fungible tokens (NFTs)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix Optional token prefix. Defaults to empty string\n * @param suffix Optional token suffix. Defaults to token name.\n * @param network Optional token network. Defaults to APT test network.\n * @param features Features of this coin. Defaults to the DEFAULT_FEATURES and REQUIRES_RESERVE defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function taptNFTCollection(\n  id: string,\n  name: string,\n  fullName: string,\n  nftCollectionId: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = 't',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.apt,\n  primaryKeyCurve: KeyCurve = KeyCurve.Ed25519\n) {\n  return aptNFTCollection(\n    id,\n    name,\n    fullName,\n    nftCollectionId,\n    asset,\n    features,\n    prefix,\n    suffix,\n    network,\n    primaryKeyCurve\n  );\n}\n\n/**\n * Factory function for fiat coin instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the coin, should start with 'fiat' or 'tfiat' followed by the 3-char ISO-4217 alphabetical code\n * @param fullName Complete human-readable name of the coin\n * @param network Network object for this coin\n * @param decimalPlaces Number of decimal places this coin supports (divisibility exponent)\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `FiatCoin`\n * @param primaryKeyCurve? The elliptic curve for this chain/token\n * @param prefix? Optional coin prefix. Defaults to empty string\n * @param suffix? Optional coin suffix. Defaults to coin name.\n * @param isToken? Whether or not this coin is a token of another coin\n */\nexport function fiat(\n  id: string,\n  name: FiatCoinName,\n  fullName: string,\n  network: BaseNetwork,\n  decimalPlaces: number,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = FiatCoin.DEFAULT_FEATURES,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  isToken = false\n) {\n  return Object.freeze(\n    new FiatCoin({\n      id,\n      name,\n      fullName,\n      network,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      isToken,\n      asset,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.FIAT,\n    })\n  );\n}\n\n/**\n * Factory function for sip10 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param assetId A unique identifier for a token, which is in the form of contractAddress.contractName::tokenName\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to Stacks main network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n * @param primaryKeyCurve The elliptic curve for this chain/token\n */\nexport function sip10Token(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  assetId: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.main.stx,\n  primaryKeyCurve: KeyCurve = KeyCurve.Secp256k1\n) {\n  return Object.freeze(\n    new Sip10Token({\n      id,\n      name,\n      fullName,\n      network,\n      assetId,\n      prefix,\n      suffix,\n      features,\n      decimalPlaces,\n      asset,\n      isToken: true,\n      primaryKeyCurve,\n      baseUnit: BaseUnit.STX,\n    })\n  );\n}\n\n/**\n * Factory function for testnet sip10 token instances.\n *\n * @param id uuid v4\n * @param name unique identifier of the token\n * @param fullName Complete human-readable name of the token\n * @param decimalPlaces Number of decimal places this token supports (divisibility exponent)\n * @param assetId A unique identifier for a token, which is in the form of contractAddress.contractName::tokenName\n * @param asset Asset which this coin represents. This is the same for both mainnet and testnet variants of a coin.\n * @param prefix? Optional token prefix. Defaults to empty string\n * @param suffix? Optional token suffix. Defaults to token name.\n * @param network? Optional token network. Defaults to the testnet Stacks network.\n * @param features? Features of this coin. Defaults to the DEFAULT_FEATURES defined in `AccountCoin`\n */\nexport function tsip10Token(\n  id: string,\n  name: string,\n  fullName: string,\n  decimalPlaces: number,\n  assetId: string,\n  asset: UnderlyingAsset,\n  features: CoinFeature[] = AccountCoin.DEFAULT_FEATURES,\n  prefix = '',\n  suffix: string = name.toUpperCase(),\n  network: AccountNetwork = Networks.test.stx\n) {\n  return sip10Token(id, name, fullName, decimalPlaces, assetId, asset, features, prefix, suffix, network);\n}\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!