PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/sdk-coin-stx/dist/src/lib

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

"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
    var ownKeys = function(o) {
        ownKeys = Object.getOwnPropertyNames || function (o) {
            var ar = [];
            for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
            return ar;
        };
        return ownKeys(o);
    };
    return function (mod) {
        if (mod && mod.__esModule) return mod;
        var result = {};
        if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
        __setModuleDefault(result, mod);
        return result;
    };
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.bufferToHexPrefixString = bufferToHexPrefixString;
exports.removeHexPrefix = removeHexPrefix;
exports.getTxSenderAddress = getTxSenderAddress;
exports.isValidAmount = isValidAmount;
exports.isValidAddress = isValidAddress;
exports.isValidTransactionId = isValidTransactionId;
exports.isValidPublicKey = isValidPublicKey;
exports.isValidPrivateKey = isValidPrivateKey;
exports.isValidRawTransaction = isValidRawTransaction;
exports.isValidMemo = isValidMemo;
exports.isValidContractAddress = isValidContractAddress;
exports.isValidContractFunctionName = isValidContractFunctionName;
exports.unpadMemo = unpadMemo;
exports.getSTXAddressFromPubKeys = getSTXAddressFromPubKeys;
exports.signMessage = signMessage;
exports.verifySignature = verifySignature;
exports.getAddressDetails = getAddressDetails;
exports.normalizeAddress = normalizeAddress;
exports.isValidAddressWithPaymentId = isValidAddressWithPaymentId;
exports.stringifyCv = stringifyCv;
exports.functionArgsToSendParams = functionArgsToSendParams;
exports.functionArgsToTokenTransferParams = functionArgsToTokenTransferParams;
exports.getAddressVersion = getAddressVersion;
exports.xpubToSTXPubkey = xpubToSTXPubkey;
exports.getBaseAddress = getBaseAddress;
exports.isSameBaseAddress = isSameBaseAddress;
exports.findTokenNameByContract = findTokenNameByContract;
exports.findContractTokenNameUsingContract = findContractTokenNameUsingContract;
exports.getMemoIdAndBaseAddressFromAddress = getMemoIdAndBaseAddressFromAddress;
const url = __importStar(require("url"));
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const ethereumjs_util_1 = require("ethereumjs-util");
const transactions_1 = require("@stacks/transactions");
const secp256k1_1 = require("@noble/curves/secp256k1");
const _ = __importStar(require("lodash"));
const sdk_core_1 = require("@bitgo/sdk-core");
const _1 = require(".");
const statics_1 = require("@bitgo/statics");
const constants_1 = require("./constants");
/**
 * Encodes a buffer as a "0x" prefixed lower-case hex string.
 *
 * @param {Buffer} buff - a buffer with a hexadecimal string
 * @returns {string} - the hexadecimal string prefixed with "0x"
 */
function bufferToHexPrefixString(buff) {
    return (0, ethereumjs_util_1.bufferToHex)(buff);
}
/**
 * Remove the "0x" prefix from the given string, if present.
 *
 * @param {string} hex - a hexadecimal string
 * @returns {string} - the hexadecimal string without a leading "0x"
 */
function removeHexPrefix(hex) {
    return (0, ethereumjs_util_1.stripHexPrefix)(hex);
}
/**
 * Get stacks address from public key hash
 *
 * @param {Buffer} publicKeyHash - hash of public key
 * @param {AddressHashMode} hashMode - hash mode
 * @param {TransactionVersion} transactionVersion - tx version
 * @returns {string} stacks address
 */
function getAddressFromPublicKeyHash(publicKeyHash, hashMode, transactionVersion) {
    if (publicKeyHash.length !== 20) {
        throw new Error('expected 20-byte pubkeyhash');
    }
    const addrVer = (0, transactions_1.addressHashModeToVersion)(hashMode, transactionVersion);
    const addr = (0, transactions_1.addressFromVersionHash)(addrVer, publicKeyHash.toString('hex'));
    const addrString = (0, transactions_1.addressToString)(addr);
    return addrString;
}
/**
 * @param tx
 */
function getTxSenderAddress(tx) {
    if (tx.auth.spendingCondition !== null && tx.auth.spendingCondition !== undefined) {
        const spendingCondition = tx.auth.spendingCondition;
        const txSender = getAddressFromPublicKeyHash(Buffer.from(spendingCondition.signer, 'hex'), spendingCondition.hashMode, tx.version);
        return txSender;
    }
    else
        throw new Error('spendingCondition should not be null');
}
/**
 * Returns whether or not the string is a valid amount number
 *
 * @param {string} amount - the string to validate
 * @returns {boolean} - the validation result
 */
function isValidAmount(amount) {
    const bigNumberAmount = new bignumber_js_1.default(amount);
    return bigNumberAmount.isInteger() && bigNumberAmount.isGreaterThanOrEqualTo(0);
}
/**
 * Returns whether or not the string is a valid protocol address
 *
 * @param {string} address - the address to be validated
 * @returns {boolean} - the validation result
 */
function isValidAddress(address) {
    return (0, transactions_1.validateStacksAddress)(address);
}
/**
 * Returns whether or not the string is a valid protocol transaction id or not.
 *
 * A valid transaction id is a SHA-512/256 hash of a serialized transaction; see
 * the txidFromData function in @stacks/transaction:
 * https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/utils.ts#L97
 *
 * @param {string} txId - the transaction id to be validated
 * @returns {boolean} - the validation result
 */
function isValidTransactionId(txId) {
    if (txId.length !== 64 && txId.length !== 66)
        return false;
    const noPrefix = removeHexPrefix(txId);
    if (noPrefix.length !== 64)
        return false;
    return allHexChars(noPrefix);
}
/**
 * Returns whether or not the string is a valid protocol public key or
 * extended public key.
 *
 * The key format is documented at
 * https://github.com/stacksgov/sips/blob/main/sips/sip-005/sip-005-blocks-and-transactions.md#transaction-authorization
 *
 * @param {string} pub - the  public key to be validated
 * @returns {boolean} - the validation result
 */
function isValidPublicKey(pub) {
    if ((0, sdk_core_1.isValidXpub)(pub))
        return true;
    if (pub.length !== 66 && pub.length !== 130)
        return false;
    const firstByte = pub.slice(0, 2);
    // uncompressed public key
    if (pub.length === 130 && firstByte !== '04')
        return false;
    // compressed public key
    if (pub.length === 66 && firstByte !== '02' && firstByte !== '03')
        return false;
    if (!allHexChars(pub))
        return false;
    // validate the public key
    try {
        secp256k1_1.secp256k1.ProjectivePoint.fromHex(pub);
        return true;
    }
    catch (e) {
        return false;
    }
}
/**
 * Returns whether or not the string is a valid protocol private key, or extended
 * private key.
 *
 * The protocol key format is described in the @stacks/transactions npm package, in the
 * createStacksPrivateKey function:
 * https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/keys.ts#L125
 *
 * @param {string} prv - the private key (or extended private key) to be validated
 * @returns {boolean} - the validation result
 */
