diff --git a/packages/codegen/src/indexer.ts b/packages/codegen/src/indexer.ts index 21ac41e3..ceb7bc1c 100644 --- a/packages/codegen/src/indexer.ts +++ b/packages/codegen/src/indexer.ts @@ -8,6 +8,7 @@ import assert from 'assert'; import Handlebars from 'handlebars'; import { Writable } from 'stream'; import _ from 'lodash'; +import { utils } from 'ethers'; import { getTsForSol } from './utils/type-mappings'; import { Param } from './utils/types'; @@ -82,7 +83,7 @@ export class Indexer { this._queries.push(queryObject); } - addEvent (name: string, params: Array, contractKind: string): void { + addEvent (name: string, params: Array, contractKind: string): void { // Check if the event is already added. if (this._events.some(event => event.name === name && event.kind === contractKind)) { return; @@ -90,17 +91,20 @@ export class Indexer { const eventObject = { name, - params: _.cloneDeep(params), + params: params.map((param) => { + const tsParamType = getTsForSol(param.type); + assert(tsParamType); + const isReferenceType = param.type === 'string' || param.type === 'bytes' || param.baseType === 'tuple' || param.baseType === 'array'; + + return { + ...param, + type: tsParamType, + isIndexedReferenceType: param.indexed && isReferenceType + }; + }), kind: contractKind }; - eventObject.params = eventObject.params.map((param) => { - const tsParamType = getTsForSol(param.type); - assert(tsParamType); - param.type = tsParamType; - return param; - }); - this._events.push(eventObject); } diff --git a/packages/codegen/src/schema.ts b/packages/codegen/src/schema.ts index 4a957287..abc7b4ce 100644 --- a/packages/codegen/src/schema.ts +++ b/packages/codegen/src/schema.ts @@ -6,6 +6,7 @@ import assert from 'assert'; import { GraphQLSchema, parse, printSchema, print } from 'graphql'; import { SchemaComposer } from 'graphql-compose'; import { Writable } from 'stream'; +import { utils } from 'ethers'; import { getTsForSol, getGqlForTs } from './utils/type-mappings'; import { Param } from './utils/types'; @@ -65,7 +66,7 @@ export class Schema { * @param name Event name. * @param params Event parameters. */ - addEventType (name: string, params: Array): void { + addEventType (name: string, params: Array): void { name = `${name}Event`; // Check if the type is already added. diff --git a/packages/codegen/src/templates/indexer-template.handlebars b/packages/codegen/src/templates/indexer-template.handlebars index 64737e70..02bc3d53 100644 --- a/packages/codegen/src/templates/indexer-template.handlebars +++ b/packages/codegen/src/templates/indexer-template.handlebars @@ -465,12 +465,14 @@ export class Indexer implements IPLDIndexerInterface { case {{capitalize event.name}}_EVENT: { eventName = logDescription.name; {{#if event.params}} - const [ {{#each event.params~}} {{this.name}} {{~#unless @last}}, {{/unless}} {{~/each}} ] = logDescription.args; + const [{{#each event.params~}} {{this.name}} {{~#unless @last}}, {{/unless}} {{~/each}}] = logDescription.args; {{/if}} eventInfo = { {{#each event.params}} {{#if (compare this.type 'bigint')}} {{this.name}}: BigInt({{this.name}}.toString()) + {{~else if this.isIndexedReferenceType}} + {{this.name}}: {{this.name}}.hash {{~else}} {{this.name}} {{~/if}} diff --git a/packages/codegen/src/visitor.ts b/packages/codegen/src/visitor.ts index 8e58750b..6d5dc8cb 100644 --- a/packages/codegen/src/visitor.ts +++ b/packages/codegen/src/visitor.ts @@ -133,14 +133,10 @@ export class Visitor { const contractInterface = new utils.Interface(abi); Object.values(contractInterface.events).forEach(event => { - const params = event.inputs.map(input => { - return { name: input.name, type: input.type }; - }); - - this._schema.addEventType(event.name, params); + this._schema.addEventType(event.name, event.inputs); assert(this._contract); - this._indexer.addEvent(event.name, params, this._contract.kind); + this._indexer.addEvent(event.name, event.inputs, this._contract.kind); }); } diff --git a/packages/moby-mask-watcher/demo.md b/packages/moby-mask-watcher/demo.md index 61f2fc12..2d026d75 100644 --- a/packages/moby-mask-watcher/demo.md +++ b/packages/moby-mask-watcher/demo.md @@ -109,7 +109,7 @@ ```bash # In MobyMask repo. - git checkout ng-use-watcher + git checkout use-laconic-watcher-as-hosted-index ``` * Run yarn to install the packages @@ -204,7 +204,7 @@ isPhisher( blockHash: "LATEST_BLOCK_HASH" contractAddress: "MOBY_ADDRESS", - key0: "phisherName" + key0: "TWT:phishername" ) { value proof { @@ -215,7 +215,7 @@ isMember( blockHash: "LATEST_BLOCK_HASH" contractAddress: "MOBY_ADDRESS", - key0: "memberName" + key0: "TWT:membername" ) { value proof { diff --git a/packages/moby-mask-watcher/src/indexer.ts b/packages/moby-mask-watcher/src/indexer.ts index 8b75b1fb..c1be9225 100644 --- a/packages/moby-mask-watcher/src/indexer.ts +++ b/packages/moby-mask-watcher/src/indexer.ts @@ -589,7 +589,6 @@ export class Indexer implements IPLDIndexerInterface { eventName = logDescription.name; const [entity, isMember] = logDescription.args; eventInfo = { - // Indexed reference type arg entity: entity.hash, isMember }; @@ -610,7 +609,6 @@ export class Indexer implements IPLDIndexerInterface { eventName = logDescription.name; const [entity, isPhisher] = logDescription.args; eventInfo = { - // Indexed reference type arg entity: entity.hash, isPhisher };