2015-03-25 14:44:59 +00:00
|
|
|
<?php
|
|
|
|
class Scores_Auth_Adapter_Db implements Zend_Auth_Adapter_Interface
|
|
|
|
{
|
|
|
|
protected $_username;
|
|
|
|
|
|
|
|
protected $_password;
|
|
|
|
|
|
|
|
protected $_hash;
|
|
|
|
|
|
|
|
protected $_timeout = 3600;
|
|
|
|
|
|
|
|
protected $checkWs = false;
|
|
|
|
|
|
|
|
protected $clients = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param string $username
|
|
|
|
* @param string $password
|
|
|
|
* @param boolean $checkWs
|
|
|
|
*/
|
|
|
|
public function __construct($username, $password, $checkWs = false)
|
|
|
|
{
|
|
|
|
$this->_username = $username;
|
|
|
|
$this->_password = $password;
|
|
|
|
$this->_hash = md5($username.'|'.$password);
|
|
|
|
$this->checkWs = $checkWs;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Limit access to only client IDs
|
|
|
|
* @param array $id
|
|
|
|
*/
|
|
|
|
public function limitClient($id = null)
|
|
|
|
{
|
|
|
|
if (is_array($id) && count($id)>0) {
|
|
|
|
$this->clients = $id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Override the timeout
|
|
|
|
* @param integer $seconds
|
|
|
|
*/
|
|
|
|
public function setTimeout($seconds = null)
|
|
|
|
{
|
|
|
|
if ($seconds===null)
|
|
|
|
return;
|
|
|
|
|
|
|
|
$this->_timeout = $seconds;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* (non-PHPdoc)
|
|
|
|
* @see Zend_Auth_Adapter_Interface::authenticate()
|
|
|
|
*/
|
|
|
|
public function authenticate()
|
|
|
|
{
|
|
|
|
$userM = new Application_Model_Sdv1Utilisateurs();
|
|
|
|
|
|
|
|
$sql = $userM->select()
|
|
|
|
->setIntegrityCheck(false)
|
|
|
|
->from(array('u'=>'sdv1.utilisateurs'), array('u.idClient', 'u.id', 'u.login', 'u.password'))
|
|
|
|
->join(array('c'=>'sdv1.clients'), 'u.idClient = c.id', array('c.timeout'))
|
|
|
|
->where('u.login=?', $this->_username)
|
|
|
|
->where('u.actif=?', 1)
|
|
|
|
->where('u.deleted=?', 0)
|
|
|
|
->where('c.actif=?','Oui');
|
|
|
|
|
|
|
|
if ( count($this->clients) > 0 ) {
|
|
|
|
$sql->where('u.idClient IN('.join(',',$this->clients).')');
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->checkWs) {
|
|
|
|
$sql->where('u.accesWS=?',1);
|
|
|
|
}
|
|
|
|
|
|
|
|
$result = $userM->fetchRow($sql);
|
|
|
|
|
|
|
|
$identity = new stdClass();
|
|
|
|
$identity->username = $this->_username;
|
|
|
|
$identity->hash = $this->_hash;
|
|
|
|
|
|
|
|
if ( null === $result ) {
|
2016-04-08 11:51:04 +02:00
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND, $identity, array("Identifiant ou mot de passe invalid"));
|
2015-03-25 14:44:59 +00:00
|
|
|
} else {
|
|
|
|
if ( $this->_password == $result->password
|
|
|
|
|| $this->_password == md5($result->login.'|'.$result->password) ) {
|
|
|
|
|
2016-04-08 11:51:04 +02:00
|
|
|
/**
|
|
|
|
* Date de debut de compte
|
|
|
|
*/
|
|
|
|
if ( !empty($result->dateDebutCompte) && $result->dateDebutCompte!='0000-00-00' ) {
|
|
|
|
$today = mktime(0, 0, 0, date('m'), date('d'), date('Y'));
|
|
|
|
$dateDebutCompte = mktime(0, 0, 0, substr($result->dateDebutCompte,5,2), substr($result->dateDebutCompte,8,2), substr($result->dateDebutCompte,0,4));
|
|
|
|
if ( $today < $dateDebutCompte ) {
|
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID, $identity, array("Date de validité dépassé"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Date de fin de compte
|
|
|
|
*/
|
|
|
|
if ( !empty($result->dateFinCompte) && $result->dateFinCompte!='0000-00-00' ) {
|
|
|
|
$today = mktime(0, 0, 0, date('m'), date('d'), date('Y'));
|
|
|
|
$dateFinCompte = mktime(0, 0, 0, substr($result->dateFinCompte,5,2), substr($result->dateFinCompte,8,2), substr($result->dateFinCompte,0,4));
|
|
|
|
if ( $today > $dateFinCompte ) {
|
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID, $identity, array("Date de validité dépassé"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-25 14:44:59 +00:00
|
|
|
$identity->id = $result->id;
|
|
|
|
$identity->idClient = $result->idClient;
|
|
|
|
$timeout = (!empty($result->timeout)) ? $result->timeout : $this->_timeout;
|
|
|
|
$identity->timeout = $timeout;
|
|
|
|
$identity->time = time() + $timeout;
|
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::SUCCESS, $identity);
|
|
|
|
|
|
|
|
} else {
|
2016-04-08 11:51:04 +02:00
|
|
|
return new Zend_Auth_Result(Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID, $identity, array("Identification impossible"));
|
2015-03-25 14:44:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|