Subversion Repositories Applications.framework

Rev

Rev 419 | Rev 432 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
291 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Classe Cache permettant de mettre en cache des données de façon extremement simple.
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.
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.
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
 *
11
 * @category	php 5.2
12
 * @package	Framework
13
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
14
 * @author		Aurélien PERONNET <aurelien@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
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
19
 * @version	$Id: CacheSimple.php 431 2013-08-23 13:45:13Z raphael $
20
 * @link		/doc/framework/
21
 */
22
class CacheSimple {
23
 
24
	private $mise_en_cache = null;
25
	private $stockage_chemin = null;
26
	private $duree_de_vie = null;
27
 
28
	private $options = array(
29
		'mise_en_cache' => 'true',
30
		'stockage_chemin' => 'Fichier::getDossierTmp()',
31
		'duree_de_vie' => '3600*24'
32
	);
33
 
34
	public function __construct($options = array()) {
35
		extract($options);
36
		$this->mise_en_cache = is_bool($mise_en_cache) ? $mise_en_cache : true;
37
 
38
		if ($this->mise_en_cache) {
39
			$this->stockage_chemin = isset($stockage_chemin) ? realpath($stockage_chemin) : Fichier::getDossierTmp();
431 raphael 40
			if(!realpath($stockage_chemin)) {
41
				error_log(sprintf("%s: Attention, realpath(%s) invalide [%s]",
42
								  __FILE__,
43
								  $stockage_chemin,
44
								  $_SERVER['REQUEST_URI']));
45
			}
291 jpm 46
			$this->duree_de_vie = isset($duree_de_vie) ? $duree_de_vie : 3600*24;
47
		}
48
	}
49
 
50
	private function initialiserOptionsParConfig() {
51
		while (list($nom, $valeur) = each($this->options)) {
52
			if (Config::existe($nom)) {
53
				$this->$nom = Config::get($nom);
54
			}
55
		}
56
	}
57
 
58
	/**
59
	 * Teste si le cache est disponible pour l'id donné et (si oui) le retourne (sinon renvoie false)
60
	 *
61
	 * @param  string  $id l'identifiant du Cache.
62
	 * @return string|false les données en cache.
63
	 */
64
	public function charger($id) {
65
		$contenu = false;
66
		if ($this->mise_en_cache) {
67
			$chemin_fichier_cache = $this->stockage_chemin.DS.$id.'.txt';
68
			if (file_exists($chemin_fichier_cache ) && (time() - @filemtime($chemin_fichier_cache) < $this->duree_de_vie)) {
69
				$contenu = file_get_contents($chemin_fichier_cache);
70
			}
71
		}
72
		return $contenu;
73
	}
74
 
75
	/**
76
	 * Sauvegarde la chaine de données dans un fichier texte.
77
	 *
78
	 * Note : $contenu est toujours de type "string". C'est à vous de gérer la sérialisation.
79
	 *
80
	 * @param  string $contenu les données à mettre en cache.
81
	 * @param  string $id	l'identifiant du Cache.
82
	 * @return boolean true si aucun problème
83
	 */
84
	public function sauver($contenu, $id) {
85
		$ok = false;
86
		if ($this->mise_en_cache) {
87
			$chemin_fichier_cache = $this->stockage_chemin.DS.$id.'.txt';
88
			if (!file_exists($chemin_fichier_cache) || (time() - @filemtime($chemin_fichier_cache) > $this->duree_de_vie)) {
419 aurelien 89
				$dossier_fichier_cache = dirname($chemin_fichier_cache);
90
				if (!is_dir($dossier_fichier_cache))
91
				{
92
					mkdir($dossier_fichier_cache, 0755, true);
93
				}
94
 
291 jpm 95
				$fh = fopen($chemin_fichier_cache,'w+');
96
				if ($fh) {
97
					if (fwrite($fh, $contenu)) {
98
						if (fclose($fh)) {
99
							$ok = true;
100
						}
101
					}
102
					// Voir #ZF-4422 pour la raison de l'utilisation de octdec()
103
					@chmod($chemin_fichier_cache,  octdec('0777'));
104
				}
105
			}
106
		}
107
		return $ok;
108
	}
109
}
110
?>