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.
|
||||
- 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.
|
||||
- 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
|
||||
### Modifications :
|
||||
|
@ -829,24 +829,7 @@ if ($this->getData(['core', 'dataVersion']) < 11400) {
|
||||
// Redirection des pages d'administration vers la bannière de connexion
|
||||
$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
|
||||
$this->deleteData(['core', 'baseUrl']);
|
||||
@ -854,3 +837,12 @@ if ($this->getData(['core', 'dataVersion']) < 11400) {
|
||||
// Mise à jour
|
||||
$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,'connectTimeout',0 ]);
|
||||
// Expiration
|
||||
$expire = $this->getInput('userLoginLongTime') ? strtotime("+1 year") : 0;
|
||||
$c = $this->getInput('userLoginLongTime', helper::FILTER_BOOLEAN) === true ? 'true' : 'false';
|
||||
$expire = $this->getInput('userLoginLongTime', helper::FILTER_BOOLEAN ) === true ? strtotime("+1 year") : 0 ;
|
||||
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_LONGTIME', $c, $expire, helper::baseUrl(false, false), '', helper::isHttps(), true);
|
||||
// Accès multiples avec le même compte
|
||||
$this->setData(['user',$userId,'accessCsrf',$_SESSION['csrf']]);
|
||||
// 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'])) {
|
||||
self::$userId = $_COOKIE['ZWII_USER_ID'];
|
||||
}
|
||||
if (!empty($_COOKIE['ZWII_USER_LONGTIME'])) {
|
||||
self::$userLongtime = $_COOKIE['ZWII_USER_LONGTIME'] == 'true' ? true : false;
|
||||
}
|
||||
// Valeurs en sortie
|
||||
$this->addOutput([
|
||||
'display' => self::DISPLAY_LAYOUT_LIGHT,
|
||||
@ -519,17 +514,12 @@ class user extends common {
|
||||
* Déconnexion
|
||||
*/
|
||||
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_LONGTIME');
|
||||
}
|
||||
helper::deleteCookie('ZWII_USER_PASSWORD');
|
||||
session_destroy();
|
||||
// Valeurs en sortie
|
||||
$this->addOutput([
|
||||
'notification' => 'Déconnexion réussie',
|
||||
'notification' => 'Vous avez été déconnecté',
|
||||
'redirect' => helper::baseUrl(false),
|
||||
'state' => true
|
||||
]);
|
||||
|
@ -30,7 +30,7 @@
|
||||
<?php endif;?>
|
||||
<div class="row">
|
||||
<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
|
||||
]); ?>
|
||||
</div>
|
||||
|
Loading…
x
Reference in New Issue
Block a user