]> WPIA git - motion.git/blob - sql/schema.sql
add: adjust user handling per host
[motion.git] / sql / schema.sql
1 DROP TABLE IF EXISTS voter;
2 CREATE TABLE voter (id serial NOT NULL,
3                    email VARCHAR(255) NOT NULL,
4                    host VARCHAR(500) NOT NULL,
5                    PRIMARY KEY(id));
6
7
8 DROP TABLE IF EXISTS motion;
9 CREATE TABLE motion (id serial NOT NULL,
10                    identifier VARCHAR(20) NOT NULL,
11                    name VARCHAR(250) NOT NULL,
12                    type VARCHAR(250) NOT NULL,
13                    host VARCHAR(500) NOT NULL,
14                    content text NOT NULL,
15                    posed timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
16                    posed_by int NOT NULL,
17                    deadline timestamp NOT NULL DEFAULT (CURRENT_TIMESTAMP + interval '3 days'),
18                    canceled timestamp NULL DEFAULT NULL,
19                    cancelation_reason text NULL DEFAULT NULL,
20                    canceled_by int NULL DEFAULT NULL,
21                    PRIMARY KEY(id));
22 CREATE UNIQUE INDEX motion_ident ON motion (identifier);
23
24 DROP TABLE IF EXISTS vote;
25 DROP TYPE IF EXISTS "vote_type";
26 CREATE TYPE "vote_type" AS ENUM ('yes', 'no', 'abstain');
27 CREATE TABLE vote (motion_id INTEGER NOT NULL,
28                  voter_id INTEGER NOT NULL,
29                  result vote_type NOT NULL,
30                  entered timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
31                  proxy_id INTEGER NOT NULL,
32                  PRIMARY KEY(motion_id, voter_id));
33
34 DROP TABLE IF EXISTS proxy;
35 CREATE TABLE proxy (id serial NOT NULL,
36                    voter_id INTEGER NOT NULL,
37                    proxy_id INTEGER NOT NULL,
38                    granted timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
39                    granted_by int NOT NULL,
40                    revoked timestamp NULL DEFAULT NULL,
41                    revoked_by int NULL DEFAULT NULL,
42                    PRIMARY KEY(id));
43 CREATE INDEX proxy_voter ON proxy (voter_id);
44 CREATE INDEX proxy_proxy ON proxy (proxy_id);
45
46 DROP TABLE IF EXISTS schema_version;
47 CREATE TABLE schema_version (version INTEGER NOT NULL);
48 INSERT INTO schema_version(version) VALUES(6);