podman-compose/examples/nodeproj/lib/commands/task.js

32 lines
710 B
JavaScript
Raw Normal View History

2022-03-18 16:05:57 +01:00
"use strict";
import {proj} from "../proj";
async function loop() {
const poped = await proj.predis.blpop("queue", 5);
const task_desc_s = poped[1];
let task_desc;
try {
task_desc = JSON.parse(task_desc_s);
} catch (e) {
2022-03-18 16:29:27 +01:00
console.exception(e);
2022-03-18 16:05:57 +01:00
}
2022-03-18 16:29:27 +01:00
console.info("got task "+task_desc.func);
2022-03-18 16:05:57 +01:00
const func = task_desc.func;
const args = task_desc.args;
if (typeof(proj.tasks[func])!="function") {
console.log(`task ${func} not found`);
process.exit(-1)
}
try {
await ((this.tasks[func])(...args));
} catch (e) {
console.exception(e);
}
}
export async function start() {
while(true) {
loop();
}
}