From 07239b65d64f3a98bee9b29cc1553530e4be9187 Mon Sep 17 00:00:00 2001 From: Aleksander Machniak Date: Tue, 16 Oct 2012 17:54:57 +0200 Subject: Fix post-filtering vlv results, fixes warning "mb_strtolower() expects parameter 1 to be a string, array given" Conflicts: program/include/rcube_ldap.php --- program/include/rcube_ldap.php | 36 +++++++++++++++++++----------------- 1 file changed, 19 insertions(+), 17 deletions(-) diff --git a/program/include/rcube_ldap.php b/program/include/rcube_ldap.php index babd34b60..17ef20aab 100644 --- a/program/include/rcube_ldap.php +++ b/program/include/rcube_ldap.php @@ -803,24 +803,26 @@ class rcube_ldap extends rcube_addressbook for ($i = 0; $i < $entries['count']; $i++) { $rec = $this->_ldap2result($entries[$i]); - foreach (array('email', 'name') as $f) { - $val = mb_strtolower($rec[$f]); - switch ($mode) { - case 1: - $got = ($val == $search); - break; - case 2: - $got = ($search == substr($val, 0, strlen($search))); - break; - default: - $got = (strpos($val, $search) !== false); - break; - } + foreach ($fields as $f) { + foreach ((array)$rec[$f] as $val) { + $val = mb_strtolower($val); + switch ($mode) { + case 1: + $got = ($val == $search); + break; + case 2: + $got = ($search == substr($val, 0, strlen($search))); + break; + default: + $got = (strpos($val, $search) !== false); + break; + } - if ($got) { - $this->result->add($rec); - $this->result->count++; - break; + if ($got) { + $this->result->add($rec); + $this->result->count++; + break 2; + } } } } -- cgit v1.2.3