function isValidPrivateKey(prv) {
    if ((0, sdk_core_1.isValidXprv)(prv))
        return true;
    if (prv.length !== 64 && prv.length !== 66)
        return false;
    if (prv.length === 66 && prv.slice(64) !== '01')
        return false;
    return allHexChars(prv);
}
/**
 * Returns whether or not the string is a composed of hex chars only
 *
 * @param {string} maybe - the  string to be validated
 * @returns {boolean} - the validation result
 */
function allHexChars(maybe) {
    return /^([0-9a-f])+$/i.test(maybe);
}
/**
 * Checks if raw transaction can be deserialized
 *
 * @param {unknown} rawTransaction - transaction in raw hex format
 * @returns {boolean} - the validation result
 */
function isValidRawTransaction(rawTransaction) {
    try {
        if (typeof rawTransaction === 'string') {
            (0, transactions_1.deserializeTransaction)(transactions_1.BufferReader.fromBuffer(Buffer.from(removeHexPrefix(rawTransaction), 'hex')));
        }
        else {
            return false;
        }
    }
    catch (e) {
        return false;
    }
    return true;
}
/**
 * Returns whether or not the memo string is valid
 *
 * @param {string} memo - the string to be validated
 * @returns {boolean} - the validation result
 */
function isValidMemo(memo) {
    try {
        (0, transactions_1.createMemoString)(memo);
    }
    catch (e) {
        return false;
    }
    return true;
}
/**
 * Checks for valid contract address
 *
 * @param {string} addr - contract deployer address
 * @param {BitgoStacksNetwork} network - network object
 * @returns {boolean} - the validation result
 */
function isValidContractAddress(addr, network) {
    return addr === network.stakingContractAddress || addr === network.sendmanymemoContractAddress;
}
/**
 * Check if the name is one of valid contract names
 *
 * @param {string} name - function name
 * @returns {boolean} - validation result
 */
function isValidContractFunctionName(name) {
    return constants_1.VALID_CONTRACT_FUNCTION_NAMES.includes(name);
}
/**
 * Unpads a memo string, so it removes nulls.
 *
 * Useful when memo is fill up the length. Result is becomes readable.
 *
 * @param {string} memo - the string to be validated
 * @returns {boolean} - the validation result
 */
function unpadMemo(memo) {
    const end = memo.indexOf('\u0000');
    if (end < 0)
        return memo;
    return memo.slice(0, end);
}
/**
 * Generate a multisig address from multiple STX public keys
 *
 * @param {string[]} pubKeys - list of public keys as strings
 * @param {AddressVersion} addressVersion - MainnetMultiSig, TestnetMultiSig
 * @param {AddressHashMode} addressHashMode - SerializeP2SH
 * @param {number} [signaturesRequired] - number of signatures required, default value its 2
 * @returns {address: string, hash160: string} - a multisig address
 */
function getSTXAddressFromPubKeys(pubKeys, addressVersion = transactions_1.AddressVersion.MainnetMultiSig, addressHashMode = transactions_1.AddressHashMode.SerializeP2SH, signaturesRequired = 2) {
    if (pubKeys.length === 0) {
        throw new Error('Invalid number of public keys');
    }
    if (!pubKeys.every(isValidPublicKey)) {
        throw new Error('Invalid public keys');
    }
    if (signaturesRequired > pubKeys.length) {
        throw new Error('Number of signatures required must be lower or equal to the number of Public Keys');
    }
    const stxPubKeys = pubKeys.map(transactions_1.createStacksPublicKey);
    const address = (0, transactions_1.addressFromPublicKeys)(addressVersion, addressHashMode, signaturesRequired, stxPubKeys);
    return { address: (0, transactions_1.addressToString)(address), hash160: address.hash160 };
}
/**
 * signs a string message
 *
 * @param keyPair
 * @param data  - message to be signed
 * @returns signed message string
 */
function signMessage(keyPair, data) {
    const prv = keyPair.getKeys().prv;
    if (prv) {
        return (0, transactions_1.signWithKey)((0, transactions_1.createStacksPrivateKey)(prv), data).data;
    }
    else {
        throw new sdk_core_1.SigningError('Missing private key');
    }
}
/**
 * Verifies a signed message
 *
 * The signature must be 130 bytes long -- see RECOVERABLE_ECDSA_SIG_LENGTH_BYTES
 * in @stacks/transactions/src/constants.ts
 *
 * @param {string} message - message to verify the signature
 * @param {string} signature - signature to verify
 * @param {string} publicKey - public key as hex string used to verify the signature
 * @returns {boolean} - verification result
 */
function verifySignature(message, signature, publicKey) {
    if (!isValidPublicKey(publicKey))
        return false;
    if (signature.length !== 130)
        return false;
    if (!allHexChars(signature))
        throw new sdk_core_1.UtilsError('Invalid signature input to verifySignature');
    if (_.isEmpty(message))
        throw new sdk_core_1.UtilsError('Cannot verify empty messages');
    // provided publicKey can be compressed or uncompressed
    const keyEncoding = publicKey.length === 66 ? transactions_1.PubKeyEncoding.Compressed : transactions_1.PubKeyEncoding.Uncompressed;
    const messageSig = (0, transactions_1.createMessageSignature)(signature);
    const foundKey = (0, transactions_1.publicKeyFromSignature)(message, messageSig, keyEncoding);
    return foundKey === publicKey;
}
/**
 * Process address into address and memo id
 *
 * @param {string} address the address to process
 * @returns {Object} object containing address and memo id
 */
function getAddressDetails(address) {
    const addressDetails = url.parse(address);
    const queryDetails = addressDetails.query ? new URLSearchParams(addressDetails.query) : undefined;
    const baseAddress = addressDetails.pathname;
    if (!isValidAddress(baseAddress)) {
        throw new sdk_core_1.UtilsError(`invalid address: ${address}`);
    }
    // address doesn't have a memo id
    if (baseAddress === address) {
        return {
            address: address,
            memoId: undefined,
        };
    }
    if (!queryDetails || _.isNil(queryDetails.get('memoId'))) {
        // if there are more properties, the query details need to contain the memo id property
        throw new sdk_core_1.UtilsError(`invalid address with memo id: ${address}`);
    }
    const memoId = queryDetails.get('memoId');
    const intMemoId = parseInt(memoId, 10);
    if (isNaN(intMemoId) || intMemoId < 0) {
        throw new Error(`invalid memo id: ${memoId}`);
    }
    return {
        address: baseAddress,
        memoId,
    };
}
/**
 * Validate and return address with appended memo id
 *
 * @param {AddressDetails} addressDetails
 * @returns {string} address with memo id
 */
function normalizeAddress({ address, memoId }) {
    if (!isValidAddress(address)) {
        throw new sdk_core_1.UtilsError(`invalid address: ${address}`);
    }
    if (!_.isUndefined(memoId)) {
        const intMemoId = parseInt(memoId, 10);
        if (isNaN(intMemoId) || intMemoId < 0) {
            throw new Error(`invalid memo id: ${memoId}`);
        }
        return `${address}?memoId=${memoId}`;
    }
    return address;
}
/**
 * Return boolean indicating whether input is a valid address with memo id
 *
 * @param {string} address address in the form <address>?memoId=<memoId>
 * @returns {boolean} true is input is a valid address
 */
