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
|
CREATE TABLE IF NOT EXISTS banned_user (
id SERIAL CONSTRAINT banned_user_pkey PRIMARY KEY,
time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP,
expires TIMESTAMP WITH TIME ZONE NULL DEFAULT NULL,
expired TIMESTAMP WITH TIME ZONE NULL DEFAULT NULL,
revoked BOOLEAN NOT NULL DEFAULT FALSE,
username VARCHAR(100) NOT NULL,
source VARCHAR(10) NOT NULL,
reason VARCHAR(100) NULL DEFAULT NULL
);
CREATE INDEX banned_user_username_idx ON banned_user (username);
CREATE INDEX banned_user_lookup_idx ON banned_user (username, revoked, expires, expired);
CREATE INDEX banned_user_list_idx ON banned_user (revoked, expires, expired);
CREATE TABLE IF NOT EXISTS banned_ip (
id SERIAL CONSTRAINT banned_ip_pkey PRIMARY KEY,
time TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP,
expires TIMESTAMP WITH TIME ZONE NULL DEFAULT NULL,
expired TIMESTAMP WITH TIME ZONE NULL DEFAULT NULL,
revoked BOOLEAN NOT NULL DEFAULT FALSE,
ip VARCHAR(39) NOT NULL,
source VARCHAR(10) NOT NULL,
reason VARCHAR(100) NULL DEFAULT NULL
);
CREATE INDEX banned_ip_ip_idx ON banned_ip (ip);
CREATE INDEX banned_ip_lookup_idx ON banned_ip (ip, revoked, expires, expired);
CREATE INDEX banned_ip_list_idx ON banned_ip (revoked, expires, expired);
|