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',
12 data longtext NOT NULL
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 default '0',
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 varchar(255) NOT NULL default '',
32 firstname varchar(128) NOT NULL default '',
33 surname varchar(128) NOT NULL default '',
34 vcard text NOT NULL default ''
37 CREATE INDEX ix_contacts_user_id ON contacts(user_id, email);
40 CREATE TABLE contactgroups (
41 contactgroup_id integer NOT NULL PRIMARY KEY,
42 user_id integer NOT NULL default '0',
43 changed datetime NOT NULL default '0000-00-00 00:00:00',
44 del tinyint NOT NULL default '0',
45 name varchar(128) NOT NULL default ''
48 CREATE INDEX ix_contactgroups_user_id ON contactgroups(user_id, del);
51 CREATE TABLE contactgroupmembers (
52 contactgroup_id integer NOT NULL,
53 contact_id integer NOT NULL default '0',
54 created datetime NOT NULL default '0000-00-00 00:00:00',
55 PRIMARY KEY (contactgroup_id, contact_id)
59 -- --------------------------------------------------------
62 -- Table structure for table identities
65 CREATE TABLE identities (
66 identity_id integer NOT NULL PRIMARY KEY,
67 user_id integer NOT NULL default '0',
68 changed datetime NOT NULL default '0000-00-00 00:00:00',
69 del tinyint NOT NULL default '0',
70 standard tinyint NOT NULL default '0',
71 name varchar(128) NOT NULL default '',
72 organization varchar(128) default '',
73 email varchar(128) NOT NULL default '',
74 "reply-to" varchar(128) NOT NULL default '',
75 bcc varchar(128) NOT NULL default '',
76 signature text NOT NULL default '',
77 html_signature tinyint NOT NULL default '0'
80 CREATE INDEX ix_identities_user_id ON identities(user_id, del);
83 -- --------------------------------------------------------
86 -- Table structure for table users
90 user_id integer NOT NULL PRIMARY KEY,
91 username varchar(128) NOT NULL default '',
92 mail_host varchar(128) NOT NULL default '',
93 alias varchar(128) NOT NULL default '',
94 created datetime NOT NULL default '0000-00-00 00:00:00',
95 last_login datetime DEFAULT NULL,
97 preferences text NOT NULL default ''
100 CREATE UNIQUE INDEX ix_users_username ON users(username, mail_host);
101 CREATE INDEX ix_users_alias ON users(alias);
103 -- --------------------------------------------------------
106 -- Table structure for table session
109 CREATE TABLE session (
110 sess_id varchar(40) NOT NULL PRIMARY KEY,
111 created datetime NOT NULL default '0000-00-00 00:00:00',
112 changed datetime NOT NULL default '0000-00-00 00:00:00',
113 ip varchar(40) NOT NULL default '',
117 CREATE INDEX ix_session_changed ON session (changed);
119 -- --------------------------------------------------------
122 -- Table structure for table messages
125 CREATE TABLE messages (
126 message_id integer NOT NULL PRIMARY KEY,
127 user_id integer NOT NULL default '0',
128 del tinyint NOT NULL default '0',
129 cache_key varchar(128) NOT NULL default '',
130 created datetime NOT NULL default '0000-00-00 00:00:00',
131 idx integer NOT NULL default '0',
132 uid integer NOT NULL default '0',
133 subject varchar(255) NOT NULL default '',
134 "from" varchar(255) NOT NULL default '',
135 "to" varchar(255) NOT NULL default '',
136 "cc" varchar(255) NOT NULL default '',
137 "date" datetime NOT NULL default '0000-00-00 00:00:00',
138 size integer NOT NULL default '0',
139 headers text NOT NULL,
143 CREATE UNIQUE INDEX ix_messages_user_cache_uid ON messages (user_id,cache_key,uid);
144 CREATE INDEX ix_messages_index ON messages (user_id,cache_key,idx);
145 CREATE INDEX ix_messages_created ON messages (created);