create table if not exists `sph_counter` ( `counter_id` int not null, `max_doc_id` int not null, primary key (`counter_id`) ); create table if not exists `sph_index` ( `id` bigint not null, `from` char(255) default null, `to` text(8192) default null, `fromdomain` char(255) default null, `todomain` text(512) default null, `subject` text(512) default null, `arrived` int unsigned not null, `sent` int unsigned not null, `body` text, `size` int default '0', `direction` int default 0, `folder` int default 0, `attachments` int default 0, `attachment_types` text(512) default null, primary key (`id`) ) Engine=InnoDB; create table if not exists `metadata` ( `id` bigint unsigned not null auto_increment, `from` varchar(128) not null, `fromdomain` varchar(64) not null, `subject` text(512) default null, `spam` tinyint(1) default 0, `arrived` int unsigned not null, `sent` int unsigned not null, `retained` int unsigned not null, `deleted` tinyint(1) default 0, `size` int default 0, `hlen` int default 0, `direction` int default 0, `attachments` int default 0, `piler_id` char(36) not null, `message_id` varchar(128) not null, `reference` char(64) not null, `digest` char(64) not null, `bodydigest` char(64) not null, `vcode` char(64) default null, primary key (`id`) ) Engine=InnoDB; create index metadata_idx on metadata(`piler_id`); create index metadata_idx2 on metadata(`message_id`); create index metadata_idx3 on metadata(`reference`); create index metadata_idx4 on metadata(`bodydigest`); create index metadata_idx5 on metadata(`deleted`); create index metadata_idx6 on metadata(`arrived`); create index metadata_idx7 on metadata(`retained`); create table if not exists `rcpt` ( `id` bigint unsigned not null, `to` varchar(128) not null, `todomain` varchar(64) not null, unique(`id`,`to`) ) Engine=InnoDB; create index `rcpt_idx` on `rcpt`(`id`); create index `rcpt_idx2` on `rcpt`(`to`); drop view if exists `v_messages`; create view `v_messages` AS select `metadata`.`id` AS `id`,`metadata`.`piler_id` AS `piler_id`,`metadata`.`from` AS `from`,`metadata`.`fromdomain` AS `fromdomain`,`rcpt`.`to` AS `to`,`rcpt`.`todomain` AS `todomain`,`metadata`.`subject` AS `subject`, `metadata`.`size` AS `size`, `metadata`.`direction` AS `direction`, `metadata`.`sent` AS `sent`, `metadata`.`arrived` AS `arrived`, `metadata`.`digest` AS `digest`, `metadata`.`bodydigest` AS `bodydigest` from (`metadata` join `rcpt`) where (`metadata`.`id` = `rcpt`.`id`); create table if not exists `attachment` ( `id` bigint unsigned not null auto_increment, `piler_id` char(36) not null, `attachment_id` int not null, `name` varchar(128) default null, `type` varchar(128) default null, `sig` char(64) not null, `size` int default 0, `ptr` bigint unsigned default 0, `deleted` tinyint(1) default 0, primary key (`id`) ) Engine=InnoDB; create index `attachment_idx` on `attachment`(`piler_id`); create index `attachment_idx2` on `attachment`(`sig`); create index `attachment_idx3` on `attachment`(`ptr`); drop view if exists `v_attachment`; create view `v_attachment` AS select `id` as `i`, `piler_id`, `attachment_id`, `ptr`, (select count(*) from `attachment` where `ptr`=`i`) as `refcount` from `attachment`; create table if not exists `tag` ( `_id` bigint unsigned auto_increment not null, `id` bigint not null, `uid` int not null, `tag` varchar(255) default null, unique(`id`, `uid`), key (`_id`) ) ENGINE=InnoDB; create table if not exists `archiving_rule` ( `id` bigint unsigned not null auto_increment, `domain` varchar(255) default null, `from` char(128) default null, `to` char(255) default null, `subject` char(255) default null, `_size` char(2) default null, `size` int default 0, `attachment_type` char(128) default null, `_attachment_size` char(2) default null, `attachment_size` int default 0, `spam` tinyint(1) default -1, `days` int default 0, primary key (`id`), unique(`from`,`to`,`subject`,`_size`,`size`,`attachment_type`,`_attachment_size`,`attachment_size`,`spam`) ) ENGINE=InnoDB; create table if not exists `retention_rule` ( `id` bigint unsigned not null auto_increment, `domain` varchar(255) default null, `from` char(128) default null, `to` char(255) default null, `subject` char(255) default null, `_size` char(2) default null, `size` int default 0, `attachment_type` char(128) default null, `_attachment_size` char(2) default null, `attachment_size` int default 0, `spam` tinyint(1) default -1, `days` int default 0, primary key (`id`), unique(`from`,`to`,`subject`,`_size`,`size`,`attachment_type`,`_attachment_size`,`attachment_size`,`spam`) ) ENGINE=InnoDB; create table if not exists `counter` ( `rcvd` bigint unsigned default 0, `virus` bigint unsigned default 0, `duplicate` bigint unsigned default 0, `ignore` bigint unsigned default 0, `size` bigint unsigned default 0 ) Engine=InnoDB; insert into `counter` values(0, 0, 0, 0, 0); create table if not exists `option` ( `key` char(64) not null, `value` char(32) not null ) Engine=InnoDB; insert into `option` (`key`, `value`) values('enable_purge', '1'); create table if not exists `search` ( `email` char(128) not null, `ts` int default 0, `term` text(512) not null ) Engine=InnoDB; create index `search_idx` on `search`(`email`); create table if not exists `user_settings` ( `username` char(64) not null unique, `pagelen` int default 20, `theme` char(8) default 'default', `lang` char(2) default NULL ); create index `user_settings_idx` on `user_settings`(`username`); create table if not exists `user` ( `uid` int unsigned not null primary key, `username` char(64) not null unique, `realname` char(64) default null, `samaccountname` char(64) default null, `password` char(128) default null, `domain` char(64) default null, `dn` char(255) default '*', `isadmin` tinyint default 0 ) Engine=InnoDB; insert into `user` (`uid`, `username`, `realname`, `samaccountname`, `password`, `isadmin`, `domain`) values (0, 'admin', 'built-in piler admin', '', '$1$PItc7d$zsUgON3JRrbdGS11t9JQW1', 1, 'local'); create table if not exists `email` ( `uid` int unsigned not null, `email` char(128) not null primary key ) ENGINE=InnoDB; insert into `email` (`uid`, `email`) values(0, 'admin@local'); create table if not exists `email_groups` ( `uid` int unsigned not null, `gid` int unsigned not null, unique key `uid` (`uid`,`gid`), key `email_groups_idx` (`uid`,`gid`) ) ENGINE=InnoDB; create table if not exists `group` ( `id` bigint unsigned not null auto_increment primary key, `groupname` char(255) not null unique ) ENGINE=InnoDB; create table if not exists `group_user` ( `id` bigint unsigned not null, `uid` int unsigned not null, key `group_user_idx` (`id`), key `group_user_idx2` (`uid`) ) ENGINE=InnoDB; create table if not exists `group_email` ( `id` bigint unsigned not null, `email` char(128) not null, key `group_email_idx` (`id`) ) ENGINE=InnoDB; create table if not exists `domain_user` ( `domain` char(64) not null, `uid` int unsigned not null, key `domain_user_idx` (`domain`), key `domain_user_idx2` (`uid`) ) ENGINE=InnoDB; create table if not exists `folder` ( `id` int not null auto_increment, `parent_id` int default 0, `name` char(64) not null, unique(`parent_id`, `name`), primary key (`id`) ) Engine=InnoDB; create table if not exists `folder_user` ( `id` bigint unsigned not null, `uid` int unsigned not null, key `folder_user_idx` (`id`), key `folder_user_idx2` (`uid`) ) ENGINE=InnoDB; create table if not exists `folder_extra` ( `id` int unsigned not null auto_increment, `uid` int unsigned not null, `name` char(64) not null, unique(uid, name), key (`id`) ) ENGINE=InnoDB; create table if not exists `folder_message` ( folder_id bigint not null, id bigint not null, unique(folder_id, id) ) ENGINE=InnoDB; create table if not exists `note` ( `_id` bigint unsigned auto_increment not null, `id` bigint unsigned not null, `uid` int not null, `note` text default null, unique(`id`, `uid`), key (`_id`) ) ENGINE=InnoDB; create table if not exists `remote` ( `remotedomain` char(64) not null primary key, `remotehost` char(64) not null, `basedn` char(255) not null, `binddn` char(255) not null, `sitedescription` char(64) default null ) ENGINE=InnoDB; create table if not exists `domain` ( `domain` char(64) not null primary key, `mapped` char(64) not null, `ldap_id` int default 0 ) ENGINE=InnoDB; insert into `domain` (`domain`, `mapped`) values('local', 'local'); create table if not exists `audit` ( `id` bigint unsigned not null auto_increment, `ts` int not null, `email` varchar(128) not null, `domain` varchar(128) not null, `action` int not null, `ipaddr` char(15) not null, `meta_id` bigint unsigned not null, `description` varchar(255) default null, `vcode` char(64) default null, primary key (`id`) ) ENGINE=InnoDB; create index `audit_idx` on `audit`(`email`); create index `audit_idx2` on `audit`(`action`); create index `audit_idx3` on `audit`(`ipaddr`); create index `audit_idx4` on `audit`(`ts`); create index `audit_idx5` on `audit`(`domain`); create table if not exists `google` ( `id` bigint unsigned not null primary key, `email` char(128) not null unique, `access_token` char(255) default null, `refresh_token` char(255) default null, `created` int default 0 ) ENGINE=InnoDB; create table if not exists `google_imap` ( `id` bigint unsigned not null, `email` char(128) not null, `last_msg_id` bigint default 0, key(`email`) ) ENGINE=InnoDB; CREATE TABLE IF NOT EXISTS `counter_stats` ( `id` int(11) NOT NULL AUTO_INCREMENT, `date` int(11) NOT NULL, `email` varchar(255) NOT NULL, `domain` varchar(255) NOT NULL, `sent` int(11) NOT NULL, `recd` int(11) NOT NULL, `sentsize` int(11) NOT NULL, `recdsize` int(11) NOT NULL, PRIMARY KEY (`id`), KEY `date` (`date`), KEY `email` (`email`), KEY `domain` (`domain`) ) ENGINE=InnoDB; create table if not exists `ldap` ( `id` int not null auto_increment primary key, `description` varchar(255) not null, `ldap_type` varchar(255) not null, `ldap_host` varchar(255) not null, `ldap_base_dn` varchar(255) not null, `ldap_bind_dn` varchar(255) not null, `ldap_bind_pw` varchar(255) not null, `ldap_auditor_member_dn` varchar(255) default null ) Engine=InnoDB; create table if not exists `customer_settings` ( `id` int not null auto_increment primary key, `domain` varchar(255) not null unique, `branding_text` varchar(255) default null, `branding_url` varchar(255) default null, `branding_logo` varchar(255) default null, `support_link` varchar(255) default null, `colour` varchar(255) default null ) Engine=InnoDB; create table if not exists `online` ( `username` varchar(255) not null, `ts` int default 0, `last_activity` int default 0, `ipaddr` varchar(255) default null, unique(`username`,`ipaddr`) ) Engine=InnoDB;