X-Git-Url: https://git.cyclocoop.org/%27.WWW_URL.%27admin/?a=blobdiff_plain;f=includes%2Fapi%2FApiOpenSearch.php;h=022ecd11e233e4ea30973f7fe4b8300c44da692d;hb=958a998611ee5a4230a316be987a26947824195f;hp=fe8217b704e06e82ced879aa9b5feafe3d2751db;hpb=380f66878f9d513b8f98f189e68d1fdc46dda28f;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/api/ApiOpenSearch.php b/includes/api/ApiOpenSearch.php index fe8217b704..022ecd11e2 100644 --- a/includes/api/ApiOpenSearch.php +++ b/includes/api/ApiOpenSearch.php @@ -1,11 +1,11 @@ @gmail.com + * Copyright © 2006 Yuri Astrakhan @gmail.com * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -19,87 +19,88 @@ * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * http://www.gnu.org/copyleft/gpl.html */ -if (!defined('MEDIAWIKI')) { +if ( !defined( 'MEDIAWIKI' ) ) { // Eclipse helper - will be ignored in production - require_once ("ApiBase.php"); + require_once( "ApiBase.php" ); } /** - * @addtogroup API + * @ingroup API */ class ApiOpenSearch extends ApiBase { - public function __construct($main, $action) { - parent :: __construct($main, $action); + public function __construct( $main, $action ) { + parent::__construct( $main, $action ); } public function getCustomPrinter() { - return $this->getMain()->createPrinterByName('json'); + return $this->getMain()->createPrinterByName( 'json' ); } public function execute() { + global $wgEnableOpenSearchSuggest, $wgSearchSuggestCacheExpiry; $params = $this->extractRequestParams(); $search = $params['search']; - - // Open search results may be stored for a very long time - $this->getMain()->setCacheMaxAge(1200); - - $title = Title :: newFromText($search); - if(!$title) - return; // Return empty result - - // Prepare nested request - $req = new FauxRequest(array ( - 'action' => 'query', - 'list' => 'allpages', - 'apnamespace' => $title->getNamespace(), - 'aplimit' => 10, - 'apprefix' => $title->getDBkey() - )); - - // Execute - $module = new ApiMain($req); - $module->execute(); - - // Get resulting data - $data = $module->getResultData(); - - // Reformat useful data for future printing by JSON engine - $srchres = array (); - foreach ($data['query']['allpages'] as & $pageinfo) { - // Note: this data will no be printable by the xml engine - // because it does not support lists of unnamed items - $srchres[] = $pageinfo['title']; + $limit = $params['limit']; + $namespaces = $params['namespace']; + $suggest = $params['suggest']; + + // MWSuggest or similar hit + if ( $suggest && !$wgEnableOpenSearchSuggest ) { + $srchres = array(); + } else { + // Open search results may be stored for a very long + // time + $this->getMain()->setCacheMaxAge( $wgSearchSuggestCacheExpiry ); + $this->getMain()->setCacheMode( 'public' ); + + $srchres = PrefixSearch::titleSearch( $search, $limit, + $namespaces ); } - // Set top level elements $result = $this->getResult(); - $result->addValue(null, 0, $search); - $result->addValue(null, 1, $srchres); + $result->addValue( null, 0, $search ); + $result->addValue( null, 1, $srchres ); } - protected function getAllowedParams() { - return array ( - 'search' => null + public function getAllowedParams() { + return array( + 'search' => null, + 'limit' => array( + ApiBase::PARAM_DFLT => 10, + ApiBase::PARAM_TYPE => 'limit', + ApiBase::PARAM_MIN => 1, + ApiBase::PARAM_MAX => 100, + ApiBase::PARAM_MAX2 => 100 + ), + 'namespace' => array( + ApiBase::PARAM_DFLT => NS_MAIN, + ApiBase::PARAM_TYPE => 'namespace', + ApiBase::PARAM_ISMULTI => true + ), + 'suggest' => false, ); } - protected function getParamDescription() { - return array ( - 'search' => 'Search string' + public function getParamDescription() { + return array( + 'search' => 'Search string', + 'limit' => 'Maximum amount of results to return', + 'namespace' => 'Namespaces to search', + 'suggest' => 'Do nothing if $wgEnableOpenSearchSuggest is false', ); } - protected function getDescription() { + public function getDescription() { return 'This module implements OpenSearch protocol'; } protected function getExamples() { - return array ( + return array( 'api.php?action=opensearch&search=Te' ); } @@ -108,4 +109,3 @@ class ApiOpenSearch extends ApiBase { return __CLASS__ . ': $Id$'; } } -