-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.ts
50 lines (40 loc) · 1.52 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
import { commander, setup, logger } from "substreams-sink";
import { fetchSubstream, createHash } from "@substreams/core";
import { handleImport } from "./src/victoria_metrics.js";
import { handleOperations, register } from "./src/prom.js";
import pkg from "./package.json" assert { type: "json" };
logger.setName(pkg.name);
export { logger };
// default user options
export const DEFAULT_HOST = 'http://0.0.0.0:8428'
export const DEFAULT_SCRAPE_INTERVAL = 30;
export const DEFAULT_COLLECT_DEFAULT_METRICS = false;
export const DEFAULT_CSV_ROOT = './csv'
export const DEFAULT_FOLDER_GRANULAR = 1000
export const DEFAULT_FILE_GRANULAR = 100
export const DEFAULT_VERBOSE = false
// Custom user options interface
export interface ActionOptions extends commander.RunOptions {
host: string;
scrapeInterval: number;
labels: Object;
manifest: string
}
export async function action(options: ActionOptions) {
const url = `${options.host}/api/v1/import/prometheus`
logger.info("url", url)
// Download substreams
const spkg = await fetchSubstream(options.manifest);
const hash = createHash(spkg.toBinary());
logger.info("download", options.manifest, hash);
// inject labels
if (options.labels) register.setDefaultLabels(options.labels);
// Run substreams
const { emitter } = await setup(options);
emitter.on("anyMessage", (messages, _cursor, clock) => {
handleOperations(messages);
handleImport(url, options.scrapeInterval, clock);
});
// Start streaming
emitter.start();
}