Skip to content
Extraits de code Groupes Projets
Archiver.php 4,07 ko
Newer Older
  • Learn to ignore specific revisions
  •  * Piwik - free/libre analytics platform
    
     *
     * @link http://piwik.org
     * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
     *
     */
    
    
    sgiehl's avatar
    sgiehl a validé
    use Piwik\Common;
    
    class Archiver extends \Piwik\Plugin\Archiver
    
        const BROWSER_SEPARATOR = ';';
    
        const DEVICE_TYPE_RECORD_NAME = 'DevicesDetection_types';
        const DEVICE_BRAND_RECORD_NAME = 'DevicesDetection_brands';
        const DEVICE_MODEL_RECORD_NAME = 'DevicesDetection_models';
    
        const OS_RECORD_NAME = 'DevicesDetection_os';
        const OS_VERSION_RECORD_NAME = 'DevicesDetection_osVersions';
        const BROWSER_RECORD_NAME = 'DevicesDetection_browsers';
    
        const BROWSER_ENGINE_RECORD_NAME = 'DevicesDetection_browserEngines';
    
        const BROWSER_VERSION_RECORD_NAME = 'DevicesDetection_browserVersions';
    
    
        const DEVICE_TYPE_FIELD = "config_device_type";
        const DEVICE_BRAND_FIELD = "config_device_brand";
    
        const DEVICE_MODEL_FIELD = "CONCAT(log_visit.config_device_brand, ';', log_visit.config_device_model)";
    
        const OS_FIELD = "config_os";
    
        const OS_VERSION_FIELD = "CONCAT(log_visit.config_os, ';', COALESCE(log_visit.config_os_version, ''))";
    
        const BROWSER_FIELD = "config_browser_name";
    
        const BROWSER_ENGINE_FIELD = "config_browser_engine";
    
        const BROWSER_VERSION_DIMENSION = "CONCAT(log_visit.config_browser_name, ';', log_visit.config_browser_version)";
    
            $this->aggregateByLabel(self::DEVICE_TYPE_FIELD, self::DEVICE_TYPE_RECORD_NAME);
            $this->aggregateByLabel(self::DEVICE_BRAND_FIELD, self::DEVICE_BRAND_RECORD_NAME);
            $this->aggregateByLabel(self::DEVICE_MODEL_FIELD, self::DEVICE_MODEL_RECORD_NAME);
            $this->aggregateByLabel(self::OS_FIELD, self::OS_RECORD_NAME);
            $this->aggregateByLabel(self::OS_VERSION_FIELD, self::OS_VERSION_RECORD_NAME);
            $this->aggregateByLabel(self::BROWSER_FIELD, self::BROWSER_RECORD_NAME);
    
            $this->aggregateByLabel(self::BROWSER_ENGINE_FIELD, self::BROWSER_ENGINE_RECORD_NAME);
    
            $this->aggregateByLabel(self::BROWSER_VERSION_DIMENSION, self::BROWSER_VERSION_RECORD_NAME);
    
        public function aggregateMultipleReports()
    
                self::DEVICE_TYPE_RECORD_NAME,
                self::DEVICE_BRAND_RECORD_NAME,
                self::DEVICE_MODEL_RECORD_NAME,
    
                self::OS_RECORD_NAME,
                self::OS_VERSION_RECORD_NAME,
                self::BROWSER_RECORD_NAME,
    
                self::BROWSER_VERSION_RECORD_NAME
    
            foreach ($dataTablesToSum as $dt) {
    
                $this->getProcessor()->aggregateDataTableRecords(
    
                    $dt,
                    $this->maximumRows,
                    $this->maximumRows,
                    $columnToSort = 'nb_visits',
    
                    $columnsToRenameAfterAggregation = null,
    
    mattab's avatar
    mattab a validé
    
        private function aggregateByLabel($labelSQL, $recordName)
        {
    
            $metrics = $this->getLogAggregator()->getMetricsFromVisitByDimension($labelSQL);
    
            if (in_array($recordName, array(self::DEVICE_TYPE_RECORD_NAME, self::DEVICE_BRAND_RECORD_NAME, self::DEVICE_MODEL_RECORD_NAME))) {
    
                $labelSQL = str_replace('log_visit.', 'log_conversion.', $labelSQL);
    
                $query = $this->getLogAggregator()->queryConversionsByDimension(array($labelSQL));
    
                if ($query === false) {
                    return;
                }
    
                while ($conversionRow = $query->fetch()) {
    
    sgiehl's avatar
    sgiehl a validé
                    $metrics->sumMetricsGoals(isset($conversionRow[$labelSQL]) ? $conversionRow[$labelSQL] : null, $conversionRow);
    
                }
                $metrics->enrichMetricsWithConversions();
            }
    
    
    sgiehl's avatar
    sgiehl a validé
            $table = $metrics->asDataTable();
            $report = $table->getSerialized($this->maximumRows, null, Metrics::INDEX_NB_VISITS);
            Common::destroy($table);
    
    mattab's avatar
    mattab a validé
            $this->getProcessor()->insertBlobRecord($recordName, $report);
    
    sgiehl's avatar
    sgiehl a validé
            unset($table, $report);
    
    mattab's avatar
    mattab a validé
        }