src/CoreBundle/Migrations/Schema/V200/Version20181025064351.php
<?php
declare(strict_types=1);
/* For licensing terms, see /license.txt */
namespace Chamilo\CoreBundle\Migrations\Schema\V200;
use Chamilo\CoreBundle\Migrations\AbstractMigrationChamilo;
use Doctrine\DBAL\Schema\Schema;
class Version20181025064351 extends AbstractMigrationChamilo
{
public function getDescription(): string
{
return 'Migrate gradebook_category';
}
public function up(Schema $schema): void
{
$table = $schema->getTable('gradebook_result_log');
if ($table->hasColumn('id_result')) {
$this->addSql('DELETE FROM gradebook_result_log WHERE id_result IS NULL');
$this->addSql('ALTER TABLE gradebook_result_log CHANGE id_result result_id INT DEFAULT NULL');
}
$this->addSql('UPDATE gradebook_result_log SET evaluation_id = NULL WHERE evaluation_id = 0');
$this->addSql('ALTER TABLE gradebook_result_log CHANGE evaluation_id evaluation_id INT DEFAULT NULL');
$this->addSql('UPDATE gradebook_result_log SET user_id = NULL WHERE user_id = 0');
$this->addSql('ALTER TABLE gradebook_result_log CHANGE user_id user_id INT DEFAULT NULL');
$this->addSql('DELETE FROM gradebook_result_log WHERE result_id NOT IN (SELECT id FROM gradebook_result) ');
if (!$table->hasForeignKey('FK_C5C4CABB7A7B643')) {
$this->addSql(
'ALTER TABLE gradebook_result_log ADD CONSTRAINT FK_C5C4CABB7A7B643 FOREIGN KEY (result_id) REFERENCES gradebook_result (id) ON DELETE CASCADE;'
);
$this->addSql('CREATE INDEX IDX_C5C4CABB7A7B643 ON gradebook_result_log (result_id)');
}
$this->addSql('DELETE FROM gradebook_result_log WHERE evaluation_id NOT IN (SELECT id FROM gradebook_evaluation) ');
if (!$table->hasForeignKey('FK_C5C4CABB456C5646')) {
$this->addSql(
'ALTER TABLE gradebook_result_log ADD CONSTRAINT FK_C5C4CABB456C5646 FOREIGN KEY (evaluation_id) REFERENCES gradebook_evaluation (id) ON DELETE CASCADE;'
);
$this->addSql('CREATE INDEX IDX_C5C4CABB456C5646 ON gradebook_result_log (evaluation_id);');
}
$this->addSql('DELETE FROM gradebook_result_log WHERE user_id NOT IN (SELECT id FROM user)');
if (false === $table->hasForeignKey('FK_C5C4CABBA76ED395')) {
$this->addSql(
'ALTER TABLE gradebook_result_log ADD CONSTRAINT FK_C5C4CABBA76ED395 FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE CASCADE'
);
}
if (false === $table->hasIndex('IDX_C5C4CABBA76ED395')) {
$this->addSql('CREATE INDEX IDX_C5C4CABBA76ED395 ON gradebook_result_log (user_id)');
}
$table = $schema->getTable('gradebook_category');
$this->addSql('ALTER TABLE gradebook_category CHANGE user_id user_id INT DEFAULT NULL');
if ($table->hasIndex('idx_gb_cat_parent')) {
$this->addSql(' DROP INDEX idx_gb_cat_parent ON gradebook_category;');
}
$this->addSql('UPDATE gradebook_category SET session_id = NULL WHERE session_id = 0 OR session_id NOT IN (SELECT id FROM session)');
$this->addSql('UPDATE gradebook_category SET parent_id = NULL WHERE parent_id = 0');
$this->addSql('DELETE FROM gradebook_category WHERE parent_id > 0 AND parent_id NOT IN (SELECT id FROM gradebook_category)');
if (false === $table->hasForeignKey('FK_96A4C705727ACA70')) {
$this->addSql('ALTER TABLE gradebook_category ADD CONSTRAINT FK_96A4C705727ACA70 FOREIGN KEY (parent_id) REFERENCES gradebook_category (id) ON DELETE CASCADE');
}
if (false === $table->hasForeignKey('FK_96A4C705613FECDF')) {
$this->addSql('ALTER TABLE gradebook_category ADD CONSTRAINT FK_96A4C705613FECDF FOREIGN KEY (session_id) REFERENCES session (id) ON DELETE CASCADE;');
}
if (false === $table->hasIndex('IDX_96A4C705613FECDF')) {
$this->addSql('CREATE INDEX IDX_96A4C705613FECDF ON gradebook_category (session_id)');
}
if (false === $table->hasIndex('IDX_96A4C705727ACA70')) {
$this->addSql('CREATE INDEX IDX_96A4C705727ACA70 ON gradebook_category (parent_id);');
}
if (false === $table->hasColumn('c_id')) {
$this->addSql('ALTER TABLE gradebook_category ADD c_id INT DEFAULT NULL');
$this->addSql('UPDATE gradebook_category SET c_id = (SELECT id FROM course WHERE code = course_code)');
$this->addSql('ALTER TABLE gradebook_category DROP course_code');
$this->addSql(
'ALTER TABLE gradebook_category ADD CONSTRAINT FK_96A4C70591D79BD3 FOREIGN KEY (c_id) REFERENCES course (id) ON DELETE CASCADE'
);
$this->addSql('CREATE INDEX IDX_96A4C70591D79BD3 ON gradebook_category (c_id);');
}
if (false === $table->hasColumn('depends')) {
$this->addSql('ALTER TABLE gradebook_category ADD depends LONGTEXT DEFAULT NULL');
}
if (false === $table->hasColumn('minimum_to_validate')) {
$this->addSql('ALTER TABLE gradebook_category ADD minimum_to_validate INT DEFAULT NULL');
}
if (false === $table->hasColumn('gradebooks_to_validate_in_dependence')) {
$this->addSql('ALTER TABLE gradebook_category ADD gradebooks_to_validate_in_dependence INT DEFAULT NULL');
}
$this->addSql('UPDATE gradebook_category SET user_id = NULL WHERE user_id NOT IN (SELECT id FROM user)');
if (false === $table->hasForeignKey('FK_96A4C705A76ED395')) {
$this->addSql(
'ALTER TABLE gradebook_category ADD CONSTRAINT FK_96A4C705A76ED395 FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE SET NULL'
);
}
if (false === $table->hasIndex('IDX_96A4C705A76ED395')) {
$this->addSql('CREATE INDEX IDX_96A4C705A76ED395 ON gradebook_category (user_id)');
}
$this->addSql('UPDATE gradebook_category SET grade_model_id = NULL WHERE grade_model_id = 0 OR grade_model_id = -1');
if (!$table->hasForeignKey('FK_96A4C705378B7921')) {
$this->addSql('ALTER TABLE gradebook_category ADD CONSTRAINT FK_96A4C705378B7921 FOREIGN KEY (grade_model_id) REFERENCES grade_model (id) ON DELETE CASCADE;');
}
if (!$table->hasIndex('IDX_96A4C705378B7921')) {
$this->addSql('CREATE INDEX IDX_96A4C705378B7921 ON gradebook_category (grade_model_id);');
}
// grade_components.
$table = $schema->getTable('grade_components');
$this->addSql('ALTER TABLE grade_components CHANGE grade_model_id grade_model_id INT DEFAULT NULL');
if (!$table->hasForeignKey('FK_F34247C378B7921')) {
$this->addSql('ALTER TABLE grade_components ADD CONSTRAINT FK_F34247C378B7921 FOREIGN KEY (grade_model_id) REFERENCES grade_model (id) ON DELETE CASCADE;');
}
if (!$table->hasIndex('IDX_F34247C378B7921')) {
$this->addSql('CREATE INDEX IDX_F34247C378B7921 ON grade_components (grade_model_id);');
}
// Evaluation.
$table = $schema->getTable('gradebook_evaluation');
if (!$table->hasColumn('c_id')) {
$this->addSql('ALTER TABLE gradebook_evaluation ADD c_id INT DEFAULT NULL');
$this->addSql('UPDATE gradebook_evaluation SET c_id = (SELECT id FROM course WHERE code = course_code)');
$this->addSql('ALTER TABLE gradebook_evaluation DROP course_code');
$this->addSql(
'ALTER TABLE gradebook_evaluation ADD CONSTRAINT FK_DDDED80491D79BD3 FOREIGN KEY (c_id) REFERENCES course (id) ON DELETE CASCADE'
);
$this->addSql('CREATE INDEX IDX_DDDED80491D79BD3 ON gradebook_evaluation (c_id)');
// $this->addSql('ALTER TABLE gradebook_evaluation RENAME INDEX fk_ddded80491d79bd3 TO IDX_DDDED80491D79BD3;');
}
if (false === $table->hasIndex('idx_ge_cat')) {
$this->addSql('CREATE INDEX idx_ge_cat ON gradebook_evaluation (category_id)');
}
$this->addSql('DELETE FROM gradebook_evaluation WHERE category_id NOT IN (SELECT id FROM gradebook_category) ');
if (!$table->hasForeignKey('FK_DDDED80412469DE2')) {
$this->addSql('ALTER TABLE gradebook_evaluation ADD CONSTRAINT FK_DDDED80412469DE2 FOREIGN KEY (category_id) REFERENCES gradebook_category (id) ON DELETE CASCADE');
}
if (false === $table->hasColumn('best_score')) {
$this->addSql('ALTER TABLE gradebook_evaluation ADD best_score DOUBLE PRECISION DEFAULT NULL');
}
if (false === $table->hasColumn('average_score')) {
$this->addSql('ALTER TABLE gradebook_evaluation ADD average_score DOUBLE PRECISION DEFAULT NULL');
}
if (false === $table->hasColumn('score_weight')) {
$this->addSql('ALTER TABLE gradebook_evaluation ADD score_weight DOUBLE PRECISION DEFAULT NULL');
}
if (false === $table->hasColumn('user_score_list')) {
$this->addSql(
'ALTER TABLE gradebook_evaluation ADD user_score_list LONGTEXT DEFAULT NULL COMMENT \'(DC2Type:array)\''
);
}
$this->addSql('ALTER TABLE gradebook_evaluation CHANGE user_id user_id INT DEFAULT NULL');
if (false === $table->hasForeignKey('FK_DDDED804A76ED395')) {
$this->addSql('DELETE FROM gradebook_evaluation WHERE user_id NOT IN (SELECT id FROM user) ');
$this->addSql(
'ALTER TABLE gradebook_evaluation ADD CONSTRAINT FK_DDDED804A76ED395 FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE CASCADE'
);
}
if (false === $table->hasIndex('IDX_DDDED804A76ED395')) {
$this->addSql('CREATE INDEX IDX_DDDED804A76ED395 ON gradebook_evaluation (user_id)');
}
$table = $schema->getTable('gradebook_link');
if (false === $table->hasColumn('c_id')) {
$this->addSql('ALTER TABLE gradebook_link ADD c_id INT DEFAULT NULL');
$this->addSql('UPDATE gradebook_link SET c_id = (SELECT id FROM course WHERE code = course_code)');
$this->addSql('ALTER TABLE gradebook_link DROP course_code');
$this->addSql(
'ALTER TABLE gradebook_link ADD CONSTRAINT FK_4F0F595F91D79BD3 FOREIGN KEY (c_id) REFERENCES course (id) ON DELETE CASCADE'
);
$this->addSql('CREATE INDEX IDX_4F0F595F91D79BD3 ON gradebook_link (c_id);');
}
if (false === $table->hasColumn('best_score')) {
$this->addSql('ALTER TABLE gradebook_link ADD best_score DOUBLE PRECISION DEFAULT NULL');
}
if (false === $table->hasColumn('average_score')) {
$this->addSql(
'ALTER TABLE gradebook_link ADD average_score DOUBLE PRECISION DEFAULT NULL'
);
}
if (false === $table->hasColumn('score_weight')) {
$this->addSql('ALTER TABLE gradebook_link ADD score_weight DOUBLE PRECISION DEFAULT NULL');
}
if (false === $table->hasColumn('user_score_list')) {
$this->addSql(
'ALTER TABLE gradebook_link ADD user_score_list LONGTEXT DEFAULT NULL COMMENT \'(DC2Type:array)\''
);
}
if (false === $table->hasIndex('idx_gl_cat')) {
$this->addSql('CREATE INDEX idx_gl_cat ON gradebook_link (category_id)');
}
$this->addSql('ALTER TABLE gradebook_link CHANGE user_id user_id INT DEFAULT NULL');
if (false === $table->hasForeignKey('FK_4F0F595FA76ED395')) {
$this->addSql('DELETE FROM gradebook_link WHERE user_id NOT IN (SELECT id FROM user)');
$this->addSql(
'ALTER TABLE gradebook_link ADD CONSTRAINT FK_4F0F595FA76ED395 FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE CASCADE'
);
}
if (false === $table->hasIndex('IDX_4F0F595FA76ED395')) {
$this->addSql('CREATE INDEX IDX_4F0F595FA76ED395 ON gradebook_link (user_id)');
}
$this->addSql('ALTER TABLE gradebook_link CHANGE category_id category_id INT DEFAULT NULL;');
$this->addSql('UPDATE gradebook_link SET category_id = NULL WHERE category_id = 0');
$this->addSql('DELETE FROM gradebook_link WHERE category_id NOT IN (SELECT id FROM gradebook_category) ');
if (false === $table->hasForeignKey('FK_4F0F595F12469DE2')) {
$this->addSql('ALTER TABLE gradebook_link ADD CONSTRAINT FK_4F0F595F12469DE2 FOREIGN KEY (category_id) REFERENCES gradebook_category (id) ON DELETE CASCADE');
}
$table = $schema->getTable('gradebook_result');
if (false === $table->hasIndex('idx_gb_uid_eid')) {
$this->addSql('CREATE INDEX idx_gb_uid_eid ON gradebook_result (user_id, evaluation_id);');
}
if (!$table->hasIndex('IDX_B88AEB67456C5646')) {
$this->addSql('CREATE INDEX IDX_B88AEB67456C5646 ON gradebook_result (evaluation_id);');
}
$this->addSql('ALTER TABLE gradebook_result CHANGE evaluation_id evaluation_id INT DEFAULT NULL;');
$this->addSql('UPDATE gradebook_result SET evaluation_id = NULL WHERE evaluation_id = 0');
$this->addSql('DELETE FROM gradebook_result WHERE evaluation_id NOT IN (SELECT id FROM gradebook_evaluation) ');
if (!$table->hasForeignKey('FK_B88AEB67456C5646')) {
$this->addSql('ALTER TABLE gradebook_result ADD CONSTRAINT FK_B88AEB67456C5646 FOREIGN KEY (evaluation_id) REFERENCES gradebook_evaluation (id) ON DELETE CASCADE');
}
$this->addSql('ALTER TABLE gradebook_result CHANGE user_id user_id INT DEFAULT NULL');
$this->addSql('UPDATE gradebook_result SET user_id = NULL WHERE user_id = 0 OR user_id NOT IN (SELECT id FROM user)');
if (!$table->hasForeignKey('FK_B88AEB67A76ED395')) {
$this->addSql(
'ALTER TABLE gradebook_result ADD CONSTRAINT FK_B88AEB67A76ED395 FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE CASCADE'
);
}
if (!$table->hasIndex('IDX_B88AEB67A76ED395')) {
$this->addSql('CREATE INDEX IDX_B88AEB67A76ED395 ON gradebook_result (user_id)');
}
$table = $schema->getTable('gradebook_certificate');
$this->addSql('ALTER TABLE gradebook_certificate CHANGE cat_id cat_id INT DEFAULT NULL;');
$this->addSql('UPDATE gradebook_certificate SET cat_id = NULL WHERE cat_id = 0 OR cat_id NOT IN (SELECT id FROM gradebook_category)');
if (false === $table->hasForeignKey('FK_650669DE6ADA943')) {
if ($table->hasIndex('idx_gradebook_certificate_category_id')) {
$this->addSql('DROP INDEX idx_gradebook_certificate_category_id ON gradebook_certificate;');
}
if ($table->hasIndex('idx_gradebook_certificate_category_id_user_id')) {
$this->addSql('DROP INDEX idx_gradebook_certificate_category_id_user_id ON gradebook_certificate;');
}
$this->addSql('ALTER TABLE gradebook_certificate ADD CONSTRAINT FK_650669DE6ADA943 FOREIGN KEY (cat_id) REFERENCES gradebook_category (id) ON DELETE CASCADE;');
}
if (false === $table->hasColumn('downloaded_at')) {
$this->addSql('ALTER TABLE gradebook_certificate ADD downloaded_at DATETIME DEFAULT NULL;');
$this->addSql(
'UPDATE gradebook_certificate gc SET downloaded_at = (
SELECT field_value from extra_field e
INNER JOIN extra_field_values v on v.field_id = e.id
WHERE variable = "downloaded_at" and item_type = 11 and item_id = gc.id
)'
);
}
$this->addSql('ALTER TABLE gradebook_certificate CHANGE user_id user_id INT DEFAULT NULL');
$this->addSql('DELETE FROM gradebook_certificate WHERE user_id NOT IN (SELECT id FROM user)');
if (false === $table->hasForeignKey('FK_650669DA76ED395')) {
$this->addSql(
'ALTER TABLE gradebook_certificate ADD CONSTRAINT FK_650669DA76ED395 FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE CASCADE'
);
}
if (false === $table->hasIndex('IDX_650669DE6ADA943')) {
$this->addSql('CREATE INDEX IDX_650669DE6ADA943 ON gradebook_certificate (cat_id);');
}
if (false === $schema->hasTable('gradebook_result_attempt')) {
$this->addSql(
'CREATE TABLE gradebook_result_attempt (id INT AUTO_INCREMENT NOT NULL, comment LONGTEXT DEFAULT NULL, score DOUBLE PRECISION DEFAULT NULL, result_id INT DEFAULT NULL, created_at DATETIME NOT NULL, updated_at DATETIME NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci ENGINE = InnoDB ROW_FORMAT = DYNAMIC;'
);
$this->addSql('ALTER TABLE gradebook_result_attempt ADD CONSTRAINT FK_28B1CC3F7A7B643 FOREIGN KEY (result_id) REFERENCES gradebook_result (id) ON DELETE CASCADE;');
$this->addSql('CREATE INDEX IDX_28B1CC3F7A7B643 ON gradebook_result_attempt (result_id);');
} else {
$table = $schema->getTable('gradebook_result_attempt');
$this->addSql('UPDATE gradebook_result_attempt SET result_id = NULL WHERE result_id = 0');
$this->addSql('ALTER TABLE gradebook_result_attempt CHANGE result_id result_id INT DEFAULT NULL');
if (!$table->hasForeignKey('FK_28B1CC3F7A7B643')) {
$this->addSql('ALTER TABLE gradebook_result_attempt ADD CONSTRAINT FK_28B1CC3F7A7B643 FOREIGN KEY (result_id) REFERENCES gradebook_result (id) ON DELETE CASCADE;');
}
if (!$table->hasIndex('IDX_28B1CC3F7A7B643')) {
$this->addSql('CREATE INDEX IDX_28B1CC3F7A7B643 ON gradebook_result_attempt (result_id);');
}
}
if (false === $table->hasForeignKey('FK_1F554C7474C99BA2')) {
}
$table = $schema->getTable('gradebook_linkeval_log');
$this->addSql('ALTER TABLE gradebook_linkeval_log CHANGE user_id_log user_id_log INT DEFAULT NULL');
$this->addSql('UPDATE gradebook_linkeval_log SET user_id_log = NULL WHERE user_id_log = 0 OR user_id_log NOT IN (SELECT id FROM user)');
if (false === $table->hasForeignKey('FK_1F554C7474C99BA2')) {
$this->addSql(
'ALTER TABLE gradebook_linkeval_log ADD CONSTRAINT FK_1F554C7474C99BA2 FOREIGN KEY (user_id_log) REFERENCES user (id) ON DELETE CASCADE'
);
}
if (false === $table->hasIndex('IDX_1F554C7474C99BA2')) {
$this->addSql('CREATE INDEX IDX_1F554C7474C99BA2 ON gradebook_linkeval_log (user_id_log)');
}
$table = $schema->getTable('gradebook_score_log');
$this->addSql('ALTER TABLE gradebook_score_log CHANGE user_id user_id INT DEFAULT NULL');
$this->addSql('ALTER TABLE gradebook_score_log CHANGE category_id category_id INT DEFAULT NULL;');
$this->addSql('DELETE FROM gradebook_score_log WHERE user_id NOT IN (SELECT id FROM user)');
$this->addSql('DELETE FROM gradebook_score_log WHERE category_id NOT IN (SELECT id FROM gradebook_category)');
if (false === $table->hasForeignKey('FK_640C6449A76ED395')) {
$this->addSql(
'ALTER TABLE gradebook_score_log ADD CONSTRAINT FK_640C6449A76ED395 FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE CASCADE'
);
}
if (false === $table->hasForeignKey('FK_640C644912469DE2')) {
$this->addSql(
'ALTER TABLE gradebook_score_log ADD CONSTRAINT FK_640C644912469DE2 FOREIGN KEY (category_id) REFERENCES gradebook_category (id) ON DELETE CASCADE;'
);
}
if (false === $table->hasIndex('IDX_640C644912469DE2')) {
$this->addSql('CREATE INDEX IDX_640C644912469DE2 ON gradebook_score_log (category_id);');
}
$table = $schema->hasTable('gradebook_comment');
if (false === $table) {
$this->addSql('CREATE TABLE gradebook_comment (id INT AUTO_INCREMENT NOT NULL, user_id INT DEFAULT NULL, gradebook_id INT DEFAULT NULL, comment LONGTEXT NOT NULL, created_at DATETIME NOT NULL, updated_at DATETIME NOT NULL, INDEX IDX_C3B70763A76ED395 (user_id), INDEX IDX_C3B70763AD3ED51C (gradebook_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB ROW_FORMAT = DYNAMIC;');
$this->addSql('ALTER TABLE gradebook_comment ADD CONSTRAINT FK_C3B70763A76ED395 FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE SET NULL;');
$this->addSql('ALTER TABLE gradebook_comment ADD CONSTRAINT FK_C3B70763AD3ED51C FOREIGN KEY (gradebook_id) REFERENCES gradebook_category (id) ON DELETE CASCADE;');
}
$table = $schema->getTable('gradebook_score_display');
$this->addSql('ALTER TABLE gradebook_score_display CHANGE category_id category_id INT DEFAULT NULL;');
$this->addSql('UPDATE gradebook_score_display SET category_id = NULL WHERE category_id = 0 OR category_id NOT IN (SELECT id FROM gradebook_category)');
if (false === $table->hasForeignKey('FK_61F7DC8412469DE2')) {
$this->addSql('ALTER TABLE gradebook_score_display ADD CONSTRAINT FK_61F7DC8412469DE2 FOREIGN KEY (category_id) REFERENCES gradebook_category (id) ON DELETE CASCADE;');
}
}
public function down(Schema $schema): void {}
}