2010-09-13 09:00:36 +00:00
|
|
|
<?php
|
2010-11-29 10:57:12 +00:00
|
|
|
require_once 'framework/fwk.php';
|
|
|
|
require_once 'framework/common/mysql.php';
|
2010-09-13 09:00:36 +00:00
|
|
|
|
|
|
|
class WebAuthAdapter implements Zend_Auth_Adapter_Interface
|
|
|
|
{
|
|
|
|
protected $_username;
|
|
|
|
protected $_password;
|
2010-12-08 14:08:09 +00:00
|
|
|
protected $_hash;
|
2010-09-13 09:00:36 +00:00
|
|
|
|
|
|
|
public function __construct($username,$password)
|
|
|
|
{
|
|
|
|
$this->_username = $username;
|
|
|
|
$this->_password = $password;
|
2010-12-08 14:08:09 +00:00
|
|
|
$this->_hash = md5($username.'|'.$password);
|
2010-09-13 09:00:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function authenticate()
|
|
|
|
{
|
2011-02-15 16:49:06 +00:00
|
|
|
/*
|
|
|
|
$identity = new stdClass();
|
|
|
|
$identity->username = $this->_username;
|
|
|
|
$identity->hash = $this->_hash;
|
|
|
|
$identity->idClient = 1;
|
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::SUCCESS, $identity);
|
|
|
|
*/
|
2010-11-29 10:57:12 +00:00
|
|
|
$iDbCrm = new WDB('sdv1');
|
2011-02-07 11:31:07 +00:00
|
|
|
$rep = $iDbCrm->select(
|
2010-11-29 10:57:12 +00:00
|
|
|
'utilisateurs u, clients c',
|
|
|
|
'u.login, u.id, u.email, u.password, u.idClient, u.typeCompte, u.actif, u.filtre_ip, u.civilite, u.nom, u.prenom, u.tel, u.fax, u.mobile, u.profil, u.raisonSociale, u.siret, u.adrNum, u.adrIndRep, u.adrTypeVoie, u.adrLibVoie, u.adrCp, u.adrVille, u.adrComp, u.tel, u.fax, u.mobile, u.pref, u.profil, u.dateInscription, u.dateValidation, u.nombreConnexions, u.dateDerniereConnexion, u.droits, u.referenceParDefaut, u.nbReponses, u.formatMail, u.dateDebutCompte, u.dateFinCompte, u.maxFicheId, c.droits AS droitsClients, c.timeout',
|
2011-02-07 11:31:07 +00:00
|
|
|
"u.login='$this->_username' AND u.idClient=c.id AND u.actif=1 AND u.deleted=0 AND u.accesWS=1 AND c.actif='Oui'",
|
2011-01-20 14:00:15 +00:00
|
|
|
false, MYSQL_ASSOC);
|
2010-11-29 10:57:12 +00:00
|
|
|
$tabRep = $rep[0];
|
2010-09-13 09:00:36 +00:00
|
|
|
|
2010-12-08 14:08:09 +00:00
|
|
|
$identity = new stdClass();
|
|
|
|
$identity->username = $this->_username;
|
|
|
|
$identity->hash = $this->_hash;
|
2011-02-08 09:21:23 +00:00
|
|
|
$identity->idClient = $tabRep['idClient'];
|
2010-12-08 14:08:09 +00:00
|
|
|
|
2010-11-29 10:57:12 +00:00
|
|
|
if (count($rep)==0){
|
|
|
|
//debugLog('W',"CheckAuth $login/$password inexistant ou inactif (IP=$ipConnexion)", __LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
2010-12-08 14:08:09 +00:00
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND, $identity);
|
2010-09-13 09:00:36 +00:00
|
|
|
} else {
|
2010-11-29 10:57:12 +00:00
|
|
|
if ( $tabRep['password']==$this->_password ){
|
|
|
|
//debugLog('W',"CheckAuth $login/$password OK", __LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
2010-12-08 14:08:09 +00:00
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::SUCCESS, $identity);
|
2010-11-29 10:57:12 +00:00
|
|
|
} else {
|
|
|
|
//debugLog('W',"CheckAuth $login/$password incorrect (IP=$ipConnexion)", __LINE__,__FILE__, __FUNCTION__, __CLASS__);
|
2010-12-08 14:08:09 +00:00
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID, $identity);
|
2010-11-29 10:57:12 +00:00
|
|
|
}
|
2010-09-13 09:00:36 +00:00
|
|
|
}
|
|
|
|
}
|
2010-11-29 10:57:12 +00:00
|
|
|
|
2010-09-13 09:00:36 +00:00
|
|
|
}
|