Sessions


1Présentation

Le système de session permet de stocker temporairement des variables, qui sont liées à un visiteur. L'intérêt est de faire des traitements dans un contrôleur en fonction des traitements effectuée précédemment dans les contrôleurs exécutés préalablement.
Chaque session est liée à un navigateur par le biais d'un cookie déposé au premier accès. Cela est transparent car géré par le framework.

L'objet de gestion des sessions est créé automatiquement par Temma, si la configuration le prévoit.


2Configuration

Dans le fichier etc/temma.php, il est possible de définir la manière dont les sessions sont stockées (voir la documentation de la configuration).

Attention, si aucune source n'est spécifiée, Temma utilise le mécanisme de sessions natif de PHP. Il faut savoir que PHP stocke les données de session dans des fichiers, qui sont verrouillés lors de leur accès. Donc une seule requête peut y accéder à la fois, ce qui peut créer des verrouillages si vous avez des requêtes qui durent longtemps (par exemple si vous utilisez des contrôleurs d'événements).


3Objet Session

Dans les contrôleurs, l'objet de session est disponible en écrivant :

$this->_session

Dans les autres objets gérés par le composant d'injection de dépendances, l'objet de session est accessible en écrivant :

$this->_loader->session

4Lecture de données

Pour lire des données depuis la session, il suffit d'utiliser l'objet comme un tableau associatif :

$currentUser = $this->_session['user'];

Pour savoir si une variable de session existe, ou si elle est vide :

// est-ce que la variable est définie ?
if (isset($this->_session['myVariable']))
    doSomething();

// est-ce que la variable est vide ?
if (empty($this->_session['myOtherVariable']))
    doSomethingElse();

// variable non définie : utilisation d'une valeur par défaut
$var = $this->_session['myVariable'] ?? 'defaultValue';

// variable non définie ou vide : valeur par défaut
$var = $this->_session['myVariable'] ?: 'defaultValue';

Avec la méthode get(), il est possible de lire une variable de session, en spécifiant une valeur par défaut qui est retournée si la donnée n'est pas présente en session :

$var = $this->_session->get('myVariable', 'Valeur par défaut');

Il est possible de récupérer toutes les variables de session avec la méthode getAll() :

$sessVariables = $this->_session->getAll();
$currentUser = $sessVariables['user'];
$basket = $sessVariables['basket'];

Il est aussi possible d'extraire un donnée de la session, c'est à dire de la lire et de l'effacer de la session en un seul appel à la méthode extract() :

$value = $this->_session->extract('myVariable');

// est équivalent à
$value = $this->_session['myVariable'];
unset($this->_session['myVariable']);

// extract() peut aussi prendre une valeur par défaut
$value = $this->_session->extract('myVariable', 'default value');

5Écriture de données

Pour créer ou modifier une variable de session :

$this->_session['myVariable'] = $value;

Si la valeur assignée à la variable vaut null, la variable est effacée de la session.

Pour lire et écrire des données, l'objet de gestion des sessions s'utilise comme un tableau. Mais cela ne permet pas d'écrire directement des valeurs sur des tableaux multi-dimensionnels.
Pour modifier un tableau multi-dimensionnel, il faut donc commencer par récupérer le tableau complet, le modifier, puis écraser la variable de session :

// cela ne fonctionne pas
$this->_session['user']['name'] = 'Einstein';

// il faut procéder ainsi
$user = $this->_session['user'];
$user['name'] = 'Einstein';
$this->_session['user'] = $user;

6Effacement de données

Pour détruire une variable de session :

unset($this->_session['myVariable']);

Pour effacer toutes les variables de la session :

$this->_session->clean();