X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Finclude%2Fclass_filter.inc;h=e8b65ac78b4810013f8d70ef4973834fe57d57ac;hb=8ae8745c45a91ec8d98216398721ccadab3ac65a;hp=6a6a4216efff52f5c61a9a59d8c889acb8339bca;hpb=2c7257e5e02afafdfd3a6c4457c6b87467f26eae;p=gosa.git
diff --git a/gosa-core/include/class_filter.inc b/gosa-core/include/class_filter.inc
index 6a6a4216e..e8b65ac78 100644
--- a/gosa-core/include/class_filter.inc
+++ b/gosa-core/include/class_filter.inc
@@ -23,19 +23,17 @@
class filter {
var $xmlData;
- var $elements= array();
- var $elementValues= array();
- var $alphabetElements= array();
- var $autocompleter= array();
+ var $searches= array();
+ var $search;
var $category= "";
var $objectStorage= array();
var $base= "";
var $scope= "";
var $query;
+ var $value= "";
var $initial= false;
var $scopeMode= "auto";
- var $alphabet= null;
- var $converter= array();
+ var $converter= null;
var $pid;
@@ -65,23 +63,38 @@ class filter {
// Load filter
if (isset($this->xmlData['search'])) {
- if (!isset($this->xmlData['search']['query'][0])){
- $this->xmlData['search']['query']= array($this->xmlData['search']['query']);
- }
- // Move information
- $entry= $this->xmlData['search'];
- $this->scopeMode= $entry['scope'];
- if ($entry['scope'] == "auto") {
- $this->scope= "one";
+ // Array conversion
+ if (!is_array($this->xmlData['search'])) {
+ $searches= array($this->xmlData['search']);
} else {
- $this->scope= $entry['scope'];
+ $searches= $this->xmlData['search'];
+ }
+
+ /* Store available searches */
+ foreach ($this->xmlData['search'] as $search) {
+
+ /* Do multi conversation */
+ if (!is_array($search['query'])){
+ $search['query']= array($search['query']);
+ }
+
+ /* Store search */
+ $this->searches[$search['label']]= $search;
+
}
- $this->query= $entry['query'];
} else {
return false;
}
+ // Transfer scope
+ $this->scopeMode= $this->xmlData['definition']['scope'];
+ if ($this->scopeMode == "auto") {
+ $this->scope= "one";
+ } else {
+ $this->scope= $this->scopeMode;
+ }
+
// Transfer initial value
if (isset($this->xmlData['definition']['initial']) && $this->xmlData['definition']['initial'] == "true"){
$this->initial= true;
@@ -92,47 +105,25 @@ class filter {
$this->category= $this->xmlData['definition']['category'];
}
- // Generate formular data
- if (isset($this->xmlData['element'])) {
- if (!isset($this->xmlData['element'][0])){
- $this->xmlData['element']= array($this->xmlData['element']);
- }
- foreach ($this->xmlData['element'] as $element) {
-
- // Ignore elements without type
- if (!isset($element['type']) || !isset($element['tag'])) {
- next;
- }
-
- $tag= $element['tag'];
-
- // Fix arrays
- if (isset($element['value']) && !isset($element['value'][0])) {
- $element['value']= array($element['value']);
- }
+ // Set default search mode
+ $this->setSearch($this->xmlData['definition']['default']);
- // Store element for quick access
- $this->elements[$tag] = $element;
+ return true;
+ }
- // Preset elementValues with default values if exist
- if (isset($element['default']) && !is_array($element['default'])) {
- $this->elementValues[$tag] = $element['default'];
- } else {
- $this->elementValues[$tag] = "";
- }
- // Does this element react on alphabet links?
- if (isset($element['alphabet']) && $element['alphabet'] == "true") {
- $this->alphabetElements[]= $tag;
- }
+ function setSearch($method)
+ {
+ // Move information
+ if (isset($this->searches[$method])) {
+ $this->query= $this->searches[$method]['query'];
+ if (!isset($this->query[0])) {
+ $this->query= array($this->query);
}
-
- uasort($this->elements, 'strlenSort');
- $this->elements= array_reverse($this->elements);
-
+ $this->search= $method;
+ } else {
+ die ("Invalid search module!");
}
-
- return true;
}
@@ -147,7 +138,7 @@ class filter {
if (isset($element['maxlength'])){
$maxlength= $element['maxlength'];
}
- $result= "";
+ $result= "";
if (isset($element['autocomplete'])) {
$frequency= "0.5";
$characters= "1";
@@ -168,64 +159,6 @@ class filter {
}
- function getCheckbox($element)
- {
- $tag= $element['tag'];
- $checked= "";
- if ($this->elementValues[$tag] == "true") {
- $checked= " checked";
- }
-
- $result= "";
- return $result;
- }
-
-
- function getCombobox($element)
- {
- $result= "";
-
- return $result;
- }
-
-
- function setComboBoxOptions($tag, $options)
- {
- if (isset($this->elements[$tag]) && $this->elements[$tag]['type'] == "combobox") {
-
- $this->elements[$tag]['value']= array();
- foreach ($options as $key => $label) {
- $this->elements[$tag]['value'][]= array('label' => $label, 'key' => $key);
- }
- }
- }
-
-
function getCurrentBase()
{
if (isset($this->search->base) && (string)$this->search->scope != "auto") {
@@ -246,9 +179,9 @@ class filter {
}
- function setConverter($field, $hook)
+ function setConverter($hook)
{
- $this->converter[$field]= $hook;
+ $this->converter= $hook;
}
@@ -270,45 +203,6 @@ class filter {
}
- function renderAlphabet($columns= 10)
- {
- // Return pre-rendered alphabet if available
- if ($this->alphabet) {
- return ($this->alphabet);
- }
-
- $characters= _("*ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789");
- $alphabet= "";
- $c= 0;
-
- /* Fill cells with charaters */
- for ($i= 0, $l= mb_strlen($characters, 'UTF8'); $i<$l; $i++){
- if ($c == 0){
- $alphabet.= "
";
- }
-
- $ch = mb_substr($characters, $i, 1, "UTF8");
- $alphabet.= " ".$ch." | ";
-
- if ($c++ == $columns){
- $alphabet.= "
";
- $c= 0;
- }
- }
-
- /* Fill remaining cells */
- while ($c++ <= $columns){
- $alphabet.= " | ";
- }
-
- /* Save alphabet */
- $this->alphabet= "";
-
- return ($this->alphabet);
- }
-
-
function renderApply()
{
return ("");
@@ -324,35 +218,12 @@ class filter {
function render()
{
- $smarty= get_smarty();
- $smarty->assign("ALPHABET", $this->renderAlphabet());
- $smarty->assign("APPLY", $this->renderApply());
- $smarty->assign("SCOPE", $this->renderScope());
-
- // Load template and replace elementsHtml[]
- foreach ($this->elements as $tag => $element) {
- $htmlCode= "";
- switch ($element['type']) {
- case "textfield":
- $htmlCode = $this->getTextfield($element);
- break;
+ $content= "";
- case "checkbox":
- $htmlCode = $this->getCheckbox($element);
- break;
-
- case "combobox":
- $htmlCode = $this->getCombobox($element);
- break;
-
- default:
- die ("Unknown element type specified!");
- }
- $smarty->assign("$tag", $htmlCode);
- }
-
- // Load template
- return ("".$smarty->fetch(get_template_path($this->xmlData['definition']['template'], true)));
+ // Return meta data
+ return ("".$content);
}
@@ -383,31 +254,17 @@ class filter {
$filter= $query['filter'];
$attributes= $query['attribute'];
- // Generate final filter
- foreach ($this->elements as $tag => $element) {
- if (!isset($element['set']) || !isset($element['unset'])) {
- continue;
- }
-
- // Handle converters if present
- if (isset($this->converter[$tag])) {
- preg_match('/([^:]+)::(.*)$/', $this->converter[$tag], $m);
- $e_set= call_user_func(array($m[1], $m[2]), preg_replace('/\$/', $this->elementValues[$tag], is_array($element['set'])?"":$element['set']));
- $e_unset= call_user_func(array($m[1], $m[2]), preg_replace('/\$/', $this->elementValues[$tag], is_array($element['unset'])?"":$element['unset']));
- } else {
- $e_set= is_array($element['set'])?"":$element['set'];
- $e_unset= is_array($element['unset'])?"":$element['unset'];
- }
+ // Handle converters if present
+ if ($this->converter) {
+ preg_match('/([^:]+)::(.*)$/', $this->converter, $m);
+ $filter= call_user_func(array($m[1], $m[2]), preg_replace('/\$/', $this->value, $filter));
+ }
- if ($this->elementValues[$tag] == "") {
- $e_unset= preg_replace('/[^\\\\]\$/', normalizeLdap($this->elementValues[$tag]), $e_unset);
- $e_unset= preg_replace('/\\\\\$/','$', $e_unset);
- $filter= preg_replace("/\\$$tag/", $e_unset, $filter);
- } else {
- $e_set= preg_replace('/[^\\\\]\$/', normalizeLdap($this->elementValues[$tag]), $e_set);
- $e_set= preg_replace('/\\\\\$/','$', $e_set);
- $filter= preg_replace("/\\$$tag/", $e_set, $filter);
- }
+ // Do not replace escaped \$ - This is required to be able to search for e.g. windows machines.
+ if ($this->value == "") {
+ $filter= preg_replace("/\\$/", '*', $filter);
+ } else {
+ $filter= preg_replace("/\\$/", "*".normalizeLdap($this->value)."*", $filter);
}
$result= array_merge($result, call_user_func(array($backend, 'query'), $this->base, $this->scope, $filter, $attributes, $this->category, $this->objectStorage));
@@ -417,38 +274,13 @@ class filter {
}
- function isValid()
- {
- foreach ($this->elements as $tag => $element) {
- if (isset($element->regex)){
- if (!preg_match('/'.(string)$element->regex.'/', $this->elementValues[$tag])){
- return false;
- }
- }
- }
- return true;
- }
-
-
function update()
{
- /* React on alphabet links if needed */
- if (isset($_GET['filter'])){
- $s= mb_substr(validate($_GET['filter']), 0, 1, "UTF8");
- foreach ($this->alphabetElements as $tag) {
- $this->elementValues[$tag]= $s;
- }
- }
-
if (isset($_POST['FILTER_PID']) && $_POST['FILTER_PID'] == $this->pid) {
- // Load post values and adapt filter, base and scope accordingly - but
- // only if we didn't get a _GET
- foreach ($this->elements as $tag => $element) {
- if (isset($_POST[$tag])){
- $this->elementValues[$tag]= validate($_POST[$tag]);
- } else {
- $this->elementValues[$tag]= "";
- }
+
+ // Save input field
+ if (isset($_POST['search_filter'])) {
+ $this->value= validate($_POST['search_filter']);
}
// Save scope if needed
@@ -460,7 +292,7 @@ class filter {
}
- function getCompletitionList($config, $tag, $value="*")
+ function getCompletitionList($config, $value="*")
{
global $class_mapping;
$res= array();
@@ -479,7 +311,7 @@ class filter {
}
// Make filter
- $filter= preg_replace("/\\$$tag/", normalizeLdap($value), $filter);
+ $filter= preg_replace("/\\$/", normalizeLdap($value), $filter);
if (isset($config['base']) && isset($config['scope']) && isset($config['category'])) {
$result= call_user_func(array($backend, 'query'), $config['base'], $config['scope'], $filter, $attributes,
$config["category"], $config["objectStorage"]);
@@ -514,22 +346,20 @@ class filter {
// Introduce maximum number of entries
$max= 25;
- foreach ($this->autocompleters as $tag => $config) {
- if(isset($_POST[$tag])){
- $result= $this->getCompletitionList($config, $tag, $_POST[$tag]);
- $result= array_unique($result);
- asort($result);
-
- echo '';
- foreach ($result as $entry) {
- echo '- '.$entry.'
';
- if ($max-- == 0) {
- break;
- }
- }
+ if(isset($this->searches[$this->search]['autocomplete'])){
+ $result= $this->getCompletitionList($this->searches[$this->search]['autocomplete'], $_POST['search_filter']);
+ $result= array_unique($result);
+ asort($result);
- echo '
';
+ echo '';
+ foreach ($result as $entry) {
+ echo '- '.mark($_POST['search_filter'], $entry).'
';
+ if ($max-- == 0) {
+ break;
+ }
}
+
+ echo '
';
}
}
@@ -558,14 +388,28 @@ class filter {
}
-}
-// Sort elements for element length to allow proper replacing later on
-function strlenSort($a, $b) {
- if (strlen($a['tag']) == strlen($b['tag'])) {
- return 0;
+ function renderFilterMenu()
+ {
+ // Load shortcut
+ $result= "".
+ "