<?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 Version20250611135410 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 channel_user_role (id INT AUTO_INCREMENT NOT NULL, channel_id VARCHAR(36) NOT NULL, auto_created_type INT DEFAULT NULL, name VARCHAR(255) NOT NULL, perms LONGTEXT DEFAULT NULL COMMENT \'(DC2Type:simple_array)\', INDEX IDX_82956D9C72F5A1AA (channel_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE channel_user_service_permissions (id INT AUTO_INCREMENT NOT NULL, created_by_id VARCHAR(36) DEFAULT NULL, updated_by_id VARCHAR(36) DEFAULT NULL, channel_user_data_id VARCHAR(36) NOT NULL, resource_id INT NOT NULL, perms LONGTEXT DEFAULT NULL COMMENT \'(DC2Type:simple_array)\', expire_at DATETIME DEFAULT NULL, start_at DATETIME DEFAULT NULL, created_at DATETIME NOT NULL, updated_at DATETIME DEFAULT NULL, INDEX IDX_A50E7CB9B03A8386 (created_by_id), INDEX IDX_A50E7CB9896DBBDE (updated_by_id), INDEX IDX_A50E7CB923887597 (channel_user_data_id), INDEX IDX_A50E7CB989329D25 (resource_id), UNIQUE INDEX UNIQ_A50E7CB92388759789329D25 (channel_user_data_id, resource_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE channel_user_session_permissions (id INT AUTO_INCREMENT NOT NULL, created_by_id VARCHAR(36) DEFAULT NULL, updated_by_id VARCHAR(36) DEFAULT NULL, channel_user_data_id VARCHAR(36) NOT NULL, resource_id INT NOT NULL, perms LONGTEXT DEFAULT NULL COMMENT \'(DC2Type:simple_array)\', expire_at DATETIME DEFAULT NULL, start_at DATETIME DEFAULT NULL, created_at DATETIME NOT NULL, updated_at DATETIME DEFAULT NULL, INDEX IDX_95CD4462B03A8386 (created_by_id), INDEX IDX_95CD4462896DBBDE (updated_by_id), INDEX IDX_95CD446223887597 (channel_user_data_id), INDEX IDX_95CD446289329D25 (resource_id), UNIQUE INDEX UNIQ_95CD44622388759789329D25 (channel_user_data_id, resource_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('ALTER TABLE channel_user_role ADD CONSTRAINT FK_82956D9C72F5A1AA FOREIGN KEY (channel_id) REFERENCES channel_channels (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_user_service_permissions ADD CONSTRAINT FK_A50E7CB9B03A8386 FOREIGN KEY (created_by_id) REFERENCES account_users (id) ON DELETE SET NULL');
$this->addSql('ALTER TABLE channel_user_service_permissions ADD CONSTRAINT FK_A50E7CB9896DBBDE FOREIGN KEY (updated_by_id) REFERENCES account_users (id) ON DELETE SET NULL');
$this->addSql('ALTER TABLE channel_user_service_permissions ADD CONSTRAINT FK_A50E7CB923887597 FOREIGN KEY (channel_user_data_id) REFERENCES channel_user_data (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_user_service_permissions ADD CONSTRAINT FK_A50E7CB989329D25 FOREIGN KEY (resource_id) REFERENCES channel_services (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_user_session_permissions ADD CONSTRAINT FK_95CD4462B03A8386 FOREIGN KEY (created_by_id) REFERENCES account_users (id) ON DELETE SET NULL');
$this->addSql('ALTER TABLE channel_user_session_permissions ADD CONSTRAINT FK_95CD4462896DBBDE FOREIGN KEY (updated_by_id) REFERENCES account_users (id) ON DELETE SET NULL');
$this->addSql('ALTER TABLE channel_user_session_permissions ADD CONSTRAINT FK_95CD446223887597 FOREIGN KEY (channel_user_data_id) REFERENCES channel_user_data (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_user_session_permissions ADD CONSTRAINT FK_95CD446289329D25 FOREIGN KEY (resource_id) REFERENCES channel_sessions (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_session_referents DROP FOREIGN KEY FK_409CEDC3A76ED395');
$this->addSql('ALTER TABLE channel_session_referents DROP FOREIGN KEY FK_409CEDC3613FECDF');
$this->addSql('ALTER TABLE channel_session_coordinators DROP FOREIGN KEY FK_E04A9B9C613FECDF');
$this->addSql('ALTER TABLE channel_session_coordinators DROP FOREIGN KEY FK_E04A9B9CA76ED395');
$this->addSql('ALTER TABLE channel_channel_permissions DROP FOREIGN KEY FK_4D88D10CA76ED395');
$this->addSql('ALTER TABLE channel_channel_permissions DROP FOREIGN KEY FK_4D88D10C158E0B66');
$this->addSql('ALTER TABLE channel_channel_permissions DROP FOREIGN KEY FK_4D88D10CB03A8386');
$this->addSql('ALTER TABLE channel_channel_permissions DROP FOREIGN KEY FK_4D88D10C896DBBDE');
$this->addSql('DROP TABLE channel_session_referents');
$this->addSql('DROP TABLE channel_session_coordinators');
$this->addSql('DROP TABLE channel_channel_permissions');
$this->addSql('ALTER TABLE channel_user_data ADD channel_user_role_id INT DEFAULT NULL, ADD expire_at DATE DEFAULT NULL, ADD start_at DATE DEFAULT NULL, ADD displayed_menu LONGTEXT DEFAULT NULL COMMENT \'(DC2Type:simple_array)\', CHANGE is_learner is_learner TINYINT(1) DEFAULT 1 NOT NULL');
$this->addSql('ALTER TABLE channel_user_data ADD CONSTRAINT FK_780F1495C27EF607 FOREIGN KEY (channel_user_role_id) REFERENCES channel_user_role (id) ON DELETE SET NULL');
$this->addSql('CREATE INDEX IDX_780F1495C27EF607 ON channel_user_data (channel_user_role_id)');
}
public function down(Schema $schema): void
{
// this down() migration is auto-generated, please modify it to your needs
$this->addSql('ALTER TABLE channel_user_data DROP FOREIGN KEY FK_780F1495C27EF607');
$this->addSql('CREATE TABLE channel_session_referents (session_id INT NOT NULL, user_id VARCHAR(36) CHARACTER SET utf8mb4 NOT NULL COLLATE `utf8mb4_unicode_ci`, INDEX IDX_409CEDC3A76ED395 (user_id), INDEX IDX_409CEDC3613FECDF (session_id), PRIMARY KEY(session_id, user_id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB COMMENT = \'\' ');
$this->addSql('CREATE TABLE channel_session_coordinators (session_id INT NOT NULL, user_id VARCHAR(36) CHARACTER SET utf8mb4 NOT NULL COLLATE `utf8mb4_unicode_ci`, INDEX IDX_E04A9B9C613FECDF (session_id), INDEX IDX_E04A9B9CA76ED395 (user_id), PRIMARY KEY(session_id, user_id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB COMMENT = \'\' ');
$this->addSql('CREATE TABLE channel_channel_permissions (id VARCHAR(36) CHARACTER SET utf8mb4 NOT NULL COLLATE `utf8mb4_unicode_ci`, user_id VARCHAR(36) CHARACTER SET utf8mb4 NOT NULL COLLATE `utf8mb4_unicode_ci`, target_id VARCHAR(36) CHARACTER SET utf8mb4 NOT NULL COLLATE `utf8mb4_unicode_ci`, created_by_id VARCHAR(36) CHARACTER SET utf8mb4 DEFAULT NULL COLLATE `utf8mb4_unicode_ci`, updated_by_id VARCHAR(36) CHARACTER SET utf8mb4 DEFAULT NULL COLLATE `utf8mb4_unicode_ci`, perms JSON NOT NULL COMMENT \'(DC2Type:json)\', expire_at DATETIME DEFAULT NULL, status VARCHAR(15) CHARACTER SET utf8mb4 NOT NULL COLLATE `utf8mb4_unicode_ci`, created_at DATETIME NOT NULL, updated_at DATETIME DEFAULT NULL, start_at DATETIME DEFAULT NULL, UNIQUE INDEX UNIQ_4D88D10CA76ED395158E0B66 (user_id, target_id), INDEX IDX_4D88D10CB03A8386 (created_by_id), INDEX IDX_4D88D10C896DBBDE (updated_by_id), INDEX IDX_4D88D10CA76ED395 (user_id), INDEX IDX_4D88D10C158E0B66 (target_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB COMMENT = \'\' ');
$this->addSql('ALTER TABLE channel_session_referents ADD CONSTRAINT FK_409CEDC3A76ED395 FOREIGN KEY (user_id) REFERENCES account_users (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_session_referents ADD CONSTRAINT FK_409CEDC3613FECDF FOREIGN KEY (session_id) REFERENCES channel_sessions (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_session_coordinators ADD CONSTRAINT FK_E04A9B9C613FECDF FOREIGN KEY (session_id) REFERENCES channel_sessions (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_session_coordinators ADD CONSTRAINT FK_E04A9B9CA76ED395 FOREIGN KEY (user_id) REFERENCES account_users (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_channel_permissions ADD CONSTRAINT FK_4D88D10CA76ED395 FOREIGN KEY (user_id) REFERENCES account_users (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_channel_permissions ADD CONSTRAINT FK_4D88D10C158E0B66 FOREIGN KEY (target_id) REFERENCES channel_channels (id) ON DELETE CASCADE');
$this->addSql('ALTER TABLE channel_channel_permissions ADD CONSTRAINT FK_4D88D10CB03A8386 FOREIGN KEY (created_by_id) REFERENCES account_users (id) ON DELETE SET NULL');
$this->addSql('ALTER TABLE channel_channel_permissions ADD CONSTRAINT FK_4D88D10C896DBBDE FOREIGN KEY (updated_by_id) REFERENCES account_users (id) ON DELETE SET NULL');
$this->addSql('ALTER TABLE channel_user_role DROP FOREIGN KEY FK_82956D9C72F5A1AA');
$this->addSql('ALTER TABLE channel_user_service_permissions DROP FOREIGN KEY FK_A50E7CB9B03A8386');
$this->addSql('ALTER TABLE channel_user_service_permissions DROP FOREIGN KEY FK_A50E7CB9896DBBDE');
$this->addSql('ALTER TABLE channel_user_service_permissions DROP FOREIGN KEY FK_A50E7CB923887597');
$this->addSql('ALTER TABLE channel_user_service_permissions DROP FOREIGN KEY FK_A50E7CB989329D25');
$this->addSql('ALTER TABLE channel_user_session_permissions DROP FOREIGN KEY FK_95CD4462B03A8386');
$this->addSql('ALTER TABLE channel_user_session_permissions DROP FOREIGN KEY FK_95CD4462896DBBDE');
$this->addSql('ALTER TABLE channel_user_session_permissions DROP FOREIGN KEY FK_95CD446223887597');
$this->addSql('ALTER TABLE channel_user_session_permissions DROP FOREIGN KEY FK_95CD446289329D25');
$this->addSql('DROP TABLE channel_user_role');
$this->addSql('DROP TABLE channel_user_service_permissions');
$this->addSql('DROP TABLE channel_user_session_permissions');
$this->addSql('DROP INDEX IDX_780F1495C27EF607 ON channel_user_data');
$this->addSql('ALTER TABLE channel_user_data DROP channel_user_role_id, DROP expire_at, DROP start_at, DROP displayed_menu, CHANGE is_learner is_learner INT DEFAULT 1 NOT NULL');
}
}