Connexion persistante
This commit is contained in:
parent
201d97ec41
commit
c605d31e48
@ -12,6 +12,7 @@
|
|||||||
- Mise à jour automatisée, affichage de l'erreur en cas d'échec.
|
- Mise à jour automatisée, affichage de l'erreur en cas d'échec.
|
||||||
- Suppression du support de l'import à partir d'une version 9, y compris pour la restauration des sauvegardes.
|
- Suppression du support de l'import à partir d'une version 9, y compris pour la restauration des sauvegardes.
|
||||||
- Optimisation du chargement des base de données, mise à jour des scripts jsonDB et dot.
|
- Optimisation du chargement des base de données, mise à jour des scripts jsonDB et dot.
|
||||||
|
- Connexion persistante, l'activation de la case à cocher *Rester connecté sur ce navigateur* ne ferme pas la session lorsque le navigateur est fermé.
|
||||||
|
|
||||||
## Version 11.4.02
|
## Version 11.4.02
|
||||||
### Modifications :
|
### Modifications :
|
||||||
|
@ -829,24 +829,7 @@ if ($this->getData(['core', 'dataVersion']) < 11400) {
|
|||||||
// Redirection des pages d'administration vers la bannière de connexion
|
// Redirection des pages d'administration vers la bannière de connexion
|
||||||
$this->setData(['config', 'connect', 'redirectLogin', true]);
|
$this->setData(['config', 'connect', 'redirectLogin', true]);
|
||||||
|
|
||||||
// Transforme les URL en références relatives
|
|
||||||
/*
|
|
||||||
$baseUrl = $this->getData(['core', 'baseUrl']);
|
|
||||||
$baseUrl2 = str_replace('?', '', $baseUrl);
|
|
||||||
foreach ($this->getHierarchy(null,null,null) as $parentKey=>$parentValue) {
|
|
||||||
$pageList [] = $parentKey;
|
|
||||||
foreach ($parentValue as $childKey) {
|
|
||||||
$pageList [] = $childKey;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
foreach ($pageList as $parentKey => $parent) {
|
|
||||||
$s = $this->getPage( $parent, self::$i18n);
|
|
||||||
// Suppression des sous-dossiers
|
|
||||||
$s = str_replace ($baseUrl, './', $s);
|
|
||||||
$s = str_replace ($baseUrl2, './', $s);
|
|
||||||
$this->setPage( $parent, $s, self::$i18n);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Suppression de la variable URL dans core
|
// Suppression de la variable URL dans core
|
||||||
$this->deleteData(['core', 'baseUrl']);
|
$this->deleteData(['core', 'baseUrl']);
|
||||||
@ -854,3 +837,12 @@ if ($this->getData(['core', 'dataVersion']) < 11400) {
|
|||||||
// Mise à jour
|
// Mise à jour
|
||||||
$this->setData(['core', 'dataVersion', 11400]);
|
$this->setData(['core', 'dataVersion', 11400]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Version 12.0.00
|
||||||
|
if ($this->getData(['core', 'dataVersion']) < 12000) {
|
||||||
|
// Supprime un cookie non nécessaire
|
||||||
|
helper::deleteCookie('ZWII_USER_LONGTIME');
|
||||||
|
|
||||||
|
// Mise à jour
|
||||||
|
$this->setData(['core', 'dataVersion', 12000]);
|
||||||
|
}
|
@ -438,11 +438,9 @@ class user extends common {
|
|||||||
$this->setData(['user',$userId,'connectFail',0 ]);
|
$this->setData(['user',$userId,'connectFail',0 ]);
|
||||||
$this->setData(['user',$userId,'connectTimeout',0 ]);
|
$this->setData(['user',$userId,'connectTimeout',0 ]);
|
||||||
// Expiration
|
// Expiration
|
||||||
$expire = $this->getInput('userLoginLongTime') ? strtotime("+1 year") : 0;
|
$expire = $this->getInput('userLoginLongTime', helper::FILTER_BOOLEAN ) === true ? strtotime("+1 year") : 0 ;
|
||||||
$c = $this->getInput('userLoginLongTime', helper::FILTER_BOOLEAN) === true ? 'true' : 'false';
|
|
||||||
setcookie('ZWII_USER_ID', $userId, $expire, helper::baseUrl(false, false) , '', helper::isHttps(), true);
|
setcookie('ZWII_USER_ID', $userId, $expire, helper::baseUrl(false, false) , '', helper::isHttps(), true);
|
||||||
setcookie('ZWII_USER_PASSWORD', $this->getData(['user', $userId, 'password']), $expire, helper::baseUrl(false, false), '', helper::isHttps(), true);
|
setcookie('ZWII_USER_PASSWORD', $this->getData(['user', $userId, 'password']), $expire, helper::baseUrl(false, false), '', helper::isHttps(), true);
|
||||||
setcookie('ZWII_USER_LONGTIME', $c, $expire, helper::baseUrl(false, false), '', helper::isHttps(), true);
|
|
||||||
// Accès multiples avec le même compte
|
// Accès multiples avec le même compte
|
||||||
$this->setData(['user',$userId,'accessCsrf',$_SESSION['csrf']]);
|
$this->setData(['user',$userId,'accessCsrf',$_SESSION['csrf']]);
|
||||||
// Valeurs en sortie lorsque le site est en maintenance et que l'utilisateur n'est pas administrateur
|
// Valeurs en sortie lorsque le site est en maintenance et que l'utilisateur n'est pas administrateur
|
||||||
@ -504,9 +502,6 @@ class user extends common {
|
|||||||
if (!empty($_COOKIE['ZWII_USER_ID'])) {
|
if (!empty($_COOKIE['ZWII_USER_ID'])) {
|
||||||
self::$userId = $_COOKIE['ZWII_USER_ID'];
|
self::$userId = $_COOKIE['ZWII_USER_ID'];
|
||||||
}
|
}
|
||||||
if (!empty($_COOKIE['ZWII_USER_LONGTIME'])) {
|
|
||||||
self::$userLongtime = $_COOKIE['ZWII_USER_LONGTIME'] == 'true' ? true : false;
|
|
||||||
}
|
|
||||||
// Valeurs en sortie
|
// Valeurs en sortie
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'display' => self::DISPLAY_LAYOUT_LIGHT,
|
'display' => self::DISPLAY_LAYOUT_LIGHT,
|
||||||
@ -519,17 +514,12 @@ class user extends common {
|
|||||||
* Déconnexion
|
* Déconnexion
|
||||||
*/
|
*/
|
||||||
public function logout() {
|
public function logout() {
|
||||||
// Ne pas effacer l'identifiant mais seulement le mot de passe
|
|
||||||
if (array_key_exists('ZWII_USER_LONGTIME',$_COOKIE)
|
|
||||||
AND $_COOKIE['ZWII_USER_LONGTIME'] !== 'true' ) {
|
|
||||||
helper::deleteCookie('ZWII_USER_ID');
|
helper::deleteCookie('ZWII_USER_ID');
|
||||||
helper::deleteCookie('ZWII_USER_LONGTIME');
|
|
||||||
}
|
|
||||||
helper::deleteCookie('ZWII_USER_PASSWORD');
|
helper::deleteCookie('ZWII_USER_PASSWORD');
|
||||||
session_destroy();
|
session_destroy();
|
||||||
// Valeurs en sortie
|
// Valeurs en sortie
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'notification' => 'Déconnexion réussie',
|
'notification' => 'Vous avez été déconnecté',
|
||||||
'redirect' => helper::baseUrl(false),
|
'redirect' => helper::baseUrl(false),
|
||||||
'state' => true
|
'state' => true
|
||||||
]);
|
]);
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
<?php endif;?>
|
<?php endif;?>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col6">
|
<div class="col6">
|
||||||
<?php echo template::checkbox('userLoginLongTime', true, 'Se souvenir de mon identifiant', [
|
<?php echo template::checkbox('userLoginLongTime', true, 'Rester connecté sur ce navigateur', [
|
||||||
'checked' => $module::$userLongtime
|
'checked' => $module::$userLongtime
|
||||||
]); ?>
|
]); ?>
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
Reference in New Issue
Block a user