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