1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-21 22:47:43 +00:00
Files
matomo/plugins/PagePerformance/API.php
Michal Kleiner 9a3ef94df6 [Coding Style] Enable rule PSR12.Files.FileHeader + unify file headers (#22132)
* [Coding Style] Enable rule PSR12.Files.FileHeader

* Apply CS

* Replace Piwik with Matomo in file headers

* Unify file headers (position, no. of lines, https links)

* Rebuild dist files

* Apply CS

* Fix system test that relies on line numbers in a file that had the file header updated

---------

Co-authored-by: Stefan Giehl <stefan@matomo.org>
2024-04-20 20:50:47 +02:00

135 خطوط
4.9 KiB
PHP

<?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\PagePerformance;
use Piwik\Archive;
use Piwik\Piwik;
use Piwik\Plugin\ProcessedMetric;
use Piwik\Plugins\PagePerformance\Columns\Metrics\AveragePageLoadTime;
use Piwik\Plugins\PagePerformance\Columns\Metrics\AverageTimeDomCompletion;
use Piwik\Plugins\PagePerformance\Columns\Metrics\AverageTimeDomProcessing;
use Piwik\Plugins\PagePerformance\Columns\Metrics\AverageTimeNetwork;
use Piwik\Plugins\PagePerformance\Columns\Metrics\AverageTimeServer;
use Piwik\Plugins\PagePerformance\Columns\Metrics\AverageTimeOnLoad;
use Piwik\Plugins\PagePerformance\Columns\Metrics\AverageTimeTransfer;
/**
* @method static \Piwik\Plugins\PagePerformance\API getInstance()
*/
class API extends \Piwik\Plugin\API
{
public function get($idSite, $period, $date, $segment = false)
{
Piwik::checkUserHasViewAccess($idSite);
$archive = Archive::build($idSite, $period, $date, $segment);
$columns = array(
Archiver::PAGEPERFORMANCE_TOTAL_NETWORK_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_NETWORK_HITS,
Archiver::PAGEPERFORMANCE_TOTAL_SERVER_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_SERVER_HITS,
Archiver::PAGEPERFORMANCE_TOTAL_TRANSFER_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_TRANSFER_HITS,
Archiver::PAGEPERFORMANCE_TOTAL_DOMPROCESSING_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_DOMPROCESSING_HITS,
Archiver::PAGEPERFORMANCE_TOTAL_DOMCOMPLETION_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_DOMCOMPLETION_HITS,
Archiver::PAGEPERFORMANCE_TOTAL_ONLOAD_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_ONLOAD_HITS,
Archiver::PAGEPERFORMANCE_TOTAL_PAGE_LOAD_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_PAGE_LOAD_HITS,
);
$dataTable = $archive->getDataTableFromNumeric($columns);
$precision = 2;
$dataTable->filter('ColumnCallbackReplace', [
[
Archiver::PAGEPERFORMANCE_TOTAL_NETWORK_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_SERVER_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_TRANSFER_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_DOMPROCESSING_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_DOMCOMPLETION_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_ONLOAD_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_PAGE_LOAD_TIME,
],
function ($value) {
return $value / 1000;
}
]);
$dataTable->filter('ColumnCallbackAddColumnQuotient', array(
$this->getMetricColumn(AverageTimeNetwork::class),
Archiver::PAGEPERFORMANCE_TOTAL_NETWORK_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_NETWORK_HITS,
$precision
));
$dataTable->filter('ColumnCallbackAddColumnQuotient', array(
$this->getMetricColumn(AverageTimeServer::class),
Archiver::PAGEPERFORMANCE_TOTAL_SERVER_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_SERVER_HITS,
$precision
));
$dataTable->filter('ColumnCallbackAddColumnQuotient', array(
$this->getMetricColumn(AverageTimeTransfer::class),
Archiver::PAGEPERFORMANCE_TOTAL_TRANSFER_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_TRANSFER_HITS,
$precision
));
$dataTable->filter('ColumnCallbackAddColumnQuotient', array(
$this->getMetricColumn(AverageTimeDomProcessing::class),
Archiver::PAGEPERFORMANCE_TOTAL_DOMPROCESSING_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_DOMPROCESSING_HITS,
$precision
));
$dataTable->filter('ColumnCallbackAddColumnQuotient', array(
$this->getMetricColumn(AverageTimeDomCompletion::class),
Archiver::PAGEPERFORMANCE_TOTAL_DOMCOMPLETION_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_DOMCOMPLETION_HITS,
$precision
));
$dataTable->filter('ColumnCallbackAddColumnQuotient', array(
$this->getMetricColumn(AverageTimeOnLoad::class),
Archiver::PAGEPERFORMANCE_TOTAL_ONLOAD_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_ONLOAD_HITS,
$precision
));
$dataTable->filter('ColumnCallbackAddColumnQuotient', array(
$this->getMetricColumn(AveragePageLoadTime::class),
Archiver::PAGEPERFORMANCE_TOTAL_PAGE_LOAD_TIME,
Archiver::PAGEPERFORMANCE_TOTAL_PAGE_LOAD_HITS,
$precision
));
$dataTable->queueFilter('ColumnDelete', array($columns));
return $dataTable;
}
/**
* @param string $class
* @return string
*/
private function getMetricColumn($class)
{
/** @var ProcessedMetric $metric */
$metric = new $class();
return $metric->getName();
}
}