diff options
Diffstat (limited to 'src/lib')
-rw-r--r-- | src/lib/extensions/discord-akairo/BushClient.ts | 56 | ||||
-rw-r--r-- | src/lib/extensions/discord-akairo/BushClientUtil.ts | 88 | ||||
-rw-r--r-- | src/lib/extensions/discord-akairo/BushCommandHandler.ts | 41 | ||||
-rw-r--r-- | src/lib/extensions/discord-akairo/BushListener.ts | 5 | ||||
-rw-r--r-- | src/lib/extensions/discord.js/BushButtonInteraction.ts | 2 | ||||
-rw-r--r-- | src/lib/extensions/discord.js/BushCommandInteraction.ts | 2 | ||||
-rw-r--r-- | src/lib/extensions/discord.js/BushGuildMember.ts | 2 | ||||
-rw-r--r-- | src/lib/extensions/discord.js/BushSelectMenuInteraction.ts | 2 | ||||
-rw-r--r-- | src/lib/index.ts | 4 | ||||
-rw-r--r-- | src/lib/models/ActivePunishment.ts (renamed from src/lib/models/PunishmentRole.ts) | 53 | ||||
-rw-r--r-- | src/lib/models/Ban.ts | 80 | ||||
-rw-r--r-- | src/lib/models/ModLog.ts | 5 | ||||
-rw-r--r-- | src/lib/models/Mute.ts | 80 |
13 files changed, 120 insertions, 300 deletions
diff --git a/src/lib/extensions/discord-akairo/BushClient.ts b/src/lib/extensions/discord-akairo/BushClient.ts index 66204ac..8eec3ce 100644 --- a/src/lib/extensions/discord-akairo/BushClient.ts +++ b/src/lib/extensions/discord-akairo/BushClient.ts @@ -18,13 +18,11 @@ import { Sequelize } from 'sequelize'; import { contentWithDurationTypeCaster } from '../../../arguments/contentWithDuration'; import { durationTypeCaster } from '../../../arguments/duration'; import { UpdateCacheTask } from '../../../tasks/updateCache'; -import { Ban } from '../../models/Ban'; +import { ActivePunishment } from '../../models/ActivePunishment'; import { Global } from '../../models/Global'; import { Guild as GuildModel } from '../../models/Guild'; import { Level } from '../../models/Level'; import { ModLog } from '../../models/ModLog'; -import { Mute } from '../../models/Mute'; -import { PunishmentRole } from '../../models/PunishmentRole'; import { StickyRole } from '../../models/StickyRole'; import { AllowedMentions } from '../../utils/AllowedMentions'; import { BushCache } from '../../utils/BushCache'; @@ -107,39 +105,23 @@ export class BushClient extends AkairoClient { public constants = BushConstants; public cache = BushCache; public constructor(config: Config) { - super( - { - ownerID: config.owners, - intents: Object.values(Intents.FLAGS).reduce((acc, p) => acc | p, 0), - presence: { - activities: [ - { - name: 'Beep Boop', - type: 'WATCHING' - } - ], - status: 'online' - } + super({ + ownerID: config.owners, + intents: Object.values(Intents.FLAGS).reduce((acc, p) => acc | p, 0), + presence: { + activities: [ + { + name: 'Beep Boop', + type: 'WATCHING' + } + ], + status: 'online' }, - { - allowedMentions: AllowedMentions.users(), // No everyone or role mentions by default - intents: Object.values(Intents.FLAGS).reduce((acc, p) => acc | p, 0), - presence: { - activities: [ - { - name: 'Beep Boop', - type: 'WATCHING' - } - ], - status: 'online' - } - } - ); + http: { api: 'https://canary.discord.com/api' }, + allowedMentions: AllowedMentions.users() // No everyone or role mentions by default + }); - // Set token this.token = config.token; - - // Set config this.config = config; // Create listener handler @@ -170,7 +152,7 @@ export class BushClient extends AkairoClient { allowMention: true, handleEdits: true, commandUtil: true, - commandUtilLifetime: 300_000, + commandUtilLifetime: 300_000, // 5 minutes argumentDefaults: { prompt: { start: 'Placeholder argument prompt. If you see this please tell my developers.', @@ -259,11 +241,9 @@ export class BushClient extends AkairoClient { Global.initModel(this.db); GuildModel.initModel(this.db, this); ModLog.initModel(this.db); - Ban.initModel(this.db); - Mute.initModel(this.db); + ActivePunishment.initModel(this.db); Level.initModel(this.db); StickyRole.initModel(this.db); - PunishmentRole.initModel(this.db); await this.db.sync({ alter: true }); // Sync all tables to fix everything if updated await this.console.success('Startup', `Successfully connected to <<database>>.`, false); } catch (e) { @@ -277,7 +257,7 @@ export class BushClient extends AkairoClient { /** Starts the bot */ public async start(): Promise<void> { - global.client = this; + global.client = this; // makes the client a global object try { await this._init(); diff --git a/src/lib/extensions/discord-akairo/BushClientUtil.ts b/src/lib/extensions/discord-akairo/BushClientUtil.ts index 0e3a904..306e049 100644 --- a/src/lib/extensions/discord-akairo/BushClientUtil.ts +++ b/src/lib/extensions/discord-akairo/BushClientUtil.ts @@ -2,7 +2,6 @@ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */ import { - Ban, BushCache, BushClient, BushConstants, @@ -14,9 +13,7 @@ import { Global, Guild, ModLog, - ModLogType, - Mute, - PunishmentRole + ModLogType } from '@lib'; import { exec } from 'child_process'; import { ClientUtil } from 'discord-akairo'; @@ -43,8 +40,8 @@ import { } from 'discord.js'; import got from 'got'; import humanizeDuration from 'humanize-duration'; -import { Op } from 'sequelize'; import { promisify } from 'util'; +import { ActivePunishment, ActivePunishmentType } from '../../models/ActivePunishment'; import { BushNewsChannel } from '../discord.js/BushNewsChannel'; import { BushTextChannel } from '../discord.js/BushTextChannel'; import { BushUserResolvable } from './BushClient'; @@ -96,12 +93,6 @@ interface bushColors { orange: '#E86100'; } -interface punishmentModels { - mute: Mute; - ban: Ban; - role: PunishmentRole; -} - interface MojangProfile { username: string; uuid: string; @@ -664,22 +655,21 @@ export class BushClientUtil extends ClientUtil { } public async createPunishmentEntry(options: { - type: 'mute' | 'ban' | 'role'; + type: 'mute' | 'ban' | 'role' | 'block'; user: BushGuildMemberResolvable; duration: number; guild: BushGuildResolvable; modlog: string; - role?: Snowflake; - }): Promise<Mute | Ban | PunishmentRole> { - const dbModel = this.findPunishmentModel(options.type); + extraInfo?: Snowflake; + }): Promise<ActivePunishment> { const expires = options.duration ? new Date(new Date().getTime() + options.duration) : null; const user = this.client.users.resolveId(options.user); const guild = this.client.guilds.resolveId(options.guild); + const type = this.findTypeEnum(options.type); - const entry = - options.type === 'role' - ? (dbModel as typeof PunishmentRole).build({ user, guild, expires, modlog: options.modlog, role: options.role }) - : dbModel.build({ user, guild, expires, modlog: options.modlog }); + const entry = options.extraInfo + ? ActivePunishment.build({ user, type, guild, expires, modlog: options.modlog, extraInfo: options.extraInfo }) + : ActivePunishment.build({ user, type, guild, expires, modlog: options.modlog }); return await entry.save().catch((e) => { this.client.console.error('createPunishmentEntry', e?.stack || e); return null; @@ -687,28 +677,23 @@ export class BushClientUtil extends ClientUtil { } public async removePunishmentEntry(options: { - type: 'mute' | 'ban' | 'role'; + type: 'mute' | 'ban' | 'role' | 'block'; user: BushGuildMemberResolvable; guild: BushGuildResolvable; }): Promise<boolean> { - const dbModel = this.findPunishmentModel(options.type); const user = this.client.users.resolveId(options.user); const guild = this.client.guilds.resolveId(options.guild); + const type = this.findTypeEnum(options.type); let success = true; - const entries = await dbModel - .findAll({ - // finding all cases of a certain type incase there were duplicates or something - where: { - user, - guild - } - }) - .catch((e) => { - this.client.console.error('removePunishmentEntry', e?.stack || e); - success = false; - }); + const entries = await ActivePunishment.findAll({ + // finding all cases of a certain type incase there were duplicates or something + where: { user, guild, type } + }).catch((e) => { + this.client.console.error('removePunishmentEntry', e?.stack || e); + success = false; + }); if (entries) { entries.forEach(async (entry) => { await entry.destroy().catch((e) => { @@ -720,33 +705,14 @@ export class BushClientUtil extends ClientUtil { return success; } - public async findExpiredEntries<K extends keyof punishmentModels>(type: K): Promise<punishmentModels[K][]> { - const dbModel = this.findPunishmentModel(type); - //@ts-ignore: stfu idc - return await dbModel.findAll({ - where: { - [Op.and]: [ - { - expires: { - [Op.lt]: new Date() // Find all rows with an expiry date before now - } - } - ] - } - }); - } - - private findPunishmentModel<K extends keyof punishmentModels>(type: K): typeof Mute | typeof Ban | typeof PunishmentRole { - switch (type) { - case 'mute': - return Mute; - case 'ban': - return Ban; - case 'role': - return PunishmentRole; - default: - throw 'choose a valid punishment entry type'; - } + private findTypeEnum(type: 'mute' | 'ban' | 'role' | 'block') { + const typeMap = { + ['mute']: ActivePunishmentType.MUTE, + ['ban']: ActivePunishmentType.BAN, + ['role']: ActivePunishmentType.ROLE, + ['block']: ActivePunishmentType.BLOCK + }; + return typeMap[type]; } public humanizeDuration(duration: number): string { @@ -782,5 +748,7 @@ export class BushClientUtil extends ClientUtil { return arrByte[1] + ', ' + arrByte[2] + ', ' + arrByte[3]; } + /* eslint-disable @typescript-eslint/no-unused-vars */ public async lockdownChannel(options: { channel: BushTextChannel | BushNewsChannel; moderator: BushUserResolvable }) {} + /* eslint-enable @typescript-eslint/no-unused-vars */ } diff --git a/src/lib/extensions/discord-akairo/BushCommandHandler.ts b/src/lib/extensions/discord-akairo/BushCommandHandler.ts index 09baf2e..dacd17f 100644 --- a/src/lib/extensions/discord-akairo/BushCommandHandler.ts +++ b/src/lib/extensions/discord-akairo/BushCommandHandler.ts @@ -1,15 +1,26 @@ /* eslint-disable @typescript-eslint/no-explicit-any */ -import { Category, CommandHandler, CommandHandlerOptions } from 'discord-akairo'; -import { Collection } from 'discord.js'; +import { Category, CommandHandler, CommandHandlerEvents, CommandHandlerOptions } from 'discord-akairo'; +import { Collection, PermissionString } from 'discord.js'; import { BushConstants } from '../../utils/BushConstants'; import { BushMessage } from '../discord.js/BushMessage'; import { BushClient } from './BushClient'; import { BushCommand } from './BushCommand'; +import { BushSlashMessage } from './BushSlashMessage'; export type BushCommandHandlerOptions = CommandHandlerOptions; -const CommandHandlerEvents = BushConstants.CommandHandlerEvents; -const BlockedReasons = BushConstants.BlockedReasons; +const commandHandlerEvents = BushConstants.CommandHandlerEvents; +const blockedReasons = BushConstants.BlockedReasons; + +export interface BushCommandHandlerEvents extends CommandHandlerEvents { + commandBlocked: [message: BushMessage, command: BushCommand, reason: string]; + + missingPermissions: [message: BushMessage, command: BushCommand, type: 'client' | 'user', missing: Array<PermissionString>]; + + slashBlocked: [message: BushSlashMessage, command: BushCommand, reason: string]; + + slashMissingPermissions: [message: BushSlashMessage, command: BushCommand, type: 'client' | 'user', missing: Array<PermissionString>]; +} export class BushCommandHandler extends CommandHandler { public declare client: BushClient; @@ -24,10 +35,10 @@ export class BushCommandHandler extends CommandHandler { const isOwner = this.client.isOwner(message.author); if (!isOwner) { this.emit( - slash ? CommandHandlerEvents.SLASH_BLOCKED : CommandHandlerEvents.COMMAND_BLOCKED, + slash ? commandHandlerEvents.SLASH_BLOCKED : commandHandlerEvents.COMMAND_BLOCKED, message, command, - BlockedReasons.OWNER + blockedReasons.OWNER ); return true; } @@ -37,10 +48,10 @@ export class BushCommandHandler extends CommandHandler { const isSuperUser = this.client.isSuperUser(message.author); if (!isSuperUser) { this.emit( - slash ? CommandHandlerEvents.SLASH_BLOCKED : CommandHandlerEvents.COMMAND_BLOCKED, + slash ? commandHandlerEvents.SLASH_BLOCKED : commandHandlerEvents.COMMAND_BLOCKED, message, command, - BlockedReasons.OWNER + blockedReasons.OWNER ); return true; } @@ -48,32 +59,32 @@ export class BushCommandHandler extends CommandHandler { if (command.channel === 'guild' && !message.guild) { this.emit( - slash ? CommandHandlerEvents.SLASH_BLOCKED : CommandHandlerEvents.COMMAND_BLOCKED, + slash ? commandHandlerEvents.SLASH_BLOCKED : commandHandlerEvents.COMMAND_BLOCKED, message, command, - BlockedReasons.GUILD + blockedReasons.GUILD ); return true; } if (command.channel === 'dm' && message.guild) { this.emit( - slash ? CommandHandlerEvents.SLASH_BLOCKED : CommandHandlerEvents.COMMAND_BLOCKED, + slash ? commandHandlerEvents.SLASH_BLOCKED : commandHandlerEvents.COMMAND_BLOCKED, message, command, - BlockedReasons.DM + blockedReasons.DM ); return true; } if (command.restrictedChannels?.length && message.channel) { if (!command.restrictedChannels.includes(message.channel.id)) { - this.emit(CommandHandlerEvents.COMMAND_BLOCKED, message, command, BlockedReasons.RESTRICTED_CHANNEL); + this.emit(commandHandlerEvents.COMMAND_BLOCKED, message, command, blockedReasons.RESTRICTED_CHANNEL); return true; } } if (command.restrictedGuilds?.length && message.guild) { if (!command.restrictedGuilds.includes(message.guild.id)) { - this.emit(CommandHandlerEvents.COMMAND_BLOCKED, message, command, BlockedReasons.RESTRICTED_GUILD); + this.emit(commandHandlerEvents.COMMAND_BLOCKED, message, command, blockedReasons.RESTRICTED_GUILD); return true; } } @@ -82,7 +93,7 @@ export class BushCommandHandler extends CommandHandler { } const reason = this.inhibitorHandler ? await this.inhibitorHandler.test('post', message, command) : null; if (reason != null) { - this.emit(CommandHandlerEvents.COMMAND_BLOCKED, message, command, reason); + this.emit(commandHandlerEvents.COMMAND_BLOCKED, message, command, reason); return true; } return !!this.runCooldowns(message, command); diff --git a/src/lib/extensions/discord-akairo/BushListener.ts b/src/lib/extensions/discord-akairo/BushListener.ts index e555e89..2583e85 100644 --- a/src/lib/extensions/discord-akairo/BushListener.ts +++ b/src/lib/extensions/discord-akairo/BushListener.ts @@ -1,6 +1,9 @@ import { Listener } from 'discord-akairo'; +import EventEmitter from 'events'; import { BushClient } from './BushClient'; - export class BushListener extends Listener { public declare client: BushClient; + public constructor(id: string, options?:{emitter: string|EventEmitter, event: string, type?: 'on'|'once', category?: string}){ + super(id, options) + } } diff --git a/src/lib/extensions/discord.js/BushButtonInteraction.ts b/src/lib/extensions/discord.js/BushButtonInteraction.ts index 3a54f61..846786c 100644 --- a/src/lib/extensions/discord.js/BushButtonInteraction.ts +++ b/src/lib/extensions/discord.js/BushButtonInteraction.ts @@ -1,4 +1,4 @@ -import { APIInteractionGuildMember } from 'discord-api-types/v8'; +import { APIInteractionGuildMember } from 'discord-api-types/v9'; import { ButtonInteraction, PartialDMChannel } from 'discord.js'; import { BushClient } from '../discord-akairo/BushClient'; import { BushDMChannel } from './BushDMChannel'; diff --git a/src/lib/extensions/discord.js/BushCommandInteraction.ts b/src/lib/extensions/discord.js/BushCommandInteraction.ts index 84c0707..e4fdb53 100644 --- a/src/lib/extensions/discord.js/BushCommandInteraction.ts +++ b/src/lib/extensions/discord.js/BushCommandInteraction.ts @@ -1,4 +1,4 @@ -import { APIInteractionGuildMember } from 'discord-api-types/v8'; +import { APIInteractionGuildMember } from 'discord-api-types/v9'; import { ApplicationCommand, CommandInteraction, diff --git a/src/lib/extensions/discord.js/BushGuildMember.ts b/src/lib/extensions/discord.js/BushGuildMember.ts index 40e4a3a..50875cc 100644 --- a/src/lib/extensions/discord.js/BushGuildMember.ts +++ b/src/lib/extensions/discord.js/BushGuildMember.ts @@ -137,7 +137,7 @@ export class BushGuildMember extends GuildMember { guild: this.guild, duration: options.duration, modlog: modlog.id, - role: options.role.id + extraInfo: options.role.id }) .catch(() => null); if (!punishmentEntrySuccess) return 'error creating role entry'; diff --git a/src/lib/extensions/discord.js/BushSelectMenuInteraction.ts b/src/lib/extensions/discord.js/BushSelectMenuInteraction.ts index 1dd1638..18db8ef 100644 --- a/src/lib/extensions/discord.js/BushSelectMenuInteraction.ts +++ b/src/lib/extensions/discord.js/BushSelectMenuInteraction.ts @@ -1,4 +1,4 @@ -import { APIInteractionGuildMember } from 'discord-api-types/v8'; +import { APIInteractionGuildMember } from 'discord-api-types/v9'; import { PartialDMChannel, SelectMenuInteraction } from 'discord.js'; import { BushClient } from '../discord-akairo/BushClient'; import { BushDMChannel } from './BushDMChannel'; diff --git a/src/lib/index.ts b/src/lib/index.ts index 1059e2b..73cee56 100644 --- a/src/lib/index.ts +++ b/src/lib/index.ts @@ -46,14 +46,12 @@ export * from './extensions/discord.js/BushThreadMemberManager'; export * from './extensions/discord.js/BushUser'; export * from './extensions/discord.js/BushVoiceChannel'; export * from './extensions/discord.js/BushVoiceState'; -export * from './models/Ban'; +export * from './models/ActivePunishment'; export * from './models/BaseModel'; export * from './models/Global'; export * from './models/Guild'; export * from './models/Level'; export * from './models/ModLog'; -export * from './models/Mute'; -export * from './models/PunishmentRole'; export * from './models/StickyRole'; export * from './utils/AllowedMentions'; export * from './utils/BushCache'; diff --git a/src/lib/models/PunishmentRole.ts b/src/lib/models/ActivePunishment.ts index 0b54f31..9fcafbe 100644 --- a/src/lib/models/PunishmentRole.ts +++ b/src/lib/models/ActivePunishment.ts @@ -3,54 +3,67 @@ import { DataTypes, Sequelize } from 'sequelize'; import { v4 as uuidv4 } from 'uuid'; import { BaseModel } from './BaseModel'; -export interface PunishmentRoleModel { +export enum ActivePunishmentType { + BAN = 'BAN', + MUTE = 'MUTE', + ROLE = 'ROLE', + BLOCK = 'BLOCK' +} + +export interface ActivePunishmentModel { id: string; + type: ActivePunishmentType; user: Snowflake; - role: Snowflake; guild: Snowflake; + extraInfo: Snowflake; expires: Date; modlog: string; } -export interface PunishmentRoleModelCreationAttributes { +export interface ActivePunishmentModelCreationAttributes { id?: string; + type: ActivePunishmentType; user: Snowflake; - role?: Snowflake; guild: Snowflake; + extraInfo?: Snowflake; expires?: Date; modlog: string; } -export class PunishmentRole - extends BaseModel<PunishmentRoleModel, PunishmentRoleModelCreationAttributes> - implements PunishmentRoleModel +export class ActivePunishment + extends BaseModel<ActivePunishmentModel, ActivePunishmentModelCreationAttributes> + implements ActivePunishmentModel { /** - * The ID of this punishment role (no real use just for a primary key) + * The ID of this punishment (no real use just for a primary key) */ id: string; /** - * The user who received a role + * The type of punishment. */ - user: Snowflake; + type: ActivePunishmentType; /** - * The role added to the user. + * The user who is punished. */ - role: Snowflake; + user: Snowflake; /** - * The guild they received a role in + * The guild they are punished in. */ guild: Snowflake; /** - * The date at which this role expires and should be removed (optional) + * Additional info about the punishment if applicable. The channel id for channel blocks and role for punishment roles. + */ + extraInfo: Snowflake; + /** + * The date when this punishment expires (optional). */ expires: Date | null; /** - * The ref to the modlog entry + * The reference to the modlog entry. */ modlog: string; static initModel(sequelize: Sequelize): void { - PunishmentRole.init( + ActivePunishment.init( { id: { type: DataTypes.STRING, @@ -58,11 +71,11 @@ export class PunishmentRole allowNull: false, defaultValue: uuidv4 }, - user: { + type: { type: DataTypes.STRING, allowNull: false }, - role: { + user: { type: DataTypes.STRING, allowNull: false }, @@ -74,6 +87,10 @@ export class PunishmentRole key: 'id' } }, + extraInfo: { + type: DataTypes.DATE, + allowNull: true + }, expires: { type: DataTypes.DATE, allowNull: true diff --git a/src/lib/models/Ban.ts b/src/lib/models/Ban.ts deleted file mode 100644 index 1bdda6f..0000000 --- a/src/lib/models/Ban.ts +++ /dev/null @@ -1,80 +0,0 @@ -import { Snowflake } from 'discord.js'; -import { DataTypes, Sequelize } from 'sequelize'; -import { v4 as uuidv4 } from 'uuid'; -import { BaseModel } from './BaseModel'; - -export interface BanModel { - id: string; - user: Snowflake; - guild: Snowflake; - expires: Date; - modlog: string; -} -export interface BanModelCreationAttributes { - id?: string; - user: Snowflake; - guild: Snowflake; - expires?: Date; - modlog: string; -} - -export class Ban extends BaseModel<BanModel, BanModelCreationAttributes> implements BanModel { - /** - * The ID of this ban (no real use just for a primary key) - */ - id: string; - /** - * The user who is banned - */ - user: Snowflake; - /** - * The guild they are banned from - */ - guild: Snowflake; - /** - * The date at which this ban expires and should be unbanned (optional) - */ - expires: Date | null; - /** - * The ref to the modlog entry - */ - modlog: string; - - static initModel(sequelize: Sequelize): void { - Ban.init( - { - id: { - type: DataTypes.STRING, - primaryKey: true, - allowNull: false, - defaultValue: uuidv4 - }, - user: { - type: DataTypes.STRING, - allowNull: false - }, - guild: { - type: DataTypes.STRING, - allowNull: false, - references: { - model: 'Guilds', - key: 'id' - } - }, - expires: { - type: DataTypes.DATE, - allowNull: true - }, - modlog: { - type: DataTypes.STRING, - allowNull: false, - references: { - model: 'ModLogs', - key: 'id' - } - } - }, - { sequelize: sequelize } - ); - } -} diff --git a/src/lib/models/ModLog.ts b/src/lib/models/ModLog.ts index 40dc86d..3375751 100644 --- a/src/lib/models/ModLog.ts +++ b/src/lib/models/ModLog.ts @@ -14,7 +14,10 @@ export enum ModLogType { WARN = 'WARN', PERM_PUNISHMENT_ROLE = 'PERM_PUNISHMENT_ROLE', TEMP_PUNISHMENT_ROLE = 'TEMP_PUNISHMENT_ROLE', - REMOVE_PUNISHMENT_ROLE = 'REMOVE_PUNISHMENT_ROLE' + REMOVE_PUNISHMENT_ROLE = 'REMOVE_PUNISHMENT_ROLE', + PERM_CHANNEL_BLOCK = 'PERM_CHANNEL_BLOCK', + TEMP_CHANNEL_BLOCK = 'TEMP_CHANNEL_BLOCK', + CHANNEL_UNBLOCK = 'CHANNEL_UNBLOCK' } export interface ModLogModel { diff --git a/src/lib/models/Mute.ts b/src/lib/models/Mute.ts deleted file mode 100644 index 4208d02..0000000 --- a/src/lib/models/Mute.ts +++ /dev/null @@ -1,80 +0,0 @@ -import { Snowflake } from 'discord.js'; -import { DataTypes, Sequelize } from 'sequelize'; -import { v4 as uuidv4 } from 'uuid'; -import { BaseModel } from './BaseModel'; - -export interface MuteModel { - id: string; - user: Snowflake; - guild: Snowflake; - expires: Date; - modlog: string; -} -export interface MuteModelCreationAttributes { - id?: string; - user: Snowflake; - guild: Snowflake; - expires?: Date; - modlog: string; -} - -export class Mute extends BaseModel<MuteModel, MuteModelCreationAttributes> implements MuteModel { - /** - * The ID of this mute (no real use just for a primary key) - */ - id: string; - /** - * The user who is muted - */ - user: Snowflake; - /** - * The guild they are muted in - */ - guild: Snowflake; - /** - * The date at which this Mute expires and should be unmuted (optional) - */ - expires: Date | null; - /** - * The ref to the modlog entry - */ - modlog: string; - - static initModel(sequelize: Sequelize): void { - Mute.init( - { - id: { - type: DataTypes.STRING, - primaryKey: true, - allowNull: false, - defaultValue: uuidv4 - }, - user: { - type: DataTypes.STRING, - allowNull: false - }, - guild: { - type: DataTypes.STRING, - allowNull: false, - references: { - model: 'Guilds', - key: 'id' - } - }, - expires: { - type: DataTypes.DATE, - allowNull: true - }, - modlog: { - type: DataTypes.STRING, - allowNull: false, - references: { - model: 'ModLogs', - key: 'id' - } - } - }, - { sequelize: sequelize } - ); - } -} |