1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Plugins\Actions;
use Piwik\Metrics as PiwikMetrics;
use Piwik\Piwik;
use Piwik\Tracker\Action;
/**
* Class encapsulating logic to process Day/Period Archiving for the Actions reports
*
*/
class Metrics
{
public static $actionTypes = array(
Action::TYPE_PAGE_URL,
Action::TYPE_OUTLINK,
Action::TYPE_DOWNLOAD,
Action::TYPE_PAGE_TITLE,
Action::TYPE_SITE_SEARCH,
);
public static $columnsToRenameAfterAggregation = array(
PiwikMetrics::INDEX_NB_UNIQ_VISITORS => PiwikMetrics::INDEX_SUM_DAILY_NB_UNIQ_VISITORS,
PiwikMetrics::INDEX_PAGE_ENTRY_NB_UNIQ_VISITORS => PiwikMetrics::INDEX_PAGE_ENTRY_SUM_DAILY_NB_UNIQ_VISITORS,
PiwikMetrics::INDEX_PAGE_EXIT_NB_UNIQ_VISITORS => PiwikMetrics::INDEX_PAGE_EXIT_SUM_DAILY_NB_UNIQ_VISITORS,
);
public static $columnsToDeleteAfterAggregation = array(
PiwikMetrics::INDEX_NB_UNIQ_VISITORS,
PiwikMetrics::INDEX_PAGE_ENTRY_NB_UNIQ_VISITORS,
PiwikMetrics::INDEX_PAGE_EXIT_NB_UNIQ_VISITORS,
);
public static function getColumnsAggregationOperation()
{
$operations = [];
$actionMetrics = self::getActionMetrics();
foreach ($actionMetrics as $actionMetric => $definition) {
if (!empty($definition['aggregation']) && $definition['aggregation'] !== 'sum') {
$operations[$actionMetric] = $definition['aggregation'];
}
}
return $operations;
}
public static function getActionMetrics()
{
$metricsConfig = array(
PiwikMetrics::INDEX_NB_VISITS => array(
'aggregation' => 'sum',
'query' => "count(distinct log_link_visit_action.idvisit)",
),
PiwikMetrics::INDEX_NB_UNIQ_VISITORS => array(
'aggregation' => false,
'query' => "count(distinct log_link_visit_action.idvisitor)",
),
PiwikMetrics::INDEX_PAGE_NB_HITS => array(
'aggregation' => 'sum',
'query' => "count(*)",
),
PiwikMetrics::INDEX_PAGE_SUM_TIME_GENERATION => array(
'aggregation' => 'sum',
'query' => "sum(
case when " . Action::DB_COLUMN_CUSTOM_FLOAT . " is null
then 0
else " . Action::DB_COLUMN_CUSTOM_FLOAT . "
end
) / 1000",
),
PiwikMetrics::INDEX_PAGE_NB_HITS_WITH_TIME_GENERATION => array(
'aggregation' => 'sum',
'query' => "sum(
case when " . Action::DB_COLUMN_CUSTOM_FLOAT . " is null
then 0
else 1
end
)",
),
PiwikMetrics::INDEX_PAGE_MIN_TIME_GENERATION => array(
'aggregation' => 'min',
'query' => "min(" . Action::DB_COLUMN_CUSTOM_FLOAT . ") / 1000",
),
PiwikMetrics::INDEX_PAGE_MAX_TIME_GENERATION => array(
'aggregation' => 'max',
'query' => "max(" . Action::DB_COLUMN_CUSTOM_FLOAT . ") / 1000",
),
);
Piwik::postEvent('Actions.Archiving.addActionMetrics', array(&$metricsConfig));
return $metricsConfig;
}
}
|