50 lines
1.7 KiB
JavaScript
50 lines
1.7 KiB
JavaScript
const { error } = require('console');
|
||
const config = require('../config/config.json')
|
||
const { parentPort, workerData } = require('worker_threads');
|
||
const { d1 } = workerData; //Declare all used variables here (if you only pass 1 variable to this command you only really need d1 in here, but it doesnt matter)
|
||
var arg = d1; // Declaring d1 as var1, just for consistancy with the last file but again, this may not be necessary in all cases.
|
||
const timer = ms => new Promise(res => setTimeout(res, ms))
|
||
|
||
warningMsg = ''+config.colours.brackets+'['+config.colours.warning+'WARNING'+config.colours.brackets+']'
|
||
errorMsg = ''+config.colours.brackets+'['+config.colours.error+'ERROR'+config.colours.brackets+']'
|
||
|
||
function consoleLog(log) {
|
||
if (config.misc.logging === "true") {
|
||
console.log(log)
|
||
} else {
|
||
return;
|
||
}
|
||
}
|
||
|
||
function errorMessage(error, code, extra) {
|
||
consoleLog('[uspam.errorMessage] '+error.code)
|
||
if (code == "BAD") {
|
||
var error = errorMsg+" SHITS_FUCKED_MAN: " + extra + " not found"
|
||
} else if (code == "TOOLARGE") {
|
||
var error = errorMsg+" Your request is too large (Maximum is 100000)"
|
||
} else {
|
||
var error = errorMsg+" Unknown error"
|
||
}
|
||
parentPort.postMessage(error);
|
||
process.exit()
|
||
}
|
||
|
||
async function sendUpstream(content) {
|
||
parentPort.postMessage(content);
|
||
process.exit()
|
||
}
|
||
|
||
var arr = []
|
||
arg.shift() //$flood
|
||
var amt = arg.shift() //number
|
||
var text = arg.join(" ")
|
||
if (amt > 100000) {
|
||
consoleLog('[flood] Request too large was made, killing worker')
|
||
errorMessage("error", "TOOLARGE")
|
||
} else {
|
||
for(var i=0; i < amt; i++){
|
||
arr.push(text)
|
||
}
|
||
}
|
||
var output = arr.join("\n")
|
||
sendUpstream(output) |