-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy path0000-init.sql
124 lines (109 loc) · 3.24 KB
/
0000-init.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
CREATE TABLE uptimes (
id BIGSERIAL NOT NULL,
identity TEXT NOT NULL,
status TEXT CHECK (status IN ('UP', 'DOWN')) NOT NULL,
epoch NUMERIC NOT NULL,
start_at TIMESTAMP WITH TIME ZONE NOT NULL,
end_at TIMESTAMP WITH TIME ZONE NOT NULL,
PRIMARY KEY(id)
);
CREATE INDEX uptime_identity_end_at ON uptimes (identity, end_at);
CREATE INDEX uptime_identity ON uptimes (identity);
CREATE TABLE commissions (
id BIGSERIAL NOT NULL,
identity TEXT NOT NULL,
commission INTEGER NOT NULL,
epoch_slot NUMERIC NOT NULL,
epoch NUMERIC NOT NULL,
created_at TIMESTAMP WITH TIME ZONE NOT NULL,
PRIMARY KEY(id)
);
CREATE INDEX commission_changes_identity_created_at ON commissions (identity, created_at);
CREATE TABLE mev (
id BIGSERIAL NOT NULL,
vote_account TEXT NOT NULL,
mev_commission INTEGER NOT NULL,
total_epoch_rewards NUMERIC,
claimed_epoch_rewards NUMERIC,
total_epoch_claimants INTEGER,
epoch_active_claimants INTEGER,
epoch_slot NUMERIC NOT NULL,
epoch NUMERIC NOT NULL,
created_at TIMESTAMP WITH TIME ZONE NOT NULL,
PRIMARY KEY(id)
)
CREATE TABLE versions (
id BIGSERIAL NOT NULL,
identity TEXT NOT NULL,
version TEXT,
epoch_slot NUMERIC NOT NULL,
epoch NUMERIC NOT NULL,
created_at TIMESTAMP WITH TIME ZONE NOT NULL,
PRIMARY KEY(id)
);
CREATE INDEX version_changes_identity_created_at ON versions (identity, created_at);
CREATE TABLE validators (
identity TEXT NOT NULL,
vote_account TEXT NOT NULL,
epoch NUMERIC NOT NULL,
info_name TEXT NULL,
info_url TEXT NULL,
info_keybase TEXT NULL,
node_ip TEXT NULL,
dc_coordinates_lat DOUBLE PRECISION NULL,
dc_coordinates_lon DOUBLE PRECISION NULL,
dc_continent TEXT NULL,
dc_country_iso TEXT NULL,
dc_country TEXT NULL,
dc_city TEXT NULL,
dc_asn INTEGER NULL,
dc_aso TEXT NULL,
commission_max_observed INTEGER NULL,
commission_min_observed INTEGER NULL,
commission_advertised INTEGER NULL,
commission_effective INTEGER NULL,
version TEXT NULL,
mnde_votes NUMERIC NULL,
activated_stake NUMERIC NOT NULL,
marinade_stake NUMERIC NOT NULL,
decentralizer_stake NUMERIC NOT NULL,
superminority BOOLEAN NOT NULL,
stake_to_become_superminority NUMERIC NOT NULL,
credits NUMERIC NOT NULL,
leader_slots NUMERIC NOT NULL,
blocks_produced NUMERIC NOT NULL,
skip_rate DOUBLE PRECISION NOT NULL,
uptime_pct DOUBLE PRECISION NULL,
uptime NUMERIC NULL,
downtime NUMERIC NULL,
updated_at TIMESTAMP WITH TIME ZONE NOT NULL,
PRIMARY KEY(identity, epoch)
);
CREATE TABLE cluster_info (
id BIGSERIAL NOT NULL,
epoch_slot NUMERIC NOT NULL,
epoch NUMERIC NOT NULL,
transaction_count NUMERIC NOT NULL,
created_at TIMESTAMP WITH TIME ZONE NOT NULL,
PRIMARY KEY(id)
);
CREATE TABLE epochs (
epoch NUMERIC NOT NULL,
start_at TIMESTAMP WITH TIME ZONE NOT NULL,
end_at TIMESTAMP WITH TIME ZONE NOT NULL,
transaction_count NUMERIC NOT NULL,
supply NUMERIC NOT NULL,
inflation DOUBLE PRECISION NOT NULL,
inflation_taper DOUBLE PRECISION NOT NULL,
PRIMARY KEY(epoch)
);
CREATE TABLE warnings (
id BIGSERIAL NOT NULL,
identity TEXT NOT NULL,
code TEXT NOT NULL,
message TEXT NOT NULL,
details TEXT,
created_at TIMESTAMP WITH TIME ZONE NOT NULL,
PRIMARY KEY(id)
);
CREATE INDEX warnings_identity ON warnings (identity);