. * */ namespace OC; /** * Provide an interface to all search providers */ class Search { static private $providers=array(); static 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) { $results=array_merge($results, $provider->search($query)); } return $results; } /** * Remove all registered search providers */ public static function clearProviders() { self::$providers=array(); self::$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, function ($element) use ($provider) { return ($element['class'] != $provider); } ); // force regeneration of providers on next search self::$providers=array(); } /** * Register a new search provider to search with * @param string $provider class name of a OC\Search\Provider */ public static function registerProvider($class, $options=array()) { self::$registeredProviders[]=array('class'=>$class, 'options'=>$options); } /** * Create instances of all the registered search providers */ private static function initProviders() { if(count(self::$providers)>0) { return; } foreach(self::$registeredProviders as $provider) { $class=$provider['class']; $options=$provider['options']; self::$providers[]=new $class($options); } } }