diff options
author | Leonid <logvinov.leon@gmail.com> | 2018-02-06 04:56:04 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-02-06 04:56:04 +0800 |
commit | 156e85a6b3347c8c7f3751632ef98757194a5ab0 (patch) | |
tree | c9a750032e3bd1664d66b94aeb91c072cf1de49d /packages/utils/src/abi_decoder.ts | |
parent | 4ddb86df53802fe5c965724d965d281528a97971 (diff) | |
parent | 6fce02d25e8133da16b1965cbd51b1edb74fcf7a (diff) | |
download | dexon-sol-tools-156e85a6b3347c8c7f3751632ef98757194a5ab0.tar dexon-sol-tools-156e85a6b3347c8c7f3751632ef98757194a5ab0.tar.gz dexon-sol-tools-156e85a6b3347c8c7f3751632ef98757194a5ab0.tar.bz2 dexon-sol-tools-156e85a6b3347c8c7f3751632ef98757194a5ab0.tar.lz dexon-sol-tools-156e85a6b3347c8c7f3751632ef98757194a5ab0.tar.xz dexon-sol-tools-156e85a6b3347c8c7f3751632ef98757194a5ab0.tar.zst dexon-sol-tools-156e85a6b3347c8c7f3751632ef98757194a5ab0.zip |
Merge pull request #366 from 0xProject/fix/abi_decoder_colision
Fix an exception when a signature collision happens
Diffstat (limited to 'packages/utils/src/abi_decoder.ts')
-rw-r--r-- | packages/utils/src/abi_decoder.ts | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/packages/utils/src/abi_decoder.ts b/packages/utils/src/abi_decoder.ts index f96ee2edb..368973b1b 100644 --- a/packages/utils/src/abi_decoder.ts +++ b/packages/utils/src/abi_decoder.ts @@ -18,7 +18,7 @@ export class AbiDecoder { return `0x${formatted}`; } constructor(abiArrays: Web3.AbiDefinition[][]) { - _.map(abiArrays, this._addABI.bind(this)); + _.forEach(abiArrays, this._addABI.bind(this)); } // This method can only decode logs from the 0x & ERC20 smart contracts public tryToDecodeLogOrNoop<ArgsType>(log: Web3.LogEntry): LogWithDecodedArgs<ArgsType> | RawLog { @@ -36,9 +36,14 @@ export class AbiDecoder { const dataTypes = _.map(nonIndexedInputs, input => input.type); const decodedData = SolidityCoder.decodeParams(dataTypes, logData.slice('0x'.length)); - _.map(event.inputs, (param: Web3.EventParameter) => { + let failedToDecode = false; + _.forEach(event.inputs, (param: Web3.EventParameter) => { // Indexed parameters are stored in topics. Non-indexed ones in decodedData let value: BigNumber | string = param.indexed ? log.topics[topicsIndex++] : decodedData[dataIndex++]; + if (_.isUndefined(value)) { + failedToDecode = true; + return; + } if (param.type === SolidityTypes.Address) { value = AbiDecoder._padZeros(new BigNumber(value).toString(16)); } else if ( @@ -51,11 +56,15 @@ export class AbiDecoder { decodedParams[param.name] = value; }); - return { - ...log, - event: event.name, - args: decodedParams, - }; + if (failedToDecode) { + return log; + } else { + return { + ...log, + event: event.name, + args: decodedParams, + }; + } } private _addABI(abiArray: Web3.AbiDefinition[]): void { _.map(abiArray, (abi: Web3.AbiDefinition) => { |