X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_filter.inc;h=0bea6c4a69439e0d332efb044255762bf63b26fa;hb=7db39a804ab721db300683f505c87b9c2b8808a5;hp=ffb8789553a8db5238af8e7923345e4e586870f8;hpb=47ca48cbfb4c794ee8d5854e420cbd0bfb0734fa;p=gosa.git diff --git a/gosa-core/include/class_filter.inc b/gosa-core/include/class_filter.inc index ffb878955..0bea6c4a6 100644 --- a/gosa-core/include/class_filter.inc +++ b/gosa-core/include/class_filter.inc @@ -1,4 +1,24 @@ load($filename)) { die("Cannot parse $filename!"); } @@ -46,13 +68,27 @@ class filter { // Move information $entry= $this->xmlData['search']; - $this->baseMode= $entry['base']; $this->scopeMode= $entry['scope']; + if ($entry['scope'] == "auto") { + $this->scope= "one"; + } else { + $this->scope= $entry['scope']; + } $this->query= $entry['query']; } else { return false; } + // Transfer initial value + if (isset($this->xmlData['definition']['initial']) && $this->xmlData['definition']['initial'] == "true"){ + $this->initial= true; + } + + // Transfer category + if (isset($this->xmlData['definition']['category'])){ + $this->category= $this->xmlData['definition']['category']; + } + // Generate formular data if (isset($this->xmlData['element'])) { if (!isset($this->xmlData['element'][0])){ @@ -87,6 +123,17 @@ class filter { $this->alphabetElements[]= $tag; } } + + // Sort elements for element length to allow proper replacing later on + function strlenSort($a, $b) { + if (strlen($a['tag']) == strlen($b['tag'])) { + return 0; + } + return (strlen($a['tag']) < strlen($b['tag']) ? -1 : 1); + } + uasort($this->elements, 'strlenSort'); + $this->elements= array_reverse($this->elements); + } return true; @@ -96,7 +143,15 @@ class filter { function getTextfield($element) { $tag= $element['tag']; - $result= ""; + $size= 30; + if (isset($element['size'])){ + $size= $element['size']; + } + $maxlength= 30; + if (isset($element['maxlength'])){ + $maxlength= $element['maxlength']; + } + $result= ""; if (isset($element['autocomplete'])) { $frequency= "0.5"; $characters= "1"; @@ -133,13 +188,30 @@ class filter { function getCombobox($element) { $result= ""; return $result; @@ -166,11 +238,6 @@ class filter { } - function setBases($bases) { - $this->bases= $bases; - } - - function setObjectStorage($storage) { $this->objectStorage= $storage; } @@ -181,12 +248,7 @@ class filter { } - function setCategory($category) { - $this->category= $category; - } - - - function setCurrentBase($base) { + function setBase($base) { $this->base= $base; } @@ -196,23 +258,6 @@ class filter { } - function renderBase() - { - $result= ""; - - return $result; - } - - function renderAlphabet($columns= 10) { // Return pre-rendered alphabet if available @@ -265,13 +310,12 @@ class filter { } - function renderFilter() + function render() { $smarty= get_smarty(); $smarty->assign("ALPHABET", $this->renderAlphabet()); $smarty->assign("APPLY", $this->renderApply()); $smarty->assign("SCOPE", $this->renderScope()); - $smarty->assign("BASE", $this->renderBase()); // Load template and replace elementsHtml[] foreach ($this->elements as $tag => $element) { @@ -296,7 +340,7 @@ class filter { } // Load template - return ("".$smarty->fetch(get_template_path("filter/".$this->xmlData['definition']['template']))); + return ("".$smarty->fetch(get_template_path($this->xmlData['definition']['template'], true))); } @@ -324,7 +368,7 @@ class filter { // Generate final filter foreach ($this->elements as $tag => $element) { if (!isset($element['set']) || !isset($element['unset'])) { - next; + continue; } $e_set= is_array($element['set'])?"":$element['set']; $e_unset= is_array($element['unset'])?"":$element['unset']; @@ -384,20 +428,58 @@ class filter { $this->elementValues[$tag]= ""; } } - } - // Save base - if (isset($_POST['BASE']) && $this->baseMode == "true") { - $base= validate($_POST['BASE']); - if (isset($this->bases[$base])) { - $this->base= $base; + // Save scope if needed + if ($this->scopeMode == "auto") { + $this->scope= isset($_POST['SCOPE'])?"sub":"one"; } } - // Save scope if needed - if ($this->scopeMode == "auto") { - $this->scope= isset($_POST['SCOPE'])?"sub":"one"; + } + + + function getCompletitionList($config, $tag, $value="*") + { + global $class_mapping; + $res= array(); + + // Is backend available? + $backend= "filter".$config['backend']; + if (!isset($class_mapping["$backend"])) { + die("Invalid backend specified in search config."); + } + + // Load filter and attributes + $filter= $config['filter']; + $attributes= $config['attribute']; + if (!is_array($attributes)) { + $attributes= array($attributes); } + + // Make filter + $filter= preg_replace("/\\$$tag/", normalizeLDAP($value), $filter); + if (isset($config['base']) && isset($config['scope']) + && isset($config['category']) && isset($config['objectbase']) ) { + $result= call_user_func(array($backend, 'query'), $config['base'], $config['scope'], $filter, $attributes, + $config["category"], $config["objectbase"]); + } else { + $result= call_user_func(array($backend, 'query'), $this->base, $this->scope, $filter, $attributes, + $this->category, $this->objectStorage, $this->objectBase); + } + + foreach ($result as $entry) { + foreach ($attributes as $attribute) { + if (is_array($entry[$attribute])) { + for ($i= 0; $i<$entry[$attribute]['count']; $i++) { + $res[]= $entry[$attribute][$i]; + } + } else { + $res[]= $entry[$attribute]; + } + } + } + + return $res; } @@ -408,36 +490,11 @@ class filter { foreach ($this->autocompleters as $tag => $config) { if(isset($_POST[$tag])){ - - // Is backend available? - $backend= "filter".$config['backend']; - if (!isset($class_mapping["$backend"])) { - die("Invalid backend specified in search config."); - } - - // Load filter and attributes - $filter= $config['filter']; - $attributes= $config['attribute']; - if (!is_array($attributes)) { - $attributes= array($attributes); - } - - // Make filter - $filter= preg_replace("/\\$$tag/", normalizeLDAP($_POST[$tag]), $filter); - $result= call_user_func(array($backend, 'query'), $this->base, $this->scope, $filter, $attributes, - $this->category, $this->objectStorage, $this->objectBase); + $result= $this->getCompletitionList($config, $tag, $_POST[$tag]); echo ''; @@ -446,6 +503,7 @@ class filter { } } + } ?>