createTable('mail_local_messages'); $localMessageTable->addColumn('id', Types::INTEGER, [ 'autoincrement' => true, 'notnull' => true, ]); $localMessageTable->addColumn('type', Types::INTEGER, [ 'notnull' => true, 'unsigned' => true, ]); $localMessageTable->addColumn('account_id', Types::INTEGER, [ 'notnull' => true, ]); $localMessageTable->addColumn('alias_id', Types::INTEGER, [ 'notnull' => false, ]); $localMessageTable->addColumn('send_at', Types::INTEGER, [ 'notnull' => false, ]); $localMessageTable->addColumn('subject', Types::TEXT, [ 'notnull' => true, 'length' => 255 ]); $localMessageTable->addColumn('body', Types::TEXT, [ 'notnull' => true ]); $localMessageTable->addColumn('html', Types::BOOLEAN, [ 'notnull' => false, 'default' => false, ]); $localMessageTable->addColumn('in_reply_to_message_id', Types::TEXT, [ 'notnull' => false, 'length' => 1023, ]); $localMessageTable->setPrimaryKey(['id']); /** @var Table $recipientsTable */ $recipientsTable = $schema->getTable('mail_recipients'); $recipientsTable->addColumn('local_message_id', Types::INTEGER, [ 'notnull' => false, ]); $recipientsTable->modifyColumn('message_id', [ 'notnull' => false ]); $recipientsTable->addForeignKeyConstraint($localMessageTable, ['local_message_id'], ['id'], ['onDelete' => 'CASCADE']); $attachmentsTable = $schema->getTable('mail_attachments'); $attachmentsTable->addColumn('local_message_id', Types::INTEGER, [ 'notnull' => false, ]); $attachmentsTable->addForeignKeyConstraint($localMessageTable, ['local_message_id'], ['id'], ['onDelete' => 'CASCADE']); return $schema; } }