mirror of
https://github.com/cerc-io/watcher-ts
synced 2025-01-24 03:59:06 +00:00
Update getFullBlocks usage (#213)
* Update getFullBlocks usage to add block number arg * Add skipStateFieldsUpdate config for uniswap-watcher Co-authored-by: nabarun <nabarun@deepstacksoft.com>
This commit is contained in:
parent
be65ca45ea
commit
266442a6d9
@ -390,9 +390,9 @@ export class Indexer implements IndexerInterface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
{{#if (subgraphPath)}}
|
{{#if (subgraphPath)}}
|
||||||
async processBlockAfterEvents (blockHash: string): Promise<void> {
|
async processBlockAfterEvents (blockHash: string, blockNumber: number): Promise<void> {
|
||||||
// Call subgraph handler for block.
|
// Call subgraph handler for block.
|
||||||
await this._graphWatcher.handleBlock(blockHash);
|
await this._graphWatcher.handleBlock(blockHash, blockNumber);
|
||||||
|
|
||||||
// Persist subgraph state to the DB.
|
// Persist subgraph state to the DB.
|
||||||
await this.dumpSubgraphState(blockHash);
|
await this.dumpSubgraphState(blockHash);
|
||||||
|
@ -310,11 +310,11 @@ export class Indexer implements IndexerInterface {
|
|||||||
this._graphWatcher.updateEntityCacheFrothyBlocks(blockProgress);
|
this._graphWatcher.updateEntityCacheFrothyBlocks(blockProgress);
|
||||||
}
|
}
|
||||||
|
|
||||||
async processBlockAfterEvents (blockHash: string): Promise<void> {
|
async processBlockAfterEvents (blockHash: string, blockNumber: number): Promise<void> {
|
||||||
console.time('time:indexer#processBlockAfterEvents-mapping_code');
|
console.time('time:indexer#processBlockAfterEvents-mapping_code');
|
||||||
|
|
||||||
// Call subgraph handler for block.
|
// Call subgraph handler for block.
|
||||||
await this._graphWatcher.handleBlock(blockHash);
|
await this._graphWatcher.handleBlock(blockHash, blockNumber);
|
||||||
|
|
||||||
console.timeEnd('time:indexer#processBlockAfterEvents-mapping_code');
|
console.timeEnd('time:indexer#processBlockAfterEvents-mapping_code');
|
||||||
|
|
||||||
|
@ -131,7 +131,7 @@ export class GraphWatcher {
|
|||||||
|
|
||||||
// Check if block data is already fetched by a previous event in the same block.
|
// Check if block data is already fetched by a previous event in the same block.
|
||||||
if (!this._context.block || this._context.block.blockHash !== block.hash) {
|
if (!this._context.block || this._context.block.blockHash !== block.hash) {
|
||||||
this._context.block = await getFullBlock(this._ethClient, this._ethProvider, block.hash);
|
this._context.block = await getFullBlock(this._ethClient, this._ethProvider, block.hash, block.number);
|
||||||
}
|
}
|
||||||
|
|
||||||
const blockData = this._context.block;
|
const blockData = this._context.block;
|
||||||
@ -194,10 +194,10 @@ export class GraphWatcher {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async handleBlock (blockHash: string) {
|
async handleBlock (blockHash: string, blockNumber: number) {
|
||||||
// Check if block data is already fetched in handleEvent method for the same block.
|
// Check if block data is already fetched in handleEvent method for the same block.
|
||||||
if (!this._context.block || this._context.block.blockHash !== blockHash) {
|
if (!this._context.block || this._context.block.blockHash !== blockHash) {
|
||||||
this._context.block = await getFullBlock(this._ethClient, this._ethProvider, blockHash);
|
this._context.block = await getFullBlock(this._ethClient, this._ethProvider, blockHash, blockNumber);
|
||||||
}
|
}
|
||||||
|
|
||||||
const blockData = this._context.block;
|
const blockData = this._context.block;
|
||||||
|
@ -216,6 +216,7 @@ class ServerConfig implements ServerConfigInterface {
|
|||||||
filterLogs: boolean;
|
filterLogs: boolean;
|
||||||
maxEventsBlockRange: number;
|
maxEventsBlockRange: number;
|
||||||
clearEntitiesCacheInterval: number;
|
clearEntitiesCacheInterval: number;
|
||||||
|
skipStateFieldsUpdate: boolean;
|
||||||
|
|
||||||
constructor () {
|
constructor () {
|
||||||
this.host = '';
|
this.host = '';
|
||||||
@ -230,5 +231,6 @@ class ServerConfig implements ServerConfigInterface {
|
|||||||
this.filterLogs = false;
|
this.filterLogs = false;
|
||||||
this.maxEventsBlockRange = 0;
|
this.maxEventsBlockRange = 0;
|
||||||
this.clearEntitiesCacheInterval = 0;
|
this.clearEntitiesCacheInterval = 0;
|
||||||
|
this.skipStateFieldsUpdate = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -319,9 +319,9 @@ export class Indexer implements IndexerInterface {
|
|||||||
this._graphWatcher.updateEntityCacheFrothyBlocks(blockProgress);
|
this._graphWatcher.updateEntityCacheFrothyBlocks(blockProgress);
|
||||||
}
|
}
|
||||||
|
|
||||||
async processBlockAfterEvents (blockHash: string): Promise<void> {
|
async processBlockAfterEvents (blockHash: string, blockNumber: number): Promise<void> {
|
||||||
// Call subgraph handler for block.
|
// Call subgraph handler for block.
|
||||||
await this._graphWatcher.handleBlock(blockHash);
|
await this._graphWatcher.handleBlock(blockHash, blockNumber);
|
||||||
|
|
||||||
// Persist subgraph state to the DB.
|
// Persist subgraph state to the DB.
|
||||||
await this.dumpSubgraphState(blockHash);
|
await this.dumpSubgraphState(blockHash);
|
||||||
|
@ -294,7 +294,7 @@ export const processBatchEvents = async (indexer: IndexerInterface, block: Block
|
|||||||
|
|
||||||
if (indexer.processBlockAfterEvents) {
|
if (indexer.processBlockAfterEvents) {
|
||||||
if (!block.isComplete) {
|
if (!block.isComplete) {
|
||||||
await indexer.processBlockAfterEvents(block.blockHash);
|
await indexer.processBlockAfterEvents(block.blockHash, block.blockNumber);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,6 +42,9 @@ export interface ServerConfig {
|
|||||||
filterLogs: boolean;
|
filterLogs: boolean;
|
||||||
maxEventsBlockRange: number;
|
maxEventsBlockRange: number;
|
||||||
clearEntitiesCacheInterval: number;
|
clearEntitiesCacheInterval: number;
|
||||||
|
|
||||||
|
// Boolean to skip updating entity fields required in state creation and not required in the frontend.
|
||||||
|
skipStateFieldsUpdate: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface UpstreamConfig {
|
export interface UpstreamConfig {
|
||||||
|
@ -179,14 +179,14 @@ class CustomFormatter extends providers.Formatter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export const getFullBlock = async (ethClient: EthClient, ethProvider: providers.BaseProvider, blockHash: string): Promise<any> => {
|
export const getFullBlock = async (ethClient: EthClient, ethProvider: providers.BaseProvider, blockHash: string, blockNumber: number): Promise<any> => {
|
||||||
const {
|
const {
|
||||||
allEthHeaderCids: {
|
allEthHeaderCids: {
|
||||||
nodes: [
|
nodes: [
|
||||||
fullBlock
|
fullBlock
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
} = await ethClient.getFullBlocks({ blockHash });
|
} = await ethClient.getFullBlocks({ blockHash, blockNumber });
|
||||||
|
|
||||||
assert(fullBlock.blockByMhKey);
|
assert(fullBlock.blockByMhKey);
|
||||||
|
|
||||||
|
@ -113,7 +113,7 @@ export interface IndexerInterface {
|
|||||||
processInitialState?: (contractAddress: string, blockHash: string) => Promise<any>
|
processInitialState?: (contractAddress: string, blockHash: string) => Promise<any>
|
||||||
processStateCheckpoint?: (contractAddress: string, blockHash: string) => Promise<boolean>
|
processStateCheckpoint?: (contractAddress: string, blockHash: string) => Promise<boolean>
|
||||||
processBlock: (blockProgres: BlockProgressInterface) => Promise<void>
|
processBlock: (blockProgres: BlockProgressInterface) => Promise<void>
|
||||||
processBlockAfterEvents?: (blockHash: string) => Promise<void>
|
processBlockAfterEvents?: (blockHash: string, blockNumber: number) => Promise<void>
|
||||||
processCanonicalBlock (blockHash: string, blockNumber: number): Promise<void>
|
processCanonicalBlock (blockHash: string, blockNumber: number): Promise<void>
|
||||||
processCheckpoint (blockHash: string): Promise<void>
|
processCheckpoint (blockHash: string): Promise<void>
|
||||||
getStorageValue (storageLayout: StorageLayout, blockHash: string, contractAddress: string, variable: string, ...mappingKeys: MappingKey[]): Promise<ValueResult>
|
getStorageValue (storageLayout: StorageLayout, blockHash: string, contractAddress: string, variable: string, ...mappingKeys: MappingKey[]): Promise<ValueResult>
|
||||||
|
Loading…
Reference in New Issue
Block a user