X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fapisearchjson.php;h=424773f12bf6bb41e7aea20b4ca780f447e764d8;hb=b15f5f0cafc08c9b63090c5b4f7494fca0634238;hp=612dbdda5c78abcaa5123c16e81bd083016f8908;hpb=3fc1d245a179efabfa862d3539642fe0fc67f856;p=quix0rs-gnu-social.git
diff --git a/actions/apisearchjson.php b/actions/apisearchjson.php
index 612dbdda5c..424773f12b 100644
--- a/actions/apisearchjson.php
+++ b/actions/apisearchjson.php
@@ -20,19 +20,15 @@
* along with this program. If not, see .
*
* @category Search
- * @package StatusNet
+ * @package GNUsocial
* @author Zach Copley
* @copyright 2008-2010 StatusNet, Inc.
+ * @copyright 2013 Free Software Foundation, Inc.
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
- * @link http://status.net/
+ * @link http://www.gnu.org/software/social/
*/
-if (!defined('STATUSNET') && !defined('LACONICA')) {
- exit(1);
-}
-
-require_once INSTALLDIR.'/lib/apiprivateauth.php';
-require_once INSTALLDIR.'/lib/jsonsearchresultslist.php';
+if (!defined('GNUSOCIAL')) { exit(1); }
/**
* Action handler for Twitter-compatible API search
@@ -61,7 +57,7 @@ class ApiSearchJSONAction extends ApiPrivateAuthAction
*
* @return boolean true if nothing goes wrong
*/
- function prepare($args)
+ function prepare(array $args=array())
{
parent::prepare($args);
@@ -89,12 +85,6 @@ class ApiSearchJSONAction extends ApiPrivateAuthAction
$this->since_id = $this->trimmed('since_id');
$this->geocode = $this->trimmed('geocode');
- if (!empty($this->auth_user)) {
- $this->auth_profile = $this->auth_user->getProfile();
- } else {
- $this->auth_profile = null;
- }
-
return true;
}
@@ -105,7 +95,7 @@ class ApiSearchJSONAction extends ApiPrivateAuthAction
*
* @return void
*/
- function handle($args)
+ function handle(array $args=array())
{
parent::handle($args);
$this->showResults();
@@ -118,77 +108,20 @@ class ApiSearchJSONAction extends ApiPrivateAuthAction
*/
function showResults()
{
- $q = strtolower($this->query);
-
// TODO: Support search operators like from: and to:, boolean, etc.
- if (preg_match('/^#([\pL\pN_\-\.]{1,64})$/ue', $q)) {
- $stream = new TagNoticeStream(substr($q, 1), $this->auth_profile);
- } else if ($this->isAnURL($q)) {
- $canon = File_redirection::_canonUrl($q);
- $file = File::staticGet('url', $canon);
- if (!empty($file)) {
- $stream = new FileNoticeStream($file, $this->auth_profile);
- }
- } else {
- $stream = new SearchNoticeStream($q, $this->auth_profile);
- }
+ $notice = new Notice();
- if (empty($stream)) {
- // XXX: This is hackish, but need some simple way to say "There's no results"
- $notice = new ArrayWrapper(array());
- } else {
- $notice = $stream->getNotices(($this->page - 1) * $this->rpp, $this->rpp + 1);
+ $this->notices = array();
+ $search_engine = $notice->getSearchEngine('notice');
+ $search_engine->set_sort_mode('chron');
+ $search_engine->limit(($this->page - 1) * $this->rpp, $this->rpp + 1);
+ if ($search_engine->query($this->query)) {
+ $cnt = $notice->find();
+ $this->notices = $notice->fetchAll();
}
- // TODO: max_id, lang, geocode
-
- $results = new JSONSearchResultsList($notice, $q, $this->rpp, $this->page, $this->since_id);
-
- $this->initDocument('json');
- $results->show();
- $this->endDocument('json');
- }
-
- function isAnURL($q) {
- $regex = '#^'.
- '(?:^|[\s\<\>\(\)\[\]\{\}\\\'\\\";]+)(?![\@\!\#])'.
- '('.
- '(?:'.
- '(?:'. //Known protocols
- '(?:'.
- '(?:(?:https?|ftps?|mms|rtsp|gopher|news|nntp|telnet|wais|file|prospero|webcal|irc)://)'.
- '|'.
- '(?:(?:mailto|aim|tel|xmpp):)'.
- ')'.
- '(?:[\pN\pL\-\_\+\%\~]+(?::[\pN\pL\-\_\+\%\~]+)?\@)?'. //user:pass@
- '(?:'.
- '(?:'.
- '\[[\pN\pL\-\_\:\.]+(?showJsonTimeline($this->notices);
}
/**
@@ -196,7 +129,7 @@ class ApiSearchJSONAction extends ApiPrivateAuthAction
*
* @return boolean true
*/
- function isReadOnly($args)
+ function isReadOnly(array $args=array())
{
return true;
}