summaryrefslogtreecommitdiff
path: root/includes/external/jobs/index.js
diff options
context:
space:
mode:
Diffstat (limited to 'includes/external/jobs/index.js')
-rw-r--r--includes/external/jobs/index.js110
1 files changed, 0 insertions, 110 deletions
diff --git a/includes/external/jobs/index.js b/includes/external/jobs/index.js
deleted file mode 100644
index 0f44cc9..0000000
--- a/includes/external/jobs/index.js
+++ /dev/null
@@ -1,110 +0,0 @@
-const fs = require('fs');
-const child_process = require('child_process');
-
-let jobsList = [];
-let jobs = [];
-let history = require('../../data/history.json');
-
-fs.writeFileSync("../../data/running.json", "null");
-
-setInterval(() => {
- if (JSON.stringify(fs.readdirSync("../../data/jobs")) !== JSON.stringify(jobsList)) {
- console.log("Updating the jobs list...");
- jobs = fs.readdirSync("../../data/jobs").map((i) => {
- let obj = JSON.parse(fs.readFileSync("../../data/jobs/" + i).toString());
- obj["_id"] = i;
- return obj;
- });
- jobsList = fs.readdirSync("../../data/jobs");
- }
-}, 1000);
-
-setTimeout(() => {
- setInterval(() => {
- if (jobs.length > 0) {
- let pickup = new Date();
-
- console.log(jobs.length + " job(s)");
- console.log("\nRunning jobs:");
-
- for (let job of jobs) {
- console.log(" " + job.name + " [" + job._id + "]");
- let output;
- let start;
- let end;
-
- fs.writeFileSync("../../data/running.json", JSON.stringify(job._id));
-
- try {
- start = new Date();
- output = child_process.execFileSync("php", [job.name + ".php", JSON.stringify(job.options)], { cwd: "../../jobs" });
- end = new Date();
-
- let runtime = end.getTime() - start.getTime();
- let description = "";
-
- for (let name of Object.keys(job.options)) {
- description = "," + name + "=" + JSON.stringify(job.options[name]);
- }
-
- fs.unlinkSync("../../data/jobs/" + job._id);
-
- history.unshift({
- completed: true,
- error: null,
- options: job.options,
- name: job.name + "(" + description.substring(1) + ")",
- output: output.toString(),
- time: runtime,
- tracking: {
- queue: new Date(job.date).toISOString(),
- pickup: pickup.toISOString(),
- start: start.toISOString(),
- end: end.toISOString(),
- logged: new Date().toISOString()
- }
- });
-
- history = history.slice(0, 200);
- fs.writeFileSync("../../data/history.json", JSON.stringify(history));
- fs.writeFileSync("../../data/running.json", "null");
- } catch (e) {
- end = start ? new Date() : null;
- console.log(" Failed to process job");
- console.error(e);
-
- let runtime = end ? (start ? end.getTime() - start.getTime() : null) : null;
- let description = "";
-
- for (let name of Object.keys(job.options)) {
- description = "," + name + "=" + JSON.stringify(job.options[name]);
- }
-
- fs.unlinkSync("../../data/jobs/" + job._id);
-
- history.unshift({
- completed: false,
- error: e.stack,
- options: job.options,
- name: job.name + "(" + description.substring(1) + ")",
- output: (output ?? e.stdout ?? e.stderr).toString(),
- time: runtime,
- tracking: {
- queue: new Date(job.date).toISOString(),
- pickup: pickup.toISOString(),
- start: start ? start.toISOString() : null,
- end: end ? end.toISOString() : null,
- logged: new Date().toISOString()
- }
- });
-
- history = history.slice(0, 200);
- fs.writeFileSync("../../data/history.json", JSON.stringify(history));
- fs.writeFileSync("../../data/running.json", "null");
- }
- }
-
- console.log("\nCompleted");
- }
- }, 1000);
-}, 500); \ No newline at end of file