1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
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 }
);
}
}
|