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
23 lines
627 B
TypeScript
23 lines
627 B
TypeScript
import { readFileSync, existsSync } from 'fs';
|
|
import { join, dirname } from 'path';
|
|
import { fileURLToPath } from 'url';
|
|
|
|
const __filename = fileURLToPath(import.meta.url);
|
|
const __dirname = dirname(__filename);
|
|
|
|
/**
|
|
* Get the seeded test token.
|
|
* The token is created by global-setup.ts before tests run via Docker.
|
|
*/
|
|
export function getTestToken(): string {
|
|
const tokenFile = join(__dirname, '.test-token');
|
|
|
|
if (existsSync(tokenFile)) {
|
|
return readFileSync(tokenFile, 'utf-8').trim();
|
|
}
|
|
|
|
throw new Error(
|
|
'No .test-token file found. Make sure Docker is running and global-setup.ts executed successfully.'
|
|
);
|
|
}
|