reduce padding in output
This commit is contained in:
parent
04d110d8fe
commit
ef16b61219
4 changed files with 25 additions and 9 deletions
|
@ -2,6 +2,7 @@ import { spawn } from 'child_process';
|
||||||
|
|
||||||
import { getArg } from './args.js';
|
import { getArg } from './args.js';
|
||||||
import { error, log } from './log.js';
|
import { error, log } from './log.js';
|
||||||
|
import { trimNewlinesEnd } from './str.js';
|
||||||
|
|
||||||
const ctx = 'getUser.js';
|
const ctx = 'getUser.js';
|
||||||
const loggedDateRegex = new RegExp('[a-zA-Z0-9]+\-[0-9]+\-([0-9]{4})([0-9]{2})([0-9]{2})_([0-9]{2})([0-9]{2})([0-9]{2})', 'gm');
|
const loggedDateRegex = new RegExp('[a-zA-Z0-9]+\-[0-9]+\-([0-9]{4})([0-9]{2})([0-9]{2})_([0-9]{2})([0-9]{2})([0-9]{2})', 'gm');
|
||||||
|
@ -47,7 +48,7 @@ export const getMany = (userDb, threadMax, directory, mode) => new Promise((reso
|
||||||
const get = () => {
|
const get = () => {
|
||||||
const checkError = (proc, currentIndex, type, codeOrError) => {
|
const checkError = (proc, currentIndex, type, codeOrError) => {
|
||||||
userDb[currentIndex].logs.push(codeOrError.toString())
|
userDb[currentIndex].logs.push(codeOrError.toString())
|
||||||
if (!!proc.exitCode && !userDb[currentIndex].running) {
|
if (!!proc.exitCode && userDb[currentIndex].running) {
|
||||||
userDb[currentIndex].running = false;
|
userDb[currentIndex].running = false;
|
||||||
onFinish(currentIndex, type);
|
onFinish(currentIndex, type);
|
||||||
}
|
}
|
||||||
|
@ -70,11 +71,11 @@ export const getMany = (userDb, threadMax, directory, mode) => new Promise((reso
|
||||||
let proc = getUser(userDb[currentIndex].user, directory, modeParams);
|
let proc = getUser(userDb[currentIndex].user, directory, modeParams);
|
||||||
userDb[currentIndex].running = true;
|
userDb[currentIndex].running = true;
|
||||||
proc.stdout.on('data', data => {
|
proc.stdout.on('data', data => {
|
||||||
userDb[currentIndex].logs.push(data);
|
userDb[currentIndex].logs.push(trimNewlinesEnd(data));
|
||||||
});
|
});
|
||||||
proc.stderr.on('data', data => checkError(proc, currentIndex, 'stderr', data));
|
proc.stderr.on('data', data => checkError(proc, currentIndex, 'stderr', trimNewlinesEnd(data)));
|
||||||
proc.on('close', code => onFinish(currentIndex, 'close', code));
|
proc.on('close', code => onFinish(currentIndex, 'close', code));
|
||||||
proc.on('error', err => checkError(proc, currentIndex, 'error', err));
|
proc.on('error', err => checkError(proc, currentIndex, 'error', trimNewlinesEnd(err)));
|
||||||
proc.on('exit', code => checkError(proc, currentIndex, 'exit', code));
|
proc.on('exit', code => checkError(proc, currentIndex, 'exit', code));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ export const getTime = () => {
|
||||||
*/
|
*/
|
||||||
export const log = (src, msg) => {
|
export const log = (src, msg) => {
|
||||||
const time = getTime();
|
const time = getTime();
|
||||||
console.log(`${time} : ${src} : ${msg}`);
|
console.log(`${time} : ${src} : ${msg.toString().trim()}`);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -26,6 +26,6 @@ export const log = (src, msg) => {
|
||||||
* @param {string} msg the message to log
|
* @param {string} msg the message to log
|
||||||
*/
|
*/
|
||||||
export const error = (src, msg) => {
|
export const error = (src, msg) => {
|
||||||
const time = new Date().toISOString();
|
const time = getTime();
|
||||||
console.error(`\x1b[33m${time} : ${src} : ${msg}\x1b[0m`);
|
console.error(`\x1b[33m${time} : ${src} : ${msg.toString().trim()}\x1b[0m`);
|
||||||
}
|
}
|
||||||
|
|
10
lib/str.js
Normal file
10
lib/str.js
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
/** https://github.com/sindresorhus/trim-newlines */
|
||||||
|
export const trimNewlinesEnd = (str) => {
|
||||||
|
let end = str.length;
|
||||||
|
|
||||||
|
while (end > 0 && (str[end - 1] === '\r' || str[end - 1] === '\n')) {
|
||||||
|
end--;
|
||||||
|
}
|
||||||
|
|
||||||
|
return end < str.length ? str.slice(0, end) : str;
|
||||||
|
}
|
|
@ -49,9 +49,13 @@ const downloadDb = async () => {
|
||||||
processes.forEach(entry => {
|
processes.forEach(entry => {
|
||||||
entry.logs.forEach(log => {
|
entry.logs.forEach(log => {
|
||||||
if (log.includes('NotFoundError')) {
|
if (log.includes('NotFoundError')) {
|
||||||
error(ctx, `${entry.user} wasn't found: "${log.replace('\n', '')}". You may want to remove them from the db.json file or update their username.`);
|
const strOut = `${entry.user} wasn't found: "${log.replace('\n', '')}". You may want to remove them from the db.json file or update their username.`;
|
||||||
|
error(ctx, strOut);
|
||||||
|
entry.lastError = strOut;
|
||||||
} else if (log.includes('AuthorizationError')) {
|
} else if (log.includes('AuthorizationError')) {
|
||||||
error(ctx, `There was an authorization error for user ${entry.user}: "${log.replace('\n', '')}"`);
|
const strOut = `There was an authorization error for user ${entry.user}: "${log.replace('\n', '')}"`;
|
||||||
|
error(ctx, strOut);
|
||||||
|
entry.lastError = strOut;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -61,6 +65,7 @@ const downloadDb = async () => {
|
||||||
let updated = processes.map(entry => ({
|
let updated = processes.map(entry => ({
|
||||||
user: entry.user,
|
user: entry.user,
|
||||||
lastUpdated: entry.lastUpdated,
|
lastUpdated: entry.lastUpdated,
|
||||||
|
lastError: entry.lastError,
|
||||||
}));
|
}));
|
||||||
await writeFile(`${directory}/db.json`, JSON.stringify(updated, null, 2));
|
await writeFile(`${directory}/db.json`, JSON.stringify(updated, null, 2));
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue