refactor checkExpired to use Promise.all

This commit is contained in:
Johann150 2023-05-30 20:40:25 +02:00
parent bed8286175
commit 7c9e118ff1
Signed by untrusted user: Johann150
GPG key ID: 9EE6577A2A06F8F1

View file

@ -10,52 +10,49 @@ const logger = queueLogger.createSubLogger('check-expired');
export async function checkExpired(job: Bull.Job<Record<string, unknown>>, done: any): Promise<void> { export async function checkExpired(job: Bull.Job<Record<string, unknown>>, done: any): Promise<void> {
logger.info('Checking expired data...'); logger.info('Checking expired data...');
const expiredMutings = await Mutings.createQueryBuilder('muting')
.where('muting.expiresAt IS NOT NULL')
.andWhere('muting.expiresAt < :now', { now: new Date() })
.innerJoinAndSelect('muting.mutee', 'mutee')
.getMany();
if (expiredMutings.length > 0) {
await Mutings.delete({
id: In(expiredMutings.map(m => m.id)),
});
for (const m of expiredMutings) {
publishUserEvent(m.muterId, 'unmute', m.mutee!);
}
}
const OlderThan = (millis: number) => { const OlderThan = (millis: number) => {
return LessThan(new Date(new Date().getTime() - millis)); return LessThan(new Date(new Date().getTime() - millis));
}; };
await Signins.delete({ await Promise.all([
createdAt: OlderThan(2 * MONTH), Mutings.createQueryBuilder('muting')
}); .where('muting.expiresAt IS NOT NULL')
.andWhere('muting.expiresAt < :now', { now: new Date() })
.innerJoinAndSelect('muting.mutee', 'mutee')
.getMany()
.then(async (expiredMutings) => {
if (expiredMutings.length > 0) {
await Mutings.delete({
id: In(expiredMutings.map(m => m.id)),
});
await AttestationChallenges.delete({ for (const m of expiredMutings) {
createdAt: OlderThan(5 * MINUTE), publishUserEvent(m.muterId, 'unmute', m.mutee!);
}); }
}
await PasswordResetRequests.delete({ }),
// this timing should be the same as in @/server/api/endpoints/reset-password.ts Signins.delete({
createdAt: OlderThan(30 * MINUTE), createdAt: OlderThan(2 * MONTH),
}); }),
AttestationChallenges.delete({
await AuthSessions.delete({ createdAt: OlderThan(5 * MINUTE),
createdAt: OlderThan(15 * MINUTE), }),
}); PasswordResetRequests.delete({
// this timing should be the same as in @/server/api/endpoints/reset-password.ts
await Notifications.delete({ createdAt: OlderThan(30 * MINUTE),
isRead: true, }),
createdAt: OlderThan(3 * MONTH), AuthSessions.delete({
}); createdAt: OlderThan(15 * MINUTE),
}),
await Users.delete({ Notifications.delete({
// delete users where the deletion status reference count has come down to zero isRead: true,
isDeleted: 0, createdAt: OlderThan(3 * MONTH),
}); }),
Users.delete({
// delete users where the deletion status reference count has come down to zero
isDeleted: 0,
}),
]);
logger.succ('Deleted expired data.'); logger.succ('Deleted expired data.');