<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
final class Version20251123135707 extends AbstractMigration
{
public function getDescription(): string
{
return 'Create gamification tables: mission, mission_level, mission_history';
}
public function up(Schema $schema): void
{
// Create mybiz_mission table
$this->addSql('CREATE TABLE mybiz_mission (
id INT AUTO_INCREMENT NOT NULL,
name VARCHAR(255) NOT NULL,
marketing_name VARCHAR(255) NOT NULL,
recurrence VARCHAR(255) NOT NULL,
is_enabled TINYINT(1) NOT NULL DEFAULT 1,
category VARCHAR(255) DEFAULT NULL,
PRIMARY KEY(id)
) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
// Create mybiz_mission_level table
$this->addSql('CREATE TABLE mybiz_mission_level (
id INT AUTO_INCREMENT NOT NULL,
badge_name VARCHAR(255) DEFAULT NULL,
badge_marketing_name VARCHAR(255) DEFAULT NULL,
badge_image VARCHAR(255) DEFAULT NULL,
threshold INT NOT NULL,
xp INT NOT NULL,
level_number INT NOT NULL,
mission_id INT NOT NULL,
INDEX IDX_MISSION_LEVEL_MISSION (mission_id),
PRIMARY KEY(id)
) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
// Create mybiz_mission_history table
$this->addSql('CREATE TABLE mybiz_mission_history (
id INT AUTO_INCREMENT NOT NULL,
member_id INT NOT NULL,
mission_id INT NOT NULL,
mission_level_id INT DEFAULT NULL,
xp INT NOT NULL,
created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\',
updated_at DATETIME DEFAULT NULL COMMENT \'(DC2Type:datetime_immutable)\',
is_deprecated TINYINT(1) NOT NULL DEFAULT 0,
INDEX IDX_MISSION_HISTORY_MEMBER (member_id),
INDEX IDX_MISSION_HISTORY_MISSION (mission_id),
INDEX IDX_MISSION_HISTORY_MISSION_LEVEL (mission_level_id),
PRIMARY KEY(id)
) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
// Add foreign key constraints
$this->addSql('ALTER TABLE mybiz_mission_level ADD CONSTRAINT FK_MISSION_LEVEL_MISSION FOREIGN KEY (mission_id) REFERENCES mybiz_mission (id)');
$this->addSql('ALTER TABLE mybiz_mission_history ADD CONSTRAINT FK_MISSION_HISTORY_MEMBER FOREIGN KEY (member_id) REFERENCES app_member (id)');
$this->addSql('ALTER TABLE mybiz_mission_history ADD CONSTRAINT FK_MISSION_HISTORY_MISSION FOREIGN KEY (mission_id) REFERENCES mybiz_mission (id)');
$this->addSql('ALTER TABLE mybiz_mission_history ADD CONSTRAINT FK_MISSION_HISTORY_MISSION_LEVEL FOREIGN KEY (mission_level_id) REFERENCES mybiz_mission_level (id)');
}
public function down(Schema $schema): void
{
// Drop foreign key constraints first
$this->addSql('ALTER TABLE mybiz_mission_history DROP FOREIGN KEY FK_MISSION_HISTORY_MEMBER');
$this->addSql('ALTER TABLE mybiz_mission_history DROP FOREIGN KEY FK_MISSION_HISTORY_MISSION');
$this->addSql('ALTER TABLE mybiz_mission_history DROP FOREIGN KEY FK_MISSION_HISTORY_MISSION_LEVEL');
$this->addSql('ALTER TABLE mybiz_mission_level DROP FOREIGN KEY FK_MISSION_LEVEL_MISSION');
// Drop tables
$this->addSql('DROP TABLE mybiz_mission_history');
$this->addSql('DROP TABLE mybiz_mission_level');
$this->addSql('DROP TABLE mybiz_mission');
}
}