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

@ -47,11 +47,11 @@ export class GuildMutes extends BaseGuildRepository {
return (await this.mutes.findOne({ where: result.identifiers[0] }))!;
}
async updateExpiryTime(userId, newExpiryTime, rolesToRestore?: string[]) {
async updateExpiryTime(userId, newExpiryTime, rolesToRestore?: string[]): Promise<void> {
const expiresAt = newExpiryTime ? moment.utc().add(newExpiryTime, "ms").format("YYYY-MM-DD HH:mm:ss") : null;
if (rolesToRestore && rolesToRestore.length) {
return this.mutes.update(
await this.mutes.update(
{
guild_id: this.guildId,
user_id: userId,
@ -62,7 +62,7 @@ export class GuildMutes extends BaseGuildRepository {
},
);
} else {
return this.mutes.update(
await this.mutes.update(
{
guild_id: this.guildId,
user_id: userId,