<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
/**
* Auto-generated Migration: Please modify to your needs!
*/
final class Version20220327113011 extends AbstractMigration
{
public function getDescription(): string
{
return '';
}
public function up(Schema $schema): void
{
// this up() migration is auto-generated, please modify it to your needs
$this->addSql('CREATE TABLE beneficiaire_transaction (id INT AUTO_INCREMENT NOT NULL, user_id INT DEFAULT NULL, pays_id INT DEFAULT NULL, devise_id INT DEFAULT NULL, nom VARCHAR(255) NOT NULL, prenom VARCHAR(255) NOT NULL, numero_carte VARCHAR(50) NOT NULL, date_expiration DATE NOT NULL, rib VARCHAR(255) NOT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', is_active TINYINT(1) NOT NULL, INDEX IDX_B488F330A76ED395 (user_id), INDEX IDX_B488F330A6E44244 (pays_id), INDEX IDX_B488F330F4445056 (devise_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE carte (id INT AUTO_INCREMENT NOT NULL, title VARCHAR(255) NOT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', is_active TINYINT(1) NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE categorie_faq (id INT AUTO_INCREMENT NOT NULL, title VARCHAR(255) NOT NULL, color VARCHAR(255) NOT NULL, is_active TINYINT(1) NOT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE chat_box (id INT AUTO_INCREMENT NOT NULL, title VARCHAR(255) NOT NULL, description LONGTEXT NOT NULL, sender VARCHAR(255) NOT NULL, recever VARCHAR(255) NOT NULL, message LONGTEXT NOT NULL, is_send_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', is_view_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE devise (id INT AUTO_INCREMENT NOT NULL, nom VARCHAR(255) NOT NULL, nom_code VARCHAR(10) DEFAULT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE display (id INT AUTO_INCREMENT NOT NULL, titre VARCHAR(255) NOT NULL, description LONGTEXT NOT NULL, link LONGTEXT DEFAULT NULL, start_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', finish_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', priority VARCHAR(255) NOT NULL, amount DOUBLE PRECISION NOT NULL, is_active TINYINT(1) NOT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE evenement (id INT AUTO_INCREMENT NOT NULL, title VARCHAR(255) NOT NULL, description LONGTEXT DEFAULT NULL, debut_at DATETIME DEFAULT NULL COMMENT \'(DC2Type:datetime_immutable)\', fin_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', is_active TINYINT(1) NOT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', images VARCHAR(255) DEFAULT NULL, video LONGTEXT DEFAULT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE faq (id INT AUTO_INCREMENT NOT NULL, categorie_id INT DEFAULT NULL, title VARCHAR(255) NOT NULL, description LONGTEXT NOT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', is_publish TINYINT(1) NOT NULL, is_publish_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', INDEX IDX_E8FF75CCBCF5E72D (categorie_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE historique_login (id INT AUTO_INCREMENT NOT NULL, user_id INT DEFAULT NULL, lat DOUBLE PRECISION DEFAULT NULL, lg DOUBLE PRECISION DEFAULT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', app_version VARCHAR(255) DEFAULT NULL, plateform VARCHAR(255) DEFAULT NULL, mobile VARCHAR(255) DEFAULT NULL, ip_adress VARCHAR(255) DEFAULT NULL, continent_code VARCHAR(255) DEFAULT NULL, continent_name VARCHAR(255) DEFAULT NULL, contry_code VARCHAR(255) DEFAULT NULL, contry_name VARCHAR(255) DEFAULT NULL, state_prov VARCHAR(255) NOT NULL, brands LONGTEXT DEFAULT NULL COMMENT \'(DC2Type:array)\', INDEX IDX_E4881163A76ED395 (user_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE notification (id INT AUTO_INCREMENT NOT NULL, title VARCHAR(255) NOT NULL, description LONGTEXT DEFAULT NULL, image VARCHAR(255) DEFAULT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', is_view TINYINT(1) NOT NULL, is_view_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE pays (id INT AUTO_INCREMENT NOT NULL, flag VARCHAR(255) DEFAULT NULL, nom VARCHAR(255) NOT NULL, nom_code VARCHAR(255) NOT NULL, code VARCHAR(10) DEFAULT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE refresh_tokens (id INT AUTO_INCREMENT NOT NULL, refresh_token VARCHAR(128) NOT NULL, username VARCHAR(255) NOT NULL, valid DATETIME NOT NULL, UNIQUE INDEX UNIQ_9BACE7E1C74F2195 (refresh_token), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE transaction (id INT AUTO_INCREMENT NOT NULL, transaction_to_id INT DEFAULT NULL, transaction_by_id INT DEFAULT NULL, motif VARCHAR(255) NOT NULL, justif VARCHAR(255) DEFAULT NULL, montant DOUBLE PRECISION NOT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', INDEX IDX_723705D191069A25 (transaction_to_id), INDEX IDX_723705D1BD4F044 (transaction_by_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE `user` (id INT AUTO_INCREMENT NOT NULL, email VARCHAR(180) NOT NULL, roles LONGTEXT NOT NULL COMMENT \'(DC2Type:json)\', auth_code VARCHAR(255) DEFAULT NULL, password VARCHAR(255) NOT NULL, is_verified TINYINT(1) NOT NULL, is_auth TINYINT(1) DEFAULT NULL, UNIQUE INDEX UNIQ_8D93D649E7927C74 (email), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('ALTER TABLE beneficiaire_transaction ADD CONSTRAINT FK_B488F330A76ED395 FOREIGN KEY (user_id) REFERENCES `user` (id)');
$this->addSql('ALTER TABLE beneficiaire_transaction ADD CONSTRAINT FK_B488F330A6E44244 FOREIGN KEY (pays_id) REFERENCES pays (id)');
$this->addSql('ALTER TABLE beneficiaire_transaction ADD CONSTRAINT FK_B488F330F4445056 FOREIGN KEY (devise_id) REFERENCES devise (id)');
$this->addSql('ALTER TABLE faq ADD CONSTRAINT FK_E8FF75CCBCF5E72D FOREIGN KEY (categorie_id) REFERENCES categorie_faq (id)');
$this->addSql('ALTER TABLE historique_login ADD CONSTRAINT FK_E4881163A76ED395 FOREIGN KEY (user_id) REFERENCES `user` (id)');
$this->addSql('ALTER TABLE transaction ADD CONSTRAINT FK_723705D191069A25 FOREIGN KEY (transaction_to_id) REFERENCES beneficiaire_transaction (id)');
$this->addSql('ALTER TABLE transaction ADD CONSTRAINT FK_723705D1BD4F044 FOREIGN KEY (transaction_by_id) REFERENCES `user` (id)');
}
public function down(Schema $schema): void
{
// this down() migration is auto-generated, please modify it to your needs
$this->addSql('ALTER TABLE transaction DROP FOREIGN KEY FK_723705D191069A25');
$this->addSql('ALTER TABLE faq DROP FOREIGN KEY FK_E8FF75CCBCF5E72D');
$this->addSql('ALTER TABLE beneficiaire_transaction DROP FOREIGN KEY FK_B488F330F4445056');
$this->addSql('ALTER TABLE beneficiaire_transaction DROP FOREIGN KEY FK_B488F330A6E44244');
$this->addSql('ALTER TABLE beneficiaire_transaction DROP FOREIGN KEY FK_B488F330A76ED395');
$this->addSql('ALTER TABLE historique_login DROP FOREIGN KEY FK_E4881163A76ED395');
$this->addSql('ALTER TABLE transaction DROP FOREIGN KEY FK_723705D1BD4F044');
$this->addSql('DROP TABLE beneficiaire_transaction');
$this->addSql('DROP TABLE carte');
$this->addSql('DROP TABLE categorie_faq');
$this->addSql('DROP TABLE chat_box');
$this->addSql('DROP TABLE devise');
$this->addSql('DROP TABLE display');
$this->addSql('DROP TABLE evenement');
$this->addSql('DROP TABLE faq');
$this->addSql('DROP TABLE historique_login');
$this->addSql('DROP TABLE notification');
$this->addSql('DROP TABLE pays');
$this->addSql('DROP TABLE refresh_tokens');
$this->addSql('DROP TABLE transaction');
$this->addSql('DROP TABLE `user`');
}
}