friendica-github/mod/qsearch.php

55 lines
1.1 KiB
PHP
Raw Normal View History

2011-02-25 15:28:07 -08:00
<?php
use Friendica\App;
use Friendica\Core\Config;
2017-11-07 22:57:46 -05:00
use Friendica\Database\DBM;
function qsearch_init(App $a) {
2011-02-25 15:28:07 -08:00
if (! local_user()) {
2011-02-25 15:28:07 -08:00
killme();
}
2011-02-25 15:28:07 -08:00
$limit = (Config::get('system','qsearch_limit') ? intval(Config::get('system','qsearch_limit')) : 100);
2011-02-25 15:28:07 -08:00
$search = ((x($_GET,'s')) ? notags(trim(urldecode($_GET['s']))) : '');
if(! strlen($search))
2011-02-25 15:28:07 -08:00
killme();
if($search)
2011-02-25 15:28:07 -08:00
$search = dbesc($search);
$results = array();
$r = q("SELECT * FROM `group` WHERE `name` REGEXP '$search' AND `deleted` = 0 AND `uid` = %d LIMIT 0, %d ",
intval(local_user()),
intval($limit)
);
2017-11-07 22:57:46 -05:00
if (DBM::is_result($r)) {
foreach($r as $rr)
$results[] = array( 0, (int) $rr['id'], $rr['name'], '', '');
2011-02-25 15:28:07 -08:00
}
$sql_extra = ((strlen($search)) ? " AND (`name` REGEXP '$search' OR `nick` REGEXP '$search') " : "");
$r = q("SELECT * FROM `contact` WHERE `uid` = %d $sql_extra ORDER BY `name` ASC LIMIT 0, %d ",
intval(local_user()),
intval($limit)
);
2017-11-07 22:57:46 -05:00
if (DBM::is_result($r)) {
foreach($r as $rr)
$results[] = array( (int) $rr['id'], 0, $rr['name'],$rr['url'],$rr['photo']);
2011-02-25 15:28:07 -08:00
}
echo json_encode((object) $results);
2011-02-25 15:28:07 -08:00
killme();
2011-02-25 19:57:44 -08:00
}