-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathaccounting_db_structure.sql
150 lines (120 loc) · 6.23 KB
/
accounting_db_structure.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
CREATE TABLE IF NOT EXISTS issues_checked (
id SERIAL PRIMARY KEY,
issue_id INTEGER NOT NULL,
checked_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
transaction_id BIGINT NOT NULL DEFAULT txid_current()
);
CREATE INDEX IF NOT EXISTS issues_checked_issue_id ON issues_checked (issue_id);
CREATE INDEX IF NOT EXISTS issues_checked_checked_at ON issues_checked (checked_at);
CREATE INDEX IF NOT EXISTS issues_checked_transaction_id ON issues_checked (transaction_id);
CREATE TABLE IF NOT EXISTS merge_requests_checked (
id SERIAL PRIMARY KEY,
merge_request_id INTEGER NOT NULL,
checked_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
transaction_id BIGINT NOT NULL DEFAULT txid_current()
);
CREATE INDEX IF NOT EXISTS merge_requests_checked_merge_request_id ON merge_requests_checked (merge_request_id);
CREATE INDEX IF NOT EXISTS merge_requests_checked_checked_at ON merge_requests_checked (checked_at);
CREATE INDEX IF NOT EXISTS merge_requests_checked_transaction_id ON merge_requests_checked (transaction_id);
CREATE TABLE IF NOT EXISTS hourly_employee_timelogs_checked (
id SERIAL PRIMARY KEY,
timelog_id INTEGER NOT NULL UNIQUE,
checked_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
transaction_id BIGINT NOT NULL DEFAULT txid_current()
);
CREATE INDEX IF NOT EXISTS hourly_employee_timelogs_checked_checked_at ON hourly_employee_timelogs_checked (checked_at);
CREATE INDEX IF NOT EXISTS hourly_employee_timelogs_checked_transaction_id ON hourly_employee_timelogs_checked (transaction_id);
CREATE TABLE IF NOT EXISTS hourly_timelogs_checked (
id SERIAL PRIMARY KEY,
timelog_id INTEGER NOT NULL UNIQUE,
checked_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
transaction_id BIGINT NOT NULL DEFAULT txid_current()
);
CREATE INDEX IF NOT EXISTS hourly_timelogs_checked_checked_at ON hourly_timelogs_checked (checked_at);
CREATE INDEX IF NOT EXISTS hourly_timelogs_checked_transaction_id ON hourly_timelogs_checked (transaction_id);
CREATE TABLE IF NOT EXISTS storage_usage (
id SERIAL PRIMARY KEY,
checked_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
client_asset_fqdn TEXT NOT NULL,
storage_asset_fqdn TEXT NOT NULL,
storage_asset_path TEXT NOT NULL,
mb_used INTEGER NOT NULL
);
CREATE INDEX IF NOT EXISTS storage_usage_checked_at ON storage_usage (checked_at);
CREATE INDEX IF NOT EXISTS storage_usage_client_asset_fqdn ON storage_usage (client_asset_fqdn);
CREATE INDEX IF NOT EXISTS storage_usage_storage_asset_fqdn ON storage_usage (storage_asset_fqdn);
CREATE INDEX IF NOT EXISTS storage_usage_storage_asset_path ON storage_usage (storage_asset_path);
CREATE INDEX IF NOT EXISTS storage_usage_uniq_combo ON storage_usage (client_asset_fqdn, storage_asset_fqdn, storage_asset_path);
CREATE TABLE IF NOT EXISTS pipeline_salt_cmd_history (
id SERIAL PRIMARY KEY,
created_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
target TEXT NOT NULL,
pipeline_id TEXT,
pipeline_url TEXT NOT NULL,
pipeline_status TEXT,
project TEXT NOT NULL,
timeout TEXT NOT NULL,
cmd TEXT NOT NULL
);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_created_at ON pipeline_salt_cmd_history (created_at);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_target ON pipeline_salt_cmd_history (target);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_pipeline_id ON pipeline_salt_cmd_history (pipeline_id);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_pipeline_status ON pipeline_salt_cmd_history (pipeline_status);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_project ON pipeline_salt_cmd_history (project);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_cmd ON pipeline_salt_cmd_history (cmd);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_target_cmd_combo ON pipeline_salt_cmd_history (target, cmd);
CREATE TABLE IF NOT EXISTS pipeline_rsnapshot_backup_history (
id SERIAL PRIMARY KEY,
created_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
target TEXT NOT NULL,
pipeline_id TEXT,
pipeline_url TEXT NOT NULL,
pipeline_status TEXT,
project TEXT NOT NULL,
timeout TEXT NOT NULL,
rsnapshot_backup_type TEXT NOT NULL,
ssh_host TEXT,
ssh_port TEXT,
ssh_jump TEXT
);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_created_at ON pipeline_salt_cmd_history (created_at);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_target ON pipeline_salt_cmd_history (target);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_pipeline_id ON pipeline_salt_cmd_history (pipeline_id);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_pipeline_status ON pipeline_salt_cmd_history (pipeline_status);
CREATE INDEX IF NOT EXISTS pipeline_salt_cmd_history_project ON pipeline_salt_cmd_history (project);
CREATE TABLE IF NOT EXISTS jobs_log (
id SERIAL PRIMARY KEY,
created_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
jobs_script_run_at TIMESTAMP WITHOUT TIME ZONE NOT NULL,
client TEXT NOT NULL,
asset_fqdn TEXT NOT NULL,
job_id TEXT NOT NULL,
job_level TEXT NOT NULL,
job_type TEXT NOT NULL,
job_cmd TEXT NOT NULL,
job_timeout TEXT NOT NULL,
job_tz TEXT NOT NULL
);
CREATE INDEX IF NOT EXISTS jobs_log_created_at ON jobs_log (created_at);
CREATE INDEX IF NOT EXISTS jobs_log_jobs_script_run_at ON jobs_log (jobs_script_run_at);
CREATE INDEX IF NOT EXISTS jobs_log_asset_fqdn ON jobs_log (asset_fqdn);
CREATE INDEX IF NOT EXISTS jobs_log_client ON jobs_log (client);
CREATE INDEX IF NOT EXISTS jobs_log_job_id ON jobs_log (job_id);
CREATE INDEX IF NOT EXISTS jobs_log_asset_fqdn_client_job_id_combo ON jobs_log (asset_fqdn, client, job_id);
CREATE TABLE IF NOT EXISTS asset_count (
id SERIAL PRIMARY KEY,
counted_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
client TEXT NOT NULL,
kind TEXT NOT NULL,
asset_count INTEGER NOT NULL
);
CREATE INDEX IF NOT EXISTS asset_count_counted_at ON asset_count (counted_at);
CREATE INDEX IF NOT EXISTS asset_count_client ON asset_count (client);
CREATE INDEX IF NOT EXISTS asset_count_kind ON asset_count (kind);
CREATE INDEX IF NOT EXISTS asset_count_counted_at_client_kind_combo ON asset_count (counted_at, client, kind);
CREATE TABLE IF NOT EXISTS timelogs_stats (
id SERIAL PRIMARY KEY,
counted_at TIMESTAMP WITHOUT TIME ZONE NOT NULL DEFAULT now(),
hours_sum NUMERIC NOT NULL
);
CREATE INDEX IF NOT EXISTS timelogs_stats_counted_at ON timelogs_stats (counted_at);