argc >= 2) { $filter = $a->argv[1]; switch ($filter) { case 'forums': $community = 1; break; case 'people': $community = 0; break; default: $community = null; $filter = null; break; } } $alpha = false; if (x($_GET, 'alpha') == 1) $alpha = true; //Query $search = ((x($_GET, 'query')) ? notags(trim($_GET['query'])) : ''); if (empty($search)) { goaway('/home'); } if ($search) { $alpha = true; } //Run our query. if ($search) { $search = dbesc($search . '*'); } $sql_extra = ((strlen($search)) ? " AND MATCH (`name`, `pdesc`, `homepage`, `locality`, `region`, `country-name`, `tags` ) AGAINST ('$search' IN BOOLEAN MODE) " : ''); if (!is_null($community)) { $sql_extra .= ' AND `comm` = ' . intval($community) . ' '; } $sql_extra = str_replace('%', '%%', $sql_extra); $total = 0; $r = q("SELECT COUNT(*) AS `total` FROM `profile` WHERE `censored` = 0 $sql_extra "); if (count($r)) { $total = $r[0]['total']; $a->set_pager_total($total); } if ($alpha) { $order = ' ORDER BY `name` ASC '; } else { $order = ' ORDER BY `updated` DESC, `id` DESC '; } $r = q("SELECT * FROM `profile` WHERE `censored` = 0 $sql_extra $order LIMIT %d , %d ", intval($a->pager['start']), intval($a->pager['itemspage']) ); //Show results. $view = new View('search'); $view->addHelper('paginate', function() use ($a) { return paginate($a); }); $view->addHelper('photoUrl', ProfileHelper::get('photoUrl')); $view->addHelper('filterAllUrl', SearchHelper::get('filterAllUrl')); $view->addHelper('filterPeopleUrl', SearchHelper::get('filterPeopleUrl')); $view->addHelper('filterForumsUrl', SearchHelper::get('filterForumsUrl')); $view->output(array( 'total' => number_format($total), 'results' => $r, 'filter' => $filter, 'query' => x($_GET, 'query') ? $_GET['query'] : '' )); }