Skip to content
Extraits de code Groupes Projets
API.php 5,79 ko
Newer Older
  • Learn to ignore specific revisions
  • <?php
    /**
     * Piwik - Open source web analytics
     *
     * @link http://piwik.org
     * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
     *
     */
    
    mattab's avatar
    mattab a validé
    use Piwik\Archive;
    
    mattab's avatar
    mattab a validé
    use Piwik\Piwik;
    
    
    /**
     * The DevicesDetection API lets you access reports on your visitors devices, brands, models, Operating system, Browsers.
    
     * @method static \Piwik\Plugins\DevicesDetection\API getInstance()
    
    {
        /**
         * @param string $name
         * @param int $idSite
         * @param string $period
         * @param string $date
         * @param string $segment
         * @return DataTable
         */
        protected function getDataTable($name, $idSite, $period, $date, $segment)
        {
            Piwik::checkUserHasViewAccess($idSite);
    
    mattab's avatar
    mattab a validé
            $archive = Archive::build($idSite, $period, $date, $segment);
    
            $dataTable = $archive->getDataTable($name);
    
            $dataTable->filter('Sort', array(Metrics::INDEX_NB_VISITS));
    
            $dataTable->queueFilter('ReplaceColumnNames');
            $dataTable->queueFilter('ReplaceSummaryRowLabel');
            return $dataTable;
        }
    
        /**
         * Gets datatable displaying number of visits by device type (eg. desktop, smartphone, tablet)
         * @param int $idSite
         * @param string $period
         * @param string $date
    
    sgiehl's avatar
    sgiehl a validé
         * @param bool|string $segment
    
         */
        public function getType($idSite, $period, $date, $segment = false)
        {
            $dataTable = $this->getDataTable('DevicesDetection_types', $idSite, $period, $date, $segment);
    
            $dataTable->filter('ColumnCallbackAddMetadata', array('label', 'logo', __NAMESPACE__ . '\getDeviceTypeLogo'));
    
            $dataTable->filter('ColumnCallbackReplace', array('label', __NAMESPACE__ . '\getDeviceTypeLabel'));
    
            return $dataTable;
        }
    
        /**
         * Gets datatable displaying number of visits by device manufacturer name
         * @param int $idSite
         * @param string $period
         * @param string $date
    
    sgiehl's avatar
    sgiehl a validé
         * @param bool|string $segment
    
         */
        public function getBrand($idSite, $period, $date, $segment = false)
        {
            $dataTable = $this->getDataTable('DevicesDetection_brands', $idSite, $period, $date, $segment);
    
            $dataTable->filter('ColumnCallbackReplace', array('label', __NAMESPACE__ . '\getDeviceBrandLabel'));
            $dataTable->filter('ColumnCallbackAddMetadata', array('label', 'logo', __NAMESPACE__ . '\getBrandLogo'));
    
            return $dataTable;
        }
    
        /**
         * Gets datatable displaying number of visits by device model
         * @param int $idSite
         * @param string $period
         * @param string $date
    
    sgiehl's avatar
    sgiehl a validé
         * @param bool|string $segment
    
         */
        public function getModel($idSite, $period, $date, $segment = false)
        {
            $dataTable = $this->getDataTable('DevicesDetection_models', $idSite, $period, $date, $segment);
    
            $dataTable->filter('ColumnCallbackReplace', array('label', __NAMESPACE__ . '\getModelName'));
    
            return $dataTable;
        }
    
        /**
         * Gets datatable displaying number of visits by OS family (eg. Windows, Android, Linux)
         * @param int $idSite
         * @param string $period
         * @param string $date
    
    sgiehl's avatar
    sgiehl a validé
         * @param bool|string $segment
    
         */
        public function getOsFamilies($idSite, $period, $date, $segment = false)
        {
            $dataTable = $this->getDataTable('DevicesDetection_os', $idSite, $period, $date, $segment);
    
            $dataTable->filter('GroupBy', array('label', __NAMESPACE__ . '\getOSFamilyFullNameExtended'));
            $dataTable->filter('ColumnCallbackAddMetadata', array('label', 'logo', __NAMESPACE__ . '\getOsFamilyLogoExtended'));
    
            return $dataTable;
        }
    
        /**
         * Gets datatable displaying number of visits by OS version (eg. Android 4.0, Windows 7)
         * @param int $idSite
         * @param string $period
         * @param string $date
    
    sgiehl's avatar
    sgiehl a validé
         * @param bool|string $segment
    
         */
        public function getOsVersions($idSite, $period, $date, $segment = false)
        {
            $dataTable = $this->getDataTable('DevicesDetection_osVersions', $idSite, $period, $date, $segment);
    
            $dataTable->filter('ColumnCallbackAddMetadata', array('label', 'logo', __NAMESPACE__ . '\getOsLogoExtended'));
            $dataTable->filter('ColumnCallbackReplace', array('label', __NAMESPACE__ . '\getOsFullNameExtended'));
    
    
            return $dataTable;
        }
    
        /**
         * Gets datatable displaying number of visits by Browser family (eg. Firefox, InternetExplorer)
    
         * @param string $period
         * @param string $date
    
    sgiehl's avatar
    sgiehl a validé
         * @param bool|string $segment
    
         */
        public function getBrowserFamilies($idSite, $period, $date, $segment = false)
        {
            $dataTable = $this->getDataTable('DevicesDetection_browsers', $idSite, $period, $date, $segment);
    
            $dataTable->filter('GroupBy', array('label', __NAMESPACE__ . '\getBrowserFamilyFullNameExtended'));
            $dataTable->filter('ColumnCallbackAddMetadata', array('label', 'logo', __NAMESPACE__ . '\getBrowserFamilyLogoExtended'));
    
            return $dataTable;
        }
    
        /**
         * Gets datatable displaying number of visits by Browser version (eg. Firefox 20, Safari 6.0)
         * @param int $idSite
         * @param string $period
         * @param string $date
    
    sgiehl's avatar
    sgiehl a validé
         * @param bool|string $segment
    
         */
        public function getBrowserVersions($idSite, $period, $date, $segment = false)
        {
            $dataTable = $this->getDataTable('DevicesDetection_browserVersions', $idSite, $period, $date, $segment);
    
            $dataTable->filter('ColumnCallbackAddMetadata', array('label', 'logo', __NAMESPACE__ . '\getBrowserLogoExtended'));
            $dataTable->filter('ColumnCallbackReplace', array('label', __NAMESPACE__ . '\getBrowserNameExtended'));