hasTable('mail_tags')) { $tagsTable = $schema->createTable('mail_tags'); $tagsTable->addColumn('id', Types::INTEGER, [ 'autoincrement' => true, 'notnull' => true, ]); $tagsTable->addColumn('user_id', Types::STRING, [ 'notnull' => true, 'length' => 64, ]); $tagsTable->addColumn('imap_label', Types::STRING, [ 'notnull' => true, 'length' => 64, ]); $tagsTable->addColumn('display_name', Types::STRING, [ 'notnull' => true, 'length' => 128, ]); $tagsTable->addColumn('color', Types::STRING, [ 'notnull' => false, 'length' => 9, 'default' => '#fff' ]); $tagsTable->addColumn('is_default_tag', Types::BOOLEAN, [ 'notnull' => false, 'default' => false ]); $tagsTable->setPrimaryKey(['id']); // Dropped in Version3600Date20240205180726 because mail_msg_tags_usr_id_index is redundant with mail_msg_tags_usr_lbl_idx // $tagsTable->addIndex(['user_id'], 'mail_msg_tags_usr_id_index'); $tagsTable->addUniqueIndex( [ 'user_id', 'imap_label', ], 'mail_msg_tags_usr_lbl_idx' ); } if (!$schema->hasTable('mail_message_tags')) { $tagsMessageTable = $schema->createTable('mail_message_tags'); $tagsMessageTable->addColumn('id', Types::INTEGER, [ 'autoincrement' => true, 'notnull' => true, ]); $tagsMessageTable->addColumn('imap_message_id', Types::STRING, [ 'notnull' => true, 'length' => 1023, ]); $tagsMessageTable->addColumn('tag_id', Types::INTEGER, [ 'notnull' => true, ]); $tagsMessageTable->setPrimaryKey(['id']); } return $schema; } }