Funzione di gestione della Cache
Come alternativa all'uso del meccanismo di default per la cache basato
sui file, potete specificare una funzione personalizzata di gestione
che verrà usata per leggere, scrivere ed eliminare i file in cache.
Create una funzione nella vostra applicazione che Smarty userà come
gestore della cache. Impostate il nome di questa funzione nella variabile
di classe $cache_handler_func.
Smarty ora userà questa funzione per gestire i dati della cache. Il primo
parametro è l'azione, che può essere 'read', 'write' o 'clear'. Il
secondo parametro è l'oggetto Smarty. Il terzo parametro è il contenuto in
cache. In una 'write', Smarty passa il contenuto da mettere in cache in
questo parametro. In una 'read', Smarty si aspetta che la funzione prenda questo
parametro per riferimento e che lo riempia con i dati della cache.
In una 'clear', il parametro non viene usato, quindi passate una variabile
dummy. Il quarto parametro è il nome del file del template (necessario
per le read e le write), il quinto parametro è il cache_id (opzionale), e
il sesto è il compile_id (opzionale).
Nota: l'ultimo parametro ($exp_time) è stato aggiunto in Smarty-2.6.0.
esempio con l'uso di MySQL per la cache
cache_handler_func = 'mysql_cache_handler';
$smarty->display('index.tpl');
il database mysql avrà questo formato:
create database SMARTY_CACHE;
create table CACHE_PAGES(
CacheID char(32) PRIMARY KEY,
CacheContents MEDIUMTEXT NOT NULL
);
*/
function mysql_cache_handler($action, &$smarty_obj, &$cache_content, $tpl_file=null, $cache_id=null, $compile_id=null, $exp_time=null)
{
// impostiamo i dati d'accesso al db
$db_host = 'localhost';
$db_user = 'myuser';
$db_pass = 'mypass';
$db_name = 'SMARTY_CACHE';
$use_gzip = false;
// creiamo un cache id unico
$CacheID = md5($tpl_file.$cache_id.$compile_id);
if(! $link = mysql_pconnect($db_host, $db_user, $db_pass)) {
$smarty_obj->_trigger_error_msg("cache_handler: could not connect to database");
return false;
}
mysql_select_db($db_name);
switch ($action) {
case 'read':
// leggiamo la cache dal database
$results = mysql_query("select CacheContents from CACHE_PAGES where CacheID='$CacheID'");
if(!$results) {
$smarty_obj->_trigger_error_msg("cache_handler: query failed.");
}
$row = mysql_fetch_array($results,MYSQL_ASSOC);
if($use_gzip && function_exists("gzuncompress")) {
$cache_content = gzuncompress($row["CacheContents"]);
} else {
$cache_content = $row["CacheContents"];
}
$return = $results;
break;
case 'write':
// salviamo la cache sul database
if($use_gzip && function_exists("gzcompress")) {
// compress the contents for storage efficiency
$contents = gzcompress($cache_content);
} else {
$contents = $cache_content;
}
$results = mysql_query("replace into CACHE_PAGES values(
'$CacheID',
'".addslashes($contents)."')
");
if(!$results) {
$smarty_obj->_trigger_error_msg("cache_handler: query failed.");
}
$return = $results;
break;
case 'clear':
// eliminiamo i dati in cache
if(empty($cache_id) && empty($compile_id) && empty($tpl_file)) {
// eliminiamo tutto
$results = mysql_query("delete from CACHE_PAGES");
} else {
$results = mysql_query("delete from CACHE_PAGES where CacheID='$CacheID'");
}
if(!$results) {
$smarty_obj->_trigger_error_msg("cache_handler: query failed.");
}
$return = $results;
break;
default:
// errore, azione non prevista
$smarty_obj->_trigger_error_msg("cache_handler: unknown action \"$action\"");
$return = false;
break;
}
mysql_close($link);
return $return;
}
?>
]]>