IndexSwitcherProxy.php 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\CatalogSearch\Model\Indexer;
  7. use Magento\Framework\ObjectManagerInterface;
  8. use Magento\Framework\Search\EngineResolverInterface;
  9. /**
  10. * Proxy for adapter-specific index switcher
  11. */
  12. class IndexSwitcherProxy implements IndexSwitcherInterface
  13. {
  14. /**
  15. * Object Manager instance
  16. *
  17. * @var ObjectManagerInterface
  18. */
  19. private $objectManager = null;
  20. /**
  21. * Instance name to create
  22. *
  23. * @var string
  24. */
  25. private $handlers;
  26. /**
  27. * @var EngineResolverInterface
  28. */
  29. private $engineResolver;
  30. /**
  31. * Factory constructor
  32. *
  33. * @param ObjectManagerInterface $objectManager
  34. * @param EngineResolverInterface $engineResolver
  35. * @param string[] $handlers
  36. */
  37. public function __construct(
  38. ObjectManagerInterface $objectManager,
  39. EngineResolverInterface $engineResolver,
  40. array $handlers = []
  41. ) {
  42. $this->objectManager = $objectManager;
  43. $this->handlers = $handlers;
  44. $this->engineResolver = $engineResolver;
  45. }
  46. /**
  47. * @inheritDoc
  48. *
  49. * As index switcher is an optional part of the search SPI, it may be not defined by a search engine.
  50. * It is especially reasonable for search engines with pre-defined indexes declaration (like Sphinx)
  51. * which cannot create temporary indexes on the fly.
  52. * That's the reason why this method do nothing for the case
  53. * when switcher is not defined for a specific search engine.
  54. */
  55. public function switchIndex(array $dimensions)
  56. {
  57. $currentHandler = $this->engineResolver->getCurrentSearchEngine();
  58. if (!isset($this->handlers[$currentHandler])) {
  59. return;
  60. }
  61. $this->create($currentHandler)->switchIndex($dimensions);
  62. }
  63. /**
  64. * Create indexer handler
  65. *
  66. * @param string $handler
  67. * @return IndexSwitcherInterface
  68. */
  69. private function create($handler)
  70. {
  71. $indexSwitcher = $this->objectManager->create($this->handlers[$handler]);
  72. if (!$indexSwitcher instanceof IndexSwitcherInterface) {
  73. throw new \InvalidArgumentException(
  74. $handler . ' index switcher doesn\'t implement ' . IndexSwitcherInterface::class
  75. );
  76. }
  77. return $indexSwitcher;
  78. }
  79. }