getTable('mail_accounts'); $accountsTable->addColumn('last_mailbox_sync', Types::INTEGER, [ 'default' => 0, ]); $mailboxTable = $schema->createTable('mail_mailboxes'); $mailboxTable->addColumn('id', Types::STRING, [ 'notnull' => true, 'length' => 255, ]); $mailboxTable->addColumn('account_id', Types::INTEGER, [ 'notnull' => true, ]); $mailboxTable->addColumn('sync_token', Types::STRING, [ 'notnull' => true, 'length' => 255, ]); $mailboxTable->addColumn('attributes', Types::STRING, [ 'length' => 255, 'default' => '[]', ]); $mailboxTable->addColumn('delimiter', Types::STRING, [ 'notnull' => true, 'length' => 1, ]); $mailboxTable->addColumn('messages', Types::INTEGER, [ 'notnull' => true, ]); $mailboxTable->addColumn('unseen', Types::INTEGER, [ 'notnull' => true, ]); $mailboxTable->addColumn('selectable', Types::BOOLEAN, [ 'notnull' => false, 'default' => true, ]); // We allow each mailbox name just once $mailboxTable->setPrimaryKey([ 'account_id', 'id', ]); return $schema; } }