vendor/bluue/labels-bundle/migrations/Version20221206230248.php line 1

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace LabelsBundleMigrations;
  4. use App\Services\ObjectSerialize;
  5. use Doctrine\DBAL\Schema\Schema;
  6. use Doctrine\Migrations\AbstractMigration;
  7. use Symfony\Component\Uid\UuidV6;
  8. final class Version20221206230248 extends AbstractMigration
  9. {
  10.     private ObjectSerialize $objectSerialize;
  11.     public function setObjectSerialize(ObjectSerialize $objectSerialize)
  12.     {
  13.         $this->objectSerialize $objectSerialize;
  14.     }
  15.     public function up(Schema $schema): void
  16.     {
  17.         $this->addSql('CREATE TABLE labels_bundle__label (id BINARY(16) NOT NULL COMMENT \'(DC2Type:uuid)\', product_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', declination_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', created_by_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', updated_by_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', deleted_by_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', name VARCHAR(255) NOT NULL, source VARCHAR(255) DEFAULT NULL, summary LONGTEXT DEFAULT NULL, description LONGTEXT DEFAULT NULL, reference VARCHAR(255) DEFAULT NULL, reference_brand VARCHAR(255) DEFAULT NULL, ean13 VARCHAR(13) DEFAULT NULL, wholesale_price NUMERIC(20, 6) DEFAULT NULL, sell_price NUMERIC(20, 6) DEFAULT NULL, attribute VARCHAR(255) DEFAULT NULL, batch_number VARCHAR(64) DEFAULT NULL, date_type_name VARCHAR(50) DEFAULT NULL, date_type_long_name VARCHAR(255) DEFAULT NULL, limit_date DATETIME DEFAULT NULL, custom_text LONGTEXT DEFAULT NULL, created_at DATETIME NOT NULL, updated_at DATETIME NOT NULL, deleted_at DATETIME DEFAULT NULL, INDEX IDX_18741D9C4584665A (product_id), INDEX IDX_18741D9C9941A932 (declination_id), INDEX IDX_18741D9CB03A8386 (created_by_id), INDEX IDX_18741D9C896DBBDE (updated_by_id), INDEX IDX_18741D9CC76F1F52 (deleted_by_id), INDEX name (name), INDEX source (source), INDEX attribute (attribute), INDEX deleted_at (deleted_at), INDEX created_at (created_at), INDEX updated_at (updated_at), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
  18.         $this->addSql('CREATE TABLE labels_bundle__label_context (id BINARY(16) NOT NULL COMMENT \'(DC2Type:uuid)\', label_id BINARY(16) NOT NULL COMMENT \'(DC2Type:uuid)\', context_id BINARY(16) NOT NULL COMMENT \'(DC2Type:uuid)\', INDEX IDX_2810AB2733B92F39 (label_id), INDEX IDX_2810AB276B00C1CF (context_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
  19.         $this->addSql('CREATE TABLE labels_bundle__label_translations (id INT AUTO_INCREMENT NOT NULL, object_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', locale VARCHAR(8) NOT NULL, field VARCHAR(32) NOT NULL, content LONGTEXT DEFAULT NULL, INDEX IDX_FA0E8E67232D562B (object_id), FULLTEXT INDEX content (content), UNIQUE INDEX lookup_unique_idx (locale, object_id, field), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
  20.         $this->addSql('CREATE TABLE labels_bundle__template (id BINARY(16) NOT NULL COMMENT \'(DC2Type:uuid)\', context_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', created_by_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', updated_by_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', deleted_by_id BINARY(16) DEFAULT NULL COMMENT \'(DC2Type:uuid)\', name VARCHAR(255) NOT NULL, content LONGTEXT DEFAULT NULL, created_at DATETIME NOT NULL, updated_at DATETIME NOT NULL, deleted_at DATETIME DEFAULT NULL, is_default TINYINT(1) NOT NULL, INDEX IDX_9E956D3F6B00C1CF (context_id), INDEX IDX_9E956D3FB03A8386 (created_by_id), INDEX IDX_9E956D3F896DBBDE (updated_by_id), INDEX IDX_9E956D3FC76F1F52 (deleted_by_id), INDEX name (name), INDEX is_default (is_default), INDEX deleted_at (deleted_at), INDEX created_at (created_at), INDEX updated_at (updated_at), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
  21.         $this->addSql('ALTER TABLE labels_bundle__label ADD CONSTRAINT FK_18741D9C4584665A FOREIGN KEY (product_id) REFERENCES products_bundle__product (id)');
  22.         $this->addSql('ALTER TABLE labels_bundle__label ADD CONSTRAINT FK_18741D9C9941A932 FOREIGN KEY (declination_id) REFERENCES products_bundle__declination (id)');
  23.         $this->addSql('ALTER TABLE labels_bundle__label ADD CONSTRAINT FK_18741D9CB03A8386 FOREIGN KEY (created_by_id) REFERENCES user (id)');
  24.         $this->addSql('ALTER TABLE labels_bundle__label ADD CONSTRAINT FK_18741D9C896DBBDE FOREIGN KEY (updated_by_id) REFERENCES user (id)');
  25.         $this->addSql('ALTER TABLE labels_bundle__label ADD CONSTRAINT FK_18741D9CC76F1F52 FOREIGN KEY (deleted_by_id) REFERENCES user (id)');
  26.         $this->addSql('ALTER TABLE labels_bundle__label_context ADD CONSTRAINT FK_2810AB2733B92F39 FOREIGN KEY (label_id) REFERENCES labels_bundle__label (id)');
  27.         $this->addSql('ALTER TABLE labels_bundle__label_context ADD CONSTRAINT FK_2810AB276B00C1CF FOREIGN KEY (context_id) REFERENCES context (id)');
  28.         $this->addSql('ALTER TABLE labels_bundle__label_translations ADD CONSTRAINT FK_FA0E8E67232D562B FOREIGN KEY (object_id) REFERENCES labels_bundle__label (id) ON DELETE CASCADE');
  29.         $this->addSql('ALTER TABLE labels_bundle__template ADD CONSTRAINT FK_9E956D3F6B00C1CF FOREIGN KEY (context_id) REFERENCES context (id)');
  30.         $this->addSql('ALTER TABLE labels_bundle__template ADD CONSTRAINT FK_9E956D3FB03A8386 FOREIGN KEY (created_by_id) REFERENCES user (id)');
  31.         $this->addSql('ALTER TABLE labels_bundle__template ADD CONSTRAINT FK_9E956D3F896DBBDE FOREIGN KEY (updated_by_id) REFERENCES user (id)');
  32.         $this->addSql('ALTER TABLE labels_bundle__template ADD CONSTRAINT FK_9E956D3FC76F1F52 FOREIGN KEY (deleted_by_id) REFERENCES user (id)');
  33.     }
  34.     public function down(Schema $schema): void
  35.     {
  36.         $this->addSql('ALTER TABLE labels_bundle__label DROP FOREIGN KEY FK_18741D9C4584665A');
  37.         $this->addSql('ALTER TABLE labels_bundle__label DROP FOREIGN KEY FK_18741D9C9941A932');
  38.         $this->addSql('ALTER TABLE labels_bundle__label DROP FOREIGN KEY FK_18741D9CB03A8386');
  39.         $this->addSql('ALTER TABLE labels_bundle__label DROP FOREIGN KEY FK_18741D9C896DBBDE');
  40.         $this->addSql('ALTER TABLE labels_bundle__label DROP FOREIGN KEY FK_18741D9CC76F1F52');
  41.         $this->addSql('ALTER TABLE labels_bundle__label_context DROP FOREIGN KEY FK_2810AB2733B92F39');
  42.         $this->addSql('ALTER TABLE labels_bundle__label_context DROP FOREIGN KEY FK_2810AB276B00C1CF');
  43.         $this->addSql('ALTER TABLE labels_bundle__label_translations DROP FOREIGN KEY FK_FA0E8E67232D562B');
  44.         $this->addSql('ALTER TABLE labels_bundle__template DROP FOREIGN KEY FK_9E956D3F6B00C1CF');
  45.         $this->addSql('ALTER TABLE labels_bundle__template DROP FOREIGN KEY FK_9E956D3FB03A8386');
  46.         $this->addSql('ALTER TABLE labels_bundle__template DROP FOREIGN KEY FK_9E956D3F896DBBDE');
  47.         $this->addSql('ALTER TABLE labels_bundle__template DROP FOREIGN KEY FK_9E956D3FC76F1F52');
  48.         $this->addSql('DROP TABLE labels_bundle__label');
  49.         $this->addSql('DROP TABLE labels_bundle__label_context');
  50.         $this->addSql('DROP TABLE labels_bundle__label_translations');
  51.         $this->addSql('DROP TABLE labels_bundle__template');
  52.     }
  53.     public function postUp(Schema $schema): void
  54.     {
  55.         parent::postUp($schema);
  56.         $now = (new \DateTime())->format('Y-m-d H:i:s');
  57.         $this->connection->insert('configuration', [
  58.             'id' => (new UuidV6())->toBinary(),
  59.             'name' => 'labels_bundle__default_number_prints',
  60.             'context_id' => null,
  61.             'value' => $this->objectSerialize->add((object) ['value' => '10']),
  62.             'created_at' => $now,
  63.             'updated_at' => $now
  64.         ]);
  65.         $this->connection->insert('configuration', [
  66.             'id' => (new UuidV6())->toBinary(),
  67.             'name' => 'labels_bundle__shared_labels',
  68.             'context_id' => null,
  69.             'value' => $this->objectSerialize->add((object) ['value' => '0']),
  70.             'created_at' => $now,
  71.             'updated_at' => $now
  72.         ]);
  73.         $fixtureFile dirname(__FILE__) . '/../src/Resources/views/Pdf/Fixtures/label.html.twig';
  74.         $content file_get_contents($fixtureFile);
  75.         $this->connection->insert('labels_bundle__template', [
  76.             'id' => (new UuidV6())->toBinary(),
  77.             'name' => 'Default',
  78.             'content' => $content,
  79.             'is_default' => 1,
  80.             'created_at' => $now,
  81.             'updated_at' => $now
  82.         ]);
  83.     }
  84. }