Subversion Repositories Sites.tela-botanica.org

Rev

Rev 609 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php

/***************************************************************************\
 *  SPIP, Systeme de publication pour l'internet                           *
 *                                                                         *
 *  Copyright (c) 2001-2005                                                *
 *  Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James  *
 *                                                                         *
 *  Ce programme est un logiciel libre distribue sous licence GNU/GPL.     *
 *  Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne.   *
\***************************************************************************/


//
// Ce fichier ne sera execute qu'une fois
if (defined("_ECRIRE_INC_AUTH_SPIP")) return;
define("_ECRIRE_INC_AUTH_SPIP", "1");

class Auth_spip {
        var $nom, $login, $email, $md5pass, $md5next, $alea_futur, $statut;

        function init() {
                return true;
        }

        // Verification du mot passe crypte (javascript)
        function verifier_challenge_md5($login, $mdpass_actuel, $mdpass_futur) {
                // Interdire mot de passe vide
                if ($mdpass_actuel == '') return false;

                $query = "SELECT * FROM spip_auteurs WHERE login='".addslashes($login)."' AND pass='".addslashes($mdpass_actuel)."' AND statut<>'5poubelle'";
                $result = spip_query($query);

                if ($row = spip_fetch_array($result)) {
                        $this->nom = $row['nom'];
                        $this->login = $row['login'];
                        $this->email = $row['email'];
                        $this->statut = $row['statut'];
                        $this->md5pass = $mdpass_actuel;
                        $this->md5next = $mdpass_futur;
                        return true;
                }
                return false;
        }

        // Verification du mot passe en clair (sans javascript)
        function verifier($login, $pass) {
                // Interdire mot de passe vide
                if ($pass == '') return false;

                $query = "SELECT alea_actuel, alea_futur FROM spip_auteurs WHERE login='".addslashes($login)."'";
                $result = spip_query($query);
                if ($row = spip_fetch_array($result)) {
                        $md5pass = md5($row['alea_actuel'] . $pass);
                        $md5next = md5($row['alea_futur'] . $pass);
                        return $this->verifier_challenge_md5($login, $md5pass, $md5next);
                }
                return false;
        }

        function lire() {
                return true;
        }

        function activer() {
                if ($this->statut == 'nouveau') { // nouvel inscrit
                        $connect_statut =
                        (lire_meta('accepter_inscriptions') == 'oui') ?
                                '1comite' : '6forum';
                        spip_query("UPDATE spip_auteurs SET statut='$connect_statut'
                                WHERE login='".addslashes($this->login)."'");
                }
                if ($this->md5next) {
                        include_ecrire("inc_session.php3");
                        // fait tourner le codage du pass dans la base
                        $nouvel_alea_futur = creer_uniqid();
                        $query = "UPDATE spip_auteurs SET alea_actuel = alea_futur, ".
                                "pass = '".addslashes($this->md5next)."', alea_futur = '$nouvel_alea_futur' ".
                                "WHERE login='".$this->login."'";
                        @spip_query($query);
                }
        }
}


?>