function elasticsearch_connector_statistics_top_pages in Elasticsearch Connector 7.5
Same name and namespace in other branches
- 7 modules/elasticsearch_connector_statistics/elasticsearch_connector_statistics.admin.inc \elasticsearch_connector_statistics_top_pages()
- 7.2 modules/elasticsearch_connector_statistics/elasticsearch_connector_statistics.admin.inc \elasticsearch_connector_statistics_top_pages()
Page callback: Displays statistics for the "top pages" (most accesses).
This displays the pages with the most hits (the "top pages") within a given time period that haven't been flushed yet. The flush interval is set on the statistics settings form, but is dependent on cron running.
Return value
A render array containing information about the the top pages.
1 string reference to 'elasticsearch_connector_statistics_top_pages'
- elasticsearch_connector_statistics_menu in modules/
elasticsearch_connector_statistics/ elasticsearch_connector_statistics.module - Implements hook_menu().
File
- modules/
elasticsearch_connector_statistics/ elasticsearch_connector_statistics.admin.inc, line 182 - Admin page callbacks for the Statistics module.
Code
function elasticsearch_connector_statistics_top_pages() {
$header = array(
array(
'data' => t('Hits'),
),
array(
'data' => t('Page'),
),
);
$rows = $facets = array();
$global_facet_name = 'path_facet';
$field_faceting = 'path';
$client_id = elasticsearch_connector_statistics_get_cluster_vars();
if (!empty($client_id)) {
$client = elasticsearch_connector_get_client_by_id($client_id);
if ($client) {
try {
$params = array();
$index_name = elasticsearch_connector_statistics_get_cluster_vars('index');
$params['index'] = $index_name;
$params['type'] = variable_get('elasticsearch_connector_statistics_type', ELASTICSEARCH_CONNECTOR_STATS_DEFAULT_TYPE);
$aggr = new \nodespark\DESConnector\Elasticsearch\Aggregations\Bucket\Terms($global_facet_name, $field_faceting);
$aggr
->setSize(variable_get('elasticsearch_connector_statistics_facet_size', 1000));
$client
->aggregations()
->setAggregation($aggr);
$search_result = $client
->search($params)
->getRawResponse();
if (!empty($search_result['aggregations'])) {
foreach ($search_result['aggregations'][$global_facet_name]['buckets'] as $bucket) {
$bucket['key'] = l(url($bucket['key'], array(
'absolute' => FALSE,
)), $bucket['key']);
$rows[] = array(
$bucket['doc_count'],
$bucket['key'],
);
}
}
} catch (Exception $e) {
// Show the error message to the user.
drupal_set_message($e
->getMessage(), 'error');
}
}
}
$build['statistics_top_pages_table'] = array(
'#theme' => 'table',
'#header' => $header,
'#rows' => $rows,
'#empty' => t('No statistics available.'),
);
return $build;
}