elasticsearch_connector_views.views.inc in Elasticsearch Connector 8.6
Same filename and directory in other branches
- 8.7 modules/elasticsearch_connector_views/elasticsearch_connector_views.views.inc
- 8.2 modules/elasticsearch_connector_views/elasticsearch_connector_views.views.inc
- 8.5 modules/elasticsearch_connector_views/elasticsearch_connector_views.views.inc
- 7.5 modules/elasticsearch_connector_views/elasticsearch_connector_views.views.inc
- 7 modules/elasticsearch_connector_views/elasticsearch_connector_views.views.inc
- 7.2 modules/elasticsearch_connector_views/elasticsearch_connector_views.views.inc
Views hook implementations for the Search API module.
File
modules/elasticsearch_connector_views/elasticsearch_connector_views.views.incView source
<?php
/**
* @file
* Views hook implementations for the Search API module.
*/
use Drupal\Component\Render\FormattableMarkup;
use Drupal\elasticsearch_connector\Entity\Cluster;
/**
* Implements hook_views_data().
*/
function elasticsearch_connector_views_views_data() {
$data = array();
$clientManager = \Drupal::service('elasticsearch_connector.client_manager');
/** @var \Drupal\elasticsearch_connector\ClusterManager $cluster_manager */
$cluster_manager = \Drupal::service('elasticsearch_connector.cluster_manager');
foreach ($cluster_manager
->loadAllClusters(FALSE) as $cluster) {
$elasticsearchClient = $clientManager
->getClientForCluster($cluster);
if ($elasticsearchClient
->isClusterOk()) {
$indices = $elasticsearchClient
->indices()
->stats();
// TODO: Handle aliases also, not only indices.
if (!empty($indices['indices'])) {
foreach ($indices['indices'] as $index_name => $index_info) {
// In elasticsearch the table is actually the document type.
// So get all types and build data array.
$mapping = $elasticsearchClient
->indices()
->getMapping(array(
'index' => $index_name,
));
if (!empty($mapping[$index_name]['mappings'])) {
foreach ($mapping[$index_name]['mappings'] as $type_name => $type_settings) {
$name = new FormattableMarkup('@cluster (@index_name - @type)', array(
'@cluster' => $cluster->name,
'@index_name' => $index_name,
'@type' => $type_name,
));
$base_table = 'elsv__' . $cluster->cluster_id . '__' . $index_name . '__' . $type_name;
$data[$base_table]['table']['group'] = t('Elasticsearch');
$data[$base_table]['table']['base'] = array(
'index' => $index_name,
'cluster_id' => $cluster->cluster_id,
'type' => $type_name,
'title' => t('Cluster :name', array(
':name' => $name,
)),
'help' => t('Searches the site with the Elasticsearch search engine for !name', array(
'!name' => $name,
)),
'query_id' => 'elasticsearch_connector_views_query',
);
// Get the list of the fields in index directly from Elasticsearch.
if (!empty($type_settings['properties'])) {
_elasticsearch_connector_views_handle_fields($base_table, $data, $type_settings['properties']);
}
// Keyword field.
$data[$base_table]['keyword'] = array(
'title' => t('Search'),
'help' => t('Fulltext search'),
'filter' => array(
'id' => 'elasticsearch_connector_views_fulltext_filter',
),
);
// Snippet field.
$data[$base_table]['snippet'] = array(
'title' => t('Snippet'),
'help' => t('Search snippet'),
'field' => array(
'handler' => 'elasticsearch_connector_views_snippet_handler_field',
'click sortable' => TRUE,
),
);
// Score field.
$data[$base_table]['score'] = array(
'title' => t('Score'),
'help' => t('Score'),
'field' => array(
'id' => 'elasticsearch_connector_views_standard',
'click sortable' => TRUE,
),
);
}
}
}
}
}
}
return $data;
}
/**
* Handle the fields mapping and handle nested data types.
*
* @param string $base_table
* The base table value.
* @param array $data
* Data array.
* @param array $fields
* Fields array.
* @param string $base_field_name
* Base field name.
*/
function _elasticsearch_connector_views_handle_fields($base_table, &$data, $fields, $base_field_name = '') {
if (!empty($fields)) {
foreach ($fields as $field_name => $field) {
// TODO: Restrict some fields if needed.
// TODO: Handle boolean.
// TODO: Handle the cases with analyzed and not analyzed.
if (empty($field['type']) && isset($field['properties'])) {
$field_type = 'object';
}
else {
$field_type = $field['type'];
}
$filter_handler = 'elasticsearch_connector_views_standard';
$field_handler = 'elasticsearch_connector_views_standard';
$set = TRUE;
switch ($field_type) {
case 'object':
if (!empty($field['properties'])) {
_elasticsearch_connector_views_handle_fields($base_table, $data, $field['properties'], $base_field_name . $field_name . '.');
}
$set = FALSE;
break;
case 'date':
$filter_handler = 'elasticsearch_connector_views_date';
$field_handler = 'elasticsearch_connector_views_date';
break;
case 'boolean':
$filter_handler = 'elasticsearch_connector_views_boolean';
$field_handler = 'elasticsearch_connector_views_boolean';
break;
case 'text':
case 'string':
// TODO: Handle the analyser and non_analyzed fields.
// TODO: For analysed fields we need to do fulltext search.
if (\Drupal::moduleHandler()
->moduleExists('views_autocomplete_filters')) {
// TODO: Handle autocomplete.
//$filter_handler = 'elasticsearch_connector_views_handler_filter_string_autocomplete';
}
else {
$field_handler = 'elasticsearch_connector_views_markup';
$filter_handler = 'elasticsearch_connector_views_string';
}
break;
// Handle numeric filter type.
case 'integer':
case 'long':
case 'float':
case 'double':
$filter_handler = 'elasticsearch_connector_views_numeric';
$field_handler = 'elasticsearch_connector_views_numeric';
break;
}
if ($set) {
$data[$base_table][$base_field_name . $field_name] = array(
'title' => $base_field_name . $field_name,
'help' => $base_field_name . $field_name,
'field' => array(
'id' => $field_handler,
'click sortable' => TRUE,
),
'filter' => array(
'id' => $filter_handler,
),
'sort' => array(
'id' => 'standard',
),
// TODO: Handle the argument class.
'argument' => array(
'id' => 'standard',
),
);
}
}
}
}
Functions
Name | Description |
---|---|
elasticsearch_connector_views_views_data | Implements hook_views_data(). |
_elasticsearch_connector_views_handle_fields | Handle the fields mapping and handle nested data types. |