Line 5... |
Line 5... |
5 |
* Le cache est stocker dans des fichiers textes.
|
5 |
* Le cache est stocker dans des fichiers textes.
|
6 |
* Le contrôle de la durée de vie du cache se fait avec la fonction PHP filemtime.
|
6 |
* Le contrôle de la durée de vie du cache se fait avec la fonction PHP filemtime.
|
7 |
* Si la durée de vie du cache est modifiée dans le constructeur ou le fichier de config, alors la durée de vie de l'ensemble
|
7 |
* Si la durée de vie du cache est modifiée dans le constructeur ou le fichier de config, alors la durée de vie de l'ensemble
|
8 |
* des fichiers de cache est modifiée en conséquence.
|
8 |
* des fichiers de cache est modifiée en conséquence.
|
9 |
* Les clés pour le tableau des options et les valeurs par défaut sont indiquées dans l'attribut options de la classe.
|
9 |
* Les clés pour le tableau des options et les valeurs par défaut sont indiquées dans l'attribut options de la classe.
|
10 |
*
|
10 |
*
|
11 |
* @category php 5.2
|
11 |
* @category php 5.2
|
12 |
* @package Framework
|
12 |
* @package Framework
|
13 |
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
|
13 |
* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
|
14 |
* @author Aurélien PERONNET <aurelien@tela-botanica.org>
|
14 |
* @author Aurélien PERONNET <aurelien@tela-botanica.org>
|
15 |
* @copyright Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
|
15 |
* @copyright Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
|
16 |
* @license http://framework.zend.com/license/new-bsd Licence New BSD
|
16 |
* @license http://framework.zend.com/license/new-bsd Licence New BSD
|
17 |
* @license http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
|
17 |
* @license http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
|
18 |
* @license http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
|
18 |
* @license http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
|
19 |
* @version $Id: CacheSimple.php 418 2012-09-06 13:23:14Z aurelien $
|
19 |
* @version $Id: CacheSimple.php 435 2013-09-04 14:29:43Z jpm $
|
20 |
* @link /doc/framework/
|
20 |
* @link /doc/framework/
|
21 |
*/
|
21 |
*/
|
- |
|
22 |
// TODO : voir ce qui est le plus pratique : error_log ou le gestionnaire de bogue du framework
|
22 |
class CacheSimple {
|
23 |
class CacheSimple {
|
23 |
|
24 |
|
24 |
private $mise_en_cache = null;
|
25 |
private $mise_en_cache = null;
|
25 |
private $stockage_chemin = null;
|
26 |
private $stockage_chemin = null;
|
26 |
private $duree_de_vie = null;
|
27 |
private $duree_de_vie = null;
|
27 |
|
28 |
|
28 |
private $options = array(
|
29 |
private $options = array(
|
29 |
'mise_en_cache' => 'true',
|
30 |
'mise_en_cache' => 'true',
|
30 |
'stockage_chemin' => 'Fichier::getDossierTmp()',
|
31 |
'stockage_chemin' => 'Fichier::getDossierTmp()',
|
31 |
'duree_de_vie' => '3600*24'
|
32 |
'duree_de_vie' => '3600*24'
|
32 |
);
|
33 |
);
|
33 |
|
34 |
|
34 |
public function __construct($options = array()) {
|
35 |
public function __construct($options = array()) {
|
35 |
extract($options);
|
36 |
extract($options);
|
36 |
$this->mise_en_cache = is_bool($mise_en_cache) ? $mise_en_cache : true;
|
37 |
$this->mise_en_cache = is_bool($mise_en_cache) ? $mise_en_cache : true;
|
37 |
|
38 |
|
38 |
if ($this->mise_en_cache) {
|
39 |
if ($this->mise_en_cache) {
|
39 |
$this->stockage_chemin = isset($stockage_chemin) ? realpath($stockage_chemin) : Fichier::getDossierTmp();
|
40 |
$this->stockage_chemin = isset($stockage_chemin) ? realpath($stockage_chemin) : Fichier::getDossierTmp();
|
- |
|
41 |
if (!realpath($stockage_chemin)) {
|
- |
|
42 |
error_log(sprintf("%s: Attention, %s invalide: creation [%s]",
|
- |
|
43 |
__FILE__,
|
- |
|
44 |
$stockage_chemin,
|
- |
|
45 |
$_SERVER['REQUEST_URI']));
|
- |
|
46 |
mkdir($stockage_chemin, 0755, TRUE);
|
- |
|
47 |
}
|
- |
|
48 |
if (!realpath($stockage_chemin)) {
|
- |
|
49 |
error_log(sprintf("%s: Attention, realpath(%s) invalide [%s]",
|
- |
|
50 |
__FILE__,
|
- |
|
51 |
$stockage_chemin,
|
- |
|
52 |
$_SERVER['REQUEST_URI']));
|
- |
|
53 |
} else if(!is_writable(realpath($stockage_chemin))) {
|
- |
|
54 |
error_log(sprintf("%s: Attention, realpath(%s) non-inscriptible [%s]",
|
- |
|
55 |
__FILE__,
|
- |
|
56 |
realpath($stockage_chemin),
|
- |
|
57 |
$_SERVER['REQUEST_URI']));
|
- |
|
58 |
} else {
|
40 |
$this->duree_de_vie = isset($duree_de_vie) ? $duree_de_vie : 3600*24;
|
59 |
$this->duree_de_vie = isset($duree_de_vie) ? $duree_de_vie : 3600*24;
|
- |
|
60 |
}
|
41 |
}
|
61 |
}
|
42 |
}
|
62 |
}
|
43 |
|
63 |
|
44 |
private function initialiserOptionsParConfig() {
|
64 |
private function initialiserOptionsParConfig() {
|
45 |
while (list($nom, $valeur) = each($this->options)) {
|
65 |
while (list($nom, $valeur) = each($this->options)) {
|
46 |
if (Config::existe($nom)) {
|
66 |
if (Config::existe($nom)) {
|
47 |
$this->$nom = Config::get($nom);
|
67 |
$this->$nom = Config::get($nom);
|
48 |
}
|
68 |
}
|
49 |
}
|
69 |
}
|
50 |
}
|
70 |
}
|
51 |
|
71 |
|
52 |
/**
|
72 |
/**
|
53 |
* Teste si le cache est disponible pour l'id donné et (si oui) le retourne (sinon renvoie false)
|
73 |
* Teste si le cache est disponible pour l'id donné et (si oui) le retourne (sinon renvoie false)
|
54 |
*
|
74 |
*
|
55 |
* @param string $id l'identifiant du Cache.
|
75 |
* @param string $id l'identifiant du Cache.
|
56 |
* @return string|false les données en cache.
|
76 |
* @return string|false les données en cache.
|
57 |
*/
|
77 |
*/
|
58 |
public function charger($id) {
|
78 |
public function charger($id) {
|
59 |
$contenu = false;
|
79 |
$contenu = false;
|
60 |
if ($this->mise_en_cache) {
|
80 |
if ($this->mise_en_cache) {
|
61 |
$chemin_fichier_cache = $this->stockage_chemin.DS.$id.'.txt';
|
81 |
$chemin_fichier_cache = $this->stockage_chemin.DS.$id.'.txt';
|
62 |
if (file_exists($chemin_fichier_cache ) && (time() - @filemtime($chemin_fichier_cache) < $this->duree_de_vie)) {
|
82 |
if (file_exists($chemin_fichier_cache ) && (time() - @filemtime($chemin_fichier_cache) < $this->duree_de_vie)) {
|
63 |
$contenu = file_get_contents($chemin_fichier_cache);
|
83 |
$contenu = file_get_contents($chemin_fichier_cache);
|
64 |
}
|
84 |
}
|
65 |
}
|
85 |
}
|
66 |
return $contenu;
|
86 |
return $contenu;
|
67 |
}
|
87 |
}
|
68 |
|
88 |
|
69 |
/**
|
89 |
/**
|
70 |
* Sauvegarde la chaine de données dans un fichier texte.
|
90 |
* Sauvegarde la chaine de données dans un fichier texte.
|
71 |
*
|
91 |
*
|
72 |
* Note : $contenu est toujours de type "string". C'est à vous de gérer la sérialisation.
|
92 |
* Note : $contenu est toujours de type "string". C'est à vous de gérer la sérialisation.
|
73 |
*
|
93 |
*
|
Line 83... |
Line 103... |
83 |
$dossier_fichier_cache = dirname($chemin_fichier_cache);
|
103 |
$dossier_fichier_cache = dirname($chemin_fichier_cache);
|
84 |
if (!is_dir($dossier_fichier_cache))
|
104 |
if (!is_dir($dossier_fichier_cache))
|
85 |
{
|
105 |
{
|
86 |
mkdir($dossier_fichier_cache, 0755, true);
|
106 |
mkdir($dossier_fichier_cache, 0755, true);
|
87 |
}
|
107 |
}
|
88 |
|
108 |
|
89 |
$fh = fopen($chemin_fichier_cache,'w+');
|
109 |
$fh = fopen($chemin_fichier_cache,'w+');
|
90 |
if ($fh) {
|
110 |
if ($fh) {
|
91 |
if (fwrite($fh, $contenu)) {
|
111 |
if (fwrite($fh, $contenu)) {
|
92 |
if (fclose($fh)) {
|
112 |
if (fclose($fh)) {
|
93 |
$ok = true;
|
113 |
$ok = true;
|