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_VERSION_DIMENSION, self::BROWSER_VERSION_RECORD_NAME); } private function aggregateByLabel($labelSQL, $recordName) { $metrics = $this->getProcessor()->getMetricsForDimension($labelSQL); $table = $this->getProcessor()->getDataTableFromDataArray($metrics); $this->getProcessor()->insertBlobRecord($recordName, $table->getSerialized($this->maximumRows, null, Metrics::INDEX_NB_VISITS)); } public function archivePeriod() { $dataTablesToSum = array( 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()->aggregateDataTableReports( $dt, $this->maximumRows, $this->maximumRows, $columnToSort = "nb_visits"); } } }