index 53084d28a2463c119143d842c47c24838d3ecf1e..5a6701d65540462693a5b681e7b475167d8e2a60 100644 (file)
static function get_list($base, $filter, $attributes, $category, $objectStorage, $flags= GL_SUBSEARCH)
{
static function get_list($base, $filter, $attributes, $category, $objectStorage, $flags= GL_SUBSEARCH)
{
- global $ui;
- global $config;
+ $ui= session::global_get('ui');
+ $config= session::global_get('config');
// Move to arrays for category and objectStorage
if (!is_array($category)) {
// Move to arrays for category and objectStorage
if (!is_array($category)) {
$bases= array();
// Get list of sub bases to search on
$bases= array();
// Get list of sub bases to search on
- foreach ($objectStorage as $oc) {
- $oc= preg_replace('/,$/', '', $oc);
- $tmp= split(',', $oc);
- if (count($tmp) == 1) {
- preg_match('/([^=]+)=(.*)$/', $oc, $m);
- if ($flags & GL_SUBSEARCH) {
- $bases[$base][]= $m[1].":dn:=".$m[2];
- } else {
- $bases["$oc,$base"][]= $m[1].":dn:=".$m[2];
- }
- } else {
- // No, there's no \, in pre defined RDN values
- preg_match('/^([^,]+),(.*)$/', $oc, $matches);
- preg_match('/([^=]+)=(.*)$/', $matches[1], $m);
- if ($flags & GL_SUBSEARCH) {
- $bases[$base][]= $m[1].":dn:=".$m[2];
+ if (count($objectStorage) == 0) {
+ $bases[$base]= "";
+ } else {
+ foreach ($objectStorage as $oc) {
+ $oc= preg_replace('/,$/', '', $oc);
+ $tmp= split(',', $oc);
+ if (count($tmp) == 1) {
+ preg_match('/([^=]+)=(.*)$/', $oc, $m);
+ if ($flags & GL_SUBSEARCH) {
+ $bases[$base][]= $m[1].":dn:=".$m[2];
+ } else {
+ $bases["$oc,$base"][]= $m[1].":dn:=".$m[2];
+ }
} else {
} else {
- $bases[$matches[2].",$base"][]= $m[1].":dn:=".$m[2];
+ // No, there's no \, in pre defined RDN values
+ preg_match('/^([^,]+),(.*)$/', $oc, $matches);
+ preg_match('/([^=]+)=(.*)$/', $matches[1], $m);
+ if ($flags & GL_SUBSEARCH) {
+ $bases[$base][]= $m[1].":dn:=".$m[2];
+ } else {
+ $bases[$matches[2].",$base"][]= $m[1].":dn:=".$m[2];
+ }
}
}
}
}
}
}
// Switch to new base and search
$ldap->cd($base);
// Switch to new base and search
$ldap->cd($base);
- $dnFilter= "(|";
- foreach ($dnFilters as $df) {
- $dnFilter.= "($df)";
+ if (is_array($dnFilters)){
+ $dnFilter= "(|";
+ foreach ($dnFilters as $df) {
+ $dnFilter.= "($df)";
+ }
+ $dnFilter.= ")";
+ } else {
+ $dnFilter= "";
}
}
- $dnFilter.= ")";
$ldap->search ("(&$filter$dnFilter)", $attributes);
// Check for size limit exceeded messages for GUI feedback
$ldap->search ("(&$filter$dnFilter)", $attributes);
// Check for size limit exceeded messages for GUI feedback