UNPKG

web3x

Version:

Typescript port of web3.js

224 lines (221 loc) 16.4 kB
"use strict"; /* This file is part of web3x. web3x is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. web3x is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with web3x. If not, see <http://www.gnu.org/licenses/>. */ Object.defineProperty(exports, "__esModule", { value: true }); const tslib_1 = require("tslib"); const bn_js_1 = tslib_1.__importDefault(require("bn.js")); const util_1 = require("util"); const address_1 = require("../address"); const bn_1 = require("./bn"); const hex_1 = require("./hex"); const hex_utf8_1 = require("./hex-utf8"); const padding_1 = require("./padding"); const sha3_1 = require("./sha3"); const elementaryName = name => { /*jshint maxcomplexity:false */ if (name.startsWith('int[')) { return 'int256' + name.slice(3); } else if (name === 'int') { return 'int256'; } else if (name.startsWith('uint[')) { return 'uint256' + name.slice(4); } else if (name === 'uint') { return 'uint256'; } else if (name.startsWith('fixed[')) { return 'fixed128x128' + name.slice(5); } else if (name === 'fixed') { return 'fixed128x128'; } else if (name.startsWith('ufixed[')) { return 'ufixed128x128' + name.slice(6); } else if (name === 'ufixed') { return 'ufixed128x128'; } return name; }; // Parse N from type<N> const parseTypeN = type => { const typesize = /^\D+(\d+).*$/.exec(type); return typesize ? parseInt(typesize[1], 10) : null; }; // Parse N from type[<N>] const parseTypeNArray = type => { const arraySize = /^\D+\d*\[(\d+)\]$/.exec(type); return arraySize ? parseInt(arraySize[1], 10) : null; }; const parseNumber = arg => { const type = typeof arg; if (type === 'string') { if (hex_1.isHexStrict(arg)) { return new bn_js_1.default(arg.replace(/0x/i, ''), 16); } else { return new bn_js_1.default(arg, 10); } } else if (type === 'number') { return new bn_js_1.default(arg); } else if (bn_1.isBN(arg)) { return arg; } else { throw new Error(arg + ' is not a number'); } }; const solidityPack = (type, value, arraySize) => { /*jshint maxcomplexity:false */ let size; let num; type = elementaryName(type); if (type === 'bytes') { if (value.replace(/^0x/i, '').length % 2 !== 0) { throw new Error('Invalid bytes characters ' + value.length); } return value; } else if (type === 'string') { return hex_utf8_1.utf8ToHex(value); } else if (type === 'bool') { return value ? '01' : '00'; } else if (type.startsWith('address')) { if (arraySize) { size = 64; } else { size = 40; } if (!address_1.Address.isAddress(value)) { throw new Error(value + ' is not a valid address, or the checksum is invalid.'); } return padding_1.leftPad(value.toLowerCase(), size); } size = parseTypeN(type); if (type.startsWith('bytes')) { if (!size) { throw new Error('bytes[] not yet supported in solidity'); } // must be 32 byte slices when in an array if (arraySize) { size = 32; } if (size < 1 || size > 32 || size < value.replace(/^0x/i, '').length / 2) { throw new Error('Invalid bytes' + size + ' for ' + value); } return padding_1.rightPad(value, size * 2); } else if (type.startsWith('uint')) { if (size % 8 || size < 8 || size > 256) { throw new Error('Invalid uint' + size + ' size'); } num = parseNumber(value); if (num.bitLength() > size) { throw new Error('Supplied uint exceeds width: ' + size + ' vs ' + num.bitLength()); } if (num.lt(new bn_js_1.default(0))) { throw new Error('Supplied uint ' + num.toString() + ' is negative'); } return size ? padding_1.leftPad(num.toString('hex'), (size / 8) * 2) : num; } else if (type.startsWith('int')) { if (size % 8 || size < 8 || size > 256) { throw new Error('Invalid int' + size + ' size'); } num = parseNumber(value); if (num.bitLength() > size) { throw new Error('Supplied int exceeds width: ' + size + ' vs ' + num.bitLength()); } if (num.lt(new bn_js_1.default(0))) { return num.toTwos(size).toString('hex'); } else { return size ? padding_1.leftPad(num.toString('hex'), (size / 8) * 2) : num; } } else { // FIXME: support all other types throw new Error('Unsupported or invalid type: ' + type); } }; const processSoliditySha3Args = arg => { /*jshint maxcomplexity:false */ if (util_1.isArray(arg)) { throw new Error('Autodetection of array types is not supported.'); } let type; let value = ''; let hexArg; let arraySize; // if type is given if (util_1.isObject(arg) && (arg.hasOwnProperty('v') || arg.hasOwnProperty('t') || arg.hasOwnProperty('value') || arg.hasOwnProperty('type'))) { type = arg.hasOwnProperty('t') ? arg.t : arg.type; value = arg.hasOwnProperty('v') ? arg.v : arg.value; // otherwise try to guess the type } else { type = hex_1.toHex(arg, true); value = hex_1.toHex(arg); if (!type.startsWith('int') && !type.startsWith('uint')) { type = 'bytes'; } } if ((type.startsWith('int') || type.startsWith('uint')) && typeof value === 'string' && !/^(-)?0x/i.test(value)) { value = new bn_js_1.default(value); } // get the array size if (util_1.isArray(value)) { arraySize = parseTypeNArray(type); if (arraySize && value.length !== arraySize) { throw new Error(type + ' is not matching the given array ' + JSON.stringify(value)); } else { arraySize = value.length; } } if (util_1.isArray(value)) { hexArg = value.map(val => { return solidityPack(type, val, arraySize) .toString('hex') .replace('0x', ''); }); return hexArg.join(''); } else { hexArg = solidityPack(type, value, arraySize); return hexArg.toString('hex').replace('0x', ''); } }; /** * Hashes solidity values to a sha3 hash using keccak 256 * * @method soliditySha3 * @return {Object} the sha3 */ exports.soliditySha3 = (...args) => { /*jshint maxcomplexity:false */ const hexArgs = args.map(processSoliditySha3Args); // console.log(args, hexArgs); // console.log('0x'+ hexArgs.join('')); return sha3_1.sha3('0x' + hexArgs.join('')); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"solidity-sha3.js","sourceRoot":"","sources":["../../src/utils/solidity-sha3.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;EAeE;;;AAEF,0DAAuB;AACvB,+BAAyC;AACzC,wCAAqC;AACrC,6BAA4B;AAC5B,+BAA2C;AAC3C,yCAAuC;AACvC,uCAA8C;AAC9C,iCAA8B;AAE9B,MAAM,cAAc,GAAG,IAAI,CAAC,EAAE;IAC5B,+BAA+B;IAE/B,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;QAC3B,OAAO,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KACjC;SAAM,IAAI,IAAI,KAAK,KAAK,EAAE;QACzB,OAAO,QAAQ,CAAC;KACjB;SAAM,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;QACnC,OAAO,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAClC;SAAM,IAAI,IAAI,KAAK,MAAM,EAAE;QAC1B,OAAO,SAAS,CAAC;KAClB;SAAM,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;QACpC,OAAO,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KACvC;SAAM,IAAI,IAAI,KAAK,OAAO,EAAE;QAC3B,OAAO,cAAc,CAAC;KACvB;SAAM,IAAI,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;QACrC,OAAO,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KACxC;SAAM,IAAI,IAAI,KAAK,QAAQ,EAAE;QAC5B,OAAO,eAAe,CAAC;KACxB;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,uBAAuB;AACvB,MAAM,UAAU,GAAG,IAAI,CAAC,EAAE;IACxB,MAAM,QAAQ,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3C,OAAO,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AACrD,CAAC,CAAC;AAEF,yBAAyB;AACzB,MAAM,eAAe,GAAG,IAAI,CAAC,EAAE;IAC7B,MAAM,SAAS,GAAG,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjD,OAAO,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AACvD,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,GAAG,CAAC,EAAE;IACxB,MAAM,IAAI,GAAG,OAAO,GAAG,CAAC;IACxB,IAAI,IAAI,KAAK,QAAQ,EAAE;QACrB,IAAI,iBAAW,CAAC,GAAG,CAAC,EAAE;YACpB,OAAO,IAAI,eAAE,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;SAC3C;aAAM;YACL,OAAO,IAAI,eAAE,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;SACxB;KACF;SAAM,IAAI,IAAI,KAAK,QAAQ,EAAE;QAC5B,OAAO,IAAI,eAAE,CAAC,GAAG,CAAC,CAAC;KACpB;SAAM,IAAI,SAAI,CAAC,GAAG,CAAC,EAAE;QACpB,OAAO,GAAG,CAAC;KACZ;SAAM;QACL,MAAM,IAAI,KAAK,CAAC,GAAG,GAAG,kBAAkB,CAAC,CAAC;KAC3C;AACH,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE;IAC9C,+BAA+B;IAE/B,IAAI,IAAI,CAAC;IACT,IAAI,GAAG,CAAC;IACR,IAAI,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;IAE5B,IAAI,IAAI,KAAK,OAAO,EAAE;QACpB,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,KAAK,CAAC,EAAE;YAC9C,MAAM,IAAI,KAAK,CAAC,2BAA2B,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;SAC7D;QAED,OAAO,KAAK,CAAC;KACd;SAAM,IAAI,IAAI,KAAK,QAAQ,EAAE;QAC5B,OAAO,oBAAS,CAAC,KAAK,CAAC,CAAC;KACzB;SAAM,IAAI,IAAI,KAAK,MAAM,EAAE;QAC1B,OAAO,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;KAC5B;SAAM,IAAI,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;QACrC,IAAI,SAAS,EAAE;YACb,IAAI,GAAG,EAAE,CAAC;SACX;aAAM;YACL,IAAI,GAAG,EAAE,CAAC;SACX;QAED,IAAI,CAAC,iBAAO,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,KAAK,GAAG,sDAAsD,CAAC,CAAC;SACjF;QAED,OAAO,iBAAO,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,CAAC;KAC3C;IAED,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;IAExB,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;QAC5B,IAAI,CAAC,IAAI,EAAE;YACT,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;SAC1D;QAED,0CAA0C;QAC1C,IAAI,SAAS,EAAE;YACb,IAAI,GAAG,EAAE,CAAC;SACX;QAED,IAAI,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YACxE,MAAM,IAAI,KAAK,CAAC,eAAe,GAAG,IAAI,GAAG,OAAO,GAAG,KAAK,CAAC,CAAC;SAC3D;QAED,OAAO,kBAAQ,CAAC,KAAK,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC;KAClC;SAAM,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;QAClC,IAAI,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,GAAG,EAAE;YACtC,MAAM,IAAI,KAAK,CAAC,cAAc,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC;SAClD;QAED,GAAG,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,GAAG,CAAC,SAAS,EAAE,GAAG,IAAI,EAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,+BAA+B,GAAG,IAAI,GAAG,MAAM,GAAG,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC;SACpF;QAED,IAAI,GAAG,CAAC,EAAE,CAAC,IAAI,eAAE,CAAC,CAAC,CAAC,CAAC,EAAE;YACrB,MAAM,IAAI,KAAK,CAAC,gBAAgB,GAAG,GAAG,CAAC,QAAQ,EAAE,GAAG,cAAc,CAAC,CAAC;SACrE;QAED,OAAO,IAAI,CAAC,CAAC,CAAC,iBAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;KAClE;SAAM,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;QACjC,IAAI,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,GAAG,EAAE;YACtC,MAAM,IAAI,KAAK,CAAC,aAAa,GAAG,IAAI,GAAG,OAAO,CAAC,CAAC;SACjD;QAED,GAAG,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,GAAG,CAAC,SAAS,EAAE,GAAG,IAAI,EAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,8BAA8B,GAAG,IAAI,GAAG,MAAM,GAAG,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC;SACnF;QAED,IAAI,GAAG,CAAC,EAAE,CAAC,IAAI,eAAE,CAAC,CAAC,CAAC,CAAC,EAAE;YACrB,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACzC;aAAM;YACL,OAAO,IAAI,CAAC,CAAC,CAAC,iBAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;SAClE;KACF;SAAM;QACL,iCAAiC;QACjC,MAAM,IAAI,KAAK,CAAC,+BAA+B,GAAG,IAAI,CAAC,CAAC;KACzD;AACH,CAAC,CAAC;AAEF,MAAM,uBAAuB,GAAG,GAAG,CAAC,EAAE;IACpC,+BAA+B;IAE/B,IAAI,cAAO,CAAC,GAAG,CAAC,EAAE;QAChB,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;KACnE;IAED,IAAI,IAAI,CAAC;IACT,IAAI,KAAK,GAAQ,EAAE,CAAC;IACpB,IAAI,MAAM,CAAC;IACX,IAAI,SAAS,CAAC;IAEd,mBAAmB;IACnB,IACE,eAAQ,CAAC,GAAG,CAAC;QACb,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,EACjH;QACA,IAAI,GAAG,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC;QAClD,KAAK,GAAG,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC;QAEpD,kCAAkC;KACnC;SAAM;QACL,IAAI,GAAG,WAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QACxB,KAAK,GAAG,WAAK,CAAC,GAAG,CAAC,CAAC;QAEnB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;YACvD,IAAI,GAAG,OAAO,CAAC;SAChB;KACF;IAED,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;QAC/G,KAAK,GAAG,IAAI,eAAE,CAAC,KAAK,CAAC,CAAC;KACvB;IAED,qBAAqB;IACrB,IAAI,cAAO,CAAC,KAAK,CAAC,EAAE;QAClB,SAAS,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,SAAS,EAAE;YAC3C,MAAM,IAAI,KAAK,CAAC,IAAI,GAAG,mCAAmC,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;SACrF;aAAM;YACL,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC;SAC1B;KACF;IAED,IAAI,cAAO,CAAC,KAAK,CAAC,EAAE;QAClB,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YACvB,OAAO,YAAY,CAAC,IAAI,EAAE,GAAG,EAAE,SAAS,CAAC;iBACtC,QAAQ,CAAC,KAAK,CAAC;iBACf,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;KACxB;SAAM;QACL,MAAM,GAAG,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;QAC9C,OAAO,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;KACjD;AACH,CAAC,CAAC;AAEF;;;;;GAKG;AACQ,QAAA,YAAY,GAAG,CAAC,GAAG,IAAW,EAAE,EAAE;IAC3C,+BAA+B;IAE/B,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,CAAC;IAElD,8BAA8B;IAC9B,uCAAuC;IAEvC,OAAO,WAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;AACvC,CAAC,CAAC"}