L'inscription Classeo se fait via invitation : un admin crée un compte, l'utilisateur reçoit un lien d'activation par email pour définir son mot de passe. Ce flow sécurisé évite les inscriptions non autorisées et garantit que seuls les utilisateurs légitimes accèdent au système. Points clés de l'implémentation : - Tokens d'activation à usage unique stockés en cache (Redis/filesystem) - Validation du consentement parental pour les mineurs < 15 ans (RGPD) - L'échec d'activation ne consume pas le token (retry possible) - Users dans un cache séparé sans TTL (pas d'expiration) - Hot reload en dev (FrankenPHP sans mode worker) Story: 1.3 - Inscription et activation de compte
34 lines
956 B
PHP
34 lines
956 B
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Administration\Domain\Model\User;
|
|
|
|
/**
|
|
* Enum représentant le statut d'activation d'un compte utilisateur.
|
|
*/
|
|
enum StatutCompte: string
|
|
{
|
|
case EN_ATTENTE = 'pending'; // Compte créé, en attente d'activation
|
|
case CONSENTEMENT_REQUIS = 'consent'; // Mineur < 15 ans, en attente consentement parental
|
|
case ACTIF = 'active'; // Compte activé et utilisable
|
|
case SUSPENDU = 'suspended'; // Compte temporairement désactivé
|
|
case ARCHIVE = 'archived'; // Compte archivé (fin de scolarité)
|
|
|
|
/**
|
|
* Vérifie si l'utilisateur peut se connecter avec ce statut.
|
|
*/
|
|
public function peutSeConnecter(): bool
|
|
{
|
|
return $this === self::ACTIF;
|
|
}
|
|
|
|
/**
|
|
* Vérifie si l'utilisateur peut activer son compte.
|
|
*/
|
|
public function peutActiver(): bool
|
|
{
|
|
return $this === self::EN_ATTENTE;
|
|
}
|
|
}
|