implemented query for multiple attributes (task #114873)
This commit is contained in:
		
							parent
							
								
									5e97605681
								
							
						
					
					
						commit
						4211e548da
					
				|  | @ -72,10 +72,18 @@ class cache { | ||||||
| 		$this->refresh_cache(true); | 		$this->refresh_cache(true); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 	/* This function returns an array ( dn1 => array(uidnumber1), dn2 => array(uidnumber2), ... ) | 	/** | ||||||
|  | 	* Queries the cache for a list of LDAP entries and their attributes. | ||||||
|  | 	* | ||||||
|  | 	* @param mixed $attributes One (string) or many (array) attribute names. | ||||||
|  | 	* @param string $objectClass The resulting entries need to contain this object class. | ||||||
|  | 	* @param string $singlescope The account type or "*" if all. | ||||||
|  | 	* @return array The found LDAP entries. | ||||||
|  | 	* <br>Format: array(dn1 => array(uidnumber1), dn2 => array(uidnumber2), ... ) if $attributes is of type string | ||||||
|  | 	* <br>or array(dn1 => array(uid => array(myuid), uidNumber => array(1234)), ... ) if $attributes is an array | ||||||
| 	* | 	* | ||||||
| 	*/ | 	*/ | ||||||
| 	function get_cache($attribute, $objectClass, $singlescope) { | 	function get_cache($attributes, $objectClass, $singlescope) { | ||||||
| 		$this->refresh_cache(); | 		$this->refresh_cache(); | ||||||
| 		// Check input variables
 | 		// Check input variables
 | ||||||
| 		$allowed_types = array ( 'user', 'group', 'host', 'domain', '*' ); | 		$allowed_types = array ( 'user', 'group', 'host', 'domain', '*' ); | ||||||
|  | @ -84,8 +92,11 @@ class cache { | ||||||
| 		if ($singlescope == '*') $scopes = $allowed_types; | 		if ($singlescope == '*') $scopes = $allowed_types; | ||||||
| 			else $scopes = array ( $singlescope ); | 			else $scopes = array ( $singlescope ); | ||||||
| 		// Add cache entry dynamic
 | 		// Add cache entry dynamic
 | ||||||
|  | 		if (!is_array($attributes)) $attributes = array($attributes); | ||||||
| 		foreach ($scopes as $scope) { | 		foreach ($scopes as $scope) { | ||||||
| 			if (!@in_array($attribute ,$this->attributes[$scope])) $add[$scope][] = $attribute; | 			for ($i = 0; $i < sizeof($attributes); $i++) { | ||||||
|  | 				if (!@in_array($attributes[$i], $this->attributes[$scope])) $add[$scope][] = $attributes[$i]; | ||||||
|  | 			} | ||||||
| 		} | 		} | ||||||
| 		if (count($add)!=0) $this->add_cache($add); | 		if (count($add)!=0) $this->add_cache($add); | ||||||
| 
 | 
 | ||||||
|  | @ -93,12 +104,16 @@ class cache { | ||||||
| 			if (isset($this->ldapcache[$scope])) { | 			if (isset($this->ldapcache[$scope])) { | ||||||
| 				$DNs = array_keys($this->ldapcache[$scope]); | 				$DNs = array_keys($this->ldapcache[$scope]); | ||||||
| 				foreach ($DNs as $dn) { | 				foreach ($DNs as $dn) { | ||||||
| 					if (isset($this->ldapcache[$scope][$dn][$attribute]) && in_array($objectClass, $this->ldapcache[$scope][$dn]['objectClass'])) { | 					// skip entries which do not fit to search
 | ||||||
| 						// return string if only attribute exists only once
 | 					if (!in_array($objectClass, $this->ldapcache[$scope][$dn]['objectClass'])) continue; | ||||||
| 						if (count($this->ldapcache[$scope][$dn][$attribute])==1) $return[$dn] = array($this->ldapcache[$scope][$dn][$attribute][0]); | 					for ($i = 0; $i < sizeof($attributes); $i++) { | ||||||
|  | 						if (isset($this->ldapcache[$scope][$dn][$attributes[$i]])) { | ||||||
|  | 							if (sizeof($attributes) > 1) { | ||||||
|  | 								$return[$dn][$attributes[$i]] = $this->ldapcache[$scope][$dn][$attributes[$i]]; | ||||||
|  | 							} | ||||||
| 							else { | 							else { | ||||||
| 							// else return array with all attributes
 | 								$return[$dn] = $this->ldapcache[$scope][$dn][$attributes[$i]]; | ||||||
| 							$return[$dn] = $this->ldapcache[$scope][$dn][$attribute]; | 							} | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue