1 -- Roundcube Webmail update script for Postgres databases
2 -- Updates from version 0.1-stable to 0.1.1
4 CREATE INDEX cache_user_id_idx ON cache (user_id, cache_key);
5 CREATE INDEX contacts_user_id_idx ON contacts (user_id);
6 CREATE INDEX identities_user_id_idx ON identities (user_id);
8 CREATE INDEX users_username_id_idx ON users (username);
9 CREATE INDEX users_alias_id_idx ON users (alias);
11 -- added ON DELETE/UPDATE actions
12 ALTER TABLE messages DROP CONSTRAINT messages_user_id_fkey;
13 ALTER TABLE messages ADD FOREIGN KEY (user_id) REFERENCES users(user_id) ON DELETE CASCADE ON UPDATE CASCADE;
14 ALTER TABLE identities DROP CONSTRAINT identities_user_id_fkey;
15 ALTER TABLE identities ADD FOREIGN KEY (user_id) REFERENCES users(user_id) ON DELETE CASCADE ON UPDATE CASCADE;
16 ALTER TABLE contacts DROP CONSTRAINT contacts_user_id_fkey;
17 ALTER TABLE contacts ADD FOREIGN KEY (user_id) REFERENCES users(user_id) ON DELETE CASCADE ON UPDATE CASCADE;
18 ALTER TABLE cache DROP CONSTRAINT cache_user_id_fkey;
19 ALTER TABLE cache ADD FOREIGN KEY (user_id) REFERENCES users(user_id) ON DELETE CASCADE ON UPDATE CASCADE;
21 -- Updates from version 0.2-alpha
23 CREATE INDEX messages_created_idx ON messages (created);
25 -- Updates from version 0.2-beta
27 ALTER TABLE cache DROP session_id;
29 CREATE INDEX session_changed_idx ON session (changed);
30 CREATE INDEX cache_created_idx ON "cache" (created);
32 ALTER TABLE users ALTER "language" DROP NOT NULL;
33 ALTER TABLE users ALTER "language" DROP DEFAULT;
35 ALTER TABLE identities ALTER del TYPE smallint;
36 ALTER TABLE identities ALTER standard TYPE smallint;
37 ALTER TABLE contacts ALTER del TYPE smallint;
38 ALTER TABLE messages ALTER del TYPE smallint;
40 -- Updates from version 0.3-stable
43 CREATE INDEX messages_index_idx ON messages (user_id, cache_key, idx);
44 DROP INDEX contacts_user_id_idx;
45 CREATE INDEX contacts_user_id_idx ON contacts (user_id, email);
47 -- Updates from version 0.3.1
49 DROP INDEX identities_user_id_idx;
50 CREATE INDEX identities_user_id_idx ON identities (user_id, del);
52 ALTER TABLE identities ADD changed timestamp with time zone DEFAULT now() NOT NULL;
54 CREATE SEQUENCE contactgroups_ids
60 CREATE TABLE contactgroups (
61 contactgroup_id integer DEFAULT nextval('contactgroups_ids'::text) PRIMARY KEY,
62 user_id integer NOT NULL
63 REFERENCES users(user_id) ON DELETE CASCADE ON UPDATE CASCADE,
64 changed timestamp with time zone DEFAULT now() NOT NULL,
65 del smallint NOT NULL DEFAULT 0,
66 name varchar(128) NOT NULL DEFAULT ''
69 CREATE INDEX contactgroups_user_id_idx ON contactgroups (user_id, del);
71 CREATE TABLE contactgroupmembers (
72 contactgroup_id integer NOT NULL
73 REFERENCES contactgroups(contactgroup_id) ON DELETE CASCADE ON UPDATE CASCADE,
74 contact_id integer NOT NULL
75 REFERENCES contacts(contact_id) ON DELETE CASCADE ON UPDATE CASCADE,
76 created timestamp with time zone DEFAULT now() NOT NULL,
77 PRIMARY KEY (contactgroup_id, contact_id)
80 -- Updates from version 0.4-beta
82 ALTER TABLE users ALTER last_login DROP NOT NULL;
83 ALTER TABLE users ALTER last_login SET DEFAULT NULL;
85 -- Updates from version 0.4.2
87 DROP INDEX users_username_id_idx;
88 ALTER TABLE users ADD CONSTRAINT users_username_key UNIQUE (username, mail_host);
89 ALTER TABLE contacts ALTER email TYPE varchar(255);
93 -- Updates from version 0.5.1
94 -- Updates from version 0.5.2
95 -- Updates from version 0.5.3
96 -- Updates from version 0.5.4
98 ALTER TABLE contacts ADD words TEXT NULL;
99 CREATE INDEX contactgroupmembers_contact_id_idx ON contactgroupmembers (contact_id);
104 -- Updates from version 0.6
106 CREATE TABLE dictionary (
107 user_id integer DEFAULT NULL
108 REFERENCES users (user_id) ON DELETE CASCADE ON UPDATE CASCADE,
109 "language" varchar(5) NOT NULL,
111 CONSTRAINT dictionary_user_id_language_key UNIQUE (user_id, "language")
114 CREATE SEQUENCE search_ids
120 CREATE TABLE searches (
121 search_id integer DEFAULT nextval('search_ids'::text) PRIMARY KEY,
122 user_id integer NOT NULL
123 REFERENCES users (user_id) ON DELETE CASCADE ON UPDATE CASCADE,
124 "type" smallint DEFAULT 0 NOT NULL,
125 name varchar(128) NOT NULL,
127 CONSTRAINT searches_user_id_key UNIQUE (user_id, "type", name)
130 DROP SEQUENCE messages_ids;
133 CREATE TABLE cache_index (
134 user_id integer NOT NULL
135 REFERENCES users (user_id) ON DELETE CASCADE ON UPDATE CASCADE,
136 mailbox varchar(255) NOT NULL,
137 changed timestamp with time zone DEFAULT now() NOT NULL,
138 valid smallint NOT NULL DEFAULT 0,
140 PRIMARY KEY (user_id, mailbox)
143 CREATE INDEX cache_index_changed_idx ON cache_index (changed);
145 CREATE TABLE cache_thread (
146 user_id integer NOT NULL
147 REFERENCES users (user_id) ON DELETE CASCADE ON UPDATE CASCADE,
148 mailbox varchar(255) NOT NULL,
149 changed timestamp with time zone DEFAULT now() NOT NULL,
151 PRIMARY KEY (user_id, mailbox)
154 CREATE INDEX cache_thread_changed_idx ON cache_thread (changed);
156 CREATE TABLE cache_messages (
157 user_id integer NOT NULL
158 REFERENCES users (user_id) ON DELETE CASCADE ON UPDATE CASCADE,
159 mailbox varchar(255) NOT NULL,
160 uid integer NOT NULL,
161 changed timestamp with time zone DEFAULT now() NOT NULL,
163 flags integer NOT NULL DEFAULT 0,
164 PRIMARY KEY (user_id, mailbox, uid)
167 CREATE INDEX cache_messages_changed_idx ON cache_messages (changed);
169 -- Updates from version 0.7-beta
171 ALTER TABLE "session" ALTER sess_id TYPE varchar(128);