Piwik\Site::setSitesFromArray PHP Method

setSitesFromArray() public static method

Sets the cached Site data with a non-associated array of site data.
public static setSitesFromArray ( array $sites )
$sites array The array of sites data. eg, array( array('idsite' => '1', 'name' => 'Site 1', ...), array('idsite' => '2', 'name' => 'Site 2', ...), )
    public static function setSitesFromArray($sites)
    {
        self::triggerSetSitesEvent($sites);
        foreach ($sites as $site) {
            $idSite = null;
            if (!empty($site['idsite'])) {
                $idSite = $site['idsite'];
            }
            self::setSiteFromArray($idSite, $site);
        }
    }

Usage Example

Example #1
0
 /**
  * Returns the list of websites from the ID array in parameters.
  * The user access is not checked in this method so the ID have to be accessible by the user!
  *
  * @param array $idSites list of website ID
  * @param bool $limit
  * @return array
  */
 private function getSitesFromIds($idSites, $limit = false)
 {
     if (count($idSites) === 0) {
         return array();
     }
     if ($limit) {
         $limit = "LIMIT " . (int) $limit;
     }
     $db = Db::get();
     $sites = $db->fetchAll("SELECT *\n\t\t\t\t\t\t\t\tFROM " . Common::prefixTable("site") . "\n\t\t\t\t\t\t\t\tWHERE idsite IN (" . implode(", ", $idSites) . ")\n\t\t\t\t\t\t\t\tORDER BY idsite ASC {$limit}");
     Site::setSitesFromArray($sites);
     return $sites;
 }
All Usage Examples Of Piwik\Site::setSitesFromArray