]> git.mxchange.org Git - friendica.git/blob - mod/qsearch.php
Issue-#3873
[friendica.git] / mod / qsearch.php
1 <?php
2
3 use Friendica\App;
4 use Friendica\Core\Config;
5
6 function qsearch_init(App $a) {
7
8         if (! local_user()) {
9                 killme();
10         }
11
12         $limit = (Config::get('system','qsearch_limit') ? intval(Config::get('system','qsearch_limit')) : 100);
13
14         $search = ((x($_GET,'s')) ? notags(trim(urldecode($_GET['s']))) : '');
15
16         if(! strlen($search))
17                 killme();
18
19
20         if($search)
21                 $search = dbesc($search);
22
23         $results = array();
24
25         $r = q("SELECT * FROM `group` WHERE `name` REGEXP '$search' AND `deleted` = 0 AND `uid` = %d LIMIT 0, %d ",
26                 intval(local_user()),
27                 intval($limit)
28         );
29
30         if (dbm::is_result($r)) {
31
32                 foreach($r as $rr)
33                         $results[] = array( 0, (int) $rr['id'], $rr['name'], '', '');
34         }
35
36         $sql_extra = ((strlen($search)) ? " AND (`name` REGEXP '$search' OR `nick` REGEXP '$search') " : "");
37
38
39         $r = q("SELECT * FROM `contact` WHERE `uid` = %d $sql_extra ORDER BY `name` ASC LIMIT 0, %d ",
40                 intval(local_user()),
41                 intval($limit)
42         );
43
44
45         if (dbm::is_result($r)) {
46
47                 foreach($r as $rr)
48                         $results[] = array( (int) $rr['id'], 0, $rr['name'],$rr['url'],$rr['photo']);
49         }
50
51         echo json_encode((object) $results);
52         killme();
53 }