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/public/search | |
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/public/search')
-rw-r--r-- | lib/public/search/provider.php | 47 | ||||
-rw-r--r-- | lib/public/search/result.php | 65 |
2 files changed, 112 insertions, 0 deletions
diff --git a/lib/public/search/provider.php b/lib/public/search/provider.php new file mode 100644 index 00000000000..0506f091dd9 --- /dev/null +++ b/lib/public/search/provider.php @@ -0,0 +1,47 @@ +<?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 OCP\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 OCP\Search\Result's + */ + abstract public function search($query); +} diff --git a/lib/public/search/result.php b/lib/public/search/result.php new file mode 100644 index 00000000000..c70f1bde880 --- /dev/null +++ b/lib/public/search/result.php @@ -0,0 +1,65 @@ +<?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 OCP\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; + } +} |