Newer
Older
include ("ecrire/inc_version.php3");
include_ecrire ("inc_connect.php3");
include_ecrire ("inc_meta.php3");
include_ecrire ("inc_session.php3");
if ($url)
// rejoue le cookie pour renouveler spip_session
if (verifier_session($spip_session)) {
$cookie = creer_cookie_session($auteur_session);
supprimer_session($spip_session);
@header('Content-Type: image/gif');
@header('Expires: 0');
@header("Cache-Control: no-store, no-cache, must-revalidate");
@header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
exit;
}
}
// tentative de connexion en auth_http
if ($essai_auth_http) {
include_local ("inc-login.php3");
auth_http($cible, $essai_auth_http);
exit;
}
// tentative de logout
if ($logout) {
include_ecrire("inc_session.php3");
verifier_visiteur();
if ($auteur_session['login'] == $logout) {
include_ecrire('inc_connect.php3');
spip_query("UPDATE spip_auteurs SET en_ligne = DATE_SUB(NOW(),INTERVAL 6 MINUTE) WHERE id_auteur = ".$auteur_session['id_auteur']);
if ($spip_session) {
supprimer_session($spip_session);
setcookie('spip_session', $spip_session, time() - 3600 * 24);
}
if ($PHP_AUTH_USER) {
include_local ("inc-login.php3");
auth_http($cible, 'logout');
}
unset ($auteur_session);
}
@Header("Location: ./spip_login.php3");
exit;
}
// tentative de login
unset ($cookie_session);
if ($session_login_hidden AND !$session_login)
$session_login = $session_login_hidden;
$login = addslashes($session_login);
if ($session_password_md5) { // mot passe en md5
$md5pass = $session_password_md5;
$md5next = $next_session_password_md5;
else { // mot passe en clair
$query = "SELECT * FROM spip_auteurs WHERE login='$login' AND statut!='5poubelle'";
$result = spip_query($query);
if ($row = mysql_fetch_array($result)) {
$md5pass = md5($row['alea_actuel'] . $session_password);
$md5next = md5($row['alea_futur'] . $session_password);
}
}
$query = "SELECT * FROM spip_auteurs WHERE login='$login' AND pass='$md5pass' AND statut<>'5poubelle'";
$result = spip_query($query);
if ($row_auteur = mysql_fetch_array($result)) { // login reussi
if ($row_auteur['statut'] == 'nouveau') { // nouvel inscrit
spip_query ("UPDATE spip_auteurs SET statut='1comite' WHERE login='$login'");
$row_auteur['statut'] = '1comite';
}
if ($row_auteur['statut'] == '0minirezo') // force le cookie pour les admins
$cookie_admin = "@".$row_auteur['login'];
$cookie_session = creer_cookie_session($row_auteur);
// fait tourner le codage du pass dans la base
$nouvel_alea_futur = creer_uniqid();
$query = "UPDATE spip_auteurs
SET alea_actuel = alea_futur,
pass = '$md5next',
alea_futur = '$nouvel_alea_futur'
WHERE login='$login'";
@spip_query($query);
$cible->addVar('bonjour','oui');
$cible->addVar('var_login', $login);
if ($session_password || $session_password_md5)
$cible->addVar('var_erreur', 'pass');
$cible->addVar('var_url', urldecode($url));
Fil
a validé
}
// cookie d'admin ?
if ($cookie_admin == "non") {
setcookie('spip_admin', $spip_admin, time() - 3600 * 24);
$cible->delVar('var_login');
else if ($cookie_admin AND $spip_admin != $cookie_admin) {
setcookie('spip_admin', $cookie_admin, time() + 3600 * 24 * 14);
Fil
a validé
// cookie de session ?
if ($cookie_session)
setcookie('spip_session', $cookie_session);
// redirection