function isValidAddressWithPaymentId(address) {
    try {
        const addressDetails = getAddressDetails(address);
        return address === normalizeAddress(addressDetails);
    }
    catch (e) {
        return false;
    }
}
/**
 * Return string representation of clarity value input
 *
 * @param {ClarityValue} cv clarity value function argument
 * @returns {String} stringified clarity value
 */
function stringifyCv(cv) {
    switch (cv.type) {
        case transactions_1.ClarityType.Int:
        case transactions_1.ClarityType.UInt:
            return { type: cv.type, value: cv.value.toString() };
        case transactions_1.ClarityType.OptionalSome:
            return { type: cv.type, value: stringifyCv(cv.value) };
        case transactions_1.ClarityType.Tuple:
            return {
                type: cv.type,
                data: _.mapValues(cv.data, (value) => stringifyCv(value)),
            };
        case transactions_1.ClarityType.List:
            return {
                type: cv.type,
                list: cv.list.map(stringifyCv),
            };
        default:
            return cv;
    }
}
/**
 * Parse functionArgs into send params for send-many-memo contract calls
 *
 * @param {ClarityValue[]} args functionArgs from a contract call payload
 * @returns {SendParams[]} An array of sendParams
 */
function functionArgsToSendParams(args) {
    if (args.length !== 1 || args[0].type !== transactions_1.ClarityType.List) {
        throw new sdk_core_1.InvalidTransactionError("function args don't match send-many-memo type declaration");
    }
    return args[0].list.map((tuple) => {
        if (tuple.type !== transactions_1.ClarityType.Tuple ||
            tuple.data.to?.type !== transactions_1.ClarityType.PrincipalStandard ||
            tuple.data.ustx?.type !== transactions_1.ClarityType.UInt ||
            tuple.data.memo?.type !== transactions_1.ClarityType.Buffer) {
            throw new sdk_core_1.InvalidTransactionError("function args don't match send-many-memo type declaration");
        }
        return {
            address: (0, transactions_1.cvToString)(tuple.data.to),
            amount: (0, transactions_1.cvToValue)(tuple.data.ustx, true),
            memo: tuple.data.memo.buffer.toString('ascii'),
        };
    });
}
function functionArgsToTokenTransferParams(args) {
    if (args.length < 3) {
        throw new sdk_core_1.InvalidTransactionError("function args don't match token transfer declaration");
    }
    if (args[0].type !== transactions_1.ClarityType.UInt ||
        args[1].type !== transactions_1.ClarityType.PrincipalStandard ||
        args[2].type !== transactions_1.ClarityType.PrincipalStandard) {
        throw new sdk_core_1.InvalidTransactionError("function args don't match token transfer declaration");
    }
    const tokenTransferParams = {
        amount: (0, transactions_1.cvToValue)(args[0], true),
        sender: (0, transactions_1.cvToString)(args[1]),
        recipient: (0, transactions_1.cvToString)(args[2]),
    };
    if (args.length === 4 && args[3].type === transactions_1.ClarityType.Buffer) {
        tokenTransferParams['memo'] = args[3].buffer.toString('ascii');
    }
    return tokenTransferParams;
}
/**
 * Gets the version of an address
 *
 * @param {String} address the address with or without the memoId
 * @returns {AddressVersion} A number that represent the Address Version
 */
function getAddressVersion(address) {
    const baseAddress = getAddressDetails(address).address;
    return (0, transactions_1.createAddress)(baseAddress).version;
}
/**
 * Returns a STX pub key from an xpub
 *
 * @param {String} xpub an xpub
 * @returns {String} a compressed STX pub key
 */
function xpubToSTXPubkey(xpub, compressed = true) {
    return new _1.KeyPair({ pub: xpub }).getKeys(compressed).pub;
}
/**
 * Returns the base address portion of an address
 *
 * @param {String} address - an address
 * @returns {String} - the base address
 */
function getBaseAddress(address) {
    const addressDetails = getAddressDetails(address);
    return addressDetails.address;
}
/**
 * Compares an address to the base address to check if matchs.
 *
 * @param {String} address - an address
 * @param {String} baseAddress - a base address
 * @returns {boolean}
 */
function isSameBaseAddress(address, baseAddress) {
    if (!isValidAddressWithPaymentId(address)) {
        throw new sdk_core_1.UtilsError(`invalid address: ${address}`);
    }
    return getBaseAddress(address) === getBaseAddress(baseAddress);
}
/**
 * Function to get tokenName from list of sip10 tokens using contract details
 *
 * @param {String} contractAddress
 * @param {String} contractName
 * @returns {String|Undefined}
 */
function findTokenNameByContract(contractAddress, contractName) {
    {
        const tokenName = statics_1.coins
            .filter((coin) => coin instanceof statics_1.Sip10Token && coin.assetId.includes(`${contractAddress}.${contractName}`))
            .map((coin) => coin.name);
        return tokenName ? tokenName[0] : undefined;
    }
}
/**
 * Function to get contractTokenName from list of sip10 tokens using contract details
 *
 * @param {String} contractAddress
 * @param {String} contractName
 * @returns {String|Undefined}
 */
function findContractTokenNameUsingContract(contractAddress, contractName) {
    {
        const sip10Token = statics_1.coins
            .filter((coin) => coin instanceof statics_1.Sip10Token && coin.assetId.includes(`${contractAddress}.${contractName}`))
            .map((coin) => coin);
        return sip10Token ? sip10Token[0].assetId.split('::')[1] : undefined;
    }
}
/**
 * Function to get address and memo details from address input
 *
 * @param address
 * @returns {AddressDetails}
 */
