51 lines
1.6 KiB
PHP
51 lines
1.6 KiB
PHP
<?php
|
|
/**
|
|
* Piwik - free/libre analytics platform
|
|
*
|
|
* @link http://piwik.org
|
|
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
|
|
*
|
|
*/
|
|
namespace Piwik\Plugins\Resolution;
|
|
|
|
use Piwik\Archive;
|
|
use Piwik\DataTable;
|
|
use Piwik\Metrics;
|
|
use Piwik\Piwik;
|
|
|
|
/**
|
|
* @see plugins/Resolution/functions.php
|
|
*/
|
|
require_once PIWIK_INCLUDE_PATH . '/plugins/Resolution/functions.php';
|
|
|
|
/**
|
|
* @method static \Piwik\Plugins\Resolution\API getInstance()
|
|
*/
|
|
class API extends \Piwik\Plugin\API
|
|
{
|
|
protected function getDataTable($name, $idSite, $period, $date, $segment)
|
|
{
|
|
Piwik::checkUserHasViewAccess($idSite);
|
|
$archive = Archive::build($idSite, $period, $date, $segment);
|
|
$dataTable = $archive->getDataTable($name);
|
|
$dataTable->queueFilter('ReplaceColumnNames');
|
|
$dataTable->queueFilter('ReplaceSummaryRowLabel');
|
|
return $dataTable;
|
|
}
|
|
|
|
public function getResolution($idSite, $period, $date, $segment = false)
|
|
{
|
|
$dataTable = $this->getDataTable(Archiver::RESOLUTION_RECORD_NAME, $idSite, $period, $date, $segment);
|
|
$dataTable->filter('AddSegmentValue');
|
|
return $dataTable;
|
|
}
|
|
|
|
public function getConfiguration($idSite, $period, $date, $segment = false)
|
|
{
|
|
$dataTable = $this->getDataTable(Archiver::CONFIGURATION_RECORD_NAME, $idSite, $period, $date, $segment);
|
|
// use GroupBy filter to avoid duplicate rows if old reports are displayed
|
|
$dataTable->queueFilter('GroupBy', array('label', __NAMESPACE__ . '\getConfigurationLabel'));
|
|
return $dataTable;
|
|
}
|
|
}
|