2022-11-23 12:50:16 +00:00
|
|
|
//
|
|
|
|
// Copyright 2022 Vulcanize, Inc.
|
|
|
|
//
|
|
|
|
|
|
|
|
import yargs from 'yargs';
|
|
|
|
import { hideBin } from 'yargs/helpers';
|
|
|
|
import 'reflect-metadata';
|
|
|
|
import assert from 'assert';
|
|
|
|
import { ConnectionOptions } from 'typeorm';
|
|
|
|
|
|
|
|
import { JsonRpcProvider } from '@ethersproject/providers';
|
|
|
|
import {
|
|
|
|
DEFAULT_CONFIG_PATH,
|
|
|
|
JobQueue,
|
|
|
|
DatabaseInterface,
|
|
|
|
IndexerInterface,
|
|
|
|
ServerConfig,
|
|
|
|
Clients,
|
2022-11-24 10:56:40 +00:00
|
|
|
JobRunner,
|
2022-11-25 10:24:35 +00:00
|
|
|
GraphWatcherInterface,
|
|
|
|
startMetricsServer,
|
|
|
|
Config
|
2022-11-23 12:50:16 +00:00
|
|
|
} from '@cerc-io/util';
|
|
|
|
|
|
|
|
import { BaseCmd } from './base';
|
|
|
|
|
|
|
|
interface Arguments {
|
|
|
|
configFile: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export class JobRunnerCmd {
|
|
|
|
_argv?: Arguments
|
|
|
|
_baseCmd: BaseCmd;
|
|
|
|
|
|
|
|
constructor () {
|
|
|
|
this._baseCmd = new BaseCmd();
|
|
|
|
}
|
|
|
|
|
2022-11-25 14:33:58 +00:00
|
|
|
get config (): Config {
|
2022-11-25 10:24:35 +00:00
|
|
|
return this._baseCmd.config;
|
|
|
|
}
|
|
|
|
|
2022-11-25 14:33:58 +00:00
|
|
|
get clients (): Clients {
|
2022-11-25 10:24:35 +00:00
|
|
|
return this._baseCmd.clients;
|
|
|
|
}
|
|
|
|
|
2022-11-25 14:33:58 +00:00
|
|
|
get ethProvider (): JsonRpcProvider {
|
2022-11-25 10:24:35 +00:00
|
|
|
return this._baseCmd.ethProvider;
|
|
|
|
}
|
|
|
|
|
2022-11-25 14:33:58 +00:00
|
|
|
get database (): DatabaseInterface {
|
2022-11-25 10:24:35 +00:00
|
|
|
return this._baseCmd.database;
|
|
|
|
}
|
|
|
|
|
2022-11-25 14:33:58 +00:00
|
|
|
get jobQueue (): JobQueue {
|
2022-11-23 12:50:16 +00:00
|
|
|
return this._baseCmd.jobQueue;
|
|
|
|
}
|
|
|
|
|
2022-11-25 14:33:58 +00:00
|
|
|
get indexer (): IndexerInterface {
|
2022-11-23 12:50:16 +00:00
|
|
|
return this._baseCmd.indexer;
|
|
|
|
}
|
|
|
|
|
|
|
|
async initConfig<ConfigType> (): Promise<ConfigType> {
|
|
|
|
this._argv = this._getArgv();
|
|
|
|
assert(this._argv);
|
|
|
|
|
|
|
|
return this._baseCmd.initConfig(this._argv.configFile);
|
|
|
|
}
|
|
|
|
|
|
|
|
async init (
|
2022-11-24 10:56:40 +00:00
|
|
|
Database: new (
|
|
|
|
config: ConnectionOptions,
|
2022-11-23 12:50:16 +00:00
|
|
|
serverConfig?: ServerConfig
|
|
|
|
) => DatabaseInterface,
|
2022-11-25 10:24:35 +00:00
|
|
|
clients: { [key: string]: any } = {}
|
|
|
|
): Promise<void> {
|
|
|
|
await this.initConfig();
|
|
|
|
|
|
|
|
await this._baseCmd.init(Database, clients);
|
|
|
|
}
|
|
|
|
|
|
|
|
async initIndexer (
|
2022-11-23 12:50:16 +00:00
|
|
|
Indexer: new (
|
|
|
|
serverConfig: ServerConfig,
|
|
|
|
db: DatabaseInterface,
|
|
|
|
clients: Clients,
|
|
|
|
ethProvider: JsonRpcProvider,
|
|
|
|
jobQueue: JobQueue,
|
2022-11-25 10:24:35 +00:00
|
|
|
graphWatcher?: GraphWatcherInterface
|
2022-11-23 12:50:16 +00:00
|
|
|
) => IndexerInterface,
|
2022-11-25 10:24:35 +00:00
|
|
|
graphWatcher?: GraphWatcherInterface
|
2022-11-25 11:49:37 +00:00
|
|
|
): Promise<void> {
|
2022-11-25 10:24:35 +00:00
|
|
|
return this._baseCmd.initIndexer(Indexer, graphWatcher);
|
2022-11-23 12:50:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
async exec (startJobRunner: (jobRunner: JobRunner) => Promise<void>): Promise<void> {
|
|
|
|
const config = this._baseCmd.config;
|
|
|
|
const jobQueue = this._baseCmd.jobQueue;
|
|
|
|
const indexer = this._baseCmd.indexer;
|
|
|
|
|
|
|
|
assert(config);
|
|
|
|
assert(jobQueue);
|
|
|
|
assert(indexer);
|
|
|
|
|
|
|
|
if (indexer.addContracts) {
|
|
|
|
await indexer.addContracts();
|
|
|
|
}
|
|
|
|
|
|
|
|
const jobRunner = new JobRunner(config.jobQueue, indexer, jobQueue);
|
|
|
|
|
|
|
|
await jobRunner.jobQueue.deleteAllJobs();
|
2022-11-24 10:56:40 +00:00
|
|
|
await jobRunner.resetToPrevIndexedBlock();
|
2022-11-23 12:50:16 +00:00
|
|
|
|
|
|
|
await startJobRunner(jobRunner);
|
2022-11-24 10:56:40 +00:00
|
|
|
jobRunner.handleShutdown();
|
2022-11-23 12:50:16 +00:00
|
|
|
|
|
|
|
await startMetricsServer(config, indexer);
|
|
|
|
}
|
|
|
|
|
|
|
|
_getArgv (): any {
|
|
|
|
return yargs(hideBin(process.argv))
|
|
|
|
.option('f', {
|
|
|
|
alias: 'config-file',
|
|
|
|
demandOption: true,
|
|
|
|
describe: 'configuration file path (toml)',
|
|
|
|
type: 'string',
|
|
|
|
default: DEFAULT_CONFIG_PATH
|
|
|
|
})
|
|
|
|
.argv;
|
|
|
|
}
|
|
|
|
}
|