From 40f9581991e12082a2708fa8fdd454c080f67a4b Mon Sep 17 00:00:00 2001 From: IRONM00N <64110067+IRONM00N@users.noreply.github.com> Date: Sun, 24 Apr 2022 23:04:49 -0400 Subject: add member ship tracking because I want to make graph --- src/lib/models/shared/MemberCount.ts | 38 ++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 src/lib/models/shared/MemberCount.ts (limited to 'src/lib/models/shared/MemberCount.ts') diff --git a/src/lib/models/shared/MemberCount.ts b/src/lib/models/shared/MemberCount.ts new file mode 100644 index 0000000..409d1ac --- /dev/null +++ b/src/lib/models/shared/MemberCount.ts @@ -0,0 +1,38 @@ +import { type Sequelize } from 'sequelize'; +const { DataTypes, Model } = (await import('sequelize')).default; + +export interface MemberCountModel { + timestamp: Date; + guildId: string; + memberCount: number; +} + +export interface MemberCountCreationAttributes { + timestamp?: Date; + guildId: string; + memberCount: number; +} + +/** + * Data specific to a certain instance of the bot. + */ +export class MemberCount extends Model implements MemberCountModel { + public declare timestamp: Date; + public declare guildId: string; + public declare memberCount: number; + + /** + * Initializes the model. + * @param sequelize The sequelize instance. + */ + public static initModel(sequelize: Sequelize): void { + MemberCount.init( + { + timestamp: { type: DataTypes.DATE, allowNull: false, defaultValue: DataTypes.NOW }, + guildId: { type: DataTypes.STRING, allowNull: false }, + memberCount: { type: DataTypes.BIGINT, allowNull: false } + }, + { sequelize, timestamps: false } + ); + } +} -- cgit