-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinit.sql
165 lines (143 loc) · 5.85 KB
/
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
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
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
CREATE EXTENSION IF NOT EXISTS postgis;
DROP SCHEMA IF EXISTS tiger CASCADE;
DROP SCHEMA IF EXISTS tiger_data CASCADE;
DROP SCHEMA IF EXISTS topology CASCADE;
SET TIME ZONE 'America/Denver';
-- users
DROP TYPE IF EXISTS roles CASCADE;
CREATE TYPE roles as ENUM('admin', 'reporter', 'agency', 'contractor');
DROP TYPE IF EXISTS auth_providers CASCADE;
CREATE TYPE auth_providers as ENUM('utahid', 'google', 'facebook');
DROP TYPE IF EXISTS org_types CASCADE;
CREATE TYPE org_types as ENUM('agency', 'contractor');
DROP TABLE IF EXISTS notification_areas CASCADE;
CREATE TABLE notification_areas
(
id serial PRIMARY KEY,
geog geography(POLYGON, 4326) NOT NULL
);
DROP TABLE IF EXISTS organizations CASCADE;
CREATE TABLE organizations
(
id serial PRIMARY KEY,
name varchar(128) NOT NULL,
org_type org_types
);
DROP TABLE IF EXISTS users CASCADE;
CREATE TABLE users
(
id serial PRIMARY KEY,
organization_id integer REFERENCES organizations (id),
role roles NOT NULL,
approved boolean,
auth_provider auth_providers NOT NULL,
auth_id varchar(64) NOT NULL,
email varchar(256) NOT NULL,
first_name varchar(25) NOT NULL,
last_name varchar(25) NOT NULL,
registered_date timestamptz NOT NULL,
last_logged_in timestamptz NOT NULL,
phone varchar(25) NOT NULL,
approved_date timestamptz
);
DROP TABLE IF EXISTS users_have_notification_areas CASCADE;
CREATE TABLE users_have_notification_areas
(
user_id integer NOT NULL REFERENCES users (id),
area_id integer NOT NULL REFERENCES notification_areas (id)
);
-- species
DROP TABLE IF EXISTS species CASCADE;
DROP TYPE IF EXISTS species_types CASCADE;
CREATE TYPE species_types as ENUM('domestic', 'wild', 'unknown');
DROP TYPE IF EXISTS species_classes CASCADE;
CREATE TYPE species_classes as ENUM('amphibians', 'birds', 'mammals', 'reptiles', 'unknown');
DROP TYPE IF EXISTS species_orders CASCADE;
CREATE TYPE species_orders as ENUM('carnivores', 'hoofed animals', 'rabbits/hares', 'rodents', 'upland birds', 'vultures', 'unknown');
DROP TYPE IF EXISTS species_families CASCADE;
CREATE TYPE species_families as ENUM('antelope', 'bears', 'beavers', 'bison', 'cats', 'cows', 'deer', 'dogs', 'frogs/toads', 'goats', 'grouse', 'horses', 'lizards', 'partridge', 'pheasant', 'porcupines', 'prairie dogs', 'ptarmingans', 'quail', 'rabbits & hares', 'raccoons', 'sheep', 'skunks', 'snakes', 'turtle/tortoise', 'vultures', 'weasels', 'unknown');
CREATE TABLE species
(
species_id serial PRIMARY KEY,
common_name varchar(128) NOT NULL,
scientific_name varchar(128) NOT NULL,
species_type species_types NOT NULL,
species_class species_classes NOT NULL,
species_order species_orders,
family species_families NOT NULL,
rare boolean NOT NULL DEFAULT false,
frequent boolean NOT NULL DEFAULT false
);
-- routes
DROP TABLE IF EXISTS routes CASCADE;
CREATE TABLE routes
(
route_id serial PRIMARY KEY,
user_id integer NOT NULL REFERENCES users (id),
geog geography(LINESTRING, 4326) NOT NULL,
start_time timestamptz NOT NULL CHECK (start_time <= CURRENT_TIMESTAMP + interval '1 minute'),
end_time timestamptz NOT NULL CHECK (end_time <= CURRENT_TIMESTAMP + interval '1 minute'),
submit_date timestamptz NOT NULL CHECK (submit_date <= CURRENT_TIMESTAMP + interval '1 minute')
);
-- reports
DROP TABLE IF EXISTS photos CASCADE;
CREATE TABLE photos
(
id serial PRIMARY KEY,
bucket_path varchar(256) NOT NULL,
photo_location geography(POINT, 4326),
photo_date timestamptz CHECK (photo_date <= CURRENT_TIMESTAMP + interval '1 minute')
);
DROP TYPE IF EXISTS confidence_levels CASCADE;
CREATE TYPE confidence_levels AS ENUM ('high', 'medium', 'low');
DROP TYPE IF EXISTS genders CASCADE;
CREATE TYPE genders AS ENUM ('male', 'female', 'unknown');
DROP TYPE IF EXISTS age_classes CASCADE;
CREATE TYPE age_classes AS ENUM ('adult', 'juvenile', 'unknown');
DROP TABLE IF EXISTS report_infos CASCADE;
CREATE TABLE report_infos
(
report_id serial PRIMARY KEY,
user_id integer NOT NULL REFERENCES users (id),
animal_location geography(POINT, 4326) NOT NULL,
photo_id integer REFERENCES photos (id),
submit_location geography(POINT, 4326) NOT NULL,
submit_date timestamptz NOT NULL CHECK (submit_date <= CURRENT_TIMESTAMP + interval '1 minute'),
species_id integer REFERENCES species (species_id),
common_name varchar(128) NOT NULL,
scientific_name varchar(128) NOT NULL,
species_type species_types NOT NULL,
species_class species_classes NOT NULL,
species_order species_orders,
family species_families NOT NULL,
species_confidence_level confidence_levels,
sex genders,
age_class age_classes,
comments varchar(512)
);
DROP TABLE IF EXISTS public_reports CASCADE;
CREATE TABLE public_reports
(
report_id integer NOT NULL REFERENCES report_infos (report_id),
repeat_submission bool NOT NULL DEFAULT false,
discovery_date timestamptz NOT NULL CHECK (discovery_date <= CURRENT_TIMESTAMP + interval '1 minute')
);
DROP TABLE IF EXISTS pickup_reports CASCADE;
CREATE TABLE pickup_reports
(
report_id integer NOT NULL REFERENCES report_infos (report_id),
pickup_date timestamptz NOT NULL CHECK (pickup_date <= CURRENT_TIMESTAMP + interval '1 minute'),
route_id integer REFERENCES routes (route_id)
);
-- roles
GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO "admin";
GRANT USAGE, SELECT ON ALL SEQUENCES IN SCHEMA public TO "admin";
GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA public TO "admin";
GRANT SELECT, INSERT, UPDATE, DELETE, REFERENCES ON ALL TABLES IN SCHEMA public TO "api";
GRANT USAGE, SELECT ON ALL SEQUENCES IN SCHEMA public TO "api";
GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA public TO "api";
GRANT SELECT, INSERT, UPDATE, DELETE, REFERENCES ON ALL TABLES IN SCHEMA public TO "editor";
GRANT USAGE, SELECT ON ALL SEQUENCES IN SCHEMA public TO "editor";
GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA public TO "editor";
GRANT SELECT ON ALL TABLES IN SCHEMA public TO "viewer";
GRANT SELECT ON ALL SEQUENCES IN SCHEMA public TO "viewer";