Catch no matching event errors while parsing logs and upgrade dependencies #1

Merged
nabarun merged 2 commits from pm-handle-parse-error into main 2024-03-19 13:12:31 +00:00
Showing only changes of commit 35350ffdc7 - Show all commits

View File

@ -513,20 +513,34 @@ export class Indexer implements IndexerInterface {
console.timeEnd('time:indexer#processBlockAfterEvents-dump_subgraph_state'); console.timeEnd('time:indexer#processBlockAfterEvents-dump_subgraph_state');
} }
parseEventNameAndArgs (kind: string, logObj: any): any { parseEventNameAndArgs (kind: string, logObj: any): { eventParsed: boolean, eventDetails: any } {
const { topics, data } = logObj; const { topics, data } = logObj;
const contract = this._contractMap.get(kind); const contract = this._contractMap.get(kind);
assert(contract); assert(contract);
const logDescription = contract.parseLog({ data, topics }); let logDescription: ethers.utils.LogDescription;
try {
logDescription = contract.parseLog({ data, topics });
} catch (err) {
// Return if no matching event found
if ((err as Error).message.includes('no matching event')) {
log(`WARNING: Skipping event for contract ${kind} as no matching event found in the ABI`);
return { eventParsed: false, eventDetails: {} };
}
throw err;
}
const { eventName, eventInfo, eventSignature } = this._baseIndexer.parseEvent(logDescription); const { eventName, eventInfo, eventSignature } = this._baseIndexer.parseEvent(logDescription);
return { return {
eventParsed: true,
eventDetails: {
eventName, eventName,
eventInfo, eventInfo,
eventSignature eventSignature
}
}; };
} }