2023-01-13 13:40:33 +09:00
|
|
|
import type Bull from "bull";
|
2019-11-07 00:02:18 +09:00
|
|
|
|
|
|
|
export function getJobInfo(job: Bull.Job, increment = false) {
|
|
|
|
const age = Date.now() - job.timestamp;
|
|
|
|
|
2023-01-13 13:40:33 +09:00
|
|
|
const formated =
|
|
|
|
age > 60000
|
|
|
|
? `${Math.floor(age / 1000 / 60)}m`
|
|
|
|
: age > 10000
|
|
|
|
? `${Math.floor(age / 1000)}s`
|
|
|
|
: `${age}ms`;
|
2019-11-07 00:02:18 +09:00
|
|
|
|
|
|
|
// onActiveとかonCompletedのattemptsMadeがなぜか0始まりなのでインクリメントする
|
|
|
|
const currentAttempts = job.attemptsMade + (increment ? 1 : 0);
|
|
|
|
const maxAttempts = job.opts ? job.opts.attempts : 0;
|
|
|
|
|
|
|
|
return `id=${job.id} attempts=${currentAttempts}/${maxAttempts} age=${formated}`;
|
|
|
|
}
|