connection = $connection; } /** * @param IOutput $output * @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper` * @param array $options * * @return ISchemaWrapper */ #[\Override] public function changeSchema(IOutput $output, Closure $schemaClosure, array $options) { /** @var ISchemaWrapper $schema */ $schema = $schemaClosure(); $mailboxTable = $schema->createTable('mail_mailboxes'); $mailboxTable->addColumn('id', Types::INTEGER, [ 'autoincrement' => true, 'notnull' => true, ]); $mailboxTable->addColumn('name', Types::STRING, [ 'notnull' => true, 'length' => 255, ]); $mailboxTable->addColumn('account_id', Types::INTEGER, [ 'notnull' => true, ]); $mailboxTable->addColumn('sync_token', Types::STRING, [ 'notnull' => false, '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, ]); $mailboxTable->setPrimaryKey(['id']); /* * We allow each mailbox name just once * @see \OCA\Mail\Migration\Version3500Date20231115184458::changeSchema */ // $mailboxTable->addUniqueIndex([ // 'account_id', // 'name', // ]); return $schema; } /** * @return void */ #[\Override] public function postSchemaChange(IOutput $output, \Closure $schemaClosure, array $options) { // Force a re-sync $update = $this->connection->getQueryBuilder(); $update->update('mail_accounts') ->set('last_mailbox_sync', $update->createNamedParameter(0)); $update->executeStatement(); } }