return array(
// TODO(vzanotti): Extend the plat/al engine to support placeholders
// in handler urls, for instance "api/1/user/%forlife/isRegistered".
- 'api/1/user' => $this->make_api_hook('user', AUTH_COOKIE, 'api_user_readonly'),
- 'api/1/search' => $this->make_api_hook('search', AUTH_COOKIE),
+ 'api/1/user' => $this->make_api_hook('user', AUTH_COOKIE, 'api_user_readonly'),
+ 'api/1/search' => $this->make_api_hook('search', AUTH_COOKIE, 'user'),
);
}
$page->trigError('Malformed search query');
return PL_BAD_REQUEST;
}
- Env::set('quick', $payload['quick']);
+
+ $query = trim($payload['quick']);
+ if (@$payload['allow_special']) {
+ if (starts_with($query, 'admin:')) {
+ $page->jsonAssign('link_type', 'admin');
+ $query = substr($query, 6);
+ } else if (starts_with($query, 'adm:')) {
+ $page->jsonAssign('link_type', 'admin');
+ $query = substr($query, 4);
+ } else if (starts_with('admin', $query) || strpos($query, ':') !== false) {
+ $page->jsonAssign('profile_count', -1);
+ $page->jsonAssign('profiles', array());
+ return PL_JSON;
+ } else {
+ $page->jsonAssign('link_type', 'profile');
+ }
+ }
+ if (strlen($query) < 3) {
+ $page->jsonAssign('profile_count', -1);
+ $page->jsonAssign('profiles', array());
+ return PL_JSON;
+ }
+
+ Env::set('quick', $query);
foreach (array('with_soundex', 'exact') as $key) {
if (isset($payload[$key])) {
Env::set($key, $payload[$key]);
require_once 'userset.inc.php';
$view = new QuickSearchSet();
- $view->addMod('json', 'JSon', true, array('with_score' => true, 'starts_with' => $byletter));
+ $view->addMod('json', 'JSon', true, $payload);
$view->apply('api/1/search', $page, 'json');
return PL_JSON;
}