2020-02-17 09:49:04 +01:00
|
|
|
CREATE TABLE profile (
|
2016-11-20 20:04:52 +01:00
|
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
|
|
|
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
2020-01-14 13:13:10 +01:00
|
|
|
deleted_at timestamptz NULL,
|
2016-11-20 20:04:52 +01:00
|
|
|
|
|
|
|
fullname text NOT NULL DEFAULT '',
|
2020-05-22 13:48:21 +02:00
|
|
|
|
2016-11-20 20:04:52 +01:00
|
|
|
email text NOT NULL,
|
2020-05-22 13:48:21 +02:00
|
|
|
pending_email text NULL,
|
|
|
|
|
2016-11-20 20:04:52 +01:00
|
|
|
photo text NOT NULL,
|
|
|
|
password text NOT NULL,
|
2019-12-09 16:27:01 +01:00
|
|
|
|
2020-01-14 13:13:10 +01:00
|
|
|
lang text NULL,
|
2020-04-08 11:57:29 +03:00
|
|
|
theme text NULL,
|
2020-01-14 13:13:10 +01:00
|
|
|
is_demo boolean NOT NULL DEFAULT false
|
2016-11-20 20:04:52 +01:00
|
|
|
);
|
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
CREATE UNIQUE INDEX profile__email__idx
|
|
|
|
ON profile (email)
|
2020-01-23 17:50:00 +01:00
|
|
|
WHERE deleted_at IS null;
|
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
CREATE INDEX profile__is_demo
|
|
|
|
ON profile (is_demo)
|
2020-01-23 17:50:00 +01:00
|
|
|
WHERE deleted_at IS null
|
|
|
|
AND is_demo IS true;
|
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
INSERT INTO profile (id, fullname, email, photo, password)
|
|
|
|
VALUES ('00000000-0000-0000-0000-000000000000'::uuid,
|
|
|
|
'System Profile',
|
|
|
|
'system@uxbox.io',
|
|
|
|
'',
|
|
|
|
'!');
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CREATE TABLE team (
|
|
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
2019-12-01 16:48:41 +01:00
|
|
|
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
2020-02-17 09:49:04 +01:00
|
|
|
deleted_at timestamptz NULL,
|
2019-12-01 16:48:41 +01:00
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
name text NOT NULL,
|
|
|
|
photo text NOT NULL,
|
2019-12-01 16:48:41 +01:00
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
is_default boolean NOT NULL DEFAULT false
|
2019-12-01 16:48:41 +01:00
|
|
|
);
|
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
CREATE TRIGGER team__modified_at__tgr
|
|
|
|
BEFORE UPDATE ON team
|
|
|
|
FOR EACH ROW EXECUTE PROCEDURE update_modified_at();
|
|
|
|
|
2020-02-24 10:57:32 +01:00
|
|
|
INSERT INTO team (id, name, photo, is_default)
|
|
|
|
VALUES ('00000000-0000-0000-0000-000000000000'::uuid,
|
|
|
|
'System Team',
|
|
|
|
'',
|
|
|
|
true);
|
|
|
|
|
2020-01-23 17:50:00 +01:00
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
|
|
|
|
CREATE TABLE team_profile_rel (
|
|
|
|
team_id uuid NOT NULL REFERENCES team(id) ON DELETE CASCADE,
|
|
|
|
profile_id uuid NOT NULL REFERENCES profile(id) ON DELETE RESTRICT,
|
2019-12-01 16:48:41 +01:00
|
|
|
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
2020-02-17 09:49:04 +01:00
|
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
2019-12-01 16:48:41 +01:00
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
is_admin boolean DEFAULT false,
|
|
|
|
is_owner boolean DEFAULT false,
|
|
|
|
can_edit boolean DEFAULT false,
|
|
|
|
|
|
|
|
PRIMARY KEY (team_id, profile_id)
|
2019-12-01 16:48:41 +01:00
|
|
|
);
|
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
COMMENT ON TABLE team_profile_rel
|
|
|
|
IS 'Relation between teams and profiles (NM)';
|
2020-01-23 17:50:00 +01:00
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
CREATE TRIGGER team_profile_rel__modified_at__tgr
|
|
|
|
BEFORE UPDATE ON team_profile_rel
|
|
|
|
FOR EACH ROW EXECUTE PROCEDURE update_modified_at();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CREATE TABLE profile_attr (
|
|
|
|
profile_id uuid NOT NULL REFERENCES profile(id) ON DELETE CASCADE,
|
2019-11-18 11:52:57 +01:00
|
|
|
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
key text NOT NULL,
|
|
|
|
val bytea NOT NULL,
|
|
|
|
|
|
|
|
PRIMARY KEY (key, profile_id)
|
2019-11-18 11:52:57 +01:00
|
|
|
);
|
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
CREATE INDEX profile_attr__profile_id__idx
|
|
|
|
ON profile_attr(profile_id);
|
2020-01-23 17:50:00 +01:00
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
CREATE TRIGGER profile_attr__modified_at__tgr
|
|
|
|
BEFORE UPDATE ON profile_attr
|
|
|
|
FOR EACH ROW EXECUTE PROCEDURE update_modified_at();
|
2019-12-01 16:48:41 +01:00
|
|
|
|
2016-11-20 20:04:52 +01:00
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
CREATE TABLE session (
|
|
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
|
|
|
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
|
|
|
|
profile_id uuid REFERENCES profile(id) ON DELETE CASCADE,
|
|
|
|
user_agent text NULL
|
|
|
|
);
|
2016-11-20 20:04:52 +01:00
|
|
|
|
2020-02-17 09:49:04 +01:00
|
|
|
CREATE INDEX session__profile_id__idx
|
|
|
|
ON session(profile_id);
|