Add user access/category tables, split index creation to after load
This commit is contained in:
parent
181e850225
commit
7c3b9d222e
@ -4,26 +4,21 @@
|
|||||||
-- To store building outlines.
|
-- To store building outlines.
|
||||||
-- Geometries form the backbone, expected to be provided from other sources.
|
-- Geometries form the backbone, expected to be provided from other sources.
|
||||||
CREATE TABLE geometries (
|
CREATE TABLE geometries (
|
||||||
-- integer for internal unique id
|
-- internal unique id
|
||||||
-- may consider guid for global uniqueness
|
|
||||||
geometry_id serial PRIMARY KEY,
|
geometry_id serial PRIMARY KEY,
|
||||||
-- jsonb document for all data, source ID, attributes
|
-- cross-reference to data source id
|
||||||
geometry_doc jsonb,
|
source_id varchar(30),
|
||||||
-- geometry as EPSG:3857 avoiding reprojection for tiles
|
-- geometry as EPSG:3857 avoiding reprojection for tiles
|
||||||
geometry_geom geometry(POLYGON, 3857)
|
geometry_geom geometry(POLYGON, 3857)
|
||||||
);
|
);
|
||||||
|
|
||||||
-- Spatial index over building outlines
|
|
||||||
CREATE INDEX geometries_idx ON geometries USING GIST ( geometry_geom );
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Buildings table
|
-- Buildings table
|
||||||
--
|
--
|
||||||
-- To store collected data.
|
-- To store collected data.
|
||||||
-- This is the core dataset to be collected by the application.
|
-- This is the core dataset to be collected by the application.
|
||||||
CREATE TABLE buildings (
|
CREATE TABLE buildings (
|
||||||
-- integer for internal unique id
|
-- internal unique id
|
||||||
-- may consider guid for global uniqueness
|
|
||||||
building_id serial PRIMARY KEY,
|
building_id serial PRIMARY KEY,
|
||||||
-- jsonb document for all data, attributes to be specified in application
|
-- jsonb document for all data, attributes to be specified in application
|
||||||
building_doc jsonb,
|
building_doc jsonb,
|
||||||
@ -31,8 +26,27 @@ CREATE TABLE buildings (
|
|||||||
geometry_id integer REFERENCES geometries
|
geometry_id integer REFERENCES geometries
|
||||||
);
|
);
|
||||||
|
|
||||||
-- Index over building geometry (expect to look up building by geometry_id)
|
--
|
||||||
CREATE INDEX building_geometry_idx ON buildings ( geometry_id );
|
-- User categories
|
||||||
|
--
|
||||||
|
-- Self-selected, optional categories
|
||||||
|
CREATE TABLE user_categories (
|
||||||
|
category_id serial PRIMARY KEY,
|
||||||
|
-- category name/short description
|
||||||
|
category varchar(60)
|
||||||
|
);
|
||||||
|
INSERT INTO user_categories ( category_id, category ) VALUES ( 1, 'Not provided');
|
||||||
|
|
||||||
|
--
|
||||||
|
-- User access levels
|
||||||
|
--
|
||||||
|
-- If necessary for moderation
|
||||||
|
CREATE TABLE user_access_levels (
|
||||||
|
access_level_id serial PRIMARY KEY,
|
||||||
|
-- name/short description
|
||||||
|
access_level varchar(60)
|
||||||
|
);
|
||||||
|
INSERT INTO user_access_levels ( access_level_id, access_level ) VALUES ( 1, 'untrusted');
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Users table
|
-- Users table
|
||||||
@ -40,7 +54,7 @@ CREATE INDEX building_geometry_idx ON buildings ( geometry_id );
|
|||||||
-- Minimal user data to support login and edit history
|
-- Minimal user data to support login and edit history
|
||||||
CREATE TABLE users (
|
CREATE TABLE users (
|
||||||
-- internal unique id
|
-- internal unique id
|
||||||
user_id uuid PRIMARY KEY,
|
user_id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
||||||
-- username for login (required)
|
-- username for login (required)
|
||||||
username varchar(30) UNIQUE NOT NULL,
|
username varchar(30) UNIQUE NOT NULL,
|
||||||
-- email address for password reset (optional)
|
-- email address for password reset (optional)
|
||||||
@ -48,7 +62,11 @@ CREATE TABLE users (
|
|||||||
-- password - as generated from hash(salt+password) via pgcrypto
|
-- password - as generated from hash(salt+password) via pgcrypto
|
||||||
pass varchar(60),
|
pass varchar(60),
|
||||||
-- date registered
|
-- date registered
|
||||||
registered timestamp default NOW()
|
registered timestamp default NOW(),
|
||||||
|
-- user category (optional, self-selected)
|
||||||
|
category integer REFERENCES user_categories NOT NULL DEFAULT 1,
|
||||||
|
-- user access level (essential, default untrusted)
|
||||||
|
access_level integer REFERENCES user_access_levels NOT NULL DEFAULT 1
|
||||||
);
|
);
|
||||||
|
|
||||||
CREATE INDEX user_username_idx ON users ( username );
|
CREATE INDEX user_username_idx ON users ( username );
|
||||||
@ -77,8 +95,9 @@ CREATE TABLE log (
|
|||||||
-- default timestamp to time now
|
-- default timestamp to time now
|
||||||
log_timestamp TIMESTAMP default NOW(),
|
log_timestamp TIMESTAMP default NOW(),
|
||||||
-- log document to be extended in application
|
-- log document to be extended in application
|
||||||
-- log change diff (CREATE/UPDATE/DELETE)
|
-- log from..to; only changed values (aim to be reversible)
|
||||||
log_doc jsonb,
|
log_from jsonb,
|
||||||
|
log_to jsonb,
|
||||||
-- log user id
|
-- log user id
|
||||||
user_id uuid REFERENCES users,
|
user_id uuid REFERENCES users,
|
||||||
-- log building id
|
-- log building id
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
-- Drop all tables
|
-- Drop all tables
|
||||||
DROP TABLE IF EXISTS log;
|
DROP TABLE IF EXISTS log;
|
||||||
DROP TABLE IF EXISTS user_sessions;
|
|
||||||
DROP TABLE IF EXISTS users;
|
DROP TABLE IF EXISTS users;
|
||||||
|
DROP TABLE IF EXISTS user_sessions;
|
||||||
|
DROP TABLE IF EXISTS user_categories;
|
||||||
|
DROP TABLE IF EXISTS user_access_levels;
|
||||||
DROP TABLE IF EXISTS buildings;
|
DROP TABLE IF EXISTS buildings;
|
||||||
DROP TABLE IF EXISTS geometries;
|
DROP TABLE IF EXISTS geometries;
|
||||||
|
7
migrations/002.index-core.up.sql
Normal file
7
migrations/002.index-core.up.sql
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
|
||||||
|
|
||||||
|
-- Spatial index over building outlines
|
||||||
|
CREATE INDEX geometries_idx ON geometries USING GIST ( geometry_geom );
|
||||||
|
|
||||||
|
-- Index over building geometry (expect to look up building by geometry_id)
|
||||||
|
CREATE INDEX building_geometry_idx ON buildings ( geometry_id );
|
Loading…
Reference in New Issue
Block a user