1 -- Roundcube Webmail initial database structure
4 -- Table structure for table cache
8 cache_id integer NOT NULL PRIMARY KEY,
9 user_id integer NOT NULL default 0,
10 cache_key varchar(128) NOT NULL default '',
11 created datetime NOT NULL default '0000-00-00 00:00:00',
15 CREATE INDEX ix_cache_user_cache_key ON cache(user_id, cache_key);
16 CREATE INDEX ix_cache_created ON cache(created);
19 -- --------------------------------------------------------
22 -- Table structure for table contacts and related
25 CREATE TABLE contacts (
26 contact_id integer NOT NULL PRIMARY KEY,
27 user_id integer NOT NULL,
28 changed datetime NOT NULL default '0000-00-00 00:00:00',
29 del tinyint NOT NULL default '0',
30 name varchar(128) NOT NULL default '',
31 email text NOT NULL default '',
32 firstname varchar(128) NOT NULL default '',
33 surname varchar(128) NOT NULL default '',
34 vcard text NOT NULL default '',
35 words text NOT NULL default ''
38 CREATE INDEX ix_contacts_user_id ON contacts(user_id, del);
41 CREATE TABLE contactgroups (
42 contactgroup_id integer NOT NULL PRIMARY KEY,
43 user_id integer NOT NULL default '0',
44 changed datetime NOT NULL default '0000-00-00 00:00:00',
45 del tinyint NOT NULL default '0',
46 name varchar(128) NOT NULL default ''
49 CREATE INDEX ix_contactgroups_user_id ON contactgroups(user_id, del);
52 CREATE TABLE contactgroupmembers (
53 contactgroup_id integer NOT NULL,
54 contact_id integer NOT NULL default '0',
55 created datetime NOT NULL default '0000-00-00 00:00:00',
56 PRIMARY KEY (contactgroup_id, contact_id)
59 CREATE INDEX ix_contactgroupmembers_contact_id ON contactgroupmembers (contact_id);
62 -- --------------------------------------------------------
65 -- Table structure for table identities
68 CREATE TABLE identities (
69 identity_id integer NOT NULL PRIMARY KEY,
70 user_id integer NOT NULL default '0',
71 changed datetime NOT NULL default '0000-00-00 00:00:00',
72 del tinyint NOT NULL default '0',
73 standard tinyint NOT NULL default '0',
74 name varchar(128) NOT NULL default '',
75 organization varchar(128) default '',
76 email varchar(128) NOT NULL default '',
77 "reply-to" varchar(128) NOT NULL default '',
78 bcc varchar(128) NOT NULL default '',
79 signature text NOT NULL default '',
80 html_signature tinyint NOT NULL default '0'
83 CREATE INDEX ix_identities_user_id ON identities(user_id, del);
86 -- --------------------------------------------------------
89 -- Table structure for table users
93 user_id integer NOT NULL PRIMARY KEY,
94 username varchar(128) NOT NULL default '',
95 mail_host varchar(128) NOT NULL default '',
96 alias varchar(128) NOT NULL default '',
97 created datetime NOT NULL default '0000-00-00 00:00:00',
98 last_login datetime DEFAULT NULL,
100 preferences text NOT NULL default ''
103 CREATE UNIQUE INDEX ix_users_username ON users(username, mail_host);
104 CREATE INDEX ix_users_alias ON users(alias);
106 -- --------------------------------------------------------
109 -- Table structure for table session
112 CREATE TABLE session (
113 sess_id varchar(128) NOT NULL PRIMARY KEY,
114 created datetime NOT NULL default '0000-00-00 00:00:00',
115 changed datetime NOT NULL default '0000-00-00 00:00:00',
116 ip varchar(40) NOT NULL default '',
120 CREATE INDEX ix_session_changed ON session (changed);
122 -- --------------------------------------------------------
125 -- Table structure for table dictionary
128 CREATE TABLE dictionary (
129 user_id integer DEFAULT NULL,
130 "language" varchar(5) NOT NULL,
134 CREATE UNIQUE INDEX ix_dictionary_user_language ON dictionary (user_id, "language");
136 -- --------------------------------------------------------
139 -- Table structure for table searches
142 CREATE TABLE searches (
143 search_id integer NOT NULL PRIMARY KEY,
144 user_id integer NOT NULL DEFAULT '0',
145 "type" smallint NOT NULL DEFAULT '0',
146 name varchar(128) NOT NULL,
150 CREATE UNIQUE INDEX ix_searches_user_type_name ON searches (user_id, type, name);
152 -- --------------------------------------------------------
155 -- Table structure for table cache_index
158 CREATE TABLE cache_index (
159 user_id integer NOT NULL,
160 mailbox varchar(255) NOT NULL,
161 changed datetime NOT NULL default '0000-00-00 00:00:00',
162 valid smallint NOT NULL DEFAULT '0',
164 PRIMARY KEY (user_id, mailbox)
167 CREATE INDEX ix_cache_index_changed ON cache_index (changed);
169 -- --------------------------------------------------------
172 -- Table structure for table cache_thread
175 CREATE TABLE cache_thread (
176 user_id integer NOT NULL,
177 mailbox varchar(255) NOT NULL,
178 changed datetime NOT NULL default '0000-00-00 00:00:00',
180 PRIMARY KEY (user_id, mailbox)
183 CREATE INDEX ix_cache_thread_changed ON cache_thread (changed);
185 -- --------------------------------------------------------
188 -- Table structure for table cache_messages
191 CREATE TABLE cache_messages (
192 user_id integer NOT NULL,
193 mailbox varchar(255) NOT NULL,
194 uid integer NOT NULL,
195 changed datetime NOT NULL default '0000-00-00 00:00:00',
197 flags integer NOT NULL DEFAULT '0',
198 PRIMARY KEY (user_id, mailbox, uid)
201 CREATE INDEX ix_cache_messages_changed ON cache_messages (changed);