forked from espebra/filebin2
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathschema.sql
67 lines (63 loc) · 1.79 KB
/
schema.sql
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
CREATE TABLE bin (
id VARCHAR(64) NOT NULL PRIMARY KEY,
readonly BOOLEAN NOT NULL,
updated_at TIMESTAMP NOT NULL,
created_at TIMESTAMP NOT NULL,
expired_at TIMESTAMP NOT NULL,
deleted_at TIMESTAMP,
approved_at TIMESTAMP,
downloads BIGINT NOT NULL,
updates BIGINT NOT NULL
);
CREATE TABLE file (
id BIGSERIAL NOT NULL PRIMARY KEY,
bin_id VARCHAR(64) REFERENCES bin(id) ON DELETE CASCADE,
filename VARCHAR(128) NOT NULL,
in_storage BOOLEAN NOT NULL,
mime VARCHAR(128) NOT NULL,
bytes BIGINT NOT NULL,
md5 VARCHAR(128) NOT NULL,
sha256 VARCHAR(128) NOT NULL,
downloads BIGINT NOT NULL,
updates BIGINT NOT NULL,
ip VARCHAR(128) NOT NULL,
client_id VARCHAR(128) NOT NULL,
headers TEXT NOT NULL,
updated_at TIMESTAMP NOT NULL,
created_at TIMESTAMP NOT NULL,
deleted_at TIMESTAMP,
UNIQUE(bin_id, filename)
);
CREATE TABLE transaction (
id BIGSERIAL NOT NULL PRIMARY KEY,
bin_id VARCHAR(64) NOT NULL,
operation TEXT NOT NULL,
timestamp TIMESTAMP NOT NULL,
completed TIMESTAMP NOT NULL,
ip VARCHAR(128) NOT NULL,
client_id VARCHAR(128) NOT NULL,
method VARCHAR(128) NOT NULL,
path TEXT NOT NULL,
filename TEXT,
headers TEXT NOT NULL,
status INT NOT NULL,
req_bytes BIGINT NOT NULL,
resp_bytes BIGINT NOT NULL,
UNIQUE(id)
);
CREATE INDEX idx_bin_id ON transaction(bin_id);
CREATE INDEX idx_file_deleted_at_in_storage ON file(deleted_at, in_storage);
CREATE INDEX idx_bin_deleted_at_expired_at ON bin(expired_at, deleted_at);
CREATE TABLE ban (
id BIGSERIAL NOT NULL PRIMARY KEY,
ip VARCHAR(64) NOT NULL,
fingerprint VARCHAR(64) NOT NULL,
network VARCHAR(64) NOT NULL,
continent VARCHAR(64) NOT NULL,
country VARCHAR(64) NOT NULL,
city VARCHAR(64) NOT NULL,
active BOOLEAN NOT NULL,
counter BIGINT NOT NULL,
created_at TIMESTAMP NOT NULL,
UNIQUE(id)
);