mirror of
https://gitlab.easter-eggs.com/ee/ldapsaisie.git
synced 2024-11-26 11:52:59 +01:00
- LSattr_ldap : Added method isUpdated()
- LSattribute :: setUpdateData() : Used LSattr_ldap::isUpdated()
This commit is contained in:
parent
6a78b6bde4
commit
95f60b6334
3 changed files with 30 additions and 13 deletions
|
@ -47,6 +47,7 @@ class LSattr_ldap {
|
||||||
function LSattr_ldap ($name,$config,&$attribute) {
|
function LSattr_ldap ($name,$config,&$attribute) {
|
||||||
$this -> name = $name;
|
$this -> name = $name;
|
||||||
$this -> config = $config;
|
$this -> config = $config;
|
||||||
|
$this -> attribute = $attribute;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,6 +72,22 @@ class LSattr_ldap {
|
||||||
function getDisplayValue($data) {
|
function getDisplayValue($data) {
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retourne vrai si la valeur passé en paramètre n'était pas la même que la
|
||||||
|
* valeur passer au formulaire
|
||||||
|
*
|
||||||
|
* @param[in] $data mixed La valeur a tester
|
||||||
|
*
|
||||||
|
* @retval boolean True uniquement si la valeur passer en paramètre différe de l'actuelle
|
||||||
|
*/
|
||||||
|
function isUpdated($data) {
|
||||||
|
$data=$this -> getUpdateData($data);
|
||||||
|
if ($this -> attribute -> data != $data) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -57,10 +57,10 @@ class LSattr_ldap_password extends LSattr_ldap {
|
||||||
switch($this -> config['ldap_options']['encode']) {
|
switch($this -> config['ldap_options']['encode']) {
|
||||||
case 'crypt':
|
case 'crypt':
|
||||||
if ($this -> config['ldap_options']['no_random_crypt_salt']) {
|
if ($this -> config['ldap_options']['no_random_crypt_salt']) {
|
||||||
return '{CRYPT}' . crypt($this -> clearPassword,substr($this -> clearPassword,0,2));
|
return array('{CRYPT}' . crypt($this -> clearPassword,substr($this -> clearPassword,0,2)));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return '{CRYPT}' . crypt($this -> clearPassword,$this -> getSalt(2));
|
return array('{CRYPT}' . crypt($this -> clearPassword,$this -> getSalt(2)));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'ext_des':
|
case 'ext_des':
|
||||||
|
@ -68,7 +68,7 @@ class LSattr_ldap_password extends LSattr_ldap {
|
||||||
LSerror :: addErrorCode('LSattr_ldap_password_01','ext_des');
|
LSerror :: addErrorCode('LSattr_ldap_password_01','ext_des');
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return '{CRYPT}' . crypt( $this -> clearPassword, '_' . $this -> getSalt(8) );
|
return array('{CRYPT}' . crypt( $this -> clearPassword, '_' . $this -> getSalt(8) ));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'blowfish':
|
case 'blowfish':
|
||||||
|
@ -76,15 +76,15 @@ class LSattr_ldap_password extends LSattr_ldap {
|
||||||
LSerror :: addErrorCode('LSattr_ldap_password_01','blowfish');
|
LSerror :: addErrorCode('LSattr_ldap_password_01','blowfish');
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return '{CRYPT}' . crypt( $this -> clearPassword, '$2a$12$' . $this -> getSalt(13) );
|
return array('{CRYPT}' . crypt( $this -> clearPassword, '$2a$12$' . $this -> getSalt(13) ));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'sha':
|
case 'sha':
|
||||||
if( function_exists('sha1') ) {
|
if( function_exists('sha1') ) {
|
||||||
return '{SHA}' . base64_encode( pack( 'H*' , sha1( $this -> clearPassword ) ) );
|
return array('{SHA}' . base64_encode( pack( 'H*' , sha1( $this -> clearPassword ) ) ));
|
||||||
}
|
}
|
||||||
elseif( function_exists( 'mhash' ) ) {
|
elseif( function_exists( 'mhash' ) ) {
|
||||||
return '{SHA}' . base64_encode( mhash( MHASH_SHA1, $this -> clearPassword ) );
|
return array('{SHA}' . base64_encode( mhash( MHASH_SHA1, $this -> clearPassword ) ));
|
||||||
} else {
|
} else {
|
||||||
LSerror :: addErrorCode('LSattr_ldap_password_01','sha');
|
LSerror :: addErrorCode('LSattr_ldap_password_01','sha');
|
||||||
}
|
}
|
||||||
|
@ -93,7 +93,7 @@ class LSattr_ldap_password extends LSattr_ldap {
|
||||||
if( function_exists( 'mhash' ) && function_exists( 'mhash_keygen_s2k' ) ) {
|
if( function_exists( 'mhash' ) && function_exists( 'mhash_keygen_s2k' ) ) {
|
||||||
mt_srand( (double) microtime() * 1000000 );
|
mt_srand( (double) microtime() * 1000000 );
|
||||||
$salt = mhash_keygen_s2k( MHASH_SHA1, $this -> clearPassword, substr( pack( "h*", md5( mt_rand() ) ), 0, 8 ), 4 );
|
$salt = mhash_keygen_s2k( MHASH_SHA1, $this -> clearPassword, substr( pack( "h*", md5( mt_rand() ) ), 0, 8 ), 4 );
|
||||||
return "{SSHA}".base64_encode( mhash( MHASH_SHA1, $this -> clearPassword.$salt ).$salt );
|
return array("{SSHA}".base64_encode( mhash( MHASH_SHA1, $this -> clearPassword.$salt ).$salt ));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
LSerror :: addErrorCode('LSattr_ldap_password_01','ssha');
|
LSerror :: addErrorCode('LSattr_ldap_password_01','ssha');
|
||||||
|
@ -103,29 +103,29 @@ class LSattr_ldap_password extends LSattr_ldap {
|
||||||
if( function_exists( 'mhash' ) && function_exists( 'mhash_keygen_s2k' ) ) {
|
if( function_exists( 'mhash' ) && function_exists( 'mhash_keygen_s2k' ) ) {
|
||||||
mt_srand( (double) microtime() * 1000000 );
|
mt_srand( (double) microtime() * 1000000 );
|
||||||
$salt = mhash_keygen_s2k( MHASH_MD5, $password_clear, substr( pack( "h*", md5( mt_rand() ) ), 0, 8 ), 4 );
|
$salt = mhash_keygen_s2k( MHASH_MD5, $password_clear, substr( pack( "h*", md5( mt_rand() ) ), 0, 8 ), 4 );
|
||||||
return "{SMD5}".base64_encode( mhash( MHASH_MD5, $password_clear.$salt ).$salt );
|
return array("{SMD5}".base64_encode( mhash( MHASH_MD5, $password_clear.$salt ).$salt ));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
LSerror :: addErrorCode('LSattr_ldap_password_01','smd5');
|
LSerror :: addErrorCode('LSattr_ldap_password_01','smd5');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'md5':
|
case 'md5':
|
||||||
return '{MD5}' . base64_encode( pack( 'H*' , md5( $this -> clearPassword ) ) );
|
return array('{MD5}' . base64_encode( pack( 'H*' , md5( $this -> clearPassword ) ) ));
|
||||||
break;
|
break;
|
||||||
case 'md5crypt':
|
case 'md5crypt':
|
||||||
if( ! defined( 'CRYPT_MD5' ) || CRYPT_MD5 == 0 ) {
|
if( ! defined( 'CRYPT_MD5' ) || CRYPT_MD5 == 0 ) {
|
||||||
LSerror :: addErrorCode('LSattr_ldap_password_01','md5crypt');
|
LSerror :: addErrorCode('LSattr_ldap_password_01','md5crypt');
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return '{CRYPT}'.crypt($this -> clearPassword,'$1$'.$this -> getSalt().'$');
|
return array('{CRYPT}'.crypt($this -> clearPassword,'$1$'.$this -> getSalt().'$'));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'clear':
|
case 'clear':
|
||||||
return $this -> clearPassword;
|
return array($this -> clearPassword);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
LSerror :: addErrorCode('LSattr_ldap_password_01',$this -> config['ldap_options']['encode']);
|
LSerror :: addErrorCode('LSattr_ldap_password_01',$this -> config['ldap_options']['encode']);
|
||||||
return $this -> clearPassword;
|
return array($this -> clearPassword);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -394,7 +394,7 @@ class LSattribute {
|
||||||
* @retval void
|
* @retval void
|
||||||
*/
|
*/
|
||||||
function setUpdateData($data) {
|
function setUpdateData($data) {
|
||||||
if($this -> getFormVal() != $data) {
|
if($this -> ldap -> isUpdated($data)) {
|
||||||
$this -> updateData=$data;
|
$this -> updateData=$data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue