This repository has been archived on 2022-10-07. You can view files and clone it, but cannot push or open issues or pull requests.
skynet-webportal/packages/health-check/src/run.js

57 lines
1.8 KiB
JavaScript
Raw Normal View History

2021-08-23 14:21:09 +00:00
const util = require("util");
2021-01-29 22:17:43 +00:00
const { getYesterdayISOString } = require("./utils");
2021-06-22 12:03:07 +00:00
const createMiddleware = require("./checks/middleware");
2021-01-29 22:17:43 +00:00
2021-01-26 16:00:13 +00:00
require("yargs/yargs")(process.argv.slice(2)).command(
"$0 <type>",
"Skynet portal health checks",
(yargs) => {
yargs
.positional("type", {
describe: "Type of checks to run",
type: "string",
2021-04-29 11:43:40 +00:00
choices: ["critical", "extended"],
2021-01-26 16:00:13 +00:00
})
.option("portal-url", {
2021-01-26 11:18:40 +00:00
describe: "Skynet portal url",
default: process.env.SKYNET_PORTAL_API || "https://siasky.net",
2021-01-26 11:18:40 +00:00
type: "string",
2021-01-26 16:00:13 +00:00
})
.option("state-dir", {
2021-01-26 11:18:40 +00:00
describe: "State directory",
default: process.env.STATE_DIR || "state",
type: "string",
2021-01-26 16:00:13 +00:00
});
},
async ({ type, portalUrl, stateDir }) => {
process.env.SKYNET_PORTAL_API = portalUrl;
2021-01-26 11:18:40 +00:00
process.env.STATE_DIR = stateDir;
const db = require("../src/db");
const checks = require(`../src/checks/${type}`);
2021-06-22 12:03:07 +00:00
const middleware = await createMiddleware();
2021-01-26 11:18:40 +00:00
const entry = {
2021-01-26 16:00:13 +00:00
date: new Date().toISOString(),
2021-06-22 12:03:07 +00:00
checks: (await Promise.all(checks.map((check) => new Promise(check)))).map(middleware),
2021-01-26 11:18:40 +00:00
};
2021-01-29 22:17:43 +00:00
db.read() // read before writing to make sure no external changes are overwritten
.get(type) // get the list of records of given type
.push(entry) // insert new record
.remove(({ date }) => date < getYesterdayISOString()) // drop old records
.write();
// exit with code 1 if any of the checks report failure
2021-06-16 10:09:56 +00:00
if (entry.checks.some(({ up }) => !up)) {
2021-08-23 14:21:09 +00:00
console.log(
util.inspect(
entry.checks.filter(({ up }) => !up),
{ colors: true, depth: 7 } // increase depth to ensure errors are printed
)
);
process.exit(1);
}
2021-01-26 16:00:13 +00:00
}
).argv;