preserve an asterisk at the start when escaping a search term

This commit is contained in:
Arthur Schiwon 2014-12-08 17:12:13 +01:00
parent 1362c0b67a
commit 45443ee28c
2 changed files with 8 additions and 3 deletions

View File

@ -1087,10 +1087,15 @@ class Access extends LDAPUtility implements user\IUserTools {
* @param string $input, the provided value * @param string $input, the provided value
* @return string the escaped string * @return string the escaped string
*/ */
public function escapeFilterPart($input) { public function escapeFilterPart($input, $allowAsterisk = false) {
$asterisk = '';
if($allowAsterisk && strlen($input) > 0 && $input[0] === '*') {
$asterisk = '*';
$input = mb_substr($input, 1, null, 'UTF-8');
}
$search = array('*', '\\', '(', ')'); $search = array('*', '\\', '(', ')');
$replace = array('\\*', '\\\\', '\\(', '\\)'); $replace = array('\\*', '\\\\', '\\(', '\\)');
return str_replace($search, $replace, $input); return $asterisk . str_replace($search, $replace, $input);
} }
/** /**

View File

@ -93,7 +93,7 @@ class USER_LDAP extends BackendUtility implements \OCP\UserInterface {
* Get a list of all users. * Get a list of all users.
*/ */
public function getUsers($search = '', $limit = 10, $offset = 0) { public function getUsers($search = '', $limit = 10, $offset = 0) {
$search = $this->access->escapeFilterPart($search); $search = $this->access->escapeFilterPart($search, true);
$cachekey = 'getUsers-'.$search.'-'.$limit.'-'.$offset; $cachekey = 'getUsers-'.$search.'-'.$limit.'-'.$offset;
//check if users are cached, if so return //check if users are cached, if so return