IndexerHandler.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Elasticsearch\Model\Indexer;
  7. use Magento\Framework\Indexer\SaveHandler\IndexerInterface;
  8. use Magento\Framework\Indexer\SaveHandler\Batch;
  9. use Magento\Framework\Indexer\IndexStructureInterface;
  10. use Magento\Elasticsearch\Model\Adapter\Elasticsearch as ElasticsearchAdapter;
  11. use Magento\Elasticsearch\Model\Adapter\Index\IndexNameResolver;
  12. use Magento\Framework\App\ScopeResolverInterface;
  13. /**
  14. * Indexer Handler for Elasticsearch engine.
  15. */
  16. class IndexerHandler implements IndexerInterface
  17. {
  18. /**
  19. * Default batch size
  20. */
  21. const DEFAULT_BATCH_SIZE = 500;
  22. /**
  23. * @var IndexStructureInterface
  24. */
  25. private $indexStructure;
  26. /**
  27. * @var ElasticsearchAdapter
  28. */
  29. private $adapter;
  30. /**
  31. * @var IndexNameResolver
  32. */
  33. private $indexNameResolver;
  34. /**
  35. * @var Batch
  36. */
  37. private $batch;
  38. /**
  39. * @var array
  40. */
  41. private $data;
  42. /**
  43. * @var int
  44. */
  45. private $batchSize;
  46. /**
  47. * @var ScopeResolverInterface
  48. */
  49. private $scopeResolver;
  50. /**
  51. * @param IndexStructureInterface $indexStructure
  52. * @param ElasticsearchAdapter $adapter
  53. * @param IndexNameResolver $indexNameResolver
  54. * @param Batch $batch
  55. * @param ScopeResolverInterface $scopeResolver
  56. * @param array $data
  57. * @param int $batchSize
  58. */
  59. public function __construct(
  60. IndexStructureInterface $indexStructure,
  61. ElasticsearchAdapter $adapter,
  62. IndexNameResolver $indexNameResolver,
  63. Batch $batch,
  64. ScopeResolverInterface $scopeResolver,
  65. array $data = [],
  66. $batchSize = self::DEFAULT_BATCH_SIZE
  67. ) {
  68. $this->indexStructure = $indexStructure;
  69. $this->adapter = $adapter;
  70. $this->indexNameResolver = $indexNameResolver;
  71. $this->batch = $batch;
  72. $this->data = $data;
  73. $this->batchSize = $batchSize;
  74. $this->scopeResolver = $scopeResolver;
  75. }
  76. /**
  77. * @inheritdoc
  78. */
  79. public function saveIndex($dimensions, \Traversable $documents)
  80. {
  81. $dimension = current($dimensions);
  82. $scopeId = $this->scopeResolver->getScope($dimension->getValue())->getId();
  83. foreach ($this->batch->getItems($documents, $this->batchSize) as $documentsBatch) {
  84. $docs = $this->adapter->prepareDocsPerStore($documentsBatch, $scopeId);
  85. $this->adapter->addDocs($docs, $scopeId, $this->getIndexerId());
  86. }
  87. $this->adapter->updateAlias($scopeId, $this->getIndexerId());
  88. return $this;
  89. }
  90. /**
  91. * @inheritdoc
  92. */
  93. public function deleteIndex($dimensions, \Traversable $documents)
  94. {
  95. $dimension = current($dimensions);
  96. $scopeId = $this->scopeResolver->getScope($dimension->getValue())->getId();
  97. $documentIds = [];
  98. foreach ($documents as $document) {
  99. $documentIds[$document] = $document;
  100. }
  101. $this->adapter->deleteDocs($documentIds, $scopeId, $this->getIndexerId());
  102. return $this;
  103. }
  104. /**
  105. * @inheritdoc
  106. */
  107. public function cleanIndex($dimensions)
  108. {
  109. $this->indexStructure->delete($this->getIndexerId(), $dimensions);
  110. $this->indexStructure->create($this->getIndexerId(), [], $dimensions);
  111. return $this;
  112. }
  113. /**
  114. * @inheritdoc
  115. */
  116. public function isAvailable($dimensions = [])
  117. {
  118. return $this->adapter->ping();
  119. }
  120. /**
  121. * Returns indexer id.
  122. *
  123. * @return string
  124. */
  125. private function getIndexerId()
  126. {
  127. return $this->indexNameResolver->getIndexMapping($this->data['indexer_id']);
  128. }
  129. }