From b47e2a54381f0d5d53fca25f3ebbd1fe6351bc1e Mon Sep 17 00:00:00 2001 From: Chase Coleman Date: Thu, 18 Nov 2021 23:38:30 -0600 Subject: [PATCH 1/4] Implement fix proposed in #1484 --- tests/core/contracts/conftest.py | 2 + .../contracts/contract_sources/Emitter.sol | 25 +- .../contracts/test_extracting_event_data.py | 22 + web3/_utils/events.py | 3 +- .../_utils/module_testing/emitter_contract.py | 513 +++++++++--------- 5 files changed, 306 insertions(+), 259 deletions(-) diff --git a/tests/core/contracts/conftest.py b/tests/core/contracts/conftest.py index a3b97b745a..0bfdb4b977 100644 --- a/tests/core/contracts/conftest.py +++ b/tests/core/contracts/conftest.py @@ -943,6 +943,7 @@ class LogFunctions: LogTripleWithIndex = 10 LogQuadrupleWithIndex = 11 LogBytes = 12 + LogStructArgs = 13 @pytest.fixture() @@ -975,6 +976,7 @@ class LogTopics: LogListArgs = _encode_to_topic("LogListArgs(bytes2[],bytes2[])") LogAddressIndexed = _encode_to_topic("LogAddressIndexed(address,address)") LogAddressNotIndexed = _encode_to_topic("LogAddressNotIndexed(address,address)") + LogStructArgs = _encode_to_topic("LogStructArgs(uint256,tuple)") @pytest.fixture() diff --git a/tests/core/contracts/contract_sources/Emitter.sol b/tests/core/contracts/contract_sources/Emitter.sol index 5d38445e3a..dde4f80afa 100644 --- a/tests/core/contracts/contract_sources/Emitter.sol +++ b/tests/core/contracts/contract_sources/Emitter.sol @@ -1,4 +1,4 @@ -pragma solidity ^0.4.21; +pragma solidity ^0.8.7; contract Emitter { @@ -23,6 +23,13 @@ contract Emitter { event LogAddressIndexed(address indexed arg0, address arg1); event LogAddressNotIndexed(address arg0, address arg1); + // Nested type functionality + struct TestTuple { + uint a; + uint b; + } + event LogStructArgs(uint arg0, TestTuple arg1); + enum WhichEvent { LogAnonymous, LogNoArguments, @@ -41,7 +48,8 @@ contract Emitter { LogDynamicArgs, LogListArgs, LogAddressIndexed, - LogAddressNotIndexed + LogAddressNotIndexed, + LogStructArgs } function logNoArgs(WhichEvent which) public { @@ -76,11 +84,11 @@ contract Emitter { else revert("Didn't match any allowable event index"); } - function logDynamicArgs(string arg0, string arg1) public { + function logDynamicArgs(string memory arg0, string memory arg1) public { emit LogDynamicArgs(arg0, arg1); } - function logListArgs(bytes2[] arg0, bytes2[] arg1) public { + function logListArgs(bytes2[] memory arg0, bytes2[] memory arg1) public { emit LogListArgs(arg0, arg1); } @@ -92,11 +100,16 @@ contract Emitter { emit LogAddressNotIndexed(arg0, arg1); } - function logBytes(bytes v) public { + function logBytes(bytes memory v) public { emit LogBytes(v); } - function logString(string v) public { + function logString(string memory v) public { emit LogString(v); } + + function logStruct(uint arg0, TestTuple memory arg1) public { + emit LogStructArgs(arg0, arg1); + } } + diff --git a/tests/core/contracts/test_extracting_event_data.py b/tests/core/contracts/test_extracting_event_data.py index f503986985..cd0451d2ea 100644 --- a/tests/core/contracts/test_extracting_event_data.py +++ b/tests/core/contracts/test_extracting_event_data.py @@ -148,6 +148,12 @@ def dup_txn_receipt( [12345, 54321, 98765, 56789], {'arg0': 12345, 'arg1': 54321, 'arg2': 98765, 'arg3': 56789}, ), + ( + 'logStruct', + 'LogStructArgs', + [12345, {'a': 0, 'b': 1}], + {'arg0': 12345, 'arg1': {'a': 0, 'b': 1}}, + ) ) ) def test_event_data_extraction(web3, @@ -558,6 +564,22 @@ def test_argument_extraction_strict_bytes_types(w3_strict_abi, 'The event signature did not match the provided ABI', False, ), + ( + 'logStruct', + 'logStructArgs', + [12345, {'a': 0, 'b': 1}], + {'arg0': 12345, 'arg1': {'a': 0, 'b': 1}}, + 'The event signature did not match the provided ABI', + True, + ), + ( + 'logStruct', + 'logStructArgs', + [12345, {'a': 0, 'b': 1}], + {'arg0': 12345, 'arg1': {'a': 0, 'b': 1}}, + 'The event signature did not match the provided ABI', + False, + ), ) ) def test_event_rich_log( diff --git a/web3/_utils/events.py b/web3/_utils/events.py index 896535af7e..02bd974e40 100644 --- a/web3/_utils/events.py +++ b/web3/_utils/events.py @@ -39,6 +39,7 @@ to_hex, to_tuple, ) +from eth_utils.abi import collapse_if_tuple from eth_utils.curried import ( apply_formatter_if, ) @@ -193,7 +194,7 @@ def get_event_abi_types_for_decoding(event_inputs: Sequence[ABIEventParams]) -> if input_abi['indexed'] and is_dynamic_sized_type(input_abi['type']): yield 'bytes32' else: - yield input_abi['type'] + yield collapse_if_tuple(input_abi) @curry diff --git a/web3/_utils/module_testing/emitter_contract.py b/web3/_utils/module_testing/emitter_contract.py index 1cf7eb813f..3791c831af 100644 --- a/web3/_utils/module_testing/emitter_contract.py +++ b/web3/_utils/module_testing/emitter_contract.py @@ -149,219 +149,155 @@ CONTRACT_EMITTER_ABI = [ { - "constant": False, - "inputs": [ - { - "name": "v", - "type": "string" - } - ], - "name": "logString", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" - }, - { - "constant": False, - "inputs": [ - { - "name": "which", - "type": "uint8" - } - ], - "name": "logNoArgs", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" - }, - { - "constant": False, + "anonymous": False, "inputs": [ { - "name": "which", - "type": "uint8" - }, - { + "indexed": True, + "internalType": "address", "name": "arg0", - "type": "uint256" + "type": "address" }, { + "indexed": False, + "internalType": "address", "name": "arg1", - "type": "uint256" - }, - { - "name": "arg2", - "type": "uint256" - }, - { - "name": "arg3", - "type": "uint256" + "type": "address" } ], - "name": "logQuadruple", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" + "name": "LogAddressIndexed", + "type": "event" }, { - "constant": False, + "anonymous": False, "inputs": [ { - "name": "which", - "type": "uint8" - }, - { + "indexed": False, + "internalType": "address", "name": "arg0", - "type": "uint256" + "type": "address" }, { + "indexed": False, + "internalType": "address", "name": "arg1", - "type": "uint256" + "type": "address" } ], - "name": "logDouble", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" + "name": "LogAddressNotIndexed", + "type": "event" + }, + { + "anonymous": True, + "inputs": [], + "name": "LogAnonymous", + "type": "event" }, { - "constant": False, + "anonymous": False, "inputs": [ { - "name": "arg0", - "type": "bytes2[]" - }, - { - "name": "arg1", - "type": "bytes2[]" + "indexed": False, + "internalType": "bytes", + "name": "v", + "type": "bytes" } ], - "name": "logListArgs", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" + "name": "LogBytes", + "type": "event" }, { - "constant": False, + "anonymous": True, "inputs": [ { - "name": "which", - "type": "uint8" - }, - { + "indexed": False, + "internalType": "uint256", "name": "arg0", "type": "uint256" }, { + "indexed": True, + "internalType": "uint256", "name": "arg1", "type": "uint256" - }, - { - "name": "arg2", - "type": "uint256" } ], - "name": "logTriple", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" + "name": "LogDoubleAnonymous", + "type": "event" }, { - "constant": False, + "anonymous": False, "inputs": [ { - "name": "which", - "type": "uint8" + "indexed": False, + "internalType": "uint256", + "name": "arg0", + "type": "uint256" }, { - "name": "arg0", + "indexed": False, + "internalType": "uint256", + "name": "arg1", "type": "uint256" } ], - "name": "logSingle", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" + "name": "LogDoubleArg", + "type": "event" }, { - "constant": False, + "anonymous": False, "inputs": [ { + "indexed": False, + "internalType": "uint256", "name": "arg0", - "type": "string" + "type": "uint256" }, { + "indexed": True, + "internalType": "uint256", "name": "arg1", - "type": "string" + "type": "uint256" } ], - "name": "logDynamicArgs", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" + "name": "LogDoubleWithIndex", + "type": "event" }, { - "constant": False, + "anonymous": False, "inputs": [ { + "indexed": True, + "internalType": "string", "name": "arg0", - "type": "address" + "type": "string" }, { + "indexed": False, + "internalType": "string", "name": "arg1", - "type": "address" - } - ], - "name": "logAddressIndexedArgs", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" - }, - { - "constant": False, - "inputs": [ - { - "name": "v", - "type": "bytes" + "type": "string" } ], - "name": "logBytes", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" + "name": "LogDynamicArgs", + "type": "event" }, { - "constant": False, + "anonymous": False, "inputs": [ { + "indexed": True, + "internalType": "bytes2[]", "name": "arg0", - "type": "address" + "type": "bytes2[]" }, { + "indexed": False, + "internalType": "bytes2[]", "name": "arg1", - "type": "address" + "type": "bytes2[]" } ], - "name": "logAddressNotIndexedArgs", - "outputs": [], - "payable": False, - "stateMutability": "nonpayable", - "type": "function" - }, - { - "anonymous": True, - "inputs": [], - "name": "LogAnonymous", + "name": "LogListArgs", "type": "event" }, { @@ -375,50 +311,30 @@ "inputs": [ { "indexed": False, - "name": "arg0", - "type": "uint256" - } - ], - "name": "LogSingleArg", - "type": "event" - }, - { - "anonymous": False, - "inputs": [ - { - "indexed": False, + "internalType": "uint256", "name": "arg0", "type": "uint256" }, { "indexed": False, + "internalType": "uint256", "name": "arg1", "type": "uint256" - } - ], - "name": "LogDoubleArg", - "type": "event" - }, - { - "anonymous": False, - "inputs": [ - { - "indexed": False, - "name": "arg0", - "type": "uint256" }, { "indexed": False, - "name": "arg1", + "internalType": "uint256", + "name": "arg2", "type": "uint256" }, { "indexed": False, - "name": "arg2", + "internalType": "uint256", + "name": "arg3", "type": "uint256" } ], - "name": "LogTripleArg", + "name": "LogQuadrupleArg", "type": "event" }, { @@ -426,38 +342,43 @@ "inputs": [ { "indexed": False, + "internalType": "uint256", "name": "arg0", "type": "uint256" }, { "indexed": False, + "internalType": "uint256", "name": "arg1", "type": "uint256" }, { - "indexed": False, + "indexed": True, + "internalType": "uint256", "name": "arg2", "type": "uint256" }, { - "indexed": False, + "indexed": True, + "internalType": "uint256", "name": "arg3", "type": "uint256" } ], - "name": "LogQuadrupleArg", + "name": "LogQuadrupleWithIndex", "type": "event" }, { - "anonymous": False, + "anonymous": True, "inputs": [ { - "indexed": False, - "name": "v", - "type": "string" + "indexed": True, + "internalType": "uint256", + "name": "arg0", + "type": "uint256" } ], - "name": "LogString", + "name": "LogSingleAnonymous", "type": "event" }, { @@ -465,35 +386,25 @@ "inputs": [ { "indexed": False, - "name": "v", - "type": "bytes" - } - ], - "name": "LogBytes", - "type": "event" - }, - { - "anonymous": False, - "inputs": [ - { - "indexed": True, + "internalType": "uint256", "name": "arg0", "type": "uint256" } ], - "name": "LogSingleWithIndex", + "name": "LogSingleArg", "type": "event" }, { - "anonymous": True, + "anonymous": False, "inputs": [ { "indexed": True, + "internalType": "uint256", "name": "arg0", "type": "uint256" } ], - "name": "LogSingleAnonymous", + "name": "LogSingleWithIndex", "type": "event" }, { @@ -501,33 +412,43 @@ "inputs": [ { "indexed": False, - "name": "arg0", - "type": "uint256" - }, - { - "indexed": True, - "name": "arg1", - "type": "uint256" + "internalType": "string", + "name": "v", + "type": "string" } ], - "name": "LogDoubleWithIndex", + "name": "LogString", "type": "event" }, { - "anonymous": True, + "anonymous": False, "inputs": [ { "indexed": False, + "internalType": "uint256", "name": "arg0", "type": "uint256" }, { - "indexed": True, + "components": [ + { + "internalType": "uint256", + "name": "a", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "b", + "type": "uint256" + } + ], + "indexed": False, + "internalType": "struct Emitter.TestTuple", "name": "arg1", - "type": "uint256" + "type": "tuple" } ], - "name": "LogDoubleAnonymous", + "name": "LogStructArgs", "type": "event" }, { @@ -535,21 +456,24 @@ "inputs": [ { "indexed": False, + "internalType": "uint256", "name": "arg0", "type": "uint256" }, { - "indexed": True, + "indexed": False, + "internalType": "uint256", "name": "arg1", "type": "uint256" }, { - "indexed": True, + "indexed": False, + "internalType": "uint256", "name": "arg2", "type": "uint256" } ], - "name": "LogTripleWithIndex", + "name": "LogTripleArg", "type": "event" }, { @@ -557,99 +481,183 @@ "inputs": [ { "indexed": False, + "internalType": "uint256", "name": "arg0", "type": "uint256" }, { - "indexed": False, + "indexed": True, + "internalType": "uint256", "name": "arg1", "type": "uint256" }, { "indexed": True, + "internalType": "uint256", "name": "arg2", "type": "uint256" - }, - { - "indexed": True, - "name": "arg3", - "type": "uint256" } ], - "name": "LogQuadrupleWithIndex", + "name": "LogTripleWithIndex", "type": "event" }, { - "anonymous": False, + "inputs": [ + { "internalType": "address", "name": "arg0", "type": "address" }, + { "internalType": "address", "name": "arg1", "type": "address" } + ], + "name": "logAddressIndexedArgs", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "address", "name": "arg0", "type": "address" }, + { "internalType": "address", "name": "arg1", "type": "address" } + ], + "name": "logAddressNotIndexedArgs", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [{ "internalType": "bytes", "name": "v", "type": "bytes" }], + "name": "logBytes", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { "inputs": [ { - "indexed": True, - "name": "arg0", - "type": "string" + "internalType": "enum Emitter.WhichEvent", + "name": "which", + "type": "uint8" }, + { "internalType": "uint256", "name": "arg0", "type": "uint256" }, + { "internalType": "uint256", "name": "arg1", "type": "uint256" } + ], + "name": "logDouble", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "string", "name": "arg0", "type": "string" }, + { "internalType": "string", "name": "arg1", "type": "string" } + ], + "name": "logDynamicArgs", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "bytes2[]", "name": "arg0", "type": "bytes2[]" }, + { "internalType": "bytes2[]", "name": "arg1", "type": "bytes2[]" } + ], + "name": "logListArgs", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ { - "indexed": False, - "name": "arg1", - "type": "string" + "internalType": "enum Emitter.WhichEvent", + "name": "which", + "type": "uint8" } ], - "name": "LogDynamicArgs", - "type": "event" + "name": "logNoArgs", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" }, { - "anonymous": False, "inputs": [ { - "indexed": True, - "name": "arg0", - "type": "bytes2[]" + "internalType": "enum Emitter.WhichEvent", + "name": "which", + "type": "uint8" }, - { - "indexed": False, - "name": "arg1", - "type": "bytes2[]" - } + { "internalType": "uint256", "name": "arg0", "type": "uint256" }, + { "internalType": "uint256", "name": "arg1", "type": "uint256" }, + { "internalType": "uint256", "name": "arg2", "type": "uint256" }, + { "internalType": "uint256", "name": "arg3", "type": "uint256" } ], - "name": "LogListArgs", - "type": "event" + "name": "logQuadruple", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" }, { - "anonymous": False, "inputs": [ { - "indexed": True, - "name": "arg0", - "type": "address" + "internalType": "enum Emitter.WhichEvent", + "name": "which", + "type": "uint8" }, - { - "indexed": False, + { "internalType": "uint256", "name": "arg0", "type": "uint256" } + ], + "name": "logSingle", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [{ "internalType": "string", "name": "v", "type": "string" }], + "name": "logString", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { "internalType": "uint256", "name": "arg0", "type": "uint256" }, + { + "components": [ + { + "internalType": "uint256", + "name": "a", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "b", + "type": "uint256" + } + ], + "internalType": "struct Emitter.TestTuple", "name": "arg1", - "type": "address" + "type": "tuple" } ], - "name": "LogAddressIndexed", - "type": "event" + "name": "logStruct", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" }, { - "anonymous": False, "inputs": [ { - "indexed": False, - "name": "arg0", - "type": "address" + "internalType": "enum Emitter.WhichEvent", + "name": "which", + "type": "uint8" }, - { - "indexed": False, - "name": "arg1", - "type": "address" - } + { "internalType": "uint256", "name": "arg0", "type": "uint256" }, + { "internalType": "uint256", "name": "arg1", "type": "uint256" }, + { "internalType": "uint256", "name": "arg2", "type": "uint256" } ], - "name": "LogAddressNotIndexed", - "type": "event" + "name": "logTriple", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" } ] - EMITTER_ENUM = { 'LogAnonymous': 0, 'LogNoArguments': 1, @@ -662,5 +670,6 @@ 'LogDoubleAnonymous': 8, 'LogDoubleWithIndex': 9, 'LogTripleWithIndex': 10, - 'LogQuadrupleWithInde': 11, + 'LogQuadrupleWithIndex': 11, + 'LogStructArg': 12 } From df0e3b004f0ca9b6ab3282cb92ca58dfaf9017da Mon Sep 17 00:00:00 2001 From: Felipe Selmo Date: Wed, 12 Jan 2022 16:14:40 -0700 Subject: [PATCH 2/4] Add support for nested tuples to event filters and logs - Nested tuples seemed to be broken when parsing event filters. This commit piggy backs off previous work and uses the collapse_if_tuple() method in the _build_argument_filters_from_even_abi() method. From testing, this seemes to have been a missing piece to get these issues resolved and the added test passing. - Remove testing nested tuple method from tests that require the test id enum. These were added in the previous commit. Instead, add a test specific to testing the new method / event for tuples. - Add testing for the new nested tuple function + event in the emitter contract. - closes 1629 - closes 2298 --- newsfragments/2211.bugfix.rst | 1 + tests/core/contracts/conftest.py | 5 +- .../contracts/contract_sources/Emitter.sol | 8 +- .../contracts/test_extracting_event_data.py | 60 ++- .../test_extracting_event_data_old.py | 4 +- tests/core/filtering/conftest.py | 7 +- .../filtering/test_contract_data_filters.py | 7 +- tests/core/filtering/test_contract_getLogs.py | 2 +- .../filtering/test_contract_topic_filters.py | 7 +- web3/_utils/events.py | 12 +- web3/_utils/filters.py | 1 + .../_utils/module_testing/emitter_contract.py | 489 ++++++++++++------ 12 files changed, 384 insertions(+), 219 deletions(-) create mode 100644 newsfragments/2211.bugfix.rst diff --git a/newsfragments/2211.bugfix.rst b/newsfragments/2211.bugfix.rst new file mode 100644 index 0000000000..b5b3212734 --- /dev/null +++ b/newsfragments/2211.bugfix.rst @@ -0,0 +1 @@ +Fixed issues with parsing tuples and nested tuples in event logs \ No newline at end of file diff --git a/tests/core/contracts/conftest.py b/tests/core/contracts/conftest.py index 0bfdb4b977..399d13f4c6 100644 --- a/tests/core/contracts/conftest.py +++ b/tests/core/contracts/conftest.py @@ -436,9 +436,7 @@ def strict_emitter(w3_strict_abi, w3 = w3_strict_abi wait_for_block(w3) - deploy_txn_hash = StrictEmitter.constructor().transact( - {'from': w3.eth.coinbase, 'gas': 1000000} - ) + deploy_txn_hash = StrictEmitter.constructor().transact({'gas': 10000000}) deploy_receipt = wait_for_transaction(w3, deploy_txn_hash) contract_address = address_conversion_func(deploy_receipt['contractAddress']) @@ -943,7 +941,6 @@ class LogFunctions: LogTripleWithIndex = 10 LogQuadrupleWithIndex = 11 LogBytes = 12 - LogStructArgs = 13 @pytest.fixture() diff --git a/tests/core/contracts/contract_sources/Emitter.sol b/tests/core/contracts/contract_sources/Emitter.sol index dde4f80afa..d0558be2d8 100644 --- a/tests/core/contracts/contract_sources/Emitter.sol +++ b/tests/core/contracts/contract_sources/Emitter.sol @@ -1,4 +1,4 @@ -pragma solidity ^0.8.7; +pragma solidity ^0.8.11; contract Emitter { @@ -11,7 +11,6 @@ contract Emitter { event LogString(string v); event LogBytes(bytes v); - // Indexed event LogSingleWithIndex(uint indexed arg0); event LogSingleAnonymous(uint indexed arg0) anonymous; event LogDoubleWithIndex(uint arg0, uint indexed arg1); @@ -23,10 +22,13 @@ contract Emitter { event LogAddressIndexed(address indexed arg0, address arg1); event LogAddressNotIndexed(address arg0, address arg1); - // Nested type functionality + struct NestedTestTuple { + uint c; + } struct TestTuple { uint a; uint b; + NestedTestTuple nested; } event LogStructArgs(uint arg0, TestTuple arg1); diff --git a/tests/core/contracts/test_extracting_event_data.py b/tests/core/contracts/test_extracting_event_data.py index cd0451d2ea..9bac522a38 100644 --- a/tests/core/contracts/test_extracting_event_data.py +++ b/tests/core/contracts/test_extracting_event_data.py @@ -31,8 +31,8 @@ def Emitter(web3, EMITTER): @pytest.fixture() def emitter(web3, Emitter, wait_for_transaction, wait_for_block, address_conversion_func): wait_for_block(web3) - deploy_txn_hash = Emitter.constructor().transact({'from': web3.eth.coinbase, 'gas': 1000000}) - deploy_receipt = web3.eth.wait_for_transaction_receipt(deploy_txn_hash) + deploy_txn_hash = Emitter.constructor().transact({'gas': 10000000}) + deploy_receipt = wait_for_transaction(web3, deploy_txn_hash) contract_address = address_conversion_func(deploy_receipt['contractAddress']) bytecode = web3.eth.get_code(contract_address) @@ -148,12 +148,6 @@ def dup_txn_receipt( [12345, 54321, 98765, 56789], {'arg0': 12345, 'arg1': 54321, 'arg2': 98765, 'arg3': 56789}, ), - ( - 'logStruct', - 'LogStructArgs', - [12345, {'a': 0, 'b': 1}], - {'arg0': 12345, 'arg1': {'a': 0, 'b': 1}}, - ) ) ) def test_event_data_extraction(web3, @@ -215,7 +209,6 @@ def test_event_data_extraction_bytes(web3, emitter, wait_for_transaction, emitter_log_topics, - emitter_event_ids, call_args, expected_args): emitter_fn = emitter.functions.logListArgs @@ -337,7 +330,7 @@ def test_argument_extraction_strict_bytes_types(w3_strict_abi, emitter_log_topics): arg_0 = [b'12'] arg_1 = [b'12'] - txn_hash = strict_emitter.functions.logListArgs(arg_0, arg_1).transact() + txn_hash = strict_emitter.functions.logListArgs(arg_0, arg_1).transact({'gas': 25000}) txn_receipt = wait_for_transaction(w3_strict_abi, txn_hash) assert len(txn_receipt['logs']) == 1 @@ -564,19 +557,19 @@ def test_argument_extraction_strict_bytes_types(w3_strict_abi, 'The event signature did not match the provided ABI', False, ), - ( + ( # nested tuples 'logStruct', - 'logStructArgs', - [12345, {'a': 0, 'b': 1}], - {'arg0': 12345, 'arg1': {'a': 0, 'b': 1}}, + 'LogStructArgs', + [1, (2, 3, (4,))], + {'arg0': 1, 'arg1': (2, 3, (4,))}, 'The event signature did not match the provided ABI', True, ), - ( + ( # nested tuples 'logStruct', - 'logStructArgs', - [12345, {'a': 0, 'b': 1}], - {'arg0': 12345, 'arg1': {'a': 0, 'b': 1}}, + 'LogStructArgs', + [1, (2, 3, (4,))], + {'arg0': 1, 'arg1': (2, 3, (4,))}, 'The event signature did not match the provided ABI', False, ), @@ -595,8 +588,13 @@ def test_event_rich_log( expected_args): emitter_fn = emitter.functions[contract_fn] - event_id = getattr(emitter_event_ids, event_name) - txn_hash = emitter_fn(event_id, *call_args).transact() + if hasattr(emitter_event_ids, event_name): + event_id = getattr(emitter_event_ids, event_name) + txn_hash = emitter_fn(event_id, *call_args).transact() + else: + # Some tests do not rely on the event_id. Rather than changing this test too much, + # bypass this here and just call the function with the provided args. + txn_hash = emitter_fn(*call_args).transact() txn_receipt = wait_for_transaction(web3, txn_hash) event_instance = emitter.events[event_name]() @@ -759,3 +757,25 @@ def test_single_log_processing_with_errors( with pytest.raises(LogTopicError, match="Expected 1 log topics. Got 0"): event_instance.processLog(dup_txn_receipt['logs'][0]) + + +def test_get_all_entries_with_nested_tuple_event(web3, emitter): + struct_args_filter = emitter.events.LogStructArgs.createFilter(fromBlock=0) + + tx_hash = emitter.functions.logStruct(1, (2, 3, (4, ))).transact({'gas': 100000}) + web3.eth.wait_for_transaction_receipt(tx_hash) + txn_receipt = web3.eth.get_transaction_receipt(tx_hash) + + entries = struct_args_filter.get_all_entries() + + assert entries != [] + assert len(entries) == 1 + + log_entry = entries[0] + + assert log_entry.args == {'arg0': 1, 'arg1': (2, 3, (4,))} + assert log_entry.event == 'LogStructArgs' + assert log_entry.blockHash == txn_receipt['blockHash'] + assert log_entry.blockNumber == txn_receipt['blockNumber'] + assert log_entry.transactionIndex == txn_receipt['transactionIndex'] + assert is_same_address(log_entry.address, emitter.address) diff --git a/tests/core/contracts/test_extracting_event_data_old.py b/tests/core/contracts/test_extracting_event_data_old.py index f3e0905f0a..1fae5c406d 100644 --- a/tests/core/contracts/test_extracting_event_data_old.py +++ b/tests/core/contracts/test_extracting_event_data_old.py @@ -17,8 +17,8 @@ def Emitter(web3, EMITTER): @pytest.fixture() def emitter(web3, Emitter, wait_for_transaction, wait_for_block, address_conversion_func): wait_for_block(web3) - deploy_txn_hash = Emitter.constructor().transact({'from': web3.eth.coinbase, 'gas': 1000000}) - deploy_receipt = web3.eth.wait_for_transaction_receipt(deploy_txn_hash) + deploy_txn_hash = Emitter.constructor().transact({'gas': 10000000}) + deploy_receipt = wait_for_transaction(web3, deploy_txn_hash) contract_address = address_conversion_func(deploy_receipt['contractAddress']) bytecode = web3.eth.get_code(contract_address) diff --git a/tests/core/filtering/conftest.py b/tests/core/filtering/conftest.py index fd161cf51a..cce7d08c95 100644 --- a/tests/core/filtering/conftest.py +++ b/tests/core/filtering/conftest.py @@ -73,12 +73,7 @@ def Emitter(web3, EMITTER): @pytest.fixture() def emitter(web3, Emitter, wait_for_transaction, wait_for_block, address_conversion_func): wait_for_block(web3) - deploy_txn_hash = Emitter.constructor().transact({ - 'from': web3.eth.coinbase, - 'gas': 1000000, - 'maxFeePerGas': 10 ** 9, - 'maxPriorityFeePerGas': 10 ** 9, - }) + deploy_txn_hash = Emitter.constructor().transact({'gas': 10000000}) deploy_receipt = wait_for_transaction(web3, deploy_txn_hash) contract_address = address_conversion_func(deploy_receipt['contractAddress']) diff --git a/tests/core/filtering/test_contract_data_filters.py b/tests/core/filtering/test_contract_data_filters.py index f8b4452480..6efb78c724 100644 --- a/tests/core/filtering/test_contract_data_filters.py +++ b/tests/core/filtering/test_contract_data_filters.py @@ -67,12 +67,7 @@ def Emitter(web3, EMITTER): @pytest.fixture(scope="module") def emitter(web3, Emitter, wait_for_transaction, wait_for_block, address_conversion_func): wait_for_block(web3) - deploy_txn_hash = Emitter.constructor().transact({ - 'from': web3.eth.coinbase, - 'gas': 1000000, - 'maxFeePerGas': 10 ** 9, - 'maxPriorityFeePerGas': 10 ** 9, - }) + deploy_txn_hash = Emitter.constructor().transact({'gas': 10000000}) deploy_receipt = wait_for_transaction(web3, deploy_txn_hash) contract_address = address_conversion_func(deploy_receipt['contractAddress']) diff --git a/tests/core/filtering/test_contract_getLogs.py b/tests/core/filtering/test_contract_getLogs.py index 8c945ebc0c..8badd8ca00 100644 --- a/tests/core/filtering/test_contract_getLogs.py +++ b/tests/core/filtering/test_contract_getLogs.py @@ -6,7 +6,7 @@ def test_contract_get_available_events( """We can iterate over available contract events""" contract = emitter events = list(contract.events) - assert len(events) == 18 + assert len(events) == 19 def test_contract_getLogs_all( diff --git a/tests/core/filtering/test_contract_topic_filters.py b/tests/core/filtering/test_contract_topic_filters.py index d174aa5ecb..6e55ed74ac 100644 --- a/tests/core/filtering/test_contract_topic_filters.py +++ b/tests/core/filtering/test_contract_topic_filters.py @@ -72,12 +72,7 @@ def Emitter(web3, EMITTER): @pytest.fixture(scope="module") def emitter(web3, Emitter, wait_for_transaction, wait_for_block, address_conversion_func): wait_for_block(web3) - deploy_txn_hash = Emitter.constructor().transact({ - 'from': web3.eth.coinbase, - 'gas': 1000000, - 'maxFeePerGas': 10 ** 9, - 'maxPriorityFeePerGas': 10 ** 9, - }) + deploy_txn_hash = Emitter.constructor().transact({'gas': 10000000}) deploy_receipt = wait_for_transaction(web3, deploy_txn_hash) contract_address = address_conversion_func(deploy_receipt['contractAddress']) diff --git a/web3/_utils/events.py b/web3/_utils/events.py index 02bd974e40..5ad79bfde8 100644 --- a/web3/_utils/events.py +++ b/web3/_utils/events.py @@ -39,7 +39,9 @@ to_hex, to_tuple, ) -from eth_utils.abi import collapse_if_tuple +from eth_utils.abi import ( + collapse_if_tuple, +) from eth_utils.curried import ( apply_formatter_if, ) @@ -194,7 +196,7 @@ def get_event_abi_types_for_decoding(event_inputs: Sequence[ABIEventParams]) -> if input_abi['indexed'] and is_dynamic_sized_type(input_abi['type']): yield 'bytes32' else: - yield collapse_if_tuple(input_abi) + yield collapse_if_tuple(dict(input_abi)) @curry @@ -431,9 +433,9 @@ def _build_argument_filters_from_event_abi( key = item['name'] value: 'BaseArgumentFilter' if item['indexed'] is True: - value = TopicArgumentFilter(abi_codec=abi_codec, arg_type=item['type']) + value = TopicArgumentFilter(abi_codec=abi_codec, arg_type=collapse_if_tuple(dict(item))) else: - value = DataArgumentFilter(arg_type=item['type']) + value = DataArgumentFilter(arg_type=collapse_if_tuple(dict(item))) yield key, value @@ -479,7 +481,7 @@ class DataArgumentFilter(BaseArgumentFilter): # type ignore b/c conflict with BaseArgumentFilter.match_values type @property def match_values(self) -> Tuple[TypeStr, Tuple[Any, ...]]: # type: ignore - return (self.arg_type, self._match_values) + return self.arg_type, self._match_values class TopicArgumentFilter(BaseArgumentFilter): diff --git a/web3/_utils/filters.py b/web3/_utils/filters.py index e7f22994a2..b6a77c385f 100644 --- a/web3/_utils/filters.py +++ b/web3/_utils/filters.py @@ -186,6 +186,7 @@ class TransactionFilter(Filter): class LogFilter(Filter): data_filter_set = None data_filter_set_regex = None + data_filter_set_function = None log_entry_formatter = None filter_params: FilterParams = None builder: EventFilterBuilder = None diff --git a/web3/_utils/module_testing/emitter_contract.py b/web3/_utils/module_testing/emitter_contract.py index 3791c831af..5e17440964 100644 --- a/web3/_utils/module_testing/emitter_contract.py +++ b/web3/_utils/module_testing/emitter_contract.py @@ -1,150 +1,270 @@ CONTRACT_EMITTER_CODE = ( - "608060405234801561001057600080fd5b50610aed806100206000396000f300608060405260043" - "6106100ae5763ffffffff7c01000000000000000000000000000000000000000000000000000000" - "006000350416630bb563d681146100b357806317c0c1801461010e57806320f0256e14610129578" - "06390b41d8b14610150578063966b50e0146101715780639c377053146101ff578063aa6fd82214" - "610223578063acabb9ed14610241578063b2ddc449146102d8578063e17bf9561461030c578063f" - "82ef69e14610365575b600080fd5b3480156100bf57600080fd5b50604080516020600480358082" - "0135601f810184900484028501840190955284845261010c9436949293602493928401919081908" - "401838280828437509497506103999650505050505050565b005b34801561011a57600080fd5b50" - "61010c60ff60043516610435565b34801561013557600080fd5b5061010c60ff600435166024356" - "04435606435608435610527565b34801561015c57600080fd5b5061010c60ff6004351660243560" - "44356105e4565b34801561017d57600080fd5b50604080516020600480358082013583810280860" - "1850190965280855261010c95369593946024949385019291829185019084908082843750506040" - "805187358901803560208181028481018201909552818452989b9a9989019892975090820195509" - "350839250850190849080828437509497506106b49650505050505050565b34801561020b576000" - "80fd5b5061010c60ff6004351660243560443560643561076d565b34801561022f57600080fd5b5" - "061010c60ff60043516602435610818565b34801561024d57600080fd5b50604080516020600480" - "3580820135601f810184900484028501840190955284845261010c9436949293602493928401919" - "0819084018382808284375050604080516020601f89358b01803591820183900483028401830190" - "9452808352979a9998810197919650918201945092508291508401838280828437509497506108c" - "a9650505050505050565b3480156102e457600080fd5b5061010c73ffffffffffffffffffffffff" - "ffffffffffffffff600435811690602435166109bb565b34801561031857600080fd5b506040805" - "160206004803580820135601f810184900484028501840190955284845261010c94369492936024" - "9392840191908190840183828082843750949750610a0d9650505050505050565b3480156103715" - "7600080fd5b5061010c73ffffffffffffffffffffffffffffffffffffffff600435811690602435" - "16610a6b565b7fa95e6e2a182411e7a6f9ed114a85c3761d87f9b8f453d842c71235aa64fff99f8" - "16040518080602001828103825283818151815260200191508051906020019080838360005b8381" - "10156103f85781810151838201526020016103e0565b50505050905090810190601f16801561042" - "55780820380516001836020036101000a031916815260200191505b509250505060405180910390" - "a150565b600181601181111561044357fe5b1415610477576040517f1e86022f78f8d04f8e3dfd1" - "3a2bdb280403e6632877c0dbee5e4eeb259908a5c90600090a1610524565b600081601181111561" - "048557fe5b141561049757604051600090a0610524565b604080517f08c379a0000000000000000" - "00000000000000000000000000000000000000000815260206004820152602660248201527f4469" - "646e2774206d6174636820616e7920616c6c6f7761626c65206576656e7460448201527f20696e6" - "4657800000000000000000000000000000000000000000000000000006064820152905190819003" - "60840190fd5b50565b600585601181111561053557fe5b141561058757604080518581526020810" - "18590528082018490526060810183905290517ff039d147f23fe975a4254bdf6b1502b8c79132ae" - "1833986b7ccef2638e73fdf99181900360800190a16105dd565b600b85601181111561059557fe5" - "b14156104975780827fa30ece802b64cd2b7e57dabf4010aabf5df26d1556977affb07b98a77ad9" - "55b58686604051808381526020018281526020019250505060405180910390a35b5050505050565" - "b60038360118111156105f257fe5b141561063857604080518381526020810183905281517fdf0c" - "b1dea99afceb3ea698d62e705b736f1345a7eee9eb07e63d1f8f556c1bc5929181900390910190a" - "16106af565b600983601181111561064657fe5b14156106875760408051838152905182917f057b" - "c32826fbe161da1c110afcdcae7c109a8b69149f727fc37a603c60ef94ca919081900360200190a" - "26106af565b600883601181111561069557fe5b1415610497576040805183815290518291819003" - "60200190a15b505050565b8160405180828051906020019060200280838360005b838110156106e" - "25781810151838201526020016106ca565b5050505090500191505060405180910390207fdbc4c1" - "d1d2f0d84e58d36ca767ec9ba2ec2f933c055e50e5ccdd57697f7b58b0826040518080602001828" - "103825283818151815260200191508051906020019060200280838360005b838110156107565781" - "8101518382015260200161073e565b505050509050019250505060405180910390a25050565b600" - "484601181111561077b57fe5b14156107c657604080518481526020810184905280820183905290" - "517f4a25b279c7c585f25eda9788ac9420ebadae78ca6b206a0e6ab488fd81f5506291819003606" - "00190a1610812565b600a8460118111156107d457fe5b1415610497576040805184815290518291" - "84917ff16c999b533366ca5138d78e85da51611089cd05749f098d6c225d4cd42ee6ec918190036" - "0200190a35b50505050565b600282601181111561082657fe5b1415610864576040805182815290" - "517f56d2ef3c5228bf5d88573621e325a4672ab50e033749a601e4f4a5e1dce905d491819003602" - "00190a16108c6565b600782601181111561087257fe5b14156108a85760405181907ff70fe689e2" - "90d8ce2b2a388ac28db36fbb0e16a6d89c6804c461f65a1b40bb1590600090a26108c6565b60068" - "260118111156108b657fe5b1415610497576040518190600090a15b5050565b8160405180828051" - "90602001908083835b602083106108fa5780518252601f1990920191602091820191016108db565" - "b51815160209384036101000a600019018019909216911617905260408051929094018290038220" - "81835287518383015287519096507fe77cf33df73da7bc2e253a2dae617e6f15e4e337eaa462a10" - "8903af4643d1b7595508794929350839283019185019080838360005b8381101561097d57818101" - "5183820152602001610965565b50505050905090810190601f1680156109aa57808203805160018" - "36020036101000a031916815260200191505b509250505060405180910390a25050565b60408051" - "73ffffffffffffffffffffffffffffffffffffffff83811682529151918416917ff922c21568954" - "8d72c3d2fe4ea8dafb2a30c43312c9b43fe5d10f713181f991c9181900360200190a25050565b7f" - "532fd6ea96cfb78bb46e09279a26828b8b493de1a2b8b1ee1face527978a15a5816040518080602" - "00182810382528381815181526020019150805190602001908083836000838110156103f8578181" - "0151838201526020016103e0565b6040805173ffffffffffffffffffffffffffffffffffffffff8" - "0851682528316602082015281517f06029e18f16caae06a69281f35b00ed3fcf47950e6c99dafa1" - "bdd8c4b93479a0929181900390910190a150505600a165627a7a72305820962bb0d0c7c052407e6" - "ad0911da133e939baa8783fbd0220169b97b54160a89e0029" + "608060405234801561001057600080fd5b5061176c806100206000396000f3fe6080604052348015610010576000" + "80fd5b50600436106100b45760003560e01c80639c377053116100715780639c37705314610161578063aa6fd822" + "1461017d578063acabb9ed14610199578063b2ddc449146101b5578063e17bf956146101d1578063f82ef69e1461" + "01ed576100b4565b80630bb563d6146100b957806317c0c180146100d557806320f0256e146100f15780635da86c" + "171461010d57806390b41d8b14610129578063966b50e014610145575b600080fd5b6100d3600480360381019061" + "00ce9190610aff565b610209565b005b6100ef60048036038101906100ea9190610b6d565b610243565b005b6101" + "0b60048036038101906101069190610bd0565b61031d565b005b61012760048036038101906101229190610cf056" + "5b61043c565b005b610143600480360381019061013e9190610d30565b610479565b005b61015f60048036038101" + "9061015a9190610ea3565b6105d9565b005b61017b60048036038101906101769190610f1b565b61062a565b005b" + "61019760048036038101906101929190610f82565b610744565b005b6101b360048036038101906101ae9190610f" + "c2565b61088b565b005b6101cf60048036038101906101ca9190611098565b6108dc565b005b6101eb6004803603" + "8101906101e69190611179565b61092e565b005b61020760048036038101906102029190611098565b610968565b" + "005b7fa95e6e2a182411e7a6f9ed114a85c3761d87f9b8f453d842c71235aa64fff99f8160405161023891906112" + "4a565b60405180910390a150565b600160128111156102575761025661126c565b5b81601281111561026a576102" + "6961126c565b5b14156102a1577f1e86022f78f8d04f8e3dfd13a2bdb280403e6632877c0dbee5e4eeb259908a5c" + "60405160405180910390a161031a565b600060128111156102b5576102b461126c565b5b8160128111156102c857" + "6102c761126c565b5b14156102de5760405160405180910390a0610319565b6040517f08c379a000000000000000" + "00000000000000000000000000000000000000000081526004016103109061130d565b60405180910390fd5b5b50" + "565b600560128111156103315761033061126c565b5b8560128111156103445761034361126c565b5b141561038c" + "577ff039d147f23fe975a4254bdf6b1502b8c79132ae1833986b7ccef2638e73fdf98484848460405161037f9493" + "92919061133c565b60405180910390a1610435565b600b60128111156103a05761039f61126c565b5b8560128111" + "156103b3576103b261126c565b5b14156103f95780827fa30ece802b64cd2b7e57dabf4010aabf5df26d1556977a" + "ffb07b98a77ad955b586866040516103ec929190611381565b60405180910390a3610434565b6040517f08c379a0" + "00000000000000000000000000000000000000000000000000000000815260040161042b9061130d565b60405180" + "910390fd5b5b5050505050565b7f8ccce2523cca5f3851d20df50b5a59509bc4ac7d9ddba344f5e331969d09b8e7" + "828260405161046d929190611417565b60405180910390a15050565b6003601281111561048d5761048c61126c56" + "5b5b8360128111156104a05761049f61126c565b5b14156104e4577fdf0cb1dea99afceb3ea698d62e705b736f13" + "45a7eee9eb07e63d1f8f556c1bc582826040516104d7929190611381565b60405180910390a16105d4565b600960" + "128111156104f8576104f761126c565b5b83601281111561050b5761050a61126c565b5b141561054e57807f057b" + "c32826fbe161da1c110afcdcae7c109a8b69149f727fc37a603c60ef94ca836040516105419190611440565b6040" + "5180910390a26105d3565b600860128111156105625761056161126c565b5b836012811115610575576105746112" + "6c565b5b141561059757808260405161058a9190611440565b60405180910390a16105d2565b6040517f08c379a0" + "0000000000000000000000000000000000000000000000000000000081526004016105c99061130d565b60405180" + "910390fd5b5b5b505050565b816040516105e79190611513565b60405180910390207fdbc4c1d1d2f0d84e58d36c" + "a767ec9ba2ec2f933c055e50e5ccdd57697f7b58b08260405161061e91906115c0565b60405180910390a2505056" + "5b6004601281111561063e5761063d61126c565b5b8460128111156106515761065061126c565b5b141561069757" + "7f4a25b279c7c585f25eda9788ac9420ebadae78ca6b206a0e6ab488fd81f5506283838360405161068a93929190" + "6115e2565b60405180910390a161073e565b600a60128111156106ab576106aa61126c565b5b8460128111156106" + "be576106bd61126c565b5b14156107025780827ff16c999b533366ca5138d78e85da51611089cd05749f098d6c22" + "5d4cd42ee6ec856040516106f59190611440565b60405180910390a361073d565b6040517f08c379a00000000000" + "000000000000000000000000000000000000000000000081526004016107349061130d565b60405180910390fd5b" + "5b50505050565b600260128111156107585761075761126c565b5b82601281111561076b5761076a61126c565b5b" + "14156107ad577f56d2ef3c5228bf5d88573621e325a4672ab50e033749a601e4f4a5e1dce905d4816040516107a0" + "9190611440565b60405180910390a1610887565b600760128111156107c1576107c061126c565b5b826012811115" + "6107d4576107d361126c565b5b141561080c57807ff70fe689e290d8ce2b2a388ac28db36fbb0e16a6d89c6804c4" + "61f65a1b40bb1560405160405180910390a2610886565b600660128111156108205761081f61126c565b5b826012" + "8111156108335761083261126c565b5b141561084a578060405160405180910390a1610885565b6040517f08c379" + "a000000000000000000000000000000000000000000000000000000000815260040161087c9061130d565b604051" + "80910390fd5b5b5b5050565b816040516108999190611655565b60405180910390207fe77cf33df73da7bc2e253a" + "2dae617e6f15e4e337eaa462a108903af4643d1b75826040516108d0919061124a565b60405180910390a2505056" + "5b8173ffffffffffffffffffffffffffffffffffffffff167ff922c215689548d72c3d2fe4ea8dafb2a30c43312c" + "9b43fe5d10f713181f991c82604051610922919061167b565b60405180910390a25050565b7f532fd6ea96cfb78b" + "b46e09279a26828b8b493de1a2b8b1ee1face527978a15a58160405161095d91906116eb565b60405180910390a1" + "50565b7f06029e18f16caae06a69281f35b00ed3fcf47950e6c99dafa1bdd8c4b93479a082826040516109999291" + "9061170d565b60405180910390a15050565b6000604051905090565b600080fd5b600080fd5b600080fd5b600080" + "fd5b6000601f19601f8301169050919050565b7f4e487b7100000000000000000000000000000000000000000000" + "000000000000600052604160045260246000fd5b610a0c826109c3565b810181811067ffffffffffffffff821117" + "15610a2b57610a2a6109d4565b5b80604052505050565b6000610a3e6109a5565b9050610a4a8282610a03565b91" + "9050565b600067ffffffffffffffff821115610a6a57610a696109d4565b5b610a73826109c3565b905060208101" + "9050919050565b82818337600083830152505050565b6000610aa2610a9d84610a4f565b610a34565b9050828152" + "60208101848484011115610abe57610abd6109be565b5b610ac9848285610a80565b509392505050565b60008260" + "1f830112610ae657610ae56109b9565b5b8135610af6848260208601610a8f565b91505092915050565b60006020" + "8284031215610b1557610b146109af565b5b600082013567ffffffffffffffff811115610b3357610b326109b456" + "5b5b610b3f84828501610ad1565b91505092915050565b60138110610b5557600080fd5b50565b60008135905061" + "0b6781610b48565b92915050565b600060208284031215610b8357610b826109af565b5b6000610b918482850161" + "0b58565b91505092915050565b6000819050919050565b610bad81610b9a565b8114610bb857600080fd5b50565b" + "600081359050610bca81610ba4565b92915050565b600080600080600060a08688031215610bec57610beb6109af" + "565b5b6000610bfa88828901610b58565b9550506020610c0b88828901610bbb565b9450506040610c1c88828901" + "610bbb565b9350506060610c2d88828901610bbb565b9250506080610c3e88828901610bbb565b91505092955092" + "95909350565b600080fd5b600060208284031215610c6657610c65610c4b565b5b610c706020610a34565b905060" + "00610c8084828501610bbb565b60008301525092915050565b600060608284031215610ca257610ca1610c4b565b" + "5b610cac6060610a34565b90506000610cbc84828501610bbb565b6000830152506020610cd084828501610bbb56" + "5b6020830152506040610ce484828501610c50565b60408301525092915050565b60008060808385031215610d07" + "57610d066109af565b5b6000610d1585828601610bbb565b9250506020610d2685828601610c8c565b9150509250" + "929050565b600080600060608486031215610d4957610d486109af565b5b6000610d5786828701610b58565b9350" + "506020610d6886828701610bbb565b9250506040610d7986828701610bbb565b9150509250925092565b600067ff" + "ffffffffffffff821115610d9e57610d9d6109d4565b5b602082029050602081019050919050565b600080fd5b60" + "007fffff00000000000000000000000000000000000000000000000000000000000082169050919050565b610de9" + "81610db4565b8114610df457600080fd5b50565b600081359050610e0681610de0565b92915050565b6000610e1f" + "610e1a84610d83565b610a34565b90508083825260208201905060208402830185811115610e4257610e41610daf" + "565b5b835b81811015610e6b5780610e578882610df7565b845260208401935050602081019050610e44565b5050" + "509392505050565b600082601f830112610e8a57610e896109b9565b5b8135610e9a848260208601610e0c565b91" + "505092915050565b60008060408385031215610eba57610eb96109af565b5b600083013567ffffffffffffffff81" + "1115610ed857610ed76109b4565b5b610ee485828601610e75565b925050602083013567ffffffffffffffff8111" + "15610f0557610f046109b4565b5b610f1185828601610e75565b9150509250929050565b60008060008060808587" + "031215610f3557610f346109af565b5b6000610f4387828801610b58565b9450506020610f5487828801610bbb56" + "5b9350506040610f6587828801610bbb565b9250506060610f7687828801610bbb565b9150509295919450925056" + "5b60008060408385031215610f9957610f986109af565b5b6000610fa785828601610b58565b9250506020610fb8" + "85828601610bbb565b9150509250929050565b60008060408385031215610fd957610fd86109af565b5b60008301" + "3567ffffffffffffffff811115610ff757610ff66109b4565b5b61100385828601610ad1565b9250506020830135" + "67ffffffffffffffff811115611024576110236109b4565b5b61103085828601610ad1565b915050925092905056" + "5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b60006110658261103a565b9050" + "919050565b6110758161105a565b811461108057600080fd5b50565b6000813590506110928161106c565b929150" + "50565b600080604083850312156110af576110ae6109af565b5b60006110bd85828601611083565b925050602061" + "10ce85828601611083565b9150509250929050565b600067ffffffffffffffff8211156110f3576110f26109d456" + "5b5b6110fc826109c3565b9050602081019050919050565b600061111c611117846110d8565b610a34565b905082" + "815260208101848484011115611138576111376109be565b5b611143848285610a80565b509392505050565b6000" + "82601f8301126111605761115f6109b9565b5b8135611170848260208601611109565b91505092915050565b6000" + "6020828403121561118f5761118e6109af565b5b600082013567ffffffffffffffff8111156111ad576111ac6109" + "b4565b5b6111b98482850161114b565b91505092915050565b600081519050919050565b60008282526020820190" + "5092915050565b60005b838110156111fc5780820151818401526020810190506111e1565b8381111561120b5760" + "00848401525b50505050565b600061121c826111c2565b61122681856111cd565b93506112368185602086016111" + "de565b61123f816109c3565b840191505092915050565b6000602082019050818103600083015261126481846112" + "11565b905092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000006000" + "52602160045260246000fd5b7f4469646e2774206d6174636820616e7920616c6c6f7761626c65206576656e7460" + "008201527f20696e6465780000000000000000000000000000000000000000000000000000602082015250565b60" + "006112f76026836111cd565b91506113028261129b565b604082019050919050565b600060208201905081810360" + "00830152611326816112ea565b9050919050565b61133681610b9a565b82525050565b6000608082019050611351" + "600083018761132d565b61135e602083018661132d565b61136b604083018561132d565b61137860608301846113" + "2d565b95945050505050565b6000604082019050611396600083018561132d565b6113a3602083018461132d565b" + "9392505050565b6113b381610b9a565b82525050565b6020820160008201516113cf60008501826113aa565b5050" + "5050565b6060820160008201516113eb60008501826113aa565b5060208201516113fe60208501826113aa565b50" + "604082015161141160408501826113b9565b50505050565b600060808201905061142c600083018561132d565b61" + "143960208301846113d5565b9392505050565b6000602082019050611455600083018461132d565b92915050565b" + "600081519050919050565b600081905092915050565b6000819050602082019050919050565b61148a81610db456" + "5b82525050565b600061149c8383611481565b60208301905092915050565b6000602082019050919050565b6000" + "6114c08261145b565b6114ca8185611466565b93506114d583611471565b8060005b838110156115065781516114" + "ed8882611490565b97506114f8836114a8565b9250506001810190506114d9565b5085935050505092915050565b" + "600061151f82846114b5565b915081905092915050565b600082825260208201905092915050565b61154481610d" + "b4565b82525050565b6000611556838361153b565b60208301905092915050565b600061156d8261145b565b6115" + "77818561152a565b935061158283611471565b8060005b838110156115b357815161159a888261154a565b975061" + "15a5836114a8565b925050600181019050611586565b5085935050505092915050565b6000602082019050818103" + "60008301526115da8184611562565b905092915050565b60006060820190506115f7600083018661132d565b6116" + "04602083018561132d565b611611604083018461132d565b949350505050565b600081905092915050565b600061" + "162f826111c2565b6116398185611619565b93506116498185602086016111de565b80840191505092915050565b" + "60006116618284611624565b915081905092915050565b6116758161105a565b82525050565b6000602082019050" + "611690600083018461166c565b92915050565b600081519050919050565b60008282526020820190509291505056" + "5b60006116bd82611696565b6116c781856116a1565b93506116d78185602086016111de565b6116e0816109c356" + "5b840191505092915050565b6000602082019050818103600083015261170581846116b2565b905092915050565b" + "6000604082019050611722600083018561166c565b61172f602083018461166c565b939250505056fea264697066" + "7358221220c210b75fcc1b13a7d08711ef833663000e885b94713c307622ffdc2214d1a22264736f6c634300080b" + "0033" ) CONTRACT_EMITTER_RUNTIME = ( - "6080604052600436106100ae5763ffffffff7c01000000000000000000000000000000000000000" - "000000000000000006000350416630bb563d681146100b357806317c0c1801461010e57806320f0" - "256e1461012957806390b41d8b14610150578063966b50e0146101715780639c377053146101ff5" - "78063aa6fd82214610223578063acabb9ed14610241578063b2ddc449146102d8578063e17bf956" - "1461030c578063f82ef69e14610365575b600080fd5b3480156100bf57600080fd5b50604080516" - "0206004803580820135601f810184900484028501840190955284845261010c9436949293602493" - "928401919081908401838280828437509497506103999650505050505050565b005b34801561011" - "a57600080fd5b5061010c60ff60043516610435565b34801561013557600080fd5b5061010c60ff" - "60043516602435604435606435608435610527565b34801561015c57600080fd5b5061010c60ff6" - "00435166024356044356105e4565b34801561017d57600080fd5b50604080516020600480358082" - "0135838102808601850190965280855261010c95369593946024949385019291829185019084908" - "082843750506040805187358901803560208181028481018201909552818452989b9a9989019892" - "975090820195509350839250850190849080828437509497506106b49650505050505050565b348" - "01561020b57600080fd5b5061010c60ff6004351660243560443560643561076d565b3480156102" - "2f57600080fd5b5061010c60ff60043516602435610818565b34801561024d57600080fd5b50604" - "0805160206004803580820135601f810184900484028501840190955284845261010c9436949293" - "6024939284019190819084018382808284375050604080516020601f89358b01803591820183900" - "4830284018301909452808352979a99988101979196509182019450925082915084018382808284" - "37509497506108ca9650505050505050565b3480156102e457600080fd5b5061010c73fffffffff" - "fffffffffffffffffffffffffffffff600435811690602435166109bb565b348015610318576000" - "80fd5b506040805160206004803580820135601f810184900484028501840190955284845261010" - "c943694929360249392840191908190840183828082843750949750610a0d965050505050505056" - "5b34801561037157600080fd5b5061010c73ffffffffffffffffffffffffffffffffffffffff600" - "43581169060243516610a6b565b7fa95e6e2a182411e7a6f9ed114a85c3761d87f9b8f453d842c7" - "1235aa64fff99f81604051808060200182810382528381815181526020019150805190602001908" - "0838360005b838110156103f85781810151838201526020016103e0565b50505050905090810190" - "601f1680156104255780820380516001836020036101000a031916815260200191505b509250505" - "060405180910390a150565b600181601181111561044357fe5b1415610477576040517f1e86022f" - "78f8d04f8e3dfd13a2bdb280403e6632877c0dbee5e4eeb259908a5c90600090a1610524565b600" - "081601181111561048557fe5b141561049757604051600090a0610524565b604080517f08c379a0" - "0000000000000000000000000000000000000000000000000000000081526020600482015260266" - "0248201527f4469646e2774206d6174636820616e7920616c6c6f7761626c65206576656e746044" - "8201527f20696e64657800000000000000000000000000000000000000000000000000006064820" - "15290519081900360840190fd5b50565b600585601181111561053557fe5b141561058757604080" - "51858152602081018590528082018490526060810183905290517ff039d147f23fe975a4254bdf6" - "b1502b8c79132ae1833986b7ccef2638e73fdf99181900360800190a16105dd565b600b85601181" - "111561059557fe5b14156104975780827fa30ece802b64cd2b7e57dabf4010aabf5df26d1556977" - "affb07b98a77ad955b58686604051808381526020018281526020019250505060405180910390a3" - "5b5050505050565b60038360118111156105f257fe5b14156106385760408051838152602081018" - "3905281517fdf0cb1dea99afceb3ea698d62e705b736f1345a7eee9eb07e63d1f8f556c1bc59291" - "81900390910190a16106af565b600983601181111561064657fe5b1415610687576040805183815" - "2905182917f057bc32826fbe161da1c110afcdcae7c109a8b69149f727fc37a603c60ef94ca9190" - "81900360200190a26106af565b600883601181111561069557fe5b1415610497576040805183815" - "29051829181900360200190a15b505050565b816040518082805190602001906020028083836000" - "5b838110156106e25781810151838201526020016106ca565b50505050905001915050604051809" - "10390207fdbc4c1d1d2f0d84e58d36ca767ec9ba2ec2f933c055e50e5ccdd57697f7b58b0826040" - "518080602001828103825283818151815260200191508051906020019060200280838360005b838" - "1101561075657818101518382015260200161073e565b5050505090500192505050604051809103" - "90a25050565b600484601181111561077b57fe5b14156107c657604080518481526020810184905" - "280820183905290517f4a25b279c7c585f25eda9788ac9420ebadae78ca6b206a0e6ab488fd81f5" - "50629181900360600190a1610812565b600a8460118111156107d457fe5b1415610497576040805" - "18481529051829184917ff16c999b533366ca5138d78e85da51611089cd05749f098d6c225d4cd4" - "2ee6ec9181900360200190a35b50505050565b600282601181111561082657fe5b1415610864576" - "040805182815290517f56d2ef3c5228bf5d88573621e325a4672ab50e033749a601e4f4a5e1dce9" - "05d49181900360200190a16108c6565b600782601181111561087257fe5b14156108a8576040518" - "1907ff70fe689e290d8ce2b2a388ac28db36fbb0e16a6d89c6804c461f65a1b40bb1590600090a2" - "6108c6565b60068260118111156108b657fe5b1415610497576040518190600090a15b5050565b8" - "16040518082805190602001908083835b602083106108fa5780518252601f199092019160209182" - "0191016108db565b51815160209384036101000a600019018019909216911617905260408051929" - "09401829003822081835287518383015287519096507fe77cf33df73da7bc2e253a2dae617e6f15" - "e4e337eaa462a108903af4643d1b7595508794929350839283019185019080838360005b8381101" - "561097d578181015183820152602001610965565b50505050905090810190601f1680156109aa57" - "80820380516001836020036101000a031916815260200191505b509250505060405180910390a25" - "050565b6040805173ffffffffffffffffffffffffffffffffffffffff8381168252915191841691" - "7ff922c215689548d72c3d2fe4ea8dafb2a30c43312c9b43fe5d10f713181f991c9181900360200" - "190a25050565b7f532fd6ea96cfb78bb46e09279a26828b8b493de1a2b8b1ee1face527978a15a5" - "8160405180806020018281038252838181518152602001915080519060200190808383600083811" - "0156103f85781810151838201526020016103e0565b6040805173ffffffffffffffffffffffffff" - "ffffffffffffff80851682528316602082015281517f06029e18f16caae06a69281f35b00ed3fcf" - "47950e6c99dafa1bdd8c4b93479a0929181900390910190a150505600a165627a7a72305820962b" - "b0d0c7c052407e6ad0911da133e939baa8783fbd0220169b97b54160a89e0029" + "608060405234801561001057600080fd5b50600436106100b45760003560e01c80639c377053116100715780639c" + "37705314610161578063aa6fd8221461017d578063acabb9ed14610199578063b2ddc449146101b5578063e17bf9" + "56146101d1578063f82ef69e146101ed576100b4565b80630bb563d6146100b957806317c0c180146100d5578063" + "20f0256e146100f15780635da86c171461010d57806390b41d8b14610129578063966b50e014610145575b600080" + "fd5b6100d360048036038101906100ce9190610aff565b610209565b005b6100ef60048036038101906100ea9190" + "610b6d565b610243565b005b61010b60048036038101906101069190610bd0565b61031d565b005b610127600480" + "36038101906101229190610cf0565b61043c565b005b610143600480360381019061013e9190610d30565b610479" + "565b005b61015f600480360381019061015a9190610ea3565b6105d9565b005b61017b6004803603810190610176" + "9190610f1b565b61062a565b005b61019760048036038101906101929190610f82565b610744565b005b6101b360" + "048036038101906101ae9190610fc2565b61088b565b005b6101cf60048036038101906101ca9190611098565b61" + "08dc565b005b6101eb60048036038101906101e69190611179565b61092e565b005b610207600480360381019061" + "02029190611098565b610968565b005b7fa95e6e2a182411e7a6f9ed114a85c3761d87f9b8f453d842c71235aa64" + "fff99f81604051610238919061124a565b60405180910390a150565b600160128111156102575761025661126c56" + "5b5b81601281111561026a5761026961126c565b5b14156102a1577f1e86022f78f8d04f8e3dfd13a2bdb280403e" + "6632877c0dbee5e4eeb259908a5c60405160405180910390a161031a565b600060128111156102b5576102b46112" + "6c565b5b8160128111156102c8576102c761126c565b5b14156102de5760405160405180910390a0610319565b60" + "40517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610310906113" + "0d565b60405180910390fd5b5b50565b600560128111156103315761033061126c565b5b85601281111561034457" + "61034361126c565b5b141561038c577ff039d147f23fe975a4254bdf6b1502b8c79132ae1833986b7ccef2638e73" + "fdf98484848460405161037f949392919061133c565b60405180910390a1610435565b600b60128111156103a057" + "61039f61126c565b5b8560128111156103b3576103b261126c565b5b14156103f95780827fa30ece802b64cd2b7e" + "57dabf4010aabf5df26d1556977affb07b98a77ad955b586866040516103ec929190611381565b60405180910390" + "a3610434565b6040517f08c379a00000000000000000000000000000000000000000000000000000000081526004" + "0161042b9061130d565b60405180910390fd5b5b5050505050565b7f8ccce2523cca5f3851d20df50b5a59509bc4" + "ac7d9ddba344f5e331969d09b8e7828260405161046d929190611417565b60405180910390a15050565b60036012" + "81111561048d5761048c61126c565b5b8360128111156104a05761049f61126c565b5b14156104e4577fdf0cb1de" + "a99afceb3ea698d62e705b736f1345a7eee9eb07e63d1f8f556c1bc582826040516104d7929190611381565b6040" + "5180910390a16105d4565b600960128111156104f8576104f761126c565b5b83601281111561050b5761050a6112" + "6c565b5b141561054e57807f057bc32826fbe161da1c110afcdcae7c109a8b69149f727fc37a603c60ef94ca8360" + "40516105419190611440565b60405180910390a26105d3565b600860128111156105625761056161126c565b5b83" + "60128111156105755761057461126c565b5b141561059757808260405161058a9190611440565b60405180910390" + "a16105d2565b6040517f08c379a00000000000000000000000000000000000000000000000000000000081526004" + "016105c99061130d565b60405180910390fd5b5b5b505050565b816040516105e79190611513565b604051809103" + "90207fdbc4c1d1d2f0d84e58d36ca767ec9ba2ec2f933c055e50e5ccdd57697f7b58b08260405161061e91906115" + "c0565b60405180910390a25050565b6004601281111561063e5761063d61126c565b5b8460128111156106515761" + "065061126c565b5b1415610697577f4a25b279c7c585f25eda9788ac9420ebadae78ca6b206a0e6ab488fd81f550" + "6283838360405161068a939291906115e2565b60405180910390a161073e565b600a60128111156106ab576106aa" + "61126c565b5b8460128111156106be576106bd61126c565b5b14156107025780827ff16c999b533366ca5138d78e" + "85da51611089cd05749f098d6c225d4cd42ee6ec856040516106f59190611440565b60405180910390a361073d56" + "5b6040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161073490" + "61130d565b60405180910390fd5b5b50505050565b600260128111156107585761075761126c565b5b8260128111" + "1561076b5761076a61126c565b5b14156107ad577f56d2ef3c5228bf5d88573621e325a4672ab50e033749a601e4" + "f4a5e1dce905d4816040516107a09190611440565b60405180910390a1610887565b600760128111156107c15761" + "07c061126c565b5b8260128111156107d4576107d361126c565b5b141561080c57807ff70fe689e290d8ce2b2a38" + "8ac28db36fbb0e16a6d89c6804c461f65a1b40bb1560405160405180910390a2610886565b600660128111156108" + "205761081f61126c565b5b8260128111156108335761083261126c565b5b141561084a5780604051604051809103" + "90a1610885565b6040517f08c379a000000000000000000000000000000000000000000000000000000000815260" + "040161087c9061130d565b60405180910390fd5b5b5b5050565b816040516108999190611655565b604051809103" + "90207fe77cf33df73da7bc2e253a2dae617e6f15e4e337eaa462a108903af4643d1b75826040516108d091906112" + "4a565b60405180910390a25050565b8173ffffffffffffffffffffffffffffffffffffffff167ff922c215689548" + "d72c3d2fe4ea8dafb2a30c43312c9b43fe5d10f713181f991c82604051610922919061167b565b60405180910390" + "a25050565b7f532fd6ea96cfb78bb46e09279a26828b8b493de1a2b8b1ee1face527978a15a58160405161095d91" + "906116eb565b60405180910390a150565b7f06029e18f16caae06a69281f35b00ed3fcf47950e6c99dafa1bdd8c4" + "b93479a0828260405161099992919061170d565b60405180910390a15050565b6000604051905090565b600080fd" + "5b600080fd5b600080fd5b600080fd5b6000601f19601f8301169050919050565b7f4e487b710000000000000000" + "0000000000000000000000000000000000000000600052604160045260246000fd5b610a0c826109c3565b810181" + "811067ffffffffffffffff82111715610a2b57610a2a6109d4565b5b80604052505050565b6000610a3e6109a556" + "5b9050610a4a8282610a03565b919050565b600067ffffffffffffffff821115610a6a57610a696109d4565b5b61" + "0a73826109c3565b9050602081019050919050565b82818337600083830152505050565b6000610aa2610a9d8461" + "0a4f565b610a34565b905082815260208101848484011115610abe57610abd6109be565b5b610ac9848285610a80" + "565b509392505050565b600082601f830112610ae657610ae56109b9565b5b8135610af6848260208601610a8f56" + "5b91505092915050565b600060208284031215610b1557610b146109af565b5b600082013567ffffffffffffffff" + "811115610b3357610b326109b4565b5b610b3f84828501610ad1565b91505092915050565b60138110610b555760" + "0080fd5b50565b600081359050610b6781610b48565b92915050565b600060208284031215610b8357610b826109" + "af565b5b6000610b9184828501610b58565b91505092915050565b6000819050919050565b610bad81610b9a565b" + "8114610bb857600080fd5b50565b600081359050610bca81610ba4565b92915050565b600080600080600060a086" + "88031215610bec57610beb6109af565b5b6000610bfa88828901610b58565b9550506020610c0b88828901610bbb" + "565b9450506040610c1c88828901610bbb565b9350506060610c2d88828901610bbb565b9250506080610c3e8882" + "8901610bbb565b9150509295509295909350565b600080fd5b600060208284031215610c6657610c65610c4b565b" + "5b610c706020610a34565b90506000610c8084828501610bbb565b60008301525092915050565b60006060828403" + "1215610ca257610ca1610c4b565b5b610cac6060610a34565b90506000610cbc84828501610bbb565b6000830152" + "506020610cd084828501610bbb565b6020830152506040610ce484828501610c50565b6040830152509291505056" + "5b60008060808385031215610d0757610d066109af565b5b6000610d1585828601610bbb565b9250506020610d26" + "85828601610c8c565b9150509250929050565b600080600060608486031215610d4957610d486109af565b5b6000" + "610d5786828701610b58565b9350506020610d6886828701610bbb565b9250506040610d7986828701610bbb565b" + "9150509250925092565b600067ffffffffffffffff821115610d9e57610d9d6109d4565b5b602082029050602081" + "019050919050565b600080fd5b60007fffff00000000000000000000000000000000000000000000000000000000" + "000082169050919050565b610de981610db4565b8114610df457600080fd5b50565b600081359050610e0681610d" + "e0565b92915050565b6000610e1f610e1a84610d83565b610a34565b905080838252602082019050602084028301" + "85811115610e4257610e41610daf565b5b835b81811015610e6b5780610e578882610df7565b8452602084019350" + "50602081019050610e44565b5050509392505050565b600082601f830112610e8a57610e896109b9565b5b813561" + "0e9a848260208601610e0c565b91505092915050565b60008060408385031215610eba57610eb96109af565b5b60" + "0083013567ffffffffffffffff811115610ed857610ed76109b4565b5b610ee485828601610e75565b9250506020" + "83013567ffffffffffffffff811115610f0557610f046109b4565b5b610f1185828601610e75565b915050925092" + "9050565b60008060008060808587031215610f3557610f346109af565b5b6000610f4387828801610b58565b9450" + "506020610f5487828801610bbb565b9350506040610f6587828801610bbb565b9250506060610f7687828801610b" + "bb565b91505092959194509250565b60008060408385031215610f9957610f986109af565b5b6000610fa7858286" + "01610b58565b9250506020610fb885828601610bbb565b9150509250929050565b60008060408385031215610fd9" + "57610fd86109af565b5b600083013567ffffffffffffffff811115610ff757610ff66109b4565b5b611003858286" + "01610ad1565b925050602083013567ffffffffffffffff811115611024576110236109b4565b5b61103085828601" + "610ad1565b9150509250929050565b600073ffffffffffffffffffffffffffffffffffffffff8216905091905056" + "5b60006110658261103a565b9050919050565b6110758161105a565b811461108057600080fd5b50565b60008135" + "90506110928161106c565b92915050565b600080604083850312156110af576110ae6109af565b5b60006110bd85" + "828601611083565b92505060206110ce85828601611083565b9150509250929050565b600067ffffffffffffffff" + "8211156110f3576110f26109d4565b5b6110fc826109c3565b9050602081019050919050565b600061111c611117" + "846110d8565b610a34565b905082815260208101848484011115611138576111376109be565b5b61114384828561" + "0a80565b509392505050565b600082601f8301126111605761115f6109b9565b5b81356111708482602086016111" + "09565b91505092915050565b60006020828403121561118f5761118e6109af565b5b600082013567ffffffffffff" + "ffff8111156111ad576111ac6109b4565b5b6111b98482850161114b565b91505092915050565b60008151905091" + "9050565b600082825260208201905092915050565b60005b838110156111fc578082015181840152602081019050" + "6111e1565b8381111561120b576000848401525b50505050565b600061121c826111c2565b61122681856111cd56" + "5b93506112368185602086016111de565b61123f816109c3565b840191505092915050565b600060208201905081" + "810360008301526112648184611211565b905092915050565b7f4e487b7100000000000000000000000000000000" + "000000000000000000000000600052602160045260246000fd5b7f4469646e2774206d6174636820616e7920616c" + "6c6f7761626c65206576656e7460008201527f20696e646578000000000000000000000000000000000000000000" + "0000000000602082015250565b60006112f76026836111cd565b91506113028261129b565b604082019050919050" + "565b60006020820190508181036000830152611326816112ea565b9050919050565b61133681610b9a565b825250" + "50565b6000608082019050611351600083018761132d565b61135e602083018661132d565b61136b604083018561" + "132d565b611378606083018461132d565b95945050505050565b6000604082019050611396600083018561132d56" + "5b6113a3602083018461132d565b9392505050565b6113b381610b9a565b82525050565b60208201600082015161" + "13cf60008501826113aa565b50505050565b6060820160008201516113eb60008501826113aa565b506020820151" + "6113fe60208501826113aa565b50604082015161141160408501826113b9565b50505050565b6000608082019050" + "61142c600083018561132d565b61143960208301846113d5565b9392505050565b60006020820190506114556000" + "83018461132d565b92915050565b600081519050919050565b600081905092915050565b60008190506020820190" + "50919050565b61148a81610db4565b82525050565b600061149c8383611481565b60208301905092915050565b60" + "00602082019050919050565b60006114c08261145b565b6114ca8185611466565b93506114d583611471565b8060" + "005b838110156115065781516114ed8882611490565b97506114f8836114a8565b9250506001810190506114d956" + "5b5085935050505092915050565b600061151f82846114b5565b915081905092915050565b600082825260208201" + "905092915050565b61154481610db4565b82525050565b6000611556838361153b565b6020830190509291505056" + "5b600061156d8261145b565b611577818561152a565b935061158283611471565b8060005b838110156115b35781" + "5161159a888261154a565b97506115a5836114a8565b925050600181019050611586565b50859350505050929150" + "50565b600060208201905081810360008301526115da8184611562565b905092915050565b600060608201905061" + "15f7600083018661132d565b611604602083018561132d565b611611604083018461132d565b949350505050565b" + "600081905092915050565b600061162f826111c2565b6116398185611619565b93506116498185602086016111de" + "565b80840191505092915050565b60006116618284611624565b915081905092915050565b6116758161105a565b" + "82525050565b6000602082019050611690600083018461166c565b92915050565b600081519050919050565b6000" + "82825260208201905092915050565b60006116bd82611696565b6116c781856116a1565b93506116d78185602086" + "016111de565b6116e0816109c3565b840191505092915050565b6000602082019050818103600083015261170581" + "846116b2565b905092915050565b6000604082019050611722600083018561166c565b61172f602083018461166c" + "565b939250505056fea2646970667358221220c210b75fcc1b13a7d08711ef833663000e885b94713c307622ffdc" + "2214d1a22264736f6c634300080b0033" ) CONTRACT_EMITTER_ABI = [ @@ -440,6 +560,18 @@ "internalType": "uint256", "name": "b", "type": "uint256" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "c", + "type": "uint256" + } + ], + "internalType": "struct Emitter.NestedTestTuple", + "name": "nested", + "type": "tuple" } ], "indexed": False, @@ -503,8 +635,12 @@ }, { "inputs": [ - { "internalType": "address", "name": "arg0", "type": "address" }, - { "internalType": "address", "name": "arg1", "type": "address" } + { + "internalType": "address", "name": "arg0", "type": "address" + }, + { + "internalType": "address", "name": "arg1", "type": "address" + } ], "name": "logAddressIndexedArgs", "outputs": [], @@ -513,8 +649,12 @@ }, { "inputs": [ - { "internalType": "address", "name": "arg0", "type": "address" }, - { "internalType": "address", "name": "arg1", "type": "address" } + { + "internalType": "address", "name": "arg0", "type": "address" + }, + { + "internalType": "address", "name": "arg1", "type": "address" + } ], "name": "logAddressNotIndexedArgs", "outputs": [], @@ -522,7 +662,9 @@ "type": "function" }, { - "inputs": [{ "internalType": "bytes", "name": "v", "type": "bytes" }], + "inputs": [{ + "internalType": "bytes", "name": "v", "type": "bytes" + }], "name": "logBytes", "outputs": [], "stateMutability": "nonpayable", @@ -535,8 +677,12 @@ "name": "which", "type": "uint8" }, - { "internalType": "uint256", "name": "arg0", "type": "uint256" }, - { "internalType": "uint256", "name": "arg1", "type": "uint256" } + { + "internalType": "uint256", "name": "arg0", "type": "uint256" + }, + { + "internalType": "uint256", "name": "arg1", "type": "uint256" + } ], "name": "logDouble", "outputs": [], @@ -545,8 +691,8 @@ }, { "inputs": [ - { "internalType": "string", "name": "arg0", "type": "string" }, - { "internalType": "string", "name": "arg1", "type": "string" } + {"internalType": "string", "name": "arg0", "type": "string"}, + {"internalType": "string", "name": "arg1", "type": "string"} ], "name": "logDynamicArgs", "outputs": [], @@ -555,8 +701,8 @@ }, { "inputs": [ - { "internalType": "bytes2[]", "name": "arg0", "type": "bytes2[]" }, - { "internalType": "bytes2[]", "name": "arg1", "type": "bytes2[]" } + {"internalType": "bytes2[]", "name": "arg0", "type": "bytes2[]"}, + {"internalType": "bytes2[]", "name": "arg1", "type": "bytes2[]"} ], "name": "logListArgs", "outputs": [], @@ -583,10 +729,10 @@ "name": "which", "type": "uint8" }, - { "internalType": "uint256", "name": "arg0", "type": "uint256" }, - { "internalType": "uint256", "name": "arg1", "type": "uint256" }, - { "internalType": "uint256", "name": "arg2", "type": "uint256" }, - { "internalType": "uint256", "name": "arg3", "type": "uint256" } + {"internalType": "uint256", "name": "arg0", "type": "uint256"}, + {"internalType": "uint256", "name": "arg1", "type": "uint256"}, + {"internalType": "uint256", "name": "arg2", "type": "uint256"}, + {"internalType": "uint256", "name": "arg3", "type": "uint256"} ], "name": "logQuadruple", "outputs": [], @@ -600,7 +746,7 @@ "name": "which", "type": "uint8" }, - { "internalType": "uint256", "name": "arg0", "type": "uint256" } + {"internalType": "uint256", "name": "arg0", "type": "uint256"} ], "name": "logSingle", "outputs": [], @@ -608,7 +754,7 @@ "type": "function" }, { - "inputs": [{ "internalType": "string", "name": "v", "type": "string" }], + "inputs": [{"internalType": "string", "name": "v", "type": "string"}], "name": "logString", "outputs": [], "stateMutability": "nonpayable", @@ -616,7 +762,7 @@ }, { "inputs": [ - { "internalType": "uint256", "name": "arg0", "type": "uint256" }, + {"internalType": "uint256", "name": "arg0", "type": "uint256"}, { "components": [ { @@ -628,6 +774,18 @@ "internalType": "uint256", "name": "b", "type": "uint256" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "c", + "type": "uint256" + } + ], + "internalType": "struct Emitter.NestedTestTuple", + "name": "nested", + "type": "tuple" } ], "internalType": "struct Emitter.TestTuple", @@ -647,9 +805,9 @@ "name": "which", "type": "uint8" }, - { "internalType": "uint256", "name": "arg0", "type": "uint256" }, - { "internalType": "uint256", "name": "arg1", "type": "uint256" }, - { "internalType": "uint256", "name": "arg2", "type": "uint256" } + {"internalType": "uint256", "name": "arg0", "type": "uint256"}, + {"internalType": "uint256", "name": "arg1", "type": "uint256"}, + {"internalType": "uint256", "name": "arg2", "type": "uint256"} ], "name": "logTriple", "outputs": [], @@ -670,6 +828,5 @@ 'LogDoubleAnonymous': 8, 'LogDoubleWithIndex': 9, 'LogTripleWithIndex': 10, - 'LogQuadrupleWithIndex': 11, - 'LogStructArg': 12 + 'LogQuadrupleWithInde': 11, } From 693592bb7ac31c6a5c9a9089b5f99c61b02b9790 Mon Sep 17 00:00:00 2001 From: Felipe Selmo Date: Thu, 13 Jan 2022 11:41:52 -0700 Subject: [PATCH 3/4] Separate emitter contract into new and old versions `enable_strict_bytes_type_checking()` appears to be broken with solidity versions `0.5.0` and above. This commit separates a new emitter contract, compiled with solidity `0.8.11`, and the older emitter contract, compiled with solidity `0.4.21`. This way, we can update the tests using the `emitter` pytest modules while the strict bytes test can use the old emitter contract until we can update `enable_strict_bytes_type_checking()` to be compatible with newer solidity versions. --- tests/core/contracts/conftest.py | 20 +- .../contract_sources/Emitter_old.sol | 106 +++ .../contracts/test_extracting_event_data.py | 2 +- .../_utils/module_testing/emitter_contract.py | 4 +- .../module_testing/emitter_contract_old.py | 672 ++++++++++++++++++ 5 files changed, 800 insertions(+), 4 deletions(-) create mode 100644 tests/core/contracts/contract_sources/Emitter_old.sol create mode 100644 web3/_utils/module_testing/emitter_contract_old.py diff --git a/tests/core/contracts/conftest.py b/tests/core/contracts/conftest.py index 399d13f4c6..a36d08ff78 100644 --- a/tests/core/contracts/conftest.py +++ b/tests/core/contracts/conftest.py @@ -11,6 +11,11 @@ CONTRACT_EMITTER_CODE, CONTRACT_EMITTER_RUNTIME, ) +from web3._utils.module_testing.emitter_contract_old import ( + CONTRACT_EMITTER_ABI_OLD, + CONTRACT_EMITTER_CODE_OLD, + CONTRACT_EMITTER_RUNTIME_OLD, +) from web3._utils.module_testing.event_contract import ( EVNT_CONTRACT_ABI, EVNT_CONTRACT_CODE, @@ -422,9 +427,20 @@ def EMITTER(EMITTER_CODE, @pytest.fixture() -def StrictEmitter(w3_strict_abi, EMITTER): +def STRICT_EMITTER(): + # Uses an older version of solidity to compile for strict bytes checking. + # See: https://github.com/ethereum/web3.py/issues/2301 + return { + 'bytecode': CONTRACT_EMITTER_CODE_OLD, + 'bytecode_runtime': CONTRACT_EMITTER_RUNTIME_OLD, + 'abi': CONTRACT_EMITTER_ABI_OLD, + } + + +@pytest.fixture() +def StrictEmitter(w3_strict_abi, STRICT_EMITTER): w3 = w3_strict_abi - return w3.eth.contract(**EMITTER) + return w3.eth.contract(**STRICT_EMITTER) @pytest.fixture() diff --git a/tests/core/contracts/contract_sources/Emitter_old.sol b/tests/core/contracts/contract_sources/Emitter_old.sol new file mode 100644 index 0000000000..c829f60f5d --- /dev/null +++ b/tests/core/contracts/contract_sources/Emitter_old.sol @@ -0,0 +1,106 @@ +// This older version of the Emitter contract can be use to keep the strict bytes test against it while we work on +// updating the strict bytes checking to be compatible with newer solidity versions. +// # See: https://github.com/ethereum/web3.py/issues/2301 + +pragma solidity ^0.4.21; + + +contract Emitter { + event LogAnonymous() anonymous; + event LogNoArguments(); + event LogSingleArg(uint arg0); + event LogDoubleArg(uint arg0, uint arg1); + event LogTripleArg(uint arg0, uint arg1, uint arg2); + event LogQuadrupleArg(uint arg0, uint arg1, uint arg2, uint arg3); + event LogString(string v); + event LogBytes(bytes v); + + // Indexed + event LogSingleWithIndex(uint indexed arg0); + event LogSingleAnonymous(uint indexed arg0) anonymous; + event LogDoubleWithIndex(uint arg0, uint indexed arg1); + event LogDoubleAnonymous(uint arg0, uint indexed arg1) anonymous; + event LogTripleWithIndex(uint arg0, uint indexed arg1, uint indexed arg2); + event LogQuadrupleWithIndex(uint arg0, uint arg1, uint indexed arg2, uint indexed arg3); + event LogDynamicArgs(string indexed arg0, string arg1); + event LogListArgs(bytes2[] indexed arg0, bytes2[] arg1); + event LogAddressIndexed(address indexed arg0, address arg1); + event LogAddressNotIndexed(address arg0, address arg1); + + enum WhichEvent { + LogAnonymous, + LogNoArguments, + LogSingleArg, + LogDoubleArg, + LogTripleArg, + LogQuadrupleArg, + LogSingleAnonymous, + LogSingleWithIndex, + LogDoubleAnonymous, + LogDoubleWithIndex, + LogTripleWithIndex, + LogQuadrupleWithIndex, + LogBytes, + LogString, + LogDynamicArgs, + LogListArgs, + LogAddressIndexed, + LogAddressNotIndexed + } + + function logNoArgs(WhichEvent which) public { + if (which == WhichEvent.LogNoArguments) emit LogNoArguments(); + else if (which == WhichEvent.LogAnonymous) emit LogAnonymous(); + else revert("Didn't match any allowable event index"); + } + + function logSingle(WhichEvent which, uint arg0) public { + if (which == WhichEvent.LogSingleArg) emit LogSingleArg(arg0); + else if (which == WhichEvent.LogSingleWithIndex) emit LogSingleWithIndex(arg0); + else if (which == WhichEvent.LogSingleAnonymous) emit LogSingleAnonymous(arg0); + else revert("Didn't match any allowable event index"); + } + + function logDouble(WhichEvent which, uint arg0, uint arg1) public { + if (which == WhichEvent.LogDoubleArg) emit LogDoubleArg(arg0, arg1); + else if (which == WhichEvent.LogDoubleWithIndex) emit LogDoubleWithIndex(arg0, arg1); + else if (which == WhichEvent.LogDoubleAnonymous) emit LogDoubleAnonymous(arg0, arg1); + else revert("Didn't match any allowable event index"); + } + + function logTriple(WhichEvent which, uint arg0, uint arg1, uint arg2) public { + if (which == WhichEvent.LogTripleArg) emit LogTripleArg(arg0, arg1, arg2); + else if (which == WhichEvent.LogTripleWithIndex) emit LogTripleWithIndex(arg0, arg1, arg2); + else revert("Didn't match any allowable event index"); + } + + function logQuadruple(WhichEvent which, uint arg0, uint arg1, uint arg2, uint arg3) public { + if (which == WhichEvent.LogQuadrupleArg) emit LogQuadrupleArg(arg0, arg1, arg2, arg3); + else if (which == WhichEvent.LogQuadrupleWithIndex) emit LogQuadrupleWithIndex(arg0, arg1, arg2, arg3); + else revert("Didn't match any allowable event index"); + } + + function logDynamicArgs(string arg0, string arg1) public { + emit LogDynamicArgs(arg0, arg1); + } + + function logListArgs(bytes2[] arg0, bytes2[] arg1) public { + emit LogListArgs(arg0, arg1); + } + + function logAddressIndexedArgs(address arg0, address arg1) public { + emit LogAddressIndexed(arg0, arg1); + } + + function logAddressNotIndexedArgs(address arg0, address arg1) public { + emit LogAddressNotIndexed(arg0, arg1); + } + + function logBytes(bytes v) public { + emit LogBytes(v); + } + + function logString(string v) public { + emit LogString(v); + } +} diff --git a/tests/core/contracts/test_extracting_event_data.py b/tests/core/contracts/test_extracting_event_data.py index 9bac522a38..3f80248f70 100644 --- a/tests/core/contracts/test_extracting_event_data.py +++ b/tests/core/contracts/test_extracting_event_data.py @@ -330,7 +330,7 @@ def test_argument_extraction_strict_bytes_types(w3_strict_abi, emitter_log_topics): arg_0 = [b'12'] arg_1 = [b'12'] - txn_hash = strict_emitter.functions.logListArgs(arg_0, arg_1).transact({'gas': 25000}) + txn_hash = strict_emitter.functions.logListArgs(arg_0, arg_1).transact() txn_receipt = wait_for_transaction(w3_strict_abi, txn_hash) assert len(txn_receipt['logs']) == 1 diff --git a/web3/_utils/module_testing/emitter_contract.py b/web3/_utils/module_testing/emitter_contract.py index 5e17440964..72a91fe717 100644 --- a/web3/_utils/module_testing/emitter_contract.py +++ b/web3/_utils/module_testing/emitter_contract.py @@ -816,6 +816,7 @@ } ] + EMITTER_ENUM = { 'LogAnonymous': 0, 'LogNoArguments': 1, @@ -828,5 +829,6 @@ 'LogDoubleAnonymous': 8, 'LogDoubleWithIndex': 9, 'LogTripleWithIndex': 10, - 'LogQuadrupleWithInde': 11, + 'LogQuadrupleWithIndex': 11, + 'LogStructArg': 12 } diff --git a/web3/_utils/module_testing/emitter_contract_old.py b/web3/_utils/module_testing/emitter_contract_old.py new file mode 100644 index 0000000000..789699d8eb --- /dev/null +++ b/web3/_utils/module_testing/emitter_contract_old.py @@ -0,0 +1,672 @@ +# Strict bytes checking seems to only be supported with solidity versions below `0.5.0`. +# This older emitter contract, compiled with solidity `0.4.21`, can still test against the strict +# bytes check but we can update all other tests using the emitter contract to use the new version +# compiled with `0.8.11`. +# See: https://github.com/ethereum/web3.py/issues/2301 + +CONTRACT_EMITTER_CODE_OLD = ( + "608060405234801561001057600080fd5b50610aed806100206000396000f300608060405260043" + "6106100ae5763ffffffff7c01000000000000000000000000000000000000000000000000000000" + "006000350416630bb563d681146100b357806317c0c1801461010e57806320f0256e14610129578" + "06390b41d8b14610150578063966b50e0146101715780639c377053146101ff578063aa6fd82214" + "610223578063acabb9ed14610241578063b2ddc449146102d8578063e17bf9561461030c578063f" + "82ef69e14610365575b600080fd5b3480156100bf57600080fd5b50604080516020600480358082" + "0135601f810184900484028501840190955284845261010c9436949293602493928401919081908" + "401838280828437509497506103999650505050505050565b005b34801561011a57600080fd5b50" + "61010c60ff60043516610435565b34801561013557600080fd5b5061010c60ff600435166024356" + "04435606435608435610527565b34801561015c57600080fd5b5061010c60ff6004351660243560" + "44356105e4565b34801561017d57600080fd5b50604080516020600480358082013583810280860" + "1850190965280855261010c95369593946024949385019291829185019084908082843750506040" + "805187358901803560208181028481018201909552818452989b9a9989019892975090820195509" + "350839250850190849080828437509497506106b49650505050505050565b34801561020b576000" + "80fd5b5061010c60ff6004351660243560443560643561076d565b34801561022f57600080fd5b5" + "061010c60ff60043516602435610818565b34801561024d57600080fd5b50604080516020600480" + "3580820135601f810184900484028501840190955284845261010c9436949293602493928401919" + "0819084018382808284375050604080516020601f89358b01803591820183900483028401830190" + "9452808352979a9998810197919650918201945092508291508401838280828437509497506108c" + "a9650505050505050565b3480156102e457600080fd5b5061010c73ffffffffffffffffffffffff" + "ffffffffffffffff600435811690602435166109bb565b34801561031857600080fd5b506040805" + "160206004803580820135601f810184900484028501840190955284845261010c94369492936024" + "9392840191908190840183828082843750949750610a0d9650505050505050565b3480156103715" + "7600080fd5b5061010c73ffffffffffffffffffffffffffffffffffffffff600435811690602435" + "16610a6b565b7fa95e6e2a182411e7a6f9ed114a85c3761d87f9b8f453d842c71235aa64fff99f8" + "16040518080602001828103825283818151815260200191508051906020019080838360005b8381" + "10156103f85781810151838201526020016103e0565b50505050905090810190601f16801561042" + "55780820380516001836020036101000a031916815260200191505b509250505060405180910390" + "a150565b600181601181111561044357fe5b1415610477576040517f1e86022f78f8d04f8e3dfd1" + "3a2bdb280403e6632877c0dbee5e4eeb259908a5c90600090a1610524565b600081601181111561" + "048557fe5b141561049757604051600090a0610524565b604080517f08c379a0000000000000000" + "00000000000000000000000000000000000000000815260206004820152602660248201527f4469" + "646e2774206d6174636820616e7920616c6c6f7761626c65206576656e7460448201527f20696e6" + "4657800000000000000000000000000000000000000000000000000006064820152905190819003" + "60840190fd5b50565b600585601181111561053557fe5b141561058757604080518581526020810" + "18590528082018490526060810183905290517ff039d147f23fe975a4254bdf6b1502b8c79132ae" + "1833986b7ccef2638e73fdf99181900360800190a16105dd565b600b85601181111561059557fe5" + "b14156104975780827fa30ece802b64cd2b7e57dabf4010aabf5df26d1556977affb07b98a77ad9" + "55b58686604051808381526020018281526020019250505060405180910390a35b5050505050565" + "b60038360118111156105f257fe5b141561063857604080518381526020810183905281517fdf0c" + "b1dea99afceb3ea698d62e705b736f1345a7eee9eb07e63d1f8f556c1bc5929181900390910190a" + "16106af565b600983601181111561064657fe5b14156106875760408051838152905182917f057b" + "c32826fbe161da1c110afcdcae7c109a8b69149f727fc37a603c60ef94ca919081900360200190a" + "26106af565b600883601181111561069557fe5b1415610497576040805183815290518291819003" + "60200190a15b505050565b8160405180828051906020019060200280838360005b838110156106e" + "25781810151838201526020016106ca565b5050505090500191505060405180910390207fdbc4c1" + "d1d2f0d84e58d36ca767ec9ba2ec2f933c055e50e5ccdd57697f7b58b0826040518080602001828" + "103825283818151815260200191508051906020019060200280838360005b838110156107565781" + "8101518382015260200161073e565b505050509050019250505060405180910390a25050565b600" + "484601181111561077b57fe5b14156107c657604080518481526020810184905280820183905290" + "517f4a25b279c7c585f25eda9788ac9420ebadae78ca6b206a0e6ab488fd81f5506291819003606" + "00190a1610812565b600a8460118111156107d457fe5b1415610497576040805184815290518291" + "84917ff16c999b533366ca5138d78e85da51611089cd05749f098d6c225d4cd42ee6ec918190036" + "0200190a35b50505050565b600282601181111561082657fe5b1415610864576040805182815290" + "517f56d2ef3c5228bf5d88573621e325a4672ab50e033749a601e4f4a5e1dce905d491819003602" + "00190a16108c6565b600782601181111561087257fe5b14156108a85760405181907ff70fe689e2" + "90d8ce2b2a388ac28db36fbb0e16a6d89c6804c461f65a1b40bb1590600090a26108c6565b60068" + "260118111156108b657fe5b1415610497576040518190600090a15b5050565b8160405180828051" + "90602001908083835b602083106108fa5780518252601f1990920191602091820191016108db565" + "b51815160209384036101000a600019018019909216911617905260408051929094018290038220" + "81835287518383015287519096507fe77cf33df73da7bc2e253a2dae617e6f15e4e337eaa462a10" + "8903af4643d1b7595508794929350839283019185019080838360005b8381101561097d57818101" + "5183820152602001610965565b50505050905090810190601f1680156109aa57808203805160018" + "36020036101000a031916815260200191505b509250505060405180910390a25050565b60408051" + "73ffffffffffffffffffffffffffffffffffffffff83811682529151918416917ff922c21568954" + "8d72c3d2fe4ea8dafb2a30c43312c9b43fe5d10f713181f991c9181900360200190a25050565b7f" + "532fd6ea96cfb78bb46e09279a26828b8b493de1a2b8b1ee1face527978a15a5816040518080602" + "00182810382528381815181526020019150805190602001908083836000838110156103f8578181" + "0151838201526020016103e0565b6040805173ffffffffffffffffffffffffffffffffffffffff8" + "0851682528316602082015281517f06029e18f16caae06a69281f35b00ed3fcf47950e6c99dafa1" + "bdd8c4b93479a0929181900390910190a150505600a165627a7a72305820962bb0d0c7c052407e6" + "ad0911da133e939baa8783fbd0220169b97b54160a89e0029" +) + +CONTRACT_EMITTER_RUNTIME_OLD = ( + "6080604052600436106100ae5763ffffffff7c01000000000000000000000000000000000000000" + "000000000000000006000350416630bb563d681146100b357806317c0c1801461010e57806320f0" + "256e1461012957806390b41d8b14610150578063966b50e0146101715780639c377053146101ff5" + "78063aa6fd82214610223578063acabb9ed14610241578063b2ddc449146102d8578063e17bf956" + "1461030c578063f82ef69e14610365575b600080fd5b3480156100bf57600080fd5b50604080516" + "0206004803580820135601f810184900484028501840190955284845261010c9436949293602493" + "928401919081908401838280828437509497506103999650505050505050565b005b34801561011" + "a57600080fd5b5061010c60ff60043516610435565b34801561013557600080fd5b5061010c60ff" + "60043516602435604435606435608435610527565b34801561015c57600080fd5b5061010c60ff6" + "00435166024356044356105e4565b34801561017d57600080fd5b50604080516020600480358082" + "0135838102808601850190965280855261010c95369593946024949385019291829185019084908" + "082843750506040805187358901803560208181028481018201909552818452989b9a9989019892" + "975090820195509350839250850190849080828437509497506106b49650505050505050565b348" + "01561020b57600080fd5b5061010c60ff6004351660243560443560643561076d565b3480156102" + "2f57600080fd5b5061010c60ff60043516602435610818565b34801561024d57600080fd5b50604" + "0805160206004803580820135601f810184900484028501840190955284845261010c9436949293" + "6024939284019190819084018382808284375050604080516020601f89358b01803591820183900" + "4830284018301909452808352979a99988101979196509182019450925082915084018382808284" + "37509497506108ca9650505050505050565b3480156102e457600080fd5b5061010c73fffffffff" + "fffffffffffffffffffffffffffffff600435811690602435166109bb565b348015610318576000" + "80fd5b506040805160206004803580820135601f810184900484028501840190955284845261010" + "c943694929360249392840191908190840183828082843750949750610a0d965050505050505056" + "5b34801561037157600080fd5b5061010c73ffffffffffffffffffffffffffffffffffffffff600" + "43581169060243516610a6b565b7fa95e6e2a182411e7a6f9ed114a85c3761d87f9b8f453d842c7" + "1235aa64fff99f81604051808060200182810382528381815181526020019150805190602001908" + "0838360005b838110156103f85781810151838201526020016103e0565b50505050905090810190" + "601f1680156104255780820380516001836020036101000a031916815260200191505b509250505" + "060405180910390a150565b600181601181111561044357fe5b1415610477576040517f1e86022f" + "78f8d04f8e3dfd13a2bdb280403e6632877c0dbee5e4eeb259908a5c90600090a1610524565b600" + "081601181111561048557fe5b141561049757604051600090a0610524565b604080517f08c379a0" + "0000000000000000000000000000000000000000000000000000000081526020600482015260266" + "0248201527f4469646e2774206d6174636820616e7920616c6c6f7761626c65206576656e746044" + "8201527f20696e64657800000000000000000000000000000000000000000000000000006064820" + "15290519081900360840190fd5b50565b600585601181111561053557fe5b141561058757604080" + "51858152602081018590528082018490526060810183905290517ff039d147f23fe975a4254bdf6" + "b1502b8c79132ae1833986b7ccef2638e73fdf99181900360800190a16105dd565b600b85601181" + "111561059557fe5b14156104975780827fa30ece802b64cd2b7e57dabf4010aabf5df26d1556977" + "affb07b98a77ad955b58686604051808381526020018281526020019250505060405180910390a3" + "5b5050505050565b60038360118111156105f257fe5b14156106385760408051838152602081018" + "3905281517fdf0cb1dea99afceb3ea698d62e705b736f1345a7eee9eb07e63d1f8f556c1bc59291" + "81900390910190a16106af565b600983601181111561064657fe5b1415610687576040805183815" + "2905182917f057bc32826fbe161da1c110afcdcae7c109a8b69149f727fc37a603c60ef94ca9190" + "81900360200190a26106af565b600883601181111561069557fe5b1415610497576040805183815" + "29051829181900360200190a15b505050565b816040518082805190602001906020028083836000" + "5b838110156106e25781810151838201526020016106ca565b50505050905001915050604051809" + "10390207fdbc4c1d1d2f0d84e58d36ca767ec9ba2ec2f933c055e50e5ccdd57697f7b58b0826040" + "518080602001828103825283818151815260200191508051906020019060200280838360005b838" + "1101561075657818101518382015260200161073e565b5050505090500192505050604051809103" + "90a25050565b600484601181111561077b57fe5b14156107c657604080518481526020810184905" + "280820183905290517f4a25b279c7c585f25eda9788ac9420ebadae78ca6b206a0e6ab488fd81f5" + "50629181900360600190a1610812565b600a8460118111156107d457fe5b1415610497576040805" + "18481529051829184917ff16c999b533366ca5138d78e85da51611089cd05749f098d6c225d4cd4" + "2ee6ec9181900360200190a35b50505050565b600282601181111561082657fe5b1415610864576" + "040805182815290517f56d2ef3c5228bf5d88573621e325a4672ab50e033749a601e4f4a5e1dce9" + "05d49181900360200190a16108c6565b600782601181111561087257fe5b14156108a8576040518" + "1907ff70fe689e290d8ce2b2a388ac28db36fbb0e16a6d89c6804c461f65a1b40bb1590600090a2" + "6108c6565b60068260118111156108b657fe5b1415610497576040518190600090a15b5050565b8" + "16040518082805190602001908083835b602083106108fa5780518252601f199092019160209182" + "0191016108db565b51815160209384036101000a600019018019909216911617905260408051929" + "09401829003822081835287518383015287519096507fe77cf33df73da7bc2e253a2dae617e6f15" + "e4e337eaa462a108903af4643d1b7595508794929350839283019185019080838360005b8381101" + "561097d578181015183820152602001610965565b50505050905090810190601f1680156109aa57" + "80820380516001836020036101000a031916815260200191505b509250505060405180910390a25" + "050565b6040805173ffffffffffffffffffffffffffffffffffffffff8381168252915191841691" + "7ff922c215689548d72c3d2fe4ea8dafb2a30c43312c9b43fe5d10f713181f991c9181900360200" + "190a25050565b7f532fd6ea96cfb78bb46e09279a26828b8b493de1a2b8b1ee1face527978a15a5" + "8160405180806020018281038252838181518152602001915080519060200190808383600083811" + "0156103f85781810151838201526020016103e0565b6040805173ffffffffffffffffffffffffff" + "ffffffffffffff80851682528316602082015281517f06029e18f16caae06a69281f35b00ed3fcf" + "47950e6c99dafa1bdd8c4b93479a0929181900390910190a150505600a165627a7a72305820962b" + "b0d0c7c052407e6ad0911da133e939baa8783fbd0220169b97b54160a89e0029" +) + +CONTRACT_EMITTER_ABI_OLD = [ + { + "constant": False, + "inputs": [ + { + "name": "v", + "type": "string" + } + ], + "name": "logString", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "which", + "type": "uint8" + } + ], + "name": "logNoArgs", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "which", + "type": "uint8" + }, + { + "name": "arg0", + "type": "uint256" + }, + { + "name": "arg1", + "type": "uint256" + }, + { + "name": "arg2", + "type": "uint256" + }, + { + "name": "arg3", + "type": "uint256" + } + ], + "name": "logQuadruple", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "which", + "type": "uint8" + }, + { + "name": "arg0", + "type": "uint256" + }, + { + "name": "arg1", + "type": "uint256" + } + ], + "name": "logDouble", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "arg0", + "type": "bytes2[]" + }, + { + "name": "arg1", + "type": "bytes2[]" + } + ], + "name": "logListArgs", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "which", + "type": "uint8" + }, + { + "name": "arg0", + "type": "uint256" + }, + { + "name": "arg1", + "type": "uint256" + }, + { + "name": "arg2", + "type": "uint256" + } + ], + "name": "logTriple", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "which", + "type": "uint8" + }, + { + "name": "arg0", + "type": "uint256" + } + ], + "name": "logSingle", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "arg0", + "type": "string" + }, + { + "name": "arg1", + "type": "string" + } + ], + "name": "logDynamicArgs", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "arg0", + "type": "address" + }, + { + "name": "arg1", + "type": "address" + } + ], + "name": "logAddressIndexedArgs", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "v", + "type": "bytes" + } + ], + "name": "logBytes", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "constant": False, + "inputs": [ + { + "name": "arg0", + "type": "address" + }, + { + "name": "arg1", + "type": "address" + } + ], + "name": "logAddressNotIndexedArgs", + "outputs": [], + "payable": False, + "stateMutability": "nonpayable", + "type": "function" + }, + { + "anonymous": True, + "inputs": [], + "name": "LogAnonymous", + "type": "event" + }, + { + "anonymous": False, + "inputs": [], + "name": "LogNoArguments", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "uint256" + } + ], + "name": "LogSingleArg", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "uint256" + }, + { + "indexed": False, + "name": "arg1", + "type": "uint256" + } + ], + "name": "LogDoubleArg", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "uint256" + }, + { + "indexed": False, + "name": "arg1", + "type": "uint256" + }, + { + "indexed": False, + "name": "arg2", + "type": "uint256" + } + ], + "name": "LogTripleArg", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "uint256" + }, + { + "indexed": False, + "name": "arg1", + "type": "uint256" + }, + { + "indexed": False, + "name": "arg2", + "type": "uint256" + }, + { + "indexed": False, + "name": "arg3", + "type": "uint256" + } + ], + "name": "LogQuadrupleArg", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "v", + "type": "string" + } + ], + "name": "LogString", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "v", + "type": "bytes" + } + ], + "name": "LogBytes", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": True, + "name": "arg0", + "type": "uint256" + } + ], + "name": "LogSingleWithIndex", + "type": "event" + }, + { + "anonymous": True, + "inputs": [ + { + "indexed": True, + "name": "arg0", + "type": "uint256" + } + ], + "name": "LogSingleAnonymous", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "uint256" + }, + { + "indexed": True, + "name": "arg1", + "type": "uint256" + } + ], + "name": "LogDoubleWithIndex", + "type": "event" + }, + { + "anonymous": True, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "uint256" + }, + { + "indexed": True, + "name": "arg1", + "type": "uint256" + } + ], + "name": "LogDoubleAnonymous", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "uint256" + }, + { + "indexed": True, + "name": "arg1", + "type": "uint256" + }, + { + "indexed": True, + "name": "arg2", + "type": "uint256" + } + ], + "name": "LogTripleWithIndex", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "uint256" + }, + { + "indexed": False, + "name": "arg1", + "type": "uint256" + }, + { + "indexed": True, + "name": "arg2", + "type": "uint256" + }, + { + "indexed": True, + "name": "arg3", + "type": "uint256" + } + ], + "name": "LogQuadrupleWithIndex", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": True, + "name": "arg0", + "type": "string" + }, + { + "indexed": False, + "name": "arg1", + "type": "string" + } + ], + "name": "LogDynamicArgs", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": True, + "name": "arg0", + "type": "bytes2[]" + }, + { + "indexed": False, + "name": "arg1", + "type": "bytes2[]" + } + ], + "name": "LogListArgs", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": True, + "name": "arg0", + "type": "address" + }, + { + "indexed": False, + "name": "arg1", + "type": "address" + } + ], + "name": "LogAddressIndexed", + "type": "event" + }, + { + "anonymous": False, + "inputs": [ + { + "indexed": False, + "name": "arg0", + "type": "address" + }, + { + "indexed": False, + "name": "arg1", + "type": "address" + } + ], + "name": "LogAddressNotIndexed", + "type": "event" + } +] + + +EMITTER_ENUM_OLD = { + 'LogAnonymous': 0, + 'LogNoArguments': 1, + 'LogSingleArg': 2, + 'LogDoubleArg': 3, + 'LogTripleArg': 4, + 'LogQuadrupleArg': 5, + 'LogSingleAnonymous': 6, + 'LogSingleWithIndex': 7, + 'LogDoubleAnonymous': 8, + 'LogDoubleWithIndex': 9, + 'LogTripleWithIndex': 10, + 'LogQuadrupleWithInde': 11, +} From 987219d5cbdcbeef29055b332aa2ca870318067c Mon Sep 17 00:00:00 2001 From: Felipe Selmo Date: Thu, 13 Jan 2022 14:51:29 -0700 Subject: [PATCH 4/4] Abstract collapsing tuple abi arg types --- web3/_utils/abi.py | 9 +++++++++ web3/_utils/events.py | 13 +++++++------ 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/web3/_utils/abi.py b/web3/_utils/abi.py index 7fbdc9968b..28f1d0c72a 100644 --- a/web3/_utils/abi.py +++ b/web3/_utils/abi.py @@ -154,6 +154,15 @@ def exclude_indexed_event_inputs(event_abi: ABIEvent) -> List[ABIEventParams]: return [arg for arg in event_abi['inputs'] if arg['indexed'] is False] +def get_normalized_abi_arg_type(abi_arg: ABIEventParams) -> str: + """ + Return the normalized type for the abi argument provided. In order to account for tuple argument + types, this abstraction makes use of `collapse_if_tuple()` to collapse the appropriate component + types within a tuple type, if present. + """ + return collapse_if_tuple(dict(abi_arg)) + + def filter_by_argument_count( num_arguments: int, contract_abi: ABI ) -> List[Union[ABIFunction, ABIEvent]]: diff --git a/web3/_utils/events.py b/web3/_utils/events.py index 5ad79bfde8..9cfe6fb685 100644 --- a/web3/_utils/events.py +++ b/web3/_utils/events.py @@ -39,9 +39,6 @@ to_hex, to_tuple, ) -from eth_utils.abi import ( - collapse_if_tuple, -) from eth_utils.curried import ( apply_formatter_if, ) @@ -58,6 +55,7 @@ exclude_indexed_event_inputs, get_abi_input_names, get_indexed_event_inputs, + get_normalized_abi_arg_type, map_abi_data, normalize_event_input_types, ) @@ -196,7 +194,7 @@ def get_event_abi_types_for_decoding(event_inputs: Sequence[ABIEventParams]) -> if input_abi['indexed'] and is_dynamic_sized_type(input_abi['type']): yield 'bytes32' else: - yield collapse_if_tuple(dict(input_abi)) + yield get_normalized_abi_arg_type(input_abi) @curry @@ -433,9 +431,12 @@ def _build_argument_filters_from_event_abi( key = item['name'] value: 'BaseArgumentFilter' if item['indexed'] is True: - value = TopicArgumentFilter(abi_codec=abi_codec, arg_type=collapse_if_tuple(dict(item))) + value = TopicArgumentFilter( + abi_codec=abi_codec, + arg_type=get_normalized_abi_arg_type(item) + ) else: - value = DataArgumentFilter(arg_type=collapse_if_tuple(dict(item))) + value = DataArgumentFilter(arg_type=get_normalized_abi_arg_type(item)) yield key, value