1
0
Fork 0

better error handling

- rate limit is stderr, so need to check to make sure only finishing on other errors
- color errors in log
- log errors to userDb
- use fallback date in case dates weren't logged (e.g. /media failed)
- report on not-found users, which may indicate a username change or deleted account
- report on authorization errors
This commit is contained in:
lightling 2024-02-10 15:07:54 -05:00
parent cd87d2e244
commit 3933505fc6
3 changed files with 31 additions and 7 deletions

View file

@ -20,6 +20,11 @@ const getDateUrlFromLog = (logs) => {
result = last; result = last;
last = loggedDateRegex.exec(flat); last = loggedDateRegex.exec(flat);
} }
if (!result) {
let fallbackDate = new Date();
return `${fallbackDate.getUTCFullYear()}-${fallbackDate.getUTCMonth()}-${fallbackDate.getUTCDate()}`
}
let date = new Date(result[1], result[2], result[3], result[4], result[5], result[6], 0); let date = new Date(result[1], result[2], result[3], result[4], result[5], result[6], 0);
// to be safe, spring forward a day // to be safe, spring forward a day
date.setDate(date.getDate() + 1); date.setDate(date.getDate() + 1);
@ -40,11 +45,19 @@ export const getMany = (userDb, threadMax, directory, mode) => new Promise((reso
let index = 0; let index = 0;
const get = () => { const get = () => {
const onFinish = (currentIndex) => { const checkError = (proc, currentIndex, type, codeOrError) => {
log(ctx, `Finished ${userDb[currentIndex].user} under ${mode} mode`); userDb[currentIndex].logs.push(codeOrError.toString())
if (!!proc.exitCode && !userDb[currentIndex].running) {
userDb[currentIndex].running = false;
onFinish(currentIndex, type);
}
};
const onFinish = (currentIndex, type) => {
log(ctx, `Finished ${userDb[currentIndex].user} under ${mode} mode.${type === 'close' ? '' : ' (Closed due to ' + type}`);
--running; --running;
get(); get();
} };
while (running < threadMax && index < userDb.length) { while (running < threadMax && index < userDb.length) {
++running; ++running;
@ -55,12 +68,14 @@ 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;
proc.stdout.on('data', data => { proc.stdout.on('data', data => {
userDb[currentIndex].logs.push(data); userDb[currentIndex].logs.push(data);
}); });
proc.stderr.on('data', _ => onFinish(currentIndex)); proc.stderr.on('data', data => checkError(proc, currentIndex, 'stderr', data));
proc.on('close', _ => onFinish(currentIndex)); proc.on('close', code => onFinish(currentIndex, 'close', code));
proc.on('error', _ => onFinish(currentIndex)); proc.on('error', err => checkError(proc, currentIndex, 'error', err));
proc.on('exit', code => checkError(proc, currentIndex, 'exit', code));
} }
if (running === 0) { if (running === 0) {

View file

@ -27,5 +27,5 @@ export const log = (src, msg) => {
*/ */
export const error = (src, msg) => { export const error = (src, msg) => {
const time = new Date().toISOString(); const time = new Date().toISOString();
console.error(`${time} : ${src} : ${msg}`); console.error(`\x1b[33m${time} : ${src} : ${msg}\x1b[0m`);
} }

View file

@ -45,6 +45,15 @@ const downloadDb = async () => {
log(ctx, 'Downloading media using /search'); log(ctx, 'Downloading media using /search');
await getMany(processes, threadMax, directory, 'search'); await getMany(processes, threadMax, directory, 'search');
processes.forEach(entry => {
entry.logs.forEach(log => {
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.`);
} else if (log.includes('AuthorizationError')) {
error(ctx, `There was an authorization error for user ${entry.user}: "${log.replace('\n', '')}"`);
}
});
});
log(ctx, 'Done'); log(ctx, 'Done');
} }