function getMemoIdAndBaseAddressFromAddress(address) {
    const [baseAddress, queryString] = address.split('?');
    const params = new URLSearchParams(queryString);
    const memoId = params.get('memoId');
    return {
        address: baseAddress,
        memoId: memoId ? memoId : undefined,
    };
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0CA,0DAEC;AAQD,0CAEC;AA4BD,gDAUC;AAQD,sCAGC;AAQD,wCAEC;AAYD,oDAMC;AAYD,4CAsBC;AAaD,8CAQC;AAkBD,sDAYC;AAQD,kCAQC;AASD,wDAEC;AAQD,kEAEC;AAUD,8BAIC;AAWD,4DAoBC;AASD,kCAOC;AAaD,0CAcC;AAQD,8CA6BC;AAQD,4CAYC;AAQD,kEAOC;AAQD,kCAoBC;AAQD,4DAmBC;AAED,8EAoBC;AAQD,8CAGC;AAQD,0CAEC;AAQD,wCAGC;AASD,8CAKC;AASD,0DAOC;AASD,gFAOC;AAQD,gFASC;AAzkBD,yCAA2B;AAC3B,gEAAqC;AACrC,qDAA8D;AAC9D,uDAwB8B;AAC9B,uDAAoD;AACpD,0CAA4B;AAC5B,8CAA8G;AAE9G,wBAA4B;AAC5B,4CAAwF;AACxF,2CAA4D;AAE5D;;;;;GAKG;AACH,SAAgB,uBAAuB,CAAC,IAAY;IAClD,OAAO,IAAA,6BAAW,EAAC,IAAI,CAAC,CAAC;AAC3B,CAAC;AAED;;;;;GAKG;AACH,SAAgB,eAAe,CAAC,GAAW;IACzC,OAAO,IAAA,gCAAc,EAAC,GAAG,CAAC,CAAC;AAC7B,CAAC;AAED;;;;;;;GAOG;AACH,SAAS,2BAA2B,CAClC,aAAqB,EACrB,QAAyB,EACzB,kBAAsC;IAEtC,IAAI,aAAa,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;QAChC,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;IACjD,CAAC;IAED,MAAM,OAAO,GAAG,IAAA,uCAAwB,EAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC;IACvE,MAAM,IAAI,GAAG,IAAA,qCAAsB,EAAC,OAAO,EAAE,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;IAC5E,MAAM,UAAU,GAAG,IAAA,8BAAe,EAAC,IAAI,CAAC,CAAC;IACzC,OAAO,UAAU,CAAC;AACpB,CAAC;AAED;;GAEG;AACH,SAAgB,kBAAkB,CAAC,EAAqB;IACtD,IAAI,EAAE,CAAC,IAAI,CAAC,iBAAiB,KAAK,IAAI,IAAI,EAAE,CAAC,IAAI,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;QAClF,MAAM,iBAAiB,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC;QACpD,MAAM,QAAQ,GAAG,2BAA2B,CAC1C,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,KAAK,CAAC,EAC5C,iBAAiB,CAAC,QAAkB,EACpC,EAAE,CAAC,OAAO,CACX,CAAC;QACF,OAAO,QAAQ,CAAC;IAClB,CAAC;;QAAM,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;AACjE,CAAC;AAED;;;;;GAKG;AACH,SAAgB,aAAa,CAAC,MAAc;IAC1C,MAAM,eAAe,GAAG,IAAI,sBAAS,CAAC,MAAM,CAAC,CAAC;IAC9C,OAAO,eAAe,CAAC,SAAS,EAAE,IAAI,eAAe,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC;AAClF,CAAC;AAED;;;;;GAKG;AACH,SAAgB,cAAc,CAAC,OAAe;IAC5C,OAAO,IAAA,oCAAqB,EAAC,OAAO,CAAC,CAAC;AACxC,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,oBAAoB,CAAC,IAAY;IAC/C,IAAI,IAAI,CAAC,MAAM,KAAK,EAAE,IAAI,IAAI,CAAC,MAAM,KAAK,EAAE;QAAE,OAAO,KAAK,CAAC;IAC3D,MAAM,QAAQ,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC;IACvC,IAAI,QAAQ,CAAC,MAAM,KAAK,EAAE;QAAE,OAAO,KAAK,CAAC;IAEzC,OAAO,WAAW,CAAC,QAAQ,CAAC,CAAC;AAC/B,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,gBAAgB,CAAC,GAAW;IAC1C,IAAI,IAAA,sBAAW,EAAC,GAAG,CAAC;QAAE,OAAO,IAAI,CAAC;IAElC,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG;QAAE,OAAO,KAAK,CAAC;IAE1D,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAElC,0BAA0B;IAC1B,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG,IAAI,SAAS,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAE3D,wBAAwB;IACxB,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,IAAI,SAAS,KAAK,IAAI,IAAI,SAAS,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAEhF,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC;QAAE,OAAO,KAAK,CAAC;IAEpC,0BAA0B;IAC1B,IAAI,CAAC;QACH,qBAAS,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACvC,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,iBAAiB,CAAC,GAAW;IAC3C,IAAI,IAAA,sBAAW,EAAC,GAAG,CAAC;QAAE,OAAO,IAAI,CAAC;IAElC,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE;QAAE,OAAO,KAAK,CAAC;IAEzD,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAE9D,OAAO,WAAW,CAAC,GAAG,CAAC,CAAC;AAC1B,CAAC;AAED;;;;;GAKG;AACH,SAAS,WAAW,CAAC,KAAa;IAChC,OAAO,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACtC,CAAC;AAED;;;;;GAKG;AACH,SAAgB,qBAAqB,CAAC,cAAuB;IAC3D,IAAI,CAAC;QACH,IAAI,OAAO,cAAc,KAAK,QAAQ,EAAE,CAAC;YACvC,IAAA,qCAAsB,EAAC,2BAAY,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;QACvG,CAAC;aAAM,CAAC;YACN,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;;;;GAKG;AACH,SAAgB,WAAW,CAAC,IAAY;IACtC,IAAI,CAAC;QACH,IAAA,+BAAgB,EAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,sBAAsB,CAAC,IAAY,EAAE,OAA2B;IAC9E,OAAO,IAAI,KAAK,OAAO,CAAC,sBAAsB,IAAI,IAAI,KAAK,OAAO,CAAC,2BAA2B,CAAC;AACjG,CAAC;AAED;;;;;GAKG;AACH,SAAgB,2BAA2B,CAAC,IAAY;IACtD,OAAO,yCAA6B,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AACtD,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,SAAS,CAAC,IAAY;IACpC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACnC,IAAI,GAAG,GAAG,CAAC;QAAE,OAAO,IAAI,CAAC;IACzB,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC5B,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,wBAAwB,CACtC,OAAiB,EACjB,iBAAiC,6BAAc,CAAC,eAAe,EAC/D,kBAAmC,8BAAe,CAAC,aAAa,EAChE,kBAAkB,GAAG,CAAC;IAEtB,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;IACnD,CAAC;IACD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAC;QACrC,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;IACzC,CAAC;IACD,IAAI,kBAAkB,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;QACxC,MAAM,IAAI,KAAK,CAAC,mFAAmF,CAAC,CAAC;IACvG,CAAC;IAED,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,oCAAqB,CAAC,CAAC;IACtD,MAAM,OAAO,GAAG,IAAA,oCAAqB,EAAC,cAAc,EAAE,eAAe,EAAE,kBAAkB,EAAE,UAAU,CAAC,CAAC;IAEvG,OAAO,EAAE,OAAO,EAAE,IAAA,8BAAe,EAAC,OAAO,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC;AACzE,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,WAAW,CAAC,OAAgB,EAAE,IAAY;IACxD,MAAM,GAAG,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC;IAClC,IAAI,GAAG,EAAE,CAAC;QACR,OAAO,IAAA,0BAAW,EAAC,IAAA,qCAAsB,EAAC,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC;IAC7D,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,uBAAY,CAAC,qBAAqB,CAAC,CAAC;IAChD,CAAC;AACH,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,eAAe,CAAC,OAAe,EAAE,SAAiB,EAAE,SAAiB;IACnF,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC;QAAE,OAAO,KAAK,CAAC;IAC/C,IAAI,SAAS,CAAC,MAAM,KAAK,GAAG;QAAE,OAAO,KAAK,CAAC;IAC3C,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC;QAAE,MAAM,IAAI,qBAAU,CAAC,4CAA4C,CAAC,CAAC;IAChG,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;QAAE,MAAM,IAAI,qBAAU,CAAC,8BAA8B,CAAC,CAAC;IAE7E,uDAAuD;IACvD,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,KAAK,EAAE,CAAC,CAAC,CAAC,6BAAc,CAAC,UAAU,CAAC,CAAC,CAAC,6BAAc,CAAC,YAAY,CAAC;IAEtG,MAAM,UAAU,GAAG,IAAA,qCAAsB,EAAC,SAAS,CAAC,CAAC;IAErD,MAAM,QAAQ,GAAG,IAAA,qCAAsB,EAAC,OAAO,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC;IAE1E,OAAO,QAAQ,KAAK,SAAS,CAAC;AAChC,CAAC;AAED;;;;;GAKG;AACH,SAAgB,iBAAiB,CAAC,OAAe;IAC/C,MAAM,cAAc,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAC1C,MAAM,YAAY,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,eAAe,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAClG,MAAM,WAAW,GAAG,cAAc,CAAC,QAAkB,CAAC;IACtD,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE,CAAC;QACjC,MAAM,IAAI,qBAAU,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAC;IACtD,CAAC;IACD,iCAAiC;IACjC,IAAI,WAAW,KAAK,OAAO,EAAE,CAAC;QAC5B,OAAO;YACL,OAAO,EAAE,OAAO;YAChB,MAAM,EAAE,SAAS;SAClB,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,YAAY,IAAI,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;QACzD,uFAAuF;QACvF,MAAM,IAAI,qBAAU,CAAC,iCAAiC,OAAO,EAAE,CAAC,CAAC;IACnE,CAAC;IACD,MAAM,MAAM,GAAG,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAW,CAAC;IACpD,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IACvC,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;QACtC,MAAM,IAAI,KAAK,CAAC,oBAAoB,MAAM,EAAE,CAAC,CAAC;IAChD,CAAC;IAED,OAAO;QACL,OAAO,EAAE,WAAW;QACpB,MAAM;KACP,CAAC;AACJ,CAAC;AAED;;;;;GAKG;AACH,SAAgB,gBAAgB,CAAC,EAAE,OAAO,EAAE,MAAM,EAAkB;IAClE,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC;QAC7B,MAAM,IAAI,qBAAU,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAC;IACtD,CAAC;IACD,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC;QAC3B,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QACvC,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;YACtC,MAAM,IAAI,KAAK,CAAC,oBAAoB,MAAM,EAAE,CAAC,CAAC;QAChD,CAAC;QACD,OAAO,GAAG,OAAO,WAAW,MAAM,EAAE,CAAC;IACvC,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;;;;GAKG;AACH,SAAgB,2BAA2B,CAAC,OAAe;IACzD,IAAI,CAAC;QACH,MAAM,cAAc,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAClD,OAAO,OAAO,KAAK,gBAAgB,CAAC,cAAc,CAAC,CAAC;IACtD,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC;AAED;;;;;GAKG;AACH,SAAgB,WAAW,CAAC,EAAgB;IAC1C,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;QAChB,KAAK,0BAAW,CAAC,GAAG,CAAC;QACrB,KAAK,0BAAW,CAAC,IAAI;YACnB,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC;QACvD,KAAK,0BAAW,CAAC,YAAY;YAC3B,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;QACzD,KAAK,0BAAW,CAAC,KAAK;YACpB,OAAO;gBACL,IAAI,EAAE,EAAE,CAAC,IAAI;gBACb,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aAC1D,CAAC;QACJ,KAAK,0BAAW,CAAC,IAAI;YACnB,OAAO;gBACL,IAAI,EAAE,EAAE,CAAC,IAAI;gBACb,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC;aAC/B,CAAC;QACJ;YACE,OAAO,EAAE,CAAC;IACd,CAAC;AACH,CAAC;AAED;;;;;GAKG;AACH,SAAgB,wBAAwB,CAAC,IAAoB;IAC3D,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,0BAAW,CAAC,IAAI,EAAE,CAAC;QAC3D,MAAM,IAAI,kCAAuB,CAAC,2DAA2D,CAAC,CAAC;IACjG,CAAC;IACD,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QAChC,IACE,KAAK,CAAC,IAAI,KAAK,0BAAW,CAAC,KAAK;YAChC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,KAAK,0BAAW,CAAC,iBAAiB;YACrD,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,KAAK,0BAAW,CAAC,IAAI;YAC1C,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,KAAK,0BAAW,CAAC,MAAM,EAC5C,CAAC;YACD,MAAM,IAAI,kCAAuB,CAAC,2DAA2D,CAAC,CAAC;QACjG,CAAC;QACD,OAAO;YACL,OAAO,EAAE,IAAA,yBAAU,EAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;YAClC,MAAM,EAAE,IAAA,wBAAS,EAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC;YACxC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC;SAC/C,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,iCAAiC,CAAC,IAAoB;IACpE,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACpB,MAAM,IAAI,kCAAuB,CAAC,sDAAsD,CAAC,CAAC;IAC5F,CAAC;IACD,IACE,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,0BAAW,CAAC,IAAI;QACjC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,0BAAW,CAAC,iBAAiB;QAC9C,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,0BAAW,CAAC,iBAAiB,EAC9C,CAAC;QACD,MAAM,IAAI,kCAAuB,CAAC,sDAAsD,CAAC,CAAC;IAC5F,CAAC;IACD,MAAM,mBAAmB,GAAG;QAC1B,MAAM,EAAE,IAAA,wBAAS,EAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC;QAChC,MAAM,EAAE,IAAA,yBAAU,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC3B,SAAS,EAAE,IAAA,yBAAU,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC;KAC/B,CAAC;IACF,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,0BAAW,CAAC,MAAM,EAAE,CAAC;QAC7D,mBAAmB,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACjE,CAAC;IACD,OAAO,mBAAmB,CAAC;AAC7B,CAAC;AAED;;;;;GAKG;AACH,SAAgB,iBAAiB,CAAC,OAAe;IAC/C,MAAM,WAAW,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC;IACvD,OAAO,IAAA,4BAAa,EAAC,WAAW,CAAC,CAAC,OAAO,CAAC;AAC5C,CAAC;AAED;;;;;GAKG;AACH,SAAgB,eAAe,CAAC,IAAY,EAAE,UAAU,GAAG,IAAI;IAC7D,OAAO,IAAI,UAAO,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC;AAC5D,CAAC;AAED;;;;;GAKG;AACH,SAAgB,cAAc,CAAC,OAAe;IAC5C,MAAM,cAAc,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;IAClD,OAAO,cAAc,CAAC,OAAO,CAAC;AAChC,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,iBAAiB,CAAC,OAAe,EAAE,WAAmB;IACpE,IAAI,CAAC,2BAA2B,CAAC,OAAO,CAAC,EAAE,CAAC;QAC1C,MAAM,IAAI,qBAAU,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAC;IACtD,CAAC;IACD,OAAO,cAAc,CAAC,OAAO,CAAC,KAAK,cAAc,CAAC,WAAW,CAAC,CAAC;AACjE,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,uBAAuB,CAAC,eAAuB,EAAE,YAAoB;IACnF,CAAC;QACC,MAAM,SAAS,GAAG,eAAK;aACpB,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,YAAY,oBAAU,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,eAAe,IAAI,YAAY,EAAE,CAAC,CAAC;aAC3G,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,OAAO,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC9C,CAAC;AACH,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,kCAAkC,CAAC,eAAuB,EAAE,YAAoB;IAC9F,CAAC;QACC,MAAM,UAAU,GAAG,eAAK;aACrB,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,YAAY,oBAAU,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,eAAe,IAAI,YAAY,EAAE,CAAC,CAAC;aAC3G,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAkB,CAAC,CAAC;QACrC,OAAO,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACvE,CAAC;AACH,CAAC;AAED;;;;;GAKG;AACH,SAAgB,kCAAkC,CAAC,OAAe;IAChE,MAAM,CAAC,WAAW,EAAE,WAAW,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACtD,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC,WAAW,CAAC,CAAC;IAChD,MAAM,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAEpC,OAAO;QACL,OAAO,EAAE,WAAW;QACpB,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;KACpC,CAAC;AACJ,CAAC","sourcesContent":["import * as url from 'url';\nimport BigNumber from 'bignumber.js';\nimport { bufferToHex, stripHexPrefix } from 'ethereumjs-util';\nimport {\n  addressFromPublicKeys,\n  addressFromVersionHash,\n  AddressHashMode,\n  addressHashModeToVersion,\n  addressToString,\n  AddressVersion,\n  BufferReader,\n  ClarityType,\n  ClarityValue,\n  createAddress,\n  createMemoString,\n  createMessageSignature,\n  createStacksPrivateKey,\n  createStacksPublicKey,\n  cvToString,\n  cvToValue,\n  deserializeTransaction,\n  PubKeyEncoding,\n  publicKeyFromSignature,\n  signWithKey,\n  StacksTransaction,\n  TransactionVersion,\n  validateStacksAddress,\n} from '@stacks/transactions';\nimport { secp256k1 } from '@noble/curves/secp256k1';\nimport * as _ from 'lodash';\nimport { InvalidTransactionError, isValidXprv, isValidXpub, SigningError, UtilsError } from '@bitgo/sdk-core';\nimport { AddressDetails, SendParams, TokenTransferParams } from './iface';\nimport { KeyPair } from '.';\nimport { coins, Sip10Token, StacksNetwork as BitgoStacksNetwork } from '@bitgo/statics';\nimport { VALID_CONTRACT_FUNCTION_NAMES } from './constants';\n\n/**\n * Encodes a buffer as a \"0x\" prefixed lower-case hex string.\n *\n * @param {Buffer} buff - a buffer with a hexadecimal string\n * @returns {string} - the hexadecimal string prefixed with \"0x\"\n */\nexport function bufferToHexPrefixString(buff: Buffer): string {\n  return bufferToHex(buff);\n}\n\n/**\n * Remove the \"0x\" prefix from the given string, if present.\n *\n * @param {string} hex - a hexadecimal string\n * @returns {string} - the hexadecimal string without a leading \"0x\"\n */\nexport function removeHexPrefix(hex: string): string {\n  return stripHexPrefix(hex);\n}\n\n/**\n * Get stacks address from public key hash\n *\n * @param {Buffer} publicKeyHash - hash of public key\n * @param {AddressHashMode} hashMode - hash mode\n * @param {TransactionVersion} transactionVersion - tx version\n * @returns {string} stacks address\n */\nfunction getAddressFromPublicKeyHash(\n  publicKeyHash: Buffer,\n  hashMode: AddressHashMode,\n  transactionVersion: TransactionVersion\n): string {\n  if (publicKeyHash.length !== 20) {\n    throw new Error('expected 20-byte pubkeyhash');\n  }\n\n  const addrVer = addressHashModeToVersion(hashMode, transactionVersion);\n  const addr = addressFromVersionHash(addrVer, publicKeyHash.toString('hex'));\n  const addrString = addressToString(addr);\n  return addrString;\n}\n\n/**\n * @param tx\n */\nexport function getTxSenderAddress(tx: StacksTransaction): string {\n  if (tx.auth.spendingCondition !== null && tx.auth.spendingCondition !== undefined) {\n    const spendingCondition = tx.auth.spendingCondition;\n    const txSender = getAddressFromPublicKeyHash(\n      Buffer.from(spendingCondition.signer, 'hex'),\n      spendingCondition.hashMode as number,\n      tx.version\n    );\n    return txSender;\n  } else throw new Error('spendingCondition should not be null');\n}\n\n/**\n * Returns whether or not the string is a valid amount number\n *\n * @param {string} amount - the string to validate\n * @returns {boolean} - the validation result\n */\nexport function isValidAmount(amount: string): boolean {\n  const bigNumberAmount = new BigNumber(amount);\n  return bigNumberAmount.isInteger() && bigNumberAmount.isGreaterThanOrEqualTo(0);\n}\n\n/**\n * Returns whether or not the string is a valid protocol address\n *\n * @param {string} address - the address to be validated\n * @returns {boolean} - the validation result\n */\nexport function isValidAddress(address: string): boolean {\n  return validateStacksAddress(address);\n}\n\n/**\n * Returns whether or not the string is a valid protocol transaction id or not.\n *\n * A valid transaction id is a SHA-512/256 hash of a serialized transaction; see\n * the txidFromData function in @stacks/transaction:\n * https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/utils.ts#L97\n *\n * @param {string} txId - the transaction id to be validated\n * @returns {boolean} - the validation result\n */\nexport function isValidTransactionId(txId: string): boolean {\n  if (txId.length !== 64 && txId.length !== 66) return false;\n  const noPrefix = removeHexPrefix(txId);\n  if (noPrefix.length !== 64) return false;\n\n  return allHexChars(noPrefix);\n}\n\n/**\n * Returns whether or not the string is a valid protocol public key or\n * extended public key.\n *\n * The key format is documented at\n * https://github.com/stacksgov/sips/blob/main/sips/sip-005/sip-005-blocks-and-transactions.md#transaction-authorization\n *\n * @param {string} pub - the  public key to be validated\n * @returns {boolean} - the validation result\n */\nexport function isValidPublicKey(pub: string): boolean {\n  if (isValidXpub(pub)) return true;\n\n  if (pub.length !== 66 && pub.length !== 130) return false;\n\n  const firstByte = pub.slice(0, 2);\n\n  // uncompressed public key\n  if (pub.length === 130 && firstByte !== '04') return false;\n\n  // compressed public key\n  if (pub.length === 66 && firstByte !== '02' && firstByte !== '03') return false;\n\n  if (!allHexChars(pub)) return false;\n\n  // validate the public key\n  try {\n    secp256k1.ProjectivePoint.fromHex(pub);\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Returns whether or not the string is a valid protocol private key, or extended\n * private key.\n *\n * The protocol key format is described in the @stacks/transactions npm package, in the\n * createStacksPrivateKey function:\n * https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/keys.ts#L125\n *\n * @param {string} prv - the private key (or extended private key) to be validated\n * @returns {boolean} - the validation result\n */\nexport function isValidPrivateKey(prv: string): boolean {\n  if (isValidXprv(prv)) return true;\n\n  if (prv.length !== 64 && prv.length !== 66) return false;\n\n  if (prv.length === 66 && prv.slice(64) !== '01') return false;\n\n  return allHexChars(prv);\n}\n\n/**\n * Returns whether or not the string is a composed of hex chars only\n *\n * @param {string} maybe - the  string to be validated\n * @returns {boolean} - the validation result\n */\nfunction allHexChars(maybe: string): boolean {\n  return /^([0-9a-f])+$/i.test(maybe);\n}\n\n/**\n * Checks if raw transaction can be deserialized\n *\n * @param {unknown} rawTransaction - transaction in raw hex format\n * @returns {boolean} - the validation result\n */\nexport function isValidRawTransaction(rawTransaction: unknown): boolean {\n  try {\n    if (typeof rawTransaction === 'string') {\n      deserializeTransaction(BufferReader.fromBuffer(Buffer.from(removeHexPrefix(rawTransaction), 'hex')));\n    } else {\n      return false;\n    }\n  } catch (e) {\n    return false;\n  }\n\n  return true;\n}\n\n/**\n * Returns whether or not the memo string is valid\n *\n * @param {string} memo - the string to be validated\n * @returns {boolean} - the validation result\n */\nexport function isValidMemo(memo: string): boolean {\n  try {\n    createMemoString(memo);\n  } catch (e) {\n    return false;\n  }\n\n  return true;\n}\n\n/**\n * Checks for valid contract address\n *\n * @param {string} addr - contract deployer address\n * @param {BitgoStacksNetwork} network - network object\n * @returns {boolean} - the validation result\n */\nexport function isValidContractAddress(addr: string, network: BitgoStacksNetwork): boolean {\n  return addr === network.stakingContractAddress || addr === network.sendmanymemoContractAddress;\n}\n\n/**\n * Check if the name is one of valid contract names\n *\n * @param {string} name - function name\n * @returns {boolean} - validation result\n */\nexport function isValidContractFunctionName(name: string): boolean {\n  return VALID_CONTRACT_FUNCTION_NAMES.includes(name);\n}\n\n/**\n * Unpads a memo string, so it removes nulls.\n *\n * Useful when memo is fill up the length. Result is becomes readable.\n *\n * @param {string} memo - the string to be validated\n * @returns {boolean} - the validation result\n */\nexport function unpadMemo(memo: string): string {\n  const end = memo.indexOf('\\u0000');\n  if (end < 0) return memo;\n  return memo.slice(0, end);\n}\n\n/**\n * Generate a multisig address from multiple STX public keys\n *\n * @param {string[]} pubKeys - list of public keys as strings\n * @param {AddressVersion} addressVersion - MainnetMultiSig, TestnetMultiSig\n * @param {AddressHashMode} addressHashMode - SerializeP2SH\n * @param {number} [signaturesRequired] - number of signatures required, default value its 2\n * @returns {address: string, hash160: string} - a multisig address\n */\nexport function getSTXAddressFromPubKeys(\n  pubKeys: string[],\n  addressVersion: AddressVersion = AddressVersion.MainnetMultiSig,\n  addressHashMode: AddressHashMode = AddressHashMode.SerializeP2SH,\n  signaturesRequired = 2\n): { address: string; hash160: string } {\n  if (pubKeys.length === 0) {\n    throw new Error('Invalid number of public keys');\n  }\n  if (!pubKeys.every(isValidPublicKey)) {\n    throw new Error('Invalid public keys');\n  }\n  if (signaturesRequired > pubKeys.length) {\n    throw new Error('Number of signatures required must be lower or equal to the number of Public Keys');\n  }\n\n  const stxPubKeys = pubKeys.map(createStacksPublicKey);\n  const address = addressFromPublicKeys(addressVersion, addressHashMode, signaturesRequired, stxPubKeys);\n\n  return { address: addressToString(address), hash160: address.hash160 };\n}\n\n/**\n * signs a string message\n *\n * @param keyPair\n * @param data  - message to be signed\n * @returns signed message string\n */\nexport function signMessage(keyPair: KeyPair, data: string): string {\n  const prv = keyPair.getKeys().prv;\n  if (prv) {\n    return signWithKey(createStacksPrivateKey(prv), data).data;\n  } else {\n    throw new SigningError('Missing private key');\n  }\n}\n\n/**\n * Verifies a signed message\n *\n * The signature must be 130 bytes long -- see RECOVERABLE_ECDSA_SIG_LENGTH_BYTES\n * in @stacks/transactions/src/constants.ts\n *\n * @param {string} message - message to verify the signature\n * @param {string} signature - signature to verify\n * @param {string} publicKey - public key as hex string used to verify the signature\n * @returns {boolean} - verification result\n */\nexport function verifySignature(message: string, signature: string, publicKey: string): boolean {\n  if (!isValidPublicKey(publicKey)) return false;\n  if (signature.length !== 130) return false;\n  if (!allHexChars(signature)) throw new UtilsError('Invalid signature input to verifySignature');\n  if (_.isEmpty(message)) throw new UtilsError('Cannot verify empty messages');\n\n  // provided publicKey can be compressed or uncompressed\n  const keyEncoding = publicKey.length === 66 ? PubKeyEncoding.Compressed : PubKeyEncoding.Uncompressed;\n\n  const messageSig = createMessageSignature(signature);\n\n  const foundKey = publicKeyFromSignature(message, messageSig, keyEncoding);\n\n  return foundKey === publicKey;\n}\n\n/**\n * Process address into address and memo id\n *\n * @param {string} address the address to process\n * @returns {Object} object containing address and memo id\n */\nexport function getAddressDetails(address: string): AddressDetails {\n  const addressDetails = url.parse(address);\n  const queryDetails = addressDetails.query ? new URLSearchParams(addressDetails.query) : undefined;\n  const baseAddress = addressDetails.pathname as string;\n  if (!isValidAddress(baseAddress)) {\n    throw new UtilsError(`invalid address: ${address}`);\n  }\n  // address doesn't have a memo id\n  if (baseAddress === address) {\n    return {\n      address: address,\n      memoId: undefined,\n    };\n  }\n\n  if (!queryDetails || _.isNil(queryDetails.get('memoId'))) {\n    // if there are more properties, the query details need to contain the memo id property\n    throw new UtilsError(`invalid address with memo id: ${address}`);\n  }\n  const memoId = queryDetails.get('memoId') as string;\n  const intMemoId = parseInt(memoId, 10);\n  if (isNaN(intMemoId) || intMemoId < 0) {\n    throw new Error(`invalid memo id: ${memoId}`);\n  }\n\n  return {\n    address: baseAddress,\n    memoId,\n  };\n}\n\n/**\n * Validate and return address with appended memo id\n *\n * @param {AddressDetails} addressDetails\n * @returns {string} address with memo id\n */\nexport function normalizeAddress({ address, memoId }: AddressDetails): string {\n  if (!isValidAddress(address)) {\n    throw new UtilsError(`invalid address: ${address}`);\n  }\n  if (!_.isUndefined(memoId)) {\n    const intMemoId = parseInt(memoId, 10);\n    if (isNaN(intMemoId) || intMemoId < 0) {\n      throw new Error(`invalid memo id: ${memoId}`);\n    }\n    return `${address}?memoId=${memoId}`;\n  }\n  return address;\n}\n\n/**\n * Return boolean indicating whether input is a valid address with memo id\n *\n * @param {string} address address in the form <address>?memoId=<memoId>\n * @returns {boolean} true is input is a valid address\n */\nexport function isValidAddressWithPaymentId(address: string): boolean {\n  try {\n    const addressDetails = getAddressDetails(address);\n    return address === normalizeAddress(addressDetails);\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Return string representation of clarity value input\n *\n * @param {ClarityValue} cv clarity value function argument\n * @returns {String} stringified clarity value\n */\nexport function stringifyCv(cv: ClarityValue): any {\n  switch (cv.type) {\n    case ClarityType.Int:\n    case ClarityType.UInt:\n      return { type: cv.type, value: cv.value.toString() };\n    case ClarityType.OptionalSome:\n      return { type: cv.type, value: stringifyCv(cv.value) };\n    case ClarityType.Tuple:\n      return {\n        type: cv.type,\n        data: _.mapValues(cv.data, (value) => stringifyCv(value)),\n      };\n    case ClarityType.List:\n      return {\n        type: cv.type,\n        list: cv.list.map(stringifyCv),\n      };\n    default:\n      return cv;\n  }\n}\n\n/**\n * Parse functionArgs into send params for send-many-memo contract calls\n *\n * @param {ClarityValue[]} args functionArgs from a contract call payload\n * @returns {SendParams[]} An array of sendParams\n */\nexport function functionArgsToSendParams(args: ClarityValue[]): SendParams[] {\n  if (args.length !== 1 || args[0].type !== ClarityType.List) {\n    throw new InvalidTransactionError(\"function args don't match send-many-memo type declaration\");\n  }\n  return args[0].list.map((tuple) => {\n    if (\n      tuple.type !== ClarityType.Tuple ||\n      tuple.data.to?.type !== ClarityType.PrincipalStandard ||\n      tuple.data.ustx?.type !== ClarityType.UInt ||\n      tuple.data.memo?.type !== ClarityType.Buffer\n    ) {\n      throw new InvalidTransactionError(\"function args don't match send-many-memo type declaration\");\n    }\n    return {\n      address: cvToString(tuple.data.to),\n      amount: cvToValue(tuple.data.ustx, true),\n      memo: tuple.data.memo.buffer.toString('ascii'),\n    };\n  });\n}\n\nexport function functionArgsToTokenTransferParams(args: ClarityValue[]): TokenTransferParams {\n  if (args.length < 3) {\n    throw new InvalidTransactionError(\"function args don't match token transfer declaration\");\n  }\n  if (\n    args[0].type !== ClarityType.UInt ||\n    args[1].type !== ClarityType.PrincipalStandard ||\n    args[2].type !== ClarityType.PrincipalStandard\n  ) {\n    throw new InvalidTransactionError(\"function args don't match token transfer declaration\");\n  }\n  const tokenTransferParams = {\n    amount: cvToValue(args[0], true),\n    sender: cvToString(args[1]),\n    recipient: cvToString(args[2]),\n  };\n  if (args.length === 4 && args[3].type === ClarityType.Buffer) {\n    tokenTransferParams['memo'] = args[3].buffer.toString('ascii');\n  }\n  return tokenTransferParams;\n}\n\n/**\n * Gets the version of an address\n *\n * @param {String} address the address with or without the memoId\n * @returns {AddressVersion} A number that represent the Address Version\n */\nexport function getAddressVersion(address: string): AddressVersion {\n  const baseAddress = getAddressDetails(address).address;\n  return createAddress(baseAddress).version;\n}\n\n/**\n * Returns a STX pub key from an xpub\n *\n * @param {String} xpub an xpub\n * @returns {String} a compressed STX pub key\n */\nexport function xpubToSTXPubkey(xpub: string, compressed = true): string {\n  return new KeyPair({ pub: xpub }).getKeys(compressed).pub;\n}\n\n/**\n * Returns the base address portion of an address\n *\n * @param {String} address - an address\n * @returns {String} - the base address\n */\nexport function getBaseAddress(address: string): string {\n  const addressDetails = getAddressDetails(address);\n  return addressDetails.address;\n}\n\n/**\n * Compares an address to the base address to check if matchs.\n *\n * @param {String} address - an address\n * @param {String} baseAddress - a base address\n * @returns {boolean}\n */\nexport function isSameBaseAddress(address: string, baseAddress: string): boolean {\n  if (!isValidAddressWithPaymentId(address)) {\n    throw new UtilsError(`invalid address: ${address}`);\n  }\n  return getBaseAddress(address) === getBaseAddress(baseAddress);\n}\n\n/**\n * Function to get tokenName from list of sip10 tokens using contract details\n *\n * @param {String} contractAddress\n * @param {String} contractName\n * @returns {String|Undefined}\n */\nexport function findTokenNameByContract(contractAddress: string, contractName: string): string | undefined {\n  {\n    const tokenName = coins\n      .filter((coin) => coin instanceof Sip10Token && coin.assetId.includes(`${contractAddress}.${contractName}`))\n      .map((coin) => coin.name);\n    return tokenName ? tokenName[0] : undefined;\n  }\n}\n\n/**\n * Function to get contractTokenName from list of sip10 tokens using contract details\n *\n * @param {String} contractAddress\n * @param {String} contractName\n * @returns {String|Undefined}\n */\nexport function findContractTokenNameUsingContract(contractAddress: string, contractName: string): string | undefined {\n  {\n    const sip10Token = coins\n      .filter((coin) => coin instanceof Sip10Token && coin.assetId.includes(`${contractAddress}.${contractName}`))\n      .map((coin) => coin as Sip10Token);\n    return sip10Token ? sip10Token[0].assetId.split('::')[1] : undefined;\n  }\n}\n\n/**\n * Function to get address and memo details from address input\n *\n * @param address\n * @returns {AddressDetails}\n */\nexport function getMemoIdAndBaseAddressFromAddress(address: string): AddressDetails {\n  const [baseAddress, queryString] = address.split('?');\n  const params = new URLSearchParams(queryString);\n  const memoId = params.get('memoId');\n\n  return {\n    address: baseAddress,\n    memoId: memoId ? memoId : undefined,\n  };\n}\n"]}

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


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