From 42d8e605b497c98ed7a4b7e6f31fa1cc6d56e38a Mon Sep 17 00:00:00 2001 From: TymanWasTaken <32660892+tymanwastaken@users.noreply.github.com> Date: Tue, 11 May 2021 22:22:19 -0600 Subject: re-organize models --- src/lib/models/Ban.ts | 47 +++++++++++++++++++++++++++++++++++++++++++++ src/lib/models/BaseModel.ts | 6 ++++++ src/lib/models/Guild.ts | 15 +++++++++++++++ src/lib/models/Modlog.ts | 42 ++++++++++++++++++++++++++++++++++++++++ src/lib/models/index.ts | 4 ++++ 5 files changed, 114 insertions(+) create mode 100644 src/lib/models/Ban.ts create mode 100644 src/lib/models/BaseModel.ts create mode 100644 src/lib/models/Guild.ts create mode 100644 src/lib/models/Modlog.ts create mode 100644 src/lib/models/index.ts (limited to 'src/lib/models') diff --git a/src/lib/models/Ban.ts b/src/lib/models/Ban.ts new file mode 100644 index 0000000..032a48b --- /dev/null +++ b/src/lib/models/Ban.ts @@ -0,0 +1,47 @@ +import { BaseModel } from './BaseModel'; + +export interface BanModel { + id: string; + user: string; + guild: string; + reason: string; + expires: Date; + modlog: string; +} +export interface BanModelCreationAttributes { + id?: string; + user: string; + guild: string; + reason?: string; + expires?: Date; + modlog: string; +} + +export class Ban + extends BaseModel + implements BanModel { + /** + * The ID of this ban (no real use just for a primary key) + */ + id: string; + /** + * The user who is banned + */ + user: string; + /** + * The guild they are banned from + */ + guild: string; + /** + * The reason they are banned (optional) + */ + reason: string | null; + /** + * The date at which this ban expires and should be unbanned (optional) + */ + expires: Date | null; + /** + * The ref to the modlog entry + */ + modlog: string; +} diff --git a/src/lib/models/BaseModel.ts b/src/lib/models/BaseModel.ts new file mode 100644 index 0000000..fdbd706 --- /dev/null +++ b/src/lib/models/BaseModel.ts @@ -0,0 +1,6 @@ +import { Model } from 'sequelize'; + +export abstract class BaseModel extends Model { + public readonly createdAt: Date; + public readonly updatedAt: Date; +} diff --git a/src/lib/models/Guild.ts b/src/lib/models/Guild.ts new file mode 100644 index 0000000..3e6c6bf --- /dev/null +++ b/src/lib/models/Guild.ts @@ -0,0 +1,15 @@ +import { Optional } from 'sequelize'; +import { BaseModel } from './BaseModel'; + +export interface GuildModel { + id: string; + prefix: string; +} +export type GuildModelCreationAttributes = Optional; + +export class Guild + extends BaseModel + implements GuildModel { + id: string; + prefix: string; +} diff --git a/src/lib/models/Modlog.ts b/src/lib/models/Modlog.ts new file mode 100644 index 0000000..0a3feba --- /dev/null +++ b/src/lib/models/Modlog.ts @@ -0,0 +1,42 @@ +import { BaseModel } from './BaseModel'; + +export enum ModlogType { + BAN = 'BAN', + TEMPBAN = 'TEMPBAN', + KICK = 'KICK', + MUTE = 'MUTE', + TEMPMUTE = 'TEMPMUTE', + WARN = 'WARN' +} + +export interface ModlogModel { + id: string; + type: ModlogType; + user: string; + moderator: string; + reason: string; + duration: number; + guild: string; +} + +export interface ModlogModelCreationAttributes { + id?: string; + type: ModlogType; + user: string; + moderator: string; + reason?: string; + duration?: number; + guild: string; +} + +export class Modlog + extends BaseModel + implements ModlogModel { + id: string; + type: ModlogType; + user: string; + moderator: string; + guild: string; + reason: string | null; + duration: number | null; +} diff --git a/src/lib/models/index.ts b/src/lib/models/index.ts new file mode 100644 index 0000000..ef65415 --- /dev/null +++ b/src/lib/models/index.ts @@ -0,0 +1,4 @@ +export * from './BaseModel'; +export * from './Guild'; +export * from './Ban'; +export * from './Modlog'; -- cgit