Centralize periodic checks for mutes, tempbans, vcalerts, reminders, and scheduled posts

This should result in a significant performance improvement.
The new method is also more precise than the old one, allowing
the aforementioned checks to be performed with second-precision.
This commit is contained in:
Dragory 2021-09-25 21:33:59 +03:00
parent c84d1a0be1
commit c7751a9da1
No known key found for this signature in database
GPG key ID: 5F387BA66DF8AAC1
55 changed files with 883 additions and 366 deletions

View file

@ -40,6 +40,10 @@ export class GuildVCAlerts extends BaseGuildRepository {
});
}
find(id: number) {
return this.allAlerts.findOne({ id });
}
async delete(id) {
await this.allAlerts.delete({
guild_id: this.guildId,
@ -48,7 +52,7 @@ export class GuildVCAlerts extends BaseGuildRepository {
}
async add(requestorId: string, userId: string, channelId: string, expiresAt: string, body: string, active: boolean) {
await this.allAlerts.insert({
const result = await this.allAlerts.insert({
guild_id: this.guildId,
requestor_id: requestorId,
user_id: userId,
@ -57,5 +61,7 @@ export class GuildVCAlerts extends BaseGuildRepository {
body,
active,
});
return (await this.find(result.identifiers[0].id))!;
}
}