2022-12-14 23:48:00 +11:00
|
|
|
-- Note database created is ephemeral and use for migra to diff only.
|
|
|
|
-- Never put data in it, or it will be lost.
|
|
|
|
DROP DATABASE IF EXISTS blast_schemaonly;
|
|
|
|
CREATE DATABASE blast_schemaonly;
|
|
|
|
|
|
|
|
\c blast_schemaonly
|
|
|
|
|
|
|
|
CREATE TABLE listeners (
|
|
|
|
listener UUID NOT NULL PRIMARY KEY,
|
|
|
|
last_seen TIMESTAMP WITH TIME ZONE
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE TABLE sessions (
|
|
|
|
session UUID NOT NULL PRIMARY KEY,
|
|
|
|
listener UUID NOT NULL,
|
|
|
|
details JSONB NOT NULL
|
|
|
|
);
|
|
|
|
CREATE INDEX session_by_listener ON sessions(listener);
|
|
|
|
|
2023-01-23 22:52:01 +11:00
|
|
|
CREATE SEQUENCE item_seq;
|
|
|
|
|
2022-12-14 23:48:00 +11:00
|
|
|
CREATE TABLE items (
|
2022-12-26 01:30:59 +11:00
|
|
|
item_id BIGSERIAL NOT NULL PRIMARY KEY,
|
|
|
|
details JSONB NOT NULL
|
2022-12-14 23:48:00 +11:00
|
|
|
);
|
2022-12-27 20:16:35 +11:00
|
|
|
CREATE UNIQUE INDEX item_index ON items ((details->>'item_type'), (details->>'item_code'));
|
2022-12-26 01:30:59 +11:00
|
|
|
CREATE INDEX item_by_loc ON items ((details->>'location'));
|
|
|
|
CREATE INDEX item_by_static ON items ((cast(details->>'is_static' as boolean)));
|
2022-12-30 00:41:46 +11:00
|
|
|
CREATE INDEX item_by_display ON items (lower(details->>'display'));
|
2023-06-07 22:38:46 +10:00
|
|
|
CREATE INDEX item_by_owner ON items (lower(details->>'owner'));
|
2022-12-30 00:41:46 +11:00
|
|
|
CREATE INDEX item_by_display_less_explicit ON items (lower(details->>'display_less_explicit'));
|
2023-04-08 23:51:18 +10:00
|
|
|
CREATE UNIQUE INDEX item_dynamic_entrance ON items (
|
|
|
|
(details->'dynamic_entrance'->>'source_item'),
|
|
|
|
(LOWER(details->'dynamic_entrance'->>'direction')));
|
2022-12-30 00:41:46 +11:00
|
|
|
|
2022-12-14 23:48:00 +11:00
|
|
|
CREATE TABLE users (
|
2022-12-27 00:20:09 +11:00
|
|
|
-- Username here is all lower case, but details has correct case version.
|
2022-12-14 23:48:00 +11:00
|
|
|
username TEXT NOT NULL PRIMARY KEY,
|
|
|
|
current_session UUID REFERENCES sessions(session),
|
|
|
|
current_listener UUID REFERENCES listeners(listener),
|
|
|
|
details JSONB NOT NULL
|
|
|
|
);
|
|
|
|
CREATE INDEX user_by_listener ON users(current_listener);
|
2022-12-26 01:30:59 +11:00
|
|
|
CREATE INDEX user_by_session ON users(current_session);
|
2022-12-14 23:48:00 +11:00
|
|
|
|
|
|
|
CREATE UNLOGGED TABLE sendqueue (
|
2022-12-23 23:31:49 +11:00
|
|
|
item BIGSERIAL NOT NULL PRIMARY KEY,
|
2022-12-14 23:48:00 +11:00
|
|
|
session UUID NOT NULL REFERENCES sessions(session),
|
|
|
|
listener UUID REFERENCES listeners(listener),
|
2022-12-25 12:42:03 +11:00
|
|
|
message TEXT /* Nullable, null means disconnect */
|
2022-12-14 23:48:00 +11:00
|
|
|
);
|
|
|
|
|
|
|
|
CREATE TABLE tasks (
|
2022-12-26 01:30:59 +11:00
|
|
|
task_id BIGSERIAL NOT NULL PRIMARY KEY,
|
|
|
|
details JSONB NOT NULL
|
2022-12-14 23:48:00 +11:00
|
|
|
);
|
2022-12-26 01:30:59 +11:00
|
|
|
CREATE UNIQUE INDEX tasks_by_code_type ON tasks((details->>'task_code'), (details->>'task_type'));
|
|
|
|
CREATE INDEX tasks_by_static ON tasks((cast(details->>'is_static' as boolean)));
|
|
|
|
CREATE INDEX tasks_by_scheduled ON tasks((details->>'next_scheduled'));
|
2023-03-02 23:25:08 +11:00
|
|
|
|
|
|
|
CREATE TABLE corps (
|
|
|
|
corp_id BIGSERIAL NOT NULL PRIMARY KEY,
|
|
|
|
details JSONB NOT NULL
|
|
|
|
);
|
2023-03-19 00:04:59 +11:00
|
|
|
CREATE INDEX corp_by_name ON corps((LOWER(details->>'name')));
|
2023-03-02 23:25:08 +11:00
|
|
|
CREATE TABLE corp_membership (
|
|
|
|
corp_id BIGSERIAL NOT NULL REFERENCES corps(corp_id),
|
|
|
|
member_username TEXT NOT NULL REFERENCES users(username),
|
|
|
|
details JSONB NOT NULL,
|
|
|
|
PRIMARY KEY (corp_id, member_username)
|
|
|
|
);
|
2023-03-19 00:04:59 +11:00
|
|
|
CREATE INDEX corp_membership_by_username ON corp_membership(member_username);
|
2023-03-19 22:59:35 +11:00
|
|
|
CREATE INDEX corp_membership_by_invited ON corp_membership((details->>'invited_at'));
|
2023-03-02 23:25:08 +11:00
|
|
|
|
|
|
|
CREATE TABLE user_consent (
|
|
|
|
consenting_user TEXT NOT NULL REFERENCES users(username),
|
|
|
|
consented_user TEXT NOT NULL REFERENCES users(username),
|
2023-03-13 15:23:07 +11:00
|
|
|
consent_type TEXT NOT NULL,
|
2023-03-02 23:25:08 +11:00
|
|
|
details JSONB NOT NULL,
|
2023-03-13 15:23:07 +11:00
|
|
|
PRIMARY KEY (consenting_user, consented_user, consent_type)
|
2023-03-02 23:25:08 +11:00
|
|
|
);
|
|
|
|
CREATE INDEX user_consent_by_consented ON user_consent (consented_user);
|
2023-03-13 15:23:07 +11:00
|
|
|
CREATE INDEX user_consent_by_expires ON user_consent ((details->>'expires'));
|
2023-03-02 23:25:08 +11:00
|
|
|
|
|
|
|
CREATE TABLE corp_consent (
|
|
|
|
consenting_corp BIGINT NOT NULL REFERENCES corps(corp_id),
|
|
|
|
consented_corp BIGINT NOT NULL REFERENCES corps(corp_id),
|
2023-03-13 15:23:07 +11:00
|
|
|
consent_type TEXT NOT NULL,
|
2023-03-02 23:25:08 +11:00
|
|
|
details JSONB NOT NULL,
|
2023-03-13 15:23:07 +11:00
|
|
|
PRIMARY KEY (consenting_corp, consented_corp, consent_type)
|
2023-03-02 23:25:08 +11:00
|
|
|
);
|
|
|
|
CREATE INDEX corp_consent_by_consented ON corp_consent (consented_corp);
|
2023-03-13 15:23:07 +11:00
|
|
|
CREATE INDEX corp_consent_by_expires ON corp_consent ((details->>'expires'));
|