mirror of
https://github.com/cerc-io/watcher-ts
synced 2025-02-02 08:12:49 +00:00
Refactor watchers for util package changes
This commit is contained in:
parent
560df57ac7
commit
68bc1c00db
@ -107,6 +107,8 @@ export const handler = async (argv: any): Promise<void> => {
|
|||||||
await indexer.updateHookStatusProcessedBlock(blockProgress.blockNumber, true);
|
await indexer.updateHookStatusProcessedBlock(blockProgress.blockNumber, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
await indexer.updateSyncStatusChainHead(blockProgress.blockHash, blockProgress.blockNumber, true);
|
||||||
|
|
||||||
dbTx.commitTransaction();
|
dbTx.commitTransaction();
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
await dbTx.rollbackTransaction();
|
await dbTx.rollbackTransaction();
|
||||||
|
@ -150,10 +150,10 @@ export class Database implements IPLDDatabaseInterface {
|
|||||||
return this._baseDatabase.updateSyncStatusCanonicalBlock(repo, blockHash, blockNumber, force);
|
return this._baseDatabase.updateSyncStatusCanonicalBlock(repo, blockHash, blockNumber, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateSyncStatusChainHead (queryRunner: QueryRunner, blockHash: string, blockNumber: number): Promise<SyncStatus> {
|
async updateSyncStatusChainHead (queryRunner: QueryRunner, blockHash: string, blockNumber: number, force = false): Promise<SyncStatus> {
|
||||||
const repo = queryRunner.manager.getRepository(SyncStatus);
|
const repo = queryRunner.manager.getRepository(SyncStatus);
|
||||||
|
|
||||||
return this._baseDatabase.updateSyncStatusChainHead(repo, blockHash, blockNumber);
|
return this._baseDatabase.updateSyncStatusChainHead(repo, blockHash, blockNumber, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
async getSyncStatus (queryRunner: QueryRunner): Promise<SyncStatus | undefined> {
|
async getSyncStatus (queryRunner: QueryRunner): Promise<SyncStatus | undefined> {
|
||||||
|
@ -39,6 +39,16 @@ export const main = async (): Promise<any> => {
|
|||||||
type: 'number',
|
type: 'number',
|
||||||
demandOption: true,
|
demandOption: true,
|
||||||
describe: 'Block number to stop processing at'
|
describe: 'Block number to stop processing at'
|
||||||
|
},
|
||||||
|
prefetch: {
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
describe: 'Block and events prefetch mode'
|
||||||
|
},
|
||||||
|
batchBlocks: {
|
||||||
|
type: 'number',
|
||||||
|
default: 10,
|
||||||
|
describe: 'Number of blocks prefetched in batch'
|
||||||
}
|
}
|
||||||
}).argv;
|
}).argv;
|
||||||
|
|
||||||
|
@ -910,8 +910,8 @@ export class Indexer implements IndexerInterface {
|
|||||||
return this._baseIndexer.updateSyncStatusIndexedBlock(blockHash, blockNumber, force);
|
return this._baseIndexer.updateSyncStatusIndexedBlock(blockHash, blockNumber, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateSyncStatusChainHead (blockHash: string, blockNumber: number): Promise<SyncStatus> {
|
async updateSyncStatusChainHead (blockHash: string, blockNumber: number, force = false): Promise<SyncStatus> {
|
||||||
return this._baseIndexer.updateSyncStatusChainHead(blockHash, blockNumber);
|
return this._baseIndexer.updateSyncStatusChainHead(blockHash, blockNumber, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateSyncStatusCanonicalBlock (blockHash: string, blockNumber: number, force = false): Promise<SyncStatus> {
|
async updateSyncStatusCanonicalBlock (blockHash: string, blockNumber: number, force = false): Promise<SyncStatus> {
|
||||||
@ -1301,8 +1301,6 @@ export class Indexer implements IndexerInterface {
|
|||||||
async _fetchAndSaveEvents ({ cid: blockCid, blockHash }: DeepPartial<BlockProgress>): Promise<BlockProgress> {
|
async _fetchAndSaveEvents ({ cid: blockCid, blockHash }: DeepPartial<BlockProgress>): Promise<BlockProgress> {
|
||||||
assert(blockHash);
|
assert(blockHash);
|
||||||
|
|
||||||
console.time('time:indexer#_fetchAndSaveEvents-logs_txs');
|
|
||||||
|
|
||||||
const logsPromise = this._ethClient.getLogs({ blockHash });
|
const logsPromise = this._ethClient.getLogs({ blockHash });
|
||||||
const transactionsPromise = this._postgraphileClient.getBlockWithTransactions({ blockHash });
|
const transactionsPromise = this._postgraphileClient.getBlockWithTransactions({ blockHash });
|
||||||
|
|
||||||
@ -1321,8 +1319,6 @@ export class Indexer implements IndexerInterface {
|
|||||||
}
|
}
|
||||||
] = await Promise.all([logsPromise, transactionsPromise]);
|
] = await Promise.all([logsPromise, transactionsPromise]);
|
||||||
|
|
||||||
console.timeEnd('time:indexer#_fetchAndSaveEvents-logs_txs');
|
|
||||||
|
|
||||||
const transactionMap = transactions.reduce((acc: {[key: string]: any}, transaction: {[key: string]: any}) => {
|
const transactionMap = transactions.reduce((acc: {[key: string]: any}, transaction: {[key: string]: any}) => {
|
||||||
acc[transaction.txHash] = transaction;
|
acc[transaction.txHash] = transaction;
|
||||||
return acc;
|
return acc;
|
||||||
|
@ -95,6 +95,8 @@ export const handler = async (argv: any): Promise<void> => {
|
|||||||
await indexer.updateHookStatusProcessedBlock(blockProgress.blockNumber, true);
|
await indexer.updateHookStatusProcessedBlock(blockProgress.blockNumber, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
await indexer.updateSyncStatusChainHead(blockProgress.blockHash, blockProgress.blockNumber, true);
|
||||||
|
|
||||||
dbTx.commitTransaction();
|
dbTx.commitTransaction();
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
await dbTx.rollbackTransaction();
|
await dbTx.rollbackTransaction();
|
||||||
|
@ -184,10 +184,10 @@ export class Database implements IPLDDatabaseInterface {
|
|||||||
return this._baseDatabase.updateSyncStatusCanonicalBlock(repo, blockHash, blockNumber, force);
|
return this._baseDatabase.updateSyncStatusCanonicalBlock(repo, blockHash, blockNumber, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateSyncStatusChainHead (queryRunner: QueryRunner, blockHash: string, blockNumber: number): Promise<SyncStatus> {
|
async updateSyncStatusChainHead (queryRunner: QueryRunner, blockHash: string, blockNumber: number, force = false): Promise<SyncStatus> {
|
||||||
const repo = queryRunner.manager.getRepository(SyncStatus);
|
const repo = queryRunner.manager.getRepository(SyncStatus);
|
||||||
|
|
||||||
return this._baseDatabase.updateSyncStatusChainHead(repo, blockHash, blockNumber);
|
return this._baseDatabase.updateSyncStatusChainHead(repo, blockHash, blockNumber, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
async getSyncStatus (queryRunner: QueryRunner): Promise<SyncStatus | undefined> {
|
async getSyncStatus (queryRunner: QueryRunner): Promise<SyncStatus | undefined> {
|
||||||
|
@ -39,6 +39,16 @@ export const main = async (): Promise<any> => {
|
|||||||
type: 'number',
|
type: 'number',
|
||||||
demandOption: true,
|
demandOption: true,
|
||||||
describe: 'Block number to stop processing at'
|
describe: 'Block number to stop processing at'
|
||||||
|
},
|
||||||
|
prefetch: {
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
describe: 'Block and events prefetch mode'
|
||||||
|
},
|
||||||
|
batchBlocks: {
|
||||||
|
type: 'number',
|
||||||
|
default: 10,
|
||||||
|
describe: 'Number of blocks prefetched in batch'
|
||||||
}
|
}
|
||||||
}).argv;
|
}).argv;
|
||||||
|
|
||||||
|
@ -486,8 +486,8 @@ export class Indexer implements IndexerInterface {
|
|||||||
return this._baseIndexer.updateSyncStatusIndexedBlock(blockHash, blockNumber, force);
|
return this._baseIndexer.updateSyncStatusIndexedBlock(blockHash, blockNumber, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateSyncStatusChainHead (blockHash: string, blockNumber: number): Promise<SyncStatus> {
|
async updateSyncStatusChainHead (blockHash: string, blockNumber: number, force = false): Promise<SyncStatus> {
|
||||||
return this._baseIndexer.updateSyncStatusChainHead(blockHash, blockNumber);
|
return this._baseIndexer.updateSyncStatusChainHead(blockHash, blockNumber, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateSyncStatusCanonicalBlock (blockHash: string, blockNumber: number, force = false): Promise<SyncStatus> {
|
async updateSyncStatusCanonicalBlock (blockHash: string, blockNumber: number, force = false): Promise<SyncStatus> {
|
||||||
|
@ -123,11 +123,11 @@ const prefetchBlocks = async (
|
|||||||
}
|
}
|
||||||
|
|
||||||
const fetchBlockPromises = blocks.map(async block => {
|
const fetchBlockPromises = blocks.map(async block => {
|
||||||
const { blockHash, blockNumber, parentHash, timestamp } = block;
|
const { cid, blockHash, blockNumber, parentHash, timestamp } = block;
|
||||||
const blockProgress = await indexer.getBlockProgress(blockHash);
|
const blockProgress = await indexer.getBlockProgress(blockHash);
|
||||||
|
|
||||||
if (!blockProgress) {
|
if (!blockProgress) {
|
||||||
await indexer.fetchBlockEvents({ blockHash, blockNumber, parentHash, blockTimestamp: timestamp });
|
await indexer.fetchBlockEvents({ cid, blockHash, blockNumber, parentHash, blockTimestamp: timestamp });
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user