Les enseignants ont besoin de moyennes à jour immédiatement après la publication ou modification des notes, sans attendre un batch nocturne. Le système recalcule via Domain Events synchrones : statistiques d'évaluation (min/max/moyenne/médiane), moyennes matières pondérées (normalisation /20), et moyenne générale par élève. Les résultats sont stockés dans des tables dénormalisées avec cache Redis (TTL 5 min). Trois endpoints API exposent les données avec contrôle d'accès par rôle. Une commande console permet le backfill des données historiques au déploiement.
37 lines
852 B
PHP
37 lines
852 B
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Scolarite\Domain\Event;
|
|
|
|
use App\Scolarite\Domain\Model\Competency\StudentCompetencyResultId;
|
|
use App\Shared\Domain\DomainEvent;
|
|
use DateTimeImmutable;
|
|
use Override;
|
|
use Ramsey\Uuid\UuidInterface;
|
|
|
|
final readonly class ResultatCompetenceModifie implements DomainEvent
|
|
{
|
|
public function __construct(
|
|
public StudentCompetencyResultId $resultId,
|
|
public string $competencyEvaluationId,
|
|
public string $studentId,
|
|
public string $oldLevelCode,
|
|
public string $newLevelCode,
|
|
private DateTimeImmutable $occurredOn,
|
|
) {
|
|
}
|
|
|
|
#[Override]
|
|
public function occurredOn(): DateTimeImmutable
|
|
{
|
|
return $this->occurredOn;
|
|
}
|
|
|
|
#[Override]
|
|
public function aggregateId(): UuidInterface
|
|
{
|
|
return $this->resultId->value;
|
|
}
|
|
}
|