diff options
author | Jörn Friedrich Dreyer <jfd@butonic.de> | 2014-06-06 01:17:02 +0200 |
---|---|---|
committer | Jörn Friedrich Dreyer <jfd@butonic.de> | 2014-06-06 01:17:02 +0200 |
commit | aaf0d131718dc9079a5b3717276455f8701feeea (patch) | |
tree | ca915a5012b5d107d8d201d25a365a312e71a095 /lib/private | |
parent | 5034bd1b129b75e7b571cb0ed239d02010c806f7 (diff) | |
download | nextcloud-server-aaf0d131718dc9079a5b3717276455f8701feeea.tar.gz nextcloud-server-aaf0d131718dc9079a5b3717276455f8701feeea.zip |
make search non-static, add ISearch to server container, make legacy a static wrapper for it, move provider and result to public api
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/legacy/search.php | 41 | ||||
-rw-r--r-- | lib/private/search.php | 49 | ||||
-rw-r--r-- | lib/private/search/provider.php | 47 | ||||
-rw-r--r-- | lib/private/search/provider/file.php | 4 | ||||
-rw-r--r-- | lib/private/search/result.php | 65 | ||||
-rw-r--r-- | lib/private/search/result/file.php | 2 | ||||
-rw-r--r-- | lib/private/server.php | 10 |
7 files changed, 78 insertions, 140 deletions
diff --git a/lib/private/legacy/search.php b/lib/private/legacy/search.php index e6396020225..f77b43be2e0 100644 --- a/lib/private/legacy/search.php +++ b/lib/private/legacy/search.php @@ -24,6 +24,45 @@ * provides an interface to all search providers * @deprecated see lib/search.php */ -class OC_Search extends \OC\Search{ +class OC_Search { + /** + * @return \OCP\ISearch + */ + private static function getSearch() { + return \OC::$server->getSearch(); + } + + /** + * Search all providers for $query + * @param string $query + * @return array An array of OCP\Search\Result's + */ + public static function search($query) { + return self::getSearch()->search($query); + } + + /** + * Register a new search provider to search with + * @param string $class class name of a OCP\Search\Provider + * @param array $options optional + */ + public static function registerProvider($class, $options = array()) { + return self::getSearch()->registerProvider($class, $options); + } + + /** + * Remove one existing search provider + * @param string $provider class name of a OCP\Search\Provider + */ + public static function removeProvider($provider) { + return self::getSearch()->removeProvider($provider); + } + + /** + * Remove all registered search providers + */ + public static function clearProviders() { + return self::getSearch()->clearProviders(); + } } diff --git a/lib/private/search.php b/lib/private/search.php index 8ac9e9fdf33..bcaebdddd9c 100644 --- a/lib/private/search.php +++ b/lib/private/search.php @@ -21,27 +21,28 @@ */ namespace OC; -use OC\Search\Provider; +use OCP\Search\Provider; +use OCP\ISearch; /** * Provide an interface to all search providers */ -class Search { +class Search implements ISearch { - static private $providers=array(); - static private $registeredProviders=array(); + private $providers = array(); + private $registeredProviders = array(); /** * Search all providers for $query * @param string $query * @return array An array of OC\Search\Result's */ - public static function search($query) { - self::initProviders(); - $results=array(); - foreach(self::$providers as $provider) { + public function search($query) { + $this->initProviders(); + $results = array(); + foreach($this->providers as $provider) { /** @var $provider Provider */ - $results=array_merge($results, $provider->search($query)); + $results = array_merge($results, $provider->search($query)); } return $results; } @@ -49,24 +50,24 @@ class Search { /** * Remove all registered search providers */ - public static function clearProviders() { - self::$providers=array(); - self::$registeredProviders=array(); + public function clearProviders() { + $this->providers=array(); + $this->registeredProviders=array(); } /** * Remove one existing search provider * @param string $provider class name of a OC\Search\Provider */ - public static function removeProvider($provider) { - self::$registeredProviders = array_filter( - self::$registeredProviders, + public function removeProvider($provider) { + $this->registeredProviders = array_filter( + $this->registeredProviders, function ($element) use ($provider) { return ($element['class'] != $provider); } ); // force regeneration of providers on next search - self::$providers=array(); + $this->providers=array(); } /** @@ -74,21 +75,21 @@ class Search { * @param string $class class name of a OC\Search\Provider * @param array $options optional */ - public static function registerProvider($class, $options=array()) { - self::$registeredProviders[]=array('class'=>$class, 'options'=>$options); + public function registerProvider($class, $options=array()) { + $this->registeredProviders[]=array('class'=>$class, 'options'=>$options); } /** * Create instances of all the registered search providers */ - private static function initProviders() { - if(count(self::$providers)>0) { + private function initProviders() { + if(count($this->providers)>0) { return; } - foreach(self::$registeredProviders as $provider) { - $class=$provider['class']; - $options=$provider['options']; - self::$providers[]=new $class($options); + foreach($this->registeredProviders as $provider) { + $class = $provider['class']; + $options = $provider['options']; + $this->providers[]=new $class($options); } } diff --git a/lib/private/search/provider.php b/lib/private/search/provider.php deleted file mode 100644 index 45d9f823c55..00000000000 --- a/lib/private/search/provider.php +++ /dev/null @@ -1,47 +0,0 @@ -<?php -/** - * ownCloud - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU AFFERO GENERAL PUBLIC LICENSE for more details. - * - * You should have received a copy of the GNU Affero General Public - * License along with this library. If not, see <http://www.gnu.org/licenses/>. - * - */ - -namespace OC\Search; - -/** - * Provides a template for search functionality throughout ownCloud; - */ -abstract class Provider { - - /** - * List of options (currently unused) - * @var array - */ - private $options; - - /** - * Constructor - * @param array $options - */ - public function __construct($options) { - $this->options = $options; - } - - /** - * Search for $query - * @param string $query - * @return array An array of OC\Search\Result's - */ - abstract public function search($query); -} diff --git a/lib/private/search/provider/file.php b/lib/private/search/provider/file.php index daf73cf79c2..cbd3a253732 100644 --- a/lib/private/search/provider/file.php +++ b/lib/private/search/provider/file.php @@ -23,12 +23,12 @@ use OC\Files\Filesystem; /** * Provide search results from the 'files' app */ -class File extends \OC\Search\Provider { +class File extends \OCP\Search\Provider { /** * Search for files and folders matching the given query * @param string $query - * @return \OC\Search\Result + * @return \OCP\Search\Result */ function search($query) { $files = Filesystem::search($query); diff --git a/lib/private/search/result.php b/lib/private/search/result.php deleted file mode 100644 index d228f833810..00000000000 --- a/lib/private/search/result.php +++ /dev/null @@ -1,65 +0,0 @@ -<?php -/** - * ownCloud - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU AFFERO GENERAL PUBLIC LICENSE for more details. - * - * You should have received a copy of the GNU Affero General Public - * License along with this library. If not, see <http://www.gnu.org/licenses/>. - * - */ - -namespace OC\Search; - -/** - * The generic result of a search - */ -class Result { - - /** - * A unique identifier for the result, usually given as the item ID in its - * corresponding application. - * @var string - */ - public $id; - - /** - * The name of the item returned; this will be displayed in the search - * results. - * @var string - */ - public $name; - - /** - * URL to the application item. - * @var string - */ - public $link; - - /** - * The type of search result returned; for consistency, name this the same - * as the class name (e.g. \OC\Search\File -> 'file') in lowercase. - * @var string - */ - public $type = 'generic'; - - /** - * Create a new search result - * @param string $id unique identifier from application: '[app_name]/[item_identifier_in_app]' - * @param string $name displayed text of result - * @param string $link URL to the result within its app - */ - public function __construct($id = null, $name = null, $link = null) { - $this->id = $id; - $this->name = $name; - $this->link = $link; - } -} diff --git a/lib/private/search/result/file.php b/lib/private/search/result/file.php index 32a4aebc700..da5fa64ef45 100644 --- a/lib/private/search/result/file.php +++ b/lib/private/search/result/file.php @@ -22,7 +22,7 @@ use \OC\Files\Filesystem; /** * A found file */ -class File extends \OC\Search\Result { +class File extends \OCP\Search\Result { /** * Type name; translated in templates diff --git a/lib/private/server.php b/lib/private/server.php index 47bdee4b0f8..da705863078 100644 --- a/lib/private/server.php +++ b/lib/private/server.php @@ -186,6 +186,9 @@ class Server extends SimpleContainer implements IServerContainer { } return $router; }); + $this->registerService('Search', function($c){ + return new Search(); + }); $this->registerService('Db', function($c){ return new Db(); }); @@ -422,6 +425,13 @@ class Server extends SimpleContainer implements IServerContainer { return $this->query('Router'); } + /** + * Returns a search instance + * @return \OCP\ISearch + */ + function getSearch() { + return $this->query('Search'); + } /** * Returns an instance of the db facade |