Files
Classeo/backend/migrations/Version20260317100224.php
Mathias STRASSER 5f3c5c2d71
Some checks failed
CI / Backend Tests (push) Has been cancelled
CI / Frontend Tests (push) Has been cancelled
CI / E2E Tests (push) Has been cancelled
CI / Naming Conventions (push) Has been cancelled
CI / Build Check (push) Has been cancelled
feat: Permettre aux administrateurs de configurer les règles de devoirs
Les établissements ont besoin de protéger les élèves et familles des
devoirs de dernière minute. Cette configuration au niveau tenant permet
de définir des règles de timing (délai minimum, pas de devoir pour
lundi après une heure limite) et un mode d'application (avertissement,
blocage ou désactivé).

Le service de validation est prêt pour être branché dans le flux de
création de devoirs (Stories 5.4/5.5). L'historique des changements
assure la traçabilité des modifications de configuration.
2026-03-17 21:28:10 +01:00

56 lines
1.9 KiB
PHP

<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
final class Version20260317100224 extends AbstractMigration
{
public function getDescription(): string
{
return 'Create homework_rules and homework_rules_history tables';
}
public function up(Schema $schema): void
{
$this->addSql(<<<'SQL'
CREATE TABLE homework_rules (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
tenant_id UUID NOT NULL UNIQUE,
rules JSONB NOT NULL DEFAULT '[]',
enforcement_mode VARCHAR(20) DEFAULT 'soft' NOT NULL,
enabled BOOLEAN DEFAULT true NOT NULL,
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
)
SQL);
$this->addSql('CREATE INDEX idx_homework_rules_tenant ON homework_rules(tenant_id)');
$this->addSql(<<<'SQL'
CREATE TABLE homework_rules_history (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
tenant_id UUID NOT NULL,
previous_rules JSONB,
new_rules JSONB NOT NULL,
enforcement_mode VARCHAR(20) NOT NULL,
enabled BOOLEAN NOT NULL,
changed_by UUID REFERENCES users(id),
changed_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
)
SQL);
$this->addSql('CREATE INDEX idx_homework_rules_history_tenant ON homework_rules_history(tenant_id)');
$this->addSql('CREATE INDEX idx_homework_rules_history_changed_at ON homework_rules_history(changed_at DESC)');
}
public function down(Schema $schema): void
{
$this->addSql('DROP TABLE IF EXISTS homework_rules_history');
$this->addSql('DROP TABLE IF EXISTS homework_rules');
}
}