$last_modified, 'file' => $tmp_file )); // si il y a une version plus recente que l'on a recu correctement if ($res['status'] == 200 and $res['length'] and $tmp_file = $res['file'] ) { if ($md5 !== md5_file($tmp_file)) { // on essaye de l'inclure pour verifier que ca ne fait pas erreur fatale include_once $tmp_file; // ok, on le copie a la place de l'ecran existant // en backupant l'ecran avant, au cas ou @copy($filename, $filename . "-bck-" . date('Y-m-d-His', $last_modified)); @rename($tmp_file, $filename); } else { @unlink($tmp_file); } } } /** * Vérifier si une nouvelle version de SPIP est disponible * * Repérer aussi si cette version est une version majeure de SPIP. * * @param string $dir * @param string $file * @param string $version * La version reçue ici est sous la forme x.y.z * On la transforme par la suite pour avoir des integer ($maj, $min, $rev) * et ainsi pouvoir mieux les comparer * * @return string */ function info_maj($dir, $file, $version) { include_spip('inc/plugin'); list($maj, $min, $rev) = preg_split('/\D+/', $version); $nom = _DIR_CACHE_XML . _VERSIONS_LISTE; $page = !file_exists($nom) ? '' : file_get_contents($nom); $page = info_maj_cache($nom, $dir, $page); // reperer toutes les versions de numero majeur superieur ou egal // (a revoir quand on arrivera a SPIP V10 ...) $p = substr("0123456789", intval($maj)); $p = ',/' . $file . '\D+([' . $p . ']+)\D+(\d+)(\D+(\d+))?.*?[.]zip",i'; preg_match_all($p, $page, $m, PREG_SET_ORDER); $page = $page_majeure = ''; // branche en cours d'utilisation $branche = implode('.', array_slice(explode('.', $version, 3), 0, 2)); foreach ($m as $v) { $v = array_pad($v, 5, 0); list(, $maj2, $min2, , $rev2) = $v; $branche_maj = $maj2 . '.' . $min2; $version_maj = $maj2 . '.' . $min2 . '.' . $rev2; // d'abord les mises à jour de la même branche if ((spip_version_compare($version, $version_maj, '<')) and (spip_version_compare($page, $version_maj, '<')) and spip_version_compare($branche, $branche_maj, '=') ) { $page = $version_maj; } // puis les mises à jours majeures if ((spip_version_compare($version, $version_maj, '<')) and (spip_version_compare($page, $version_maj, '<')) and spip_version_compare($branche, $branche_maj, '<') ) { $page_majeure = $version_maj; } } if (!$page and !$page_majeure) { return ""; } $message = $page ? _T('nouvelle_version_spip', array('version' => $page)) . ($page_majeure ? ' | ' : '') : ''; $message .= $page_majeure ? _T('nouvelle_version_spip_majeure', array('version' => $page_majeure)) : ''; return "" . $message . ''; } /** * Vérifie que la liste $page des versions dans le fichier $nom est à jour. * * Ce fichier rajoute dans ce fichier l'aléa éphémère courant; * on teste la nouveauté par If-Modified-Since, * et seulement quand celui-ci a changé pour limiter les accès HTTP. * Si le fichier n'a pas été modifié, on garde l'ancienne version. * * @see info_maj() * * @param string $nom * Nom du fichier contenant les infos de mise à jour. * @param string $dir * @param string $page * @return string * Contenu du fichier de cache de l'info de maj de SPIP. */ function info_maj_cache($nom, $dir, $page = '') { include_spip('inc/acces'); $alea_ephemere = charger_aleas(); $re = ''; if (preg_match("/$re/", $page)) { return $page; } $url = _VERSIONS_SERVEUR . $dir . '/' . _VERSIONS_LISTE; $a = file_exists($nom) ? filemtime($nom) : ''; include_spip('inc/distant'); $res = recuperer_url_cache($url, array('if_modified_since' => $a)); // Si rien de neuf (ou inaccessible), garder l'ancienne if ($res) { $page = $res['page'] ? $res['page'] : $page; } // Placer l'indicateur de fraicheur $page = preg_replace('/^/', $re, $page); sous_repertoire(_DIR_CACHE_XML); ecrire_fichier($nom, $page); return $page; }