1 | <?php |
||
17 | class SearchEngineIndexerFactory |
||
18 | { |
||
19 | /** |
||
20 | * @var \eZ\Bundle\EzPublishCoreBundle\ApiLoader\RepositoryConfigurationProvider |
||
21 | */ |
||
22 | private $repositoryConfigurationProvider; |
||
23 | |||
24 | /** |
||
25 | * Hash of registered search engine indexers. |
||
26 | * Key is the search engine identifier, value indexer itself. |
||
27 | * |
||
28 | * @var \eZ\Publish\Core\Search\Common\Indexer[] |
||
29 | */ |
||
30 | protected $searchEngineIndexers = []; |
||
31 | |||
32 | public function __construct(RepositoryConfigurationProvider $repositoryConfigurationProvider) |
||
36 | |||
37 | /** |
||
38 | * Registers $searchEngineIndexer as a valid search engine indexer with identifier $searchEngineIdentifier. |
||
39 | * |
||
40 | * @note It is strongly recommended to register indexer as a lazy service. |
||
41 | * |
||
42 | * @param \eZ\Publish\Core\Search\Common\Indexer $searchEngineIndexer |
||
43 | * @param string $searchEngineIdentifier |
||
44 | */ |
||
45 | public function registerSearchEngineIndexer(SearchEngineIndexer $searchEngineIndexer, $searchEngineIdentifier) |
||
49 | |||
50 | /** |
||
51 | * Returns registered search engine indexers. |
||
52 | * |
||
53 | * @return \eZ\Publish\Core\Search\Common\Indexer[] |
||
54 | */ |
||
55 | public function getSearchEngineIndexers() |
||
59 | |||
60 | /** |
||
61 | * Build search engine indexer identified by its identifier (the "alias" attribute in the service tag), |
||
62 | * resolved for current siteaccess. |
||
63 | * |
||
64 | * @throws \eZ\Bundle\EzPublishCoreBundle\ApiLoader\Exception\InvalidSearchEngineIndexer |
||
65 | * |
||
66 | * @return \eZ\Publish\Core\Search\Common\Indexer |
||
67 | */ |
||
68 | public function buildSearchEngineIndexer() |
||
87 | } |
||
88 |