-
Notifications
You must be signed in to change notification settings - Fork 37
/
Copy pathuserdata.sql
94 lines (83 loc) · 2.56 KB
/
userdata.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
-- All the tables for user data
DROP TABLE IF EXISTS users CASCADE;
DROP TABLE IF EXISTS petition CASCADE;
DROP TABLE IF EXISTS signatory CASCADE;
DROP TABLE IF EXISTS responses CASCADE;
DROP TABLE IF EXISTS messages CASCADE;
DROP TABLE IF EXISTS contacts CASCADE;
CREATE TABLE users(
id serial primary key,
password varchar(256),
prefix varchar(5),
lname varchar(30),
fname varchar(30),
email varchar(320) UNIQUE, -- max allowed email length.
addr1 varchar(64),
addr2 varchar(64),
city varchar(64),
state varchar(2) references state,
zip5 varchar(5),
zip4 varchar(4),
phone varchar(15),
verified boolean default false -- done verified activity at least once
);
CREATE TABLE petition(
id varchar(256) primary key,
title text,
description text,
owner_id int references users,
created timestamp,
deleted timestamp,
published timestamp, -- null for drafts; same as created if published
last_modified timestamp default now(),
to_congress boolean
);
CREATE TABLE signatory(
id serial primary key,
user_id int references users,
petition_id varchar(256) references petition,
share_with char(1), -- E=everybody, A=author of petition, N=nobody
comment text,
signed timestamp default now(),
deleted timestamp,
referrer int references users,
UNIQUE (user_id, petition_id)
);
-- store all the msgs sent to reps/senators whether they are from petition signs or wyr
CREATE TABLE messages(
id serial primary key,
from_id int references users,
to_id varchar(256) references politician,
subject text,
body text,
source_id varchar(15), -- s<signid> or 'wyr'
sent boolean,
written timestamp default now()
);
CREATE TABLE responses(
id serial primary key,
msg_id int references messages,
response text,
category char(1), --S=support, O=oppose, U=undecided, N=No answer
received timestamp
);
-- save contacts imported from yahoo, google etc.,
-- emails can be 64+1+255 char
CREATE TABLE contacts(
user_id int references users,
uemail VARCHAR(320),
cemail VARCHAR(320),
cname VARCHAR(80),
provider VARCHAR(20),
UNIQUE(user_id, uemail, cemail)
);
GRANT ALL ON users TO watchdog;
GRANT ALL ON users_id_seq TO watchdog;
GRANT ALL ON petition TO watchdog;
GRANT ALL ON signatory TO watchdog;
GRANT ALL ON signatory_id_seq TO watchdog;
GRANT ALL ON contacts TO watchdog;
GRANT ALL ON messages TO watchdog;
GRANT ALL ON messages_id_seq TO watchdog;
GRANT ALL ON responses TO watchdog;
GRANT ALL ON responses_id_seq TO watchdog;