Subversion Repositories Applications.framework

Rev

Rev 418 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 418 Rev 435
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;