Skip to content

Commit

Permalink
Merge branch '2.10.x' into 2.11.x
Browse files Browse the repository at this point in the history
  • Loading branch information
rbayet committed Jan 13, 2025
2 parents ba7354d + ef91cfe commit 310636d
Show file tree
Hide file tree
Showing 7 changed files with 202 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -141,21 +141,50 @@ protected function getFilteredResultCountMetric()
'filter' => $this->queryFactory->create(
QueryInterface::TYPE_BOOL,
[
'must' => [
$this->getIsFirstPageQuery(),
],
'mustNot' => [
$this->queryFactory->create(
QueryInterface::TYPE_NESTED,
[
'path' => 'page.product_list.filters',
'query' => $this->queryFactory->create(
QueryInterface::TYPE_EXISTS,
['field' => 'page.product_list.filters']
),
]
),
$this->hasNavigationFiltersQuery(),
],
]
),
]
);
}

/**
* Return "only first page" query.
*
* @return QueryInterface
*/
protected function getIsFirstPageQuery()
{
return $this->queryFactory->create(
QueryInterface::TYPE_TERM,
[
'field' => 'page.product_list.current_page',
'value' => 1,
]
);
}

/**
* Return query indicating there are active product list filters.
*
* @return QueryInterface
*/
protected function hasNavigationFiltersQuery()
{
return $this->queryFactory->create(
QueryInterface::TYPE_NESTED,
[
'path' => 'page.product_list.filters',
'query' => $this->queryFactory->create(
QueryInterface::TYPE_EXISTS,
['field' => 'page.product_list.filters']
),
]
);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
use Smile\ElasticsuiteAnalytics\Model\Search\Usage\Terms\AggregationProvider as TermsAggregationProvider;
use Smile\ElasticsuiteCore\Search\Request\BucketInterface;
use Smile\ElasticsuiteCore\Search\Request\MetricInterface;
use Smile\ElasticsuiteCore\Search\Request\QueryInterface;

/**
* Aggregation provider for terms that always return 0 results
Expand All @@ -34,6 +35,7 @@ public function getAggregation()
$aggParams = [
'field' => 'search_query_void.sortable',
'name' => 'search_terms',
'filter' => $this->getIsFirstPageQuery(),
'metrics' => $this->getMetrics(),
'pipelines' => $this->getPipelines(),
'sortOrder' => ['unique_sessions' => 'desc'],
Expand Down
3 changes: 3 additions & 0 deletions src/module-elasticsuite-core/etc/elasticsuite_analysis.xml
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,9 @@
<filter name="stemmer" type="stemmer" language="el">
<language>greek</language>
</filter>
<filter name="stemmer" type="stemmer" language="et">
<language>estonian</language>
</filter>
<filter name="stemmer" type="stemmer" language="fi">
<language>finnish</language>
</filter>
Expand Down
130 changes: 128 additions & 2 deletions src/module-elasticsuite-indices/Model/IndexStatsProvider.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
use Exception;
use Psr\Log\LoggerInterface;
use Smile\ElasticsuiteCore\Api\Client\ClientInterface;
use Smile\ElasticsuiteCore\Helper\Cache as CacheHelper;
use Smile\ElasticsuiteIndices\Block\Widget\Grid\Column\Renderer\IndexStatus;

/**
Expand All @@ -27,6 +28,26 @@
*/
class IndexStatsProvider
{
/**
* Cache Key Prefix.
*/
const CACHE_KEY_PREFIX = 'es_index_settings_';

/**
* Cache Tag.
*/
const CACHE_TAG = 'index_settings';

/**
* @var int Cache lifetime.
*/
const CACHE_LIFETIME = 7200;

/**
* @var CacheHelper
*/
private $cacheHelper;

/**
* @var ClientInterface
*/
Expand Down Expand Up @@ -57,20 +78,28 @@ class IndexStatsProvider
*/
private $indicesStats = null;

/**
* @var array
*/
private $cachedIndexSettings = [];

/**
* Constructor.
*
* @param CacheHelper $cacheHelper ES cache helper.
* @param ClientInterface $client ES client.
* @param IndicesList $indicesList Index list.
* @param IndexStatusProvider $indexStatusProvider Index Status Provider.
* @param LoggerInterface $logger Logger.
*/
public function __construct(
CacheHelper $cacheHelper,
ClientInterface $client,
IndicesList $indicesList,
IndexStatusProvider $indexStatusProvider,
LoggerInterface $logger
) {
$this->cacheHelper = $cacheHelper;
$this->client = $client;
$this->indicesList = $indicesList;
$this->indexStatusProvider = $indexStatusProvider;
Expand Down Expand Up @@ -122,11 +151,17 @@ public function indexStats($indexName, $alias): array
$data = [
'index_name' => $indexName,
'index_alias' => $alias,
'number_of_documents' => 'undefined',
'size' => 'undefined',
'number_of_documents' => 'N/A',
'size' => 'N/A',
'number_of_shards' => 'N/A',
'number_of_replicas' => 'N/A',
];

try {
// Retrieve number of shards and replicas configuration.
$data['number_of_shards'] = $this->getShardsConfiguration($indexName);
$data['number_of_replicas'] = $this->getReplicasConfiguration($indexName);

if (!isset($this->indicesStats[$indexName])) {
$indexStatsResponse = $this->client->indexStats($indexName);
$this->indicesStats[$indexName] = current($indexStatsResponse['indices']);
Expand All @@ -151,6 +186,84 @@ public function indexStats($indexName, $alias): array
return $data;
}

/**
* Get index settings with caching.
*
* @param string $indexName Index name.
* @return array
*
* @SuppressWarnings(PHPMD.ElseExpression)
*/
public function getIndexSettings(string $indexName): array
{
$cacheKey = self::CACHE_KEY_PREFIX . $indexName;

// Check if the settings are already in memory.
if (!isset($this->cachedIndexSettings[$cacheKey])) {
$cachedData = $this->cacheHelper->loadCache($cacheKey);

if ($cachedData) {
$this->cachedIndexSettings[$cacheKey] = $cachedData;
} else {
$settingsData = $this->client->getSettings($indexName);

// Save to cache with a tag.
$this->cacheHelper->saveCache(
$cacheKey,
$settingsData,
$this->getCacheTags(),
self::CACHE_LIFETIME
);

$this->cachedIndexSettings[$cacheKey] = $settingsData;
}
}

return $this->cachedIndexSettings[$cacheKey];
}

/**
* Retrieve number of shards from index settings.
*
* @param string $indexName Index name.
*
* @return int
*/
public function getShardsConfiguration($indexName)
{
// Retrieve the index settings.
$indexSettings = $this->getIndexSettings($indexName);

// Check if settings for the given index exist and retrieve number_of_shards.
if (isset($indexSettings[$indexName]['settings']['index']['number_of_shards'])) {
return (int) $indexSettings[$indexName]['settings']['index']['number_of_shards'];
}

// Return null or throw an exception if the value doesn't exist.
throw new \RuntimeException("number_of_shards setting not found for index: $indexName");
}

/**
* Retrieve number of replicas from index settings.
*
* @param string $indexName Index name.
*
* @return int
*/
public function getReplicasConfiguration($indexName)
{
// Retrieve the index settings.
$indexSettings = $this->getIndexSettings($indexName);

// Check if settings for the given index exist and retrieve number_of_replicas.
if (isset($indexSettings[$indexName]['settings']['index']['number_of_replicas'])) {
return (int) $indexSettings[$indexName]['settings']['index']['number_of_replicas'];
}

// Return null or throw an exception if the value doesn't exist.
throw new \RuntimeException("number_of_replicas setting not found for index: $indexName");
}

/**
* Returns if index is elastic suite index.
*
Expand Down Expand Up @@ -206,4 +319,17 @@ private function initStats()
}
}
}

/**
* Get cache tags.
*
* @return array
*/
private function getCacheTags()
{
return [
\Smile\ElasticsuiteCore\Cache\Type\Elasticsuite::CACHE_TAG,
self::CACHE_TAG,
];
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ class WarningAboutClusterShardsMisconfig implements MessageInterface
*/
private const ES_INDICES_SETTINGS_WIKI_PAGE = 'https://github.com/Smile-SA/elasticsuite/wiki/ModuleInstall#indices-settings';

public const UNDEFINED_SIZE = 'undefined';
public const UNDEFINED_SIZE = 'N/A';

/**
* @var IndexSettingsHelper
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,6 @@
</arguments>
</block>


<block class="Magento\Backend\Block\Widget\Grid\Column" as="size">
<arguments>
<argument name="header" xsi:type="string" translate="true">Size</argument>
Expand All @@ -82,6 +81,28 @@
</arguments>
</block>

<block class="Magento\Backend\Block\Widget\Grid\Column" as="number_of_shards">
<arguments>
<argument name="header" xsi:type="string" translate="true">Shards</argument>
<argument name="index" xsi:type="string">number_of_shards</argument>
<argument name="filter" xsi:type="string">0</argument>
<argument name="type" xsi:type="string">text</argument>
<argument name="align" xsi:type="string">right</argument>
<argument name="sortable" xsi:type="boolean">0</argument>
</arguments>
</block>

<block class="Magento\Backend\Block\Widget\Grid\Column" as="number_of_replicas">
<arguments>
<argument name="header" xsi:type="string" translate="true">Replicas</argument>
<argument name="index" xsi:type="string">number_of_replicas</argument>
<argument name="filter" xsi:type="string">0</argument>
<argument name="type" xsi:type="string">text</argument>
<argument name="align" xsi:type="string">right</argument>
<argument name="sortable" xsi:type="boolean">0</argument>
</arguments>
</block>

<block class="Magento\Backend\Block\Widget\Grid\Column" as="index_status">
<arguments>
<argument name="header" xsi:type="string" translate="true">Index Status</argument>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,14 @@
.col-index_status {
max-width: 13rem;
}
.col-number_of_documents, .col-size {
.col-number_of_documents, .col-size, .col-number_of_shards, .col-number_of_replicas {
text-align: right;
}
.col-number_of_shards, .col-number_of_replicas {
width: 70px;
}
.col-actions {
width: 170px;
}
}
}

0 comments on commit 310636d

Please sign in to comment.