You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
n-core/inc/ncore_cache.php

117 lines
3.5 KiB
PHTML

<?php
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}
if (!defined('_NCORE_DIRCACHE')) {
define('_NCORE_DIRCACHE', _DIR_CACHE . 'ncore/');
}
if (!defined('_NCORE_NOMCACHE_NOISETTE_SIGNATURE')) {
define('_NCORE_NOMCACHE_NOISETTE_SIGNATURE', 'noisettes_signature.php');
}
if (!defined('_NCORE_NOMCACHE_NOISETTE_DESCRIPTION')) {
define('_NCORE_NOMCACHE_NOISETTE_DESCRIPTION', 'noisettes_description.php');
}
if (!defined('_NCORE_NOMCACHE_NOISETTE_AJAX')) {
define('_NCORE_NOMCACHE_NOISETTE_AJAX', 'noisettes_ajax.php');
}
if (!defined('_NCORE_NOMCACHE_NOISETTE_INCLUSION')) {
define('_NCORE_NOMCACHE_NOISETTE_INCLUSION', 'noisettes_inclusion.php');
}
if (!defined('_NCORE_NOMCACHE_NOISETTE_CONTEXTE')) {
define('_NCORE_NOMCACHE_NOISETTE_CONTEXTE', 'noisettes_contexte.php');
}
/**
* Lit le cache spécifié pour un service donné et renvoie le contenu sous forme de tableau éventuellement
* vide.
*
* @package SPIP\NCORE\CACHE
*
* @param string $service
* Le service permet de distinguer l'appelant qui peut-être un plugin comme le noiZetier ou
* un script. Pour un plugin, le plus pertinent est d'utiliser le préfixe.
* @param string $nom_cache
* Nom et extension du fichier cache.
*
* @return array
* Contenu du fichier sous la forme d'un tableau éventuellement vide.
*/
function cache_lire($service, $nom_cache) {
// Initialisation du contenu du cache
$cache = array();
// Détermination du nom du cache en fonction du service appelant et du type
$fichier_cache = _NCORE_DIRCACHE . "${service}/${nom_cache}";
include_spip('inc/flock');
if (lire_fichier_securise($fichier_cache, $contenu)) {
$cache = unserialize($contenu);
}
return $cache;
}
/**
* Ecrit le contenu d'un tableau dans le cache spécifié pour un service donné.
*
* @package SPIP\NCORE\CACHE
*
* @param string $service
* Le service permet de distinguer l'appelant qui peut-être un plugin comme le noiZetier ou
* un script. Pour un plugin, le plus pertinent est d'utiliser le préfixe.
* @param string $nom_cache
* Nom et extension du fichier cache.
* @param array $contenu_cache
* Contenu sous forme de tableau à stocker dans un fichier cache après sérialisation.
*
* @return void
*/
function cache_ecrire($service, $nom_cache, $contenu_cache) {
// Création du répertoire du cache si besoin
$dir_cache = sous_repertoire(_DIR_CACHE, 'ncore');
$dir_cache = sous_repertoire($dir_cache, $service);
// Détermination du nom du cache en fonction du service appelant et du type
$fichier_cache = "${dir_cache}${nom_cache}";
// On vérifie que le contenu est bien un tableau. Si ce n'est pas le cas on le transforme en tableau.
if (!is_array($contenu_cache)) {
$contenu_cache = $contenu_cache ? array($contenu_cache) : array();
}
// Ecriture du fichier cache
include_spip('inc/flock');
ecrire_fichier_securise($fichier_cache, serialize($contenu_cache));
}
/**
* Supprime le cache cache spécifié pour un service donné.
*
* @package SPIP\NCORE\CACHE
*
* @param string $service
* Le service permet de distinguer l'appelant qui peut-être un plugin comme le noiZetier ou
* un script. Pour un plugin, le plus pertinent est d'utiliser le préfixe.
* @param string $nom_cache
* Nom et extension du fichier cache.
*
* @return void
*/
function cache_supprimer($service, $nom_cache) {
// Détermination du nom du cache en fonction du service appelant et du type
$fichier_cache = _NCORE_DIRCACHE . "${service}/${nom_cache}";
// Suppression du fichier cache
include_spip('inc/flock');
supprimer_fichier($fichier_cache);
}