forked from across-protocol/relayer
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.ts
88 lines (79 loc) · 2.45 KB
/
index.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import minimist from "minimist";
import {
config,
delay,
exit,
retrieveSignerFromCLIArgs,
help,
Logger,
usage,
waitForLogger,
stringifyThrownValue,
} from "./src/utils";
import { runRelayer } from "./src/relayer";
import { runDataworker } from "./src/dataworker";
import { runMonitor } from "./src/monitor";
import { runFinalizer } from "./src/finalizer";
import { version } from "./package.json";
let logger: typeof Logger;
let cmd: string;
export async function run(args: { [k: string]: boolean | string }): Promise<void> {
logger = Logger;
const cmds = {
dataworker: runDataworker,
finalizer: runFinalizer,
help: help,
monitor: runMonitor,
relayer: runRelayer,
};
// todo Make the mode of operation an operand, rather than an option.
// i.e. ts-node ./index.ts [options] <relayer|...>
// Note: ts does not produce a narrow type from Object.keys, so we have to help.
cmd = Object.keys(cmds).find((_cmd) => !!args[_cmd]);
if (cmd === "help") {
cmds[cmd]();
} // no return
else if (cmd === undefined) {
usage("");
} // no return
else if (typeof args["wallet"] !== "string" || args["wallet"].length === 0) {
// todo: Update usage() to provide a hint that wallet is missing/malformed.
usage(""); // no return
} else {
// One global signer for use with a specific per-chain provider.
// todo: Support a void signer for monitor mode (only) if no wallet was supplied.
const signer = await retrieveSignerFromCLIArgs();
await cmds[cmd](logger, signer);
}
}
if (require.main === module) {
// Inject version into process.env so CommonConfig and all subclasses inherit it.
process.env.ACROSS_BOT_VERSION = version;
config();
const opts = {
boolean: ["dataworker", "finalizer", "help", "monitor", "relayer"],
string: ["wallet", "keys", "address"],
default: { wallet: "secret" },
alias: { h: "help" },
unknown: usage,
};
const args = minimist(process.argv.slice(2), opts);
let exitCode = 0;
run(args)
.catch(async (error) => {
exitCode = 1;
const stringifiedError = stringifyThrownValue(error);
logger.error({
at: cmd ?? "unknown process",
message: "There was an execution error!",
error: stringifiedError,
args,
notificationPath: "across-error",
});
})
.finally(async () => {
await waitForLogger(logger);
await delay(5); // Wait 5s for logger to flush.
exit(exitCode);
});
}