_RENOUVELLE_ALEA + $GLOBALS['meta']['alea_ephemere_date'])) { // si on n'a pas l'acces en ecriture sur le cache, // ne pas renouveller l'alea sinon le cache devient faux if (supprimer_fichier($cache)) { include_spip('inc/acces'); renouvelle_alea(); $new = false; } else spip_log("impossible d'ecrire dans " . $cache); } // et refaire le cache si on a du lire en base if (!$new) touch_meta(false, $table); } // fonctions aussi appelees a l'install ==> spip_query en premiere requete // pour eviter l'erreur fatale (serveur non encore configure) // http://doc.spip.org/@lire_metas function lire_metas($table='meta') { if ($result = spip_query("SELECT nom,valeur FROM spip_$table")) { include_spip('base/abstract_sql'); $GLOBALS[$table] = array(); while ($row = sql_fetch($result)) $GLOBALS[$table][$row['nom']] = $row['valeur']; sql_free($result); if (!$GLOBALS[$table]['charset'] OR $GLOBALS[$table]['charset']=='_DEFAULT_CHARSET' // hum, correction d'un bug ayant abime quelques install ) ecrire_meta('charset', _DEFAULT_CHARSET, NULL, $table); } return $GLOBALS[$table]; } // Mettre en cache la liste des meta, sauf les valeurs sensibles // pour qu'elles ne soient pas visibiles dans un fichier.souvent en 777 // http://doc.spip.org/@touch_meta function touch_meta($antidate= false, $table='meta'){ $file = cache_meta($table); if (!$antidate OR !@touch($file, $antidate)) { $r = $GLOBALS[$table]; unset($r['alea_ephemere']); unset($r['alea_ephemere_ancien']); // le secret du site est utilise pour encoder les contextes ajax que l'on considere fiables // mais le sortir deu cache meta implique une requete sql des qu'on a un form dynamique // meme si son squelette est en cache //unset($r['secret_du_site']); if ($antidate) $r['touch']= $antidate; ecrire_fichier_securise($file, serialize($r)); } } // http://doc.spip.org/@effacer_meta function effacer_meta($nom, $table='meta') { // section critique sur le cache: // l'invalider avant et apres la MAJ de la BD // c'est un peu moins bien qu'un vrai verrou mais ca suffira // et utiliser une statique pour eviter des acces disques a repetition static $touch = array(); $antidate = time() - (_META_CACHE_TIME<<4); if (!isset($touch[$table])) {touch_meta($antidate, $table);} sql_delete('spip_' . $table, "nom='$nom'"); unset($GLOBALS[$table][$nom]); if (!isset($touch[$table])) {touch_meta($antidate, $table); $touch[$table] = false;} } // http://doc.spip.org/@ecrire_meta function ecrire_meta($nom, $valeur, $importable = NULL, $table='meta') { static $touch = array(); if (!$nom) return; include_spip('base/abstract_sql'); $res = sql_select("*",'spip_' . $table,"nom=" . sql_quote($nom),'','','','','','continue'); // table pas encore installee, travailler en php seulement if (!$res) { $GLOBALS[$table][$nom] = $valeur; return; } $row = sql_fetch($res); sql_free($res); // ne pas invalider le cache si affectation a l'identique // (tant pis si impt aurait du changer) if ($row AND $valeur == $row['valeur'] AND $GLOBALS[$table][$nom] == $valeur) return; $GLOBALS[$table][$nom] = $valeur; // cf effacer pour comprendre le double touch $antidate = time() - (_META_CACHE_TIME<<1); if (!isset($touch[$table])) {touch_meta($antidate, $table);} $r = array('nom' => $nom, 'valeur' => $valeur); // Gaffe aux tables sans impt (vieilles versions de SPIP notamment) if ($importable AND isset($row['impt'])) $r['impt'] = $importable; if ($row) { sql_updateq('spip_' . $table, $r,"nom=" . sql_quote($nom)); } else { sql_insertq('spip_' . $table, $r); } if (!isset($touch[$table])) {touch_meta($antidate, $table); $touch[$table] = false;} } function cache_meta($table='meta') { return ($table=='meta') ? _FILE_META : (_DIR_CACHE . $table . '.php'); } ?>