1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-21 22:47:43 +00:00
Files
matomo/plugins/ExamplePlugin/RecordBuilders/ExampleMetric.php
Stefan Giehl 75290a04f4 Use https URLs (#23072)
* Use https URLs

* Build vue files

* use matomo.org instead of piwik.org in some links

* updates expected UI test file

---------

Co-authored-by: innocraft-automation <innocraft-automation@users.noreply.github.com>
2025-02-27 16:34:08 +01:00

94 خطوط
3.2 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\ExamplePlugin\RecordBuilders;
use Piwik\ArchiveProcessor;
use Piwik\ArchiveProcessor\Record;
use Piwik\ArchiveProcessor\RecordBuilder;
use Piwik\Date;
/**
* The RecordBuilder class processes raw data into ready ro read reports.
* It must implement two methods, one for aggregating daily reports
* aggregate() and another returning information about the record.
*
* Plugins can have more than one RecordBuilder, and should try to divide them
* up into the smallest number they can, while still performing as few total log aggregation
* queries as possible (this results in improved performance overall).
*
* For more detailed information about RecordBuilders please visit Matomo developer guide
* https://developer.matomo.org/api-reference/Piwik/ArchiveProcessor/RecordBuilder
*/
class ExampleMetric extends RecordBuilder
{
/**
* It is good practice to store your archive names (reports stored in database)
* as class constants. You can define as many record names as you want
* for your plugin.
*
* Also important to note that record names must be prefixed with the plugin name.
*
* These are only example record names, so feel free to change them to suit your needs.
*/
public const EXAMPLEPLUGIN_ARCHIVE_RECORD = "ExamplePlugin_archive_record";
public const EXAMPLEPLUGIN_METRIC_NAME = 'ExamplePlugin_example_metric';
private $daysFrom = '2016-07-08';
/**
* This method should return the list of records this RecordBuilder creates. This example
* archives one metric, so we return some information about them.
*/
public function getRecordMetadata(ArchiveProcessor $archiveProcessor): array
{
return [
Record::make(Record::TYPE_NUMERIC, self::EXAMPLEPLUGIN_METRIC_NAME),
];
}
/**
* inside this method you can implement your LogAggregator usage
* to process daily reports. this code for example, uses idvisitor to group results:
*
* ```
* $record = new DataTable();
*
* $query = $archiveProcessor->getLogAggregator()->queryVisitsByDimension(['idvisitor']);
* while ($row = $query->fetch()) {
* $label = $row['idvisitor'];
* unset($row['idvisitor']);
* $record->sumRowWithLabel($label, $row);
* }
*
* return [self::EXAMPLEPLUGIN_ARCHIVE_RECORD => $record];
* ```
*
* non-day periods will automatically be aggregated together
*/
protected function aggregate(ArchiveProcessor $archiveProcessor): array
{
$params = $archiveProcessor->getParams();
$records = [];
// insert a test numeric metric that is the difference in days between the day we're archiving and
// $this->daysFrom.
$daysFrom = Date::factory($this->daysFrom);
$date = $params->getPeriod()->getDateStart();
$differenceInSeconds = $daysFrom->getTimestamp() - $date->getTimestamp();
$differenceInDays = round($differenceInSeconds / 86400);
$records[self::EXAMPLEPLUGIN_METRIC_NAME] = $differenceInDays;
return $records;
}
}