| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245 | import { AbiCoder } from './ethersUtils.js';import { TronWeb } from '../tronweb.js';import { ADDRESS_PREFIX, ADDRESS_PREFIX_REGEX } from './address.js';const abiCoder = new AbiCoder();function _addressToHex(value) {    return TronWeb.address.toHex(value).replace(ADDRESS_PREFIX_REGEX, '0x');}export function decodeParams(names, types, output, ignoreMethodHash = false) {    if (ignoreMethodHash && output.replace(/^0x/, '').length % 64 === 8)        output = '0x' + output.replace(/^0x/, '').substring(8);    if (output.replace(/^0x/, '').length % 64) {        throw new Error('The encoded string is not valid. Its length must be a multiple of 64.');    }    // workaround for unsupported trcToken type    types = types.map((type) => {        if (/trcToken/.test(type)) {            type = type.replace(/trcToken/, 'uint256');        }        return type;    });    return abiCoder.decode(types, output).reduce((obj, arg, index) => {        if (types[index] == 'address') {            arg = ADDRESS_PREFIX + arg.substr(2).toLowerCase();        }        if (names.length) {            obj[names[index]] = arg;        }        else {            obj.push(arg);        }        return obj;    }, names.length ? {} : []);}export function encodeParams(types, values) {    for (let i = 0; i < types.length; i++) {        if (types[i] === 'address') {            values[i] = TronWeb.address.toHex(values[i]).replace(ADDRESS_PREFIX_REGEX, '0x');        }    }    return abiCoder.encode(types, values);}function extractSize(type) {    const size = type.match(/([a-zA-Z0-9])(\[.*\])/);    return size ? size[2] : '';}function extractArrayDim(type) {    const size = extractSize(type);    return (size.match(/\]\[/g) || []).length + 1;}export function encodeParamsV2ByABI(funABI, args) {    const types = [];    const buildFullTypeDefinition = (typeDef) => {        if (typeDef && typeDef.type.indexOf('tuple') === 0 && typeDef.components) {            const innerTypes = typeDef.components.map((innerType) => {                return buildFullTypeDefinition(innerType);            });            return `tuple(${innerTypes.join(',')})${extractSize(typeDef.type)}`;        }        if (/trcToken/.test(typeDef.type))            return typeDef.type.replace(/trcToken/, 'uint256');        return typeDef.type;    };    const convertTypes = (types) => {        for (let i = 0; i < types.length; i++) {            const type = types[i];            if (/trcToken/.test(type))                types[i] = type.replace(/trcToken/, 'uint256');        }    };    const convertAddresses = (addrArr) => {        if (Array.isArray(addrArr)) {            addrArr.forEach((addrs, i) => {                addrArr[i] = convertAddresses(addrs);            });            return addrArr;        }        else {            return _addressToHex(addrArr);        }    };    const mapTuple = (components, args, dimension) => {        if (dimension > 1) {            if (args.length) {                args.forEach((arg) => {                    mapTuple(components, arg, dimension - 1);                });            }        }        else {            if (args.length && dimension) {                args.forEach((arg) => {                    encodeArgs(components, arg);                });            }        }    };    const encodeArgs = (inputs = [], args) => {        if (inputs.length)            inputs.forEach((input, i) => {                const type = input.type;                if (args[i])                    if (type === 'address')                        args[i] = _addressToHex(args[i]);                    else if (type.match(/^([^\x5b]*)(\x5b|$)/)[0] === 'address[')                        convertAddresses(args[i]);                    else if (type.indexOf('tuple') === 0)                        if (extractSize(type)) {                            const dimension = extractArrayDim(type);                            mapTuple(input.components, args[i], dimension);                        }                        else                            encodeArgs(input.components, args[i]);            });    };    if (funABI.inputs && funABI.inputs.length) {        for (let i = 0; i < funABI.inputs.length; i++) {            const type = funABI.inputs[i].type;            // "false" will be converting to `false` and "true" will be working            // fine as abiCoder assume anything in quotes as `true`            if (type === 'bool' && args[i] === 'false') {                args[i] = false;            }            types.push(type.indexOf('tuple') === 0 ? buildFullTypeDefinition(funABI.inputs[i]) : type);            if (args.length < types.length) {                args.push('');            }        }    }    encodeArgs(funABI.inputs, args);    convertTypes(types);    return abiCoder.encode(types, args);}export function decodeParamsV2ByABI(funABI, data) {    const convertTypeNames = (types) => {        for (let i = 0; i < types.length; i++) {            const type = types[i];            if (/^trcToken/.test(type))                types[i] = type.replace(/^trcToken/, 'uint256');        }    };    const convertAddresses = (addrArr) => {        if (Array.isArray(addrArr)) {            addrArr.forEach((addrs, i) => {                addrArr[i] = convertAddresses(addrs);            });            return addrArr;        }        else {            return TronWeb.address.toHex(addrArr);        }    };    const mapTuple = (components, args, dimension) => {        if (dimension > 1) {            if (args.length) {                args.forEach((arg) => {                    mapTuple(components, arg, dimension - 1);                });            }        }        else {            if (args.length && dimension) {                args.forEach((arg) => {                    decodeResult(components, arg);                });            }        }    };    const buildFullTypeNameDefinition = (typeDef) => {        const name = typeDef.name ? ` ${typeDef.name}` : '';        if (typeDef && typeDef.type.indexOf('tuple') === 0 && typeDef.components) {            const innerTypes = typeDef.components.map((innerType) => {                return buildFullTypeNameDefinition(innerType);            });            return `tuple(${innerTypes.join(',')})${extractSize(typeDef.type)}${name}`;        }        if (/trcToken/.test(typeDef.type))            return typeDef.type.replace(/trcToken/, 'uint256') + name;        return typeDef.type + name;    };    const decodeResult = (outputs, result) => {        if (outputs.length)            outputs.forEach((output, i) => {                const { type, name } = output;                if (result[i]) {                    if (type === 'address') {                        result[i] = TronWeb.address.toHex(result[i]);                        // eslint-disable-next-line @typescript-eslint/ban-ts-comment                        //@ts-ignore                        if (name)                            result[name] = TronWeb.address.toHex(result[i]);                    }                    else if (type.match(/^([^\x5b]*)(\x5b|$)/)[0] === 'address[') {                        convertAddresses(result[i]);                        // eslint-disable-next-line @typescript-eslint/ban-ts-comment                        //@ts-ignore                        if (name)                            result[name] = convertAddresses(result[i]);                    }                    else if (type.indexOf('tuple') === 0) {                        if (extractSize(type)) {                            const dimension = extractArrayDim(type);                            mapTuple(output.components, result[i], dimension);                        }                        else                            decodeResult(output.components, result[i]);                        // eslint-disable-next-line @typescript-eslint/ban-ts-comment                        //@ts-ignore                        if (name)                            result[name] = result[i];                    }                    else {                        // eslint-disable-next-line @typescript-eslint/ban-ts-comment                        //@ts-ignore                        if (name)                            result[name] = result[i];                    }                }                else {                    // eslint-disable-next-line @typescript-eslint/ban-ts-comment                    //@ts-ignore                    if (name)                        result[name] = result[i];                }            });    };    // Only decode if there supposed to be fields    if ('outputs' in funABI && funABI.outputs && funABI.outputs.length > 0) {        const outputTypes = [];        for (let i = 0; i < funABI.outputs.length; i++) {            const type = funABI.outputs[i].type;            const name = funABI.outputs[i].name ? ` ${funABI.outputs[i].name}` : '';            outputTypes.push(type.indexOf('tuple') === 0 ? buildFullTypeNameDefinition(funABI.outputs[i]) : type + name);        }        convertTypeNames(outputTypes);        if (!data || !data.length)            data = new Uint8Array(32 * funABI.outputs.length); // ensuring the data is at least filled by 0 cause `AbiCoder` throws if there's not engouh data        // decode data        const decodeRes = abiCoder.decode(outputTypes, data);        const decodeResCopy = decodeRes.toArray(true);        decodeResult(funABI.outputs, decodeResCopy);        return decodeResCopy;    }    return [];}//# sourceMappingURL=abi.js.map
 |