From 190d540db4eaa16968e989c20e3f48bcf9cb5ca8 Mon Sep 17 00:00:00 2001 From: smartcontracts Date: Thu, 13 May 2021 17:11:09 -0400 Subject: [PATCH] feat[contracts]: Update Lib_AddressManager.AddressSet event to speed up data transport layer (#820) * feat: update and improve AddressSet event * chore: add changeset * Update Lib_AddressManager.sol --- .changeset/flat-bananas-perform.md | 6 ++++ .../libraries/resolver/Lib_AddressManager.sol | 12 +++++--- packages/core-utils/src/events.ts | 1 + .../src/services/l1-ingestion/service.ts | 29 +++++++------------ 4 files changed, 25 insertions(+), 23 deletions(-) create mode 100644 .changeset/flat-bananas-perform.md diff --git a/.changeset/flat-bananas-perform.md b/.changeset/flat-bananas-perform.md new file mode 100644 index 000000000000..620d6955ad06 --- /dev/null +++ b/.changeset/flat-bananas-perform.md @@ -0,0 +1,6 @@ +--- +'@eth-optimism/contracts': minor +'@eth-optimism/data-transport-layer': minor +--- + +Update AddressSet event to speed search up a bit. Breaks AddressSet API. diff --git a/packages/contracts/contracts/optimistic-ethereum/libraries/resolver/Lib_AddressManager.sol b/packages/contracts/contracts/optimistic-ethereum/libraries/resolver/Lib_AddressManager.sol index e123573f604f..865ddec49e74 100644 --- a/packages/contracts/contracts/optimistic-ethereum/libraries/resolver/Lib_AddressManager.sol +++ b/packages/contracts/contracts/optimistic-ethereum/libraries/resolver/Lib_AddressManager.sol @@ -14,8 +14,9 @@ contract Lib_AddressManager is Ownable { **********/ event AddressSet( - string _name, - address _newAddress + string indexed _name, + address _newAddress, + address _oldAddress ); @@ -42,11 +43,14 @@ contract Lib_AddressManager is Ownable { external onlyOwner { - addresses[_getNameHash(_name)] = _address; + bytes32 nameHash = _getNameHash(_name); + address oldAddress = addresses[nameHash]; + addresses[nameHash] = _address; emit AddressSet( _name, - _address + _address, + oldAddress ); } diff --git a/packages/core-utils/src/events.ts b/packages/core-utils/src/events.ts index c7fa940fb68d..b0a2306a171b 100644 --- a/packages/core-utils/src/events.ts +++ b/packages/core-utils/src/events.ts @@ -3,6 +3,7 @@ import { ethers } from 'ethers' export interface EventArgsAddressSet { _name: string _newAddress: string + _oldAddress: string } export interface EventArgsTransactionEnqueued { diff --git a/packages/data-transport-layer/src/services/l1-ingestion/service.ts b/packages/data-transport-layer/src/services/l1-ingestion/service.ts index b8b8cb4c39b2..f93436fee049 100644 --- a/packages/data-transport-layer/src/services/l1-ingestion/service.ts +++ b/packages/data-transport-layer/src/services/l1-ingestion/service.ts @@ -281,13 +281,11 @@ export class L1IngestionService extends BaseService { // We need to figure out how to make this work without Infura. Mark and I think that infura is // doing some indexing of events beyond Geth's native capabilities, meaning some event logic // will only work on Infura and not on a local geth instance. Not great. - const addressSetEvents = ((await this.state.contracts.Lib_AddressManager.queryFilter( - this.state.contracts.Lib_AddressManager.filters.AddressSet(), + const addressSetEvents = await this.state.contracts.Lib_AddressManager.queryFilter( + this.state.contracts.Lib_AddressManager.filters.AddressSet(contractName), fromL1Block, toL1Block - )) as TypedEthersEvent[]).filter((event) => { - return event.args._name === contractName - }) + ) // We're going to parse things out in ranges because the address of a given contract may have // changed in the range provided by the user. @@ -370,21 +368,14 @@ export class L1IngestionService extends BaseService { contractName: string, blockNumber: number ): Promise { - // TODO: Should be much easier than this. Need to change the params of this event. - const relevantAddressSetEvents = ( - await this.state.contracts.Lib_AddressManager.queryFilter( - this.state.contracts.Lib_AddressManager.filters.AddressSet(), - this.state.startingL1BlockNumber - ) - ).filter((event) => { - return ( - event.args._name === contractName && event.blockNumber < blockNumber - ) - }) + const events = await this.state.contracts.Lib_AddressManager.queryFilter( + this.state.contracts.Lib_AddressManager.filters.AddressSet(contractName), + this.state.startingL1BlockNumber, + blockNumber + ) - if (relevantAddressSetEvents.length > 0) { - return relevantAddressSetEvents[relevantAddressSetEvents.length - 1].args - ._newAddress + if (events.length > 0) { + return events[events.length - 1].args._newAddress } else { // Address wasn't set before this. return constants.AddressZero