Newer
Older
/***************************************************************************\
* SPIP, Systeme de publication pour l'internet *
* *
* Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
* *
* Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
* Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
\***************************************************************************/
// Ce fichier regroupe la quasi totalite des definitions de #BALISES de spip
// Pour chaque balise, il est possible de surcharger, dans mes_fonctions,
// la fonction balise_TOTO_dist par une fonction balise_TOTO() respectant la
esj
a validé
// elle recoit en entree un objet de classe CHAMP, le modifie et le retourne.
// Cette classe est definie dans public/interfaces
if (!defined("_ECRIRE_INC_VERSION")) return;
Christian Lefebvre
a validé
// http://doc.spip.org/@interprete_argument_balise
function interprete_argument_balise($n,$p) {
if (($p->param) && (!$p->param[0][0]) && (count($p->param[0])>$n))
return calculer_liste($p->param[0][$n],
$p->descr,
$p->boucles,
$p->id_boucle);
else
//
// Definition des balises
//
// http://doc.spip.org/@balise_NOM_SITE_SPIP_dist
#$p->interdire_scripts = true;
// http://doc.spip.org/@balise_EMAIL_WEBMASTER_dist
#$p->interdire_scripts = true;
// http://doc.spip.org/@balise_DESCRIPTIF_SITE_SPIP_dist
function balise_DESCRIPTIF_SITE_SPIP_dist($p) {
$p->code = "\$GLOBALS['meta']['descriptif_site']";
#$p->interdire_scripts = true;
return $p;
}
// http://doc.spip.org/@balise_CHARSET_dist
#$p->interdire_scripts = true;
// http://doc.spip.org/@balise_LANG_LEFT_dist
$_lang = champ_sql('lang', $p);
$p->code = "lang_dir($_lang, 'left','right')";
$p->interdire_scripts = false;
// http://doc.spip.org/@balise_LANG_RIGHT_dist
$_lang = champ_sql('lang', $p);
$p->code = "lang_dir($_lang, 'right','left')";
$p->interdire_scripts = false;
// http://doc.spip.org/@balise_LANG_DIR_dist
$_lang = champ_sql('lang', $p);
$p->code = "lang_dir($_lang, 'ltr','rtl')";
$p->interdire_scripts = false;
// http://doc.spip.org/@balise_PUCE_dist
$p->interdire_scripts = false;
return $p;
}
// #DATE
// Cette fonction sait aller chercher dans le contexte general
// quand #DATE est en dehors des boucles
// http://www.spip.net/fr_article1971.html
// http://doc.spip.org/@balise_DATE_dist
$d = champ_sql('date', $p);
# if ($d === "@\$Pile[0]['date']")
# $d = "isset(\$Pile[0]['date']) ? $d : time()";
$p->code = $d;
return $p;
}
// #DATE_REDAC
// http://www.spip.net/fr_article1971.html
// http://doc.spip.org/@balise_DATE_REDAC_dist
$d = champ_sql('date_redac', $p);
# if ($d === "@\$Pile[0]['date_redac']")
# $d = "isset(\$Pile[0]['date_redac']) ? $d : time()";
$p->code = $d;
$p->interdire_scripts = false;
return $p;
}
// #DATE_MODIF
// http://www.spip.net/fr_article1971.html
// http://doc.spip.org/@balise_DATE_MODIF_dist
$p->code = champ_sql('date_modif', $p);
$p->interdire_scripts = false;
return $p;
}
// #DATE_NOUVEAUTES
// http://www.spip.net/fr_article1971.html
// http://doc.spip.org/@balise_DATE_NOUVEAUTES_dist
AND @is_readable(_DIR_TMP . 'mail.lock')) ?
@filemtime(_DIR_TMP . 'mail.lock') :
$p->interdire_scripts = false;
// http://doc.spip.org/@balise_DOSSIER_SQUELETTE_dist
function balise_DOSSIER_SQUELETTE_dist($p) {
$code = substr(addslashes(dirname($p->descr['sourcefile'])), strlen(_DIR_RACINE));
$p->code = "_DIR_RACINE . '$code'" .
$p->interdire_scripts = false;
function balise_SQUELETTE_dist($p) {
$code = addslashes($p->descr['sourcefile']);
$p->code = "'$code'" .
$p->interdire_scripts = false;
return $p;
}
tetue
a validé
// http://doc.spip.org/@balise_SPIP_VERSION_dist
function balise_SPIP_VERSION_dist($p) {
$p->code = "spip_version()";
$p->interdire_scripts = false;
tetue
a validé
return $p;
}
// #NOM_SITE affiche le nom du site, ou sinon l'URL ou le titre de l'objet
// http://doc.spip.org/@balise_NOM_SITE_dist
function balise_NOM_SITE_dist($p) {
if (!$p->etoile) {
$p->code = "supprimer_numero(calculer_url(" .
Fil
a validé
champ_sql('url_site',$p) ."," .
champ_sql('nom_site',$p) .
", 'titre', \$connect))";
} else
$p->code = champ_sql('nom_site',$p);
$p->interdire_scripts = true;
// http://doc.spip.org/@balise_NOTES_dist
function balise_NOTES_dist($p) {
// Recuperer les notes
$p->code = 'calculer_notes()';
#$p->interdire_scripts = true;
// http://doc.spip.org/@balise_RECHERCHE_dist
$p->code = 'entites_html(_request("recherche"))';
$p->interdire_scripts = false;
// http://doc.spip.org/@balise_COMPTEUR_BOUCLE_dist
$b = $p->nom_boucle ? $p->nom_boucle : $p->descr['id_mere'];
$msg = array('zbug_champ_hors_boucle',
array('champ' => '#COMPTEUR_BOUCLE')
);
erreur_squelette($msg, $p);
} else {
$p->code = "\$Numrows['$b']['compteur_boucle']";
$p->boucles[$b]->cptrows = true;
$p->interdire_scripts = false;
return $p;
}
// http://doc.spip.org/@balise_TOTAL_BOUCLE_dist
$b = $p->nom_boucle ? $p->nom_boucle : $p->descr['id_mere'];
if ($b === '' || !isset($p->boucles[$b])) {
$msg = array('zbug_champ_hors_boucle',
array('champ' => "#$b" . 'TOTAL_BOUCLE')
);
erreur_squelette($msg, $p);
$p->code = "\$Numrows['$b']['total']";
$p->interdire_scripts = false;
// Si on est hors d'une boucle {recherche}, ne pas "prendre" cette balise
// http://doc.spip.org/@balise_POINTS_dist
return rindex_pile($p, 'points', 'recherche');
// http://doc.spip.org/@balise_POPULARITE_ABSOLUE_dist
function balise_POPULARITE_ABSOLUE_dist($p) {
$p->code = 'ceil(' .
champ_sql('popularite', $p) .
')';
$p->interdire_scripts = false;
// http://doc.spip.org/@balise_POPULARITE_SITE_dist
$p->interdire_scripts = false;
// http://doc.spip.org/@balise_POPULARITE_MAX_dist
$p->interdire_scripts = false;
// http://doc.spip.org/@balise_EXPOSE_dist
function balise_EXPOSE_dist($p) {
if (($v = interprete_argument_balise(1,$p))!==NULL){
$on = $v;
if (($v = interprete_argument_balise(2,$p))!==NULL)
$off = $v;
return calculer_balise_expose($p, $on, $off);
}
// http://doc.spip.org/@calculer_balise_expose
function calculer_balise_expose($p, $on, $off)
{
$b = $p->nom_boucle ? $p->nom_boucle : $p->id_boucle;
$key = $p->boucles[$b]->primary;
$type = $p->boucles[$p->id_boucle]->primary;
$desc = $p->boucles[$b]->show;
$connect = sql_quote($p->boucles[$b]->sql_serveur);
if (!$key) {
$msg = array('zbug_champ_hors_boucle', array('champ' => '#EXPOSER'));
erreur_squelette($msg, $p);
// Ne pas utiliser champ_sql, on jongle avec le nom boucle explicite
$c = index_pile($p->id_boucle, $type, $p->boucles);
if (isset($desc['field']['id_parent'])) {
$parent = 0; // pour if (!$parent) dans calculer_expose
} elseif (isset($desc['field']['id_rubrique'])) {
$parent = index_pile($p->id_boucle, 'id_rubrique', $p->boucles, $b);
} elseif (isset($desc['field']['id_groupe'])) {
$parent = index_pile($p->id_boucle, 'id_groupe', $p->boucles, $b);
} else $parent = "''";
$p->code = "(calcul_exposer($c, '$type', \$Pile[0], $parent, '$key', $connect) ? $on : $off)";
$p->interdire_scripts = false;
return $p;
}
// Debut et fin de surlignage auto des mots de la recherche
// on insere une balise Span avec une classe sans spec:
// c'est transparent s'il n'y a pas de recherche,
// sinon elles seront remplacees par les fontions de inc_surligne
// http://doc.spip.org/@balise_DEBUT_SURLIGNE_dist
// http://doc.spip.org/@balise_FIN_SURLIGNE_dist
Fil
a validé
// #SPIP_CRON
// a documenter
// insere un <div> avec un lien background-image vers les taches de fond.
// Si cette balise est presente sur la page de sommaire, le site ne devrait
// quasiment jamais se trouver ralenti par des taches de fond un peu lentes
// http://doc.spip.org/@balise_SPIP_CRON_dist
Fil
a validé
function balise_SPIP_CRON_dist ($p) {
$p->code = '"<!-- SPIP-CRON --><div style=\"background-image: url(\'' .
generer_url_action('cron') .
'\');\"></div>"';
$p->interdire_scripts = false;
Fil
a validé
return $p;
}
// #INTRODUCTION
// #INTRODUCTION{longueur}
Fil
a validé
// http://www.spip.net/@introduction
// http://doc.spip.org/@balise_INTRODUCTION_dist
function balise_INTRODUCTION_dist($p) {
$_descriptif = ($type == 'articles' OR $type == 'rubriques') ? champ_sql('descriptif', $p) : "''";
if ($type == 'articles') {
$_chapo = champ_sql('chapo', $p);
$_texte = "(strlen($_descriptif) OR chapo_redirigetil($_chapo))
? ''
: $_chapo . \"\\n\\n\" . $_texte";
// longueur en parametre, ou valeur par defaut
if (($v = interprete_argument_balise(1,$p))!==NULL) {
$longueur = 'intval('.$v.')';
} else {
switch ($type) {
case 'articles':
$longueur = '500';
break;
case 'breves':
$longueur = '300';
break;
case 'rubriques':
default:
$longueur = '600';
break;
}
}
$f = chercher_filtre('introduction');
$p->code = "$f($_descriptif, $_texte, $longueur, \$connect)";
$p->etoile = '*'; // propre est deja fait dans le calcul de l'intro
// affiche la langue de l'objet (ou superieure), et a defaut la langue courante
// (celle du site ou celle qui a ete passee dans l'URL par le visiteur)
// #LANG* n'affiche rien si aucune langue n'est trouvee dans le sql/le contexte
// http://doc.spip.org/@balise_LANG_dist
function balise_LANG_dist ($p) {
$_lang = champ_sql('lang', $p);
if (!$p->etoile)
$p->code = "htmlentities($_lang ? $_lang : \$GLOBALS['spip_lang'])";
else
$p->code = "htmlentities($_lang)";
$p->interdire_scripts = false;
function balise_CHAPO_dist ($p) {
$_chapo = champ_sql('chapo', $p);
if (($p->etoile) OR (strpos($_chapo, '$Pile[$SP') === false))
$p->code = $_chapo;
else
$p->code = "nettoyer_chapo($_chapo)";
// #LESAUTEURS
// les auteurs d'un article (ou d'un article syndique)
// http://www.spip.net/fr_article902.html
// http://www.spip.net/fr_article911.html
// http://doc.spip.org/@balise_LESAUTEURS_dist
function balise_LESAUTEURS_dist ($p) {
// Cherche le champ 'lesauteurs' dans la pile
$_lesauteurs = champ_sql('lesauteurs', $p);
// Si le champ n'existe pas (cas de spip_articles), on applique
// le modele lesauteurs.html en passant id_article dans le contexte;
// dans le cas contraire on prend le champ 'lesauteurs'
// (cf extension sites/)
if ($_lesauteurs
AND $_lesauteurs != '@$Pile[0][\'lesauteurs\']') {
$p->code = "safehtml($_lesauteurs)";
// $p->interdire_scripts = true;
} else {
$connect = !$p->id_boucle ? ''
: $p->boucles[$p->id_boucle]->sql_serveur;
$c = memoriser_contexte_compil($p);
$p->code = sprintf(CODE_RECUPERER_FOND, "'modeles/lesauteurs'",
"array('id_article' => ".champ_sql('id_article', $p) .")",
"'trim'=>true, 'compil'=>array($c)",
_q($connect));
$p->interdire_scripts = false; // securite apposee par recuperer_fond()
}
return $p;
}
// #RANG
// affiche le "numero de l'article" quand on l'a titre '1. Premier article';
// ceci est transitoire afin de preparer une migration vers un vrai systeme de
// tri des articles dans une rubrique (et plus si affinites)
// http://doc.spip.org/@balise_RANG_dist
function balise_RANG_dist ($p) {
$_titre = champ_sql('titre', $p);
$_rang = champ_sql('rang', $p);
$p->code = "(($_rang)?($_rang):recuperer_numero($_titre))";
$p->interdire_scripts = false;
return $p;
}
// #POPULARITE
// http://www.spip.net/fr_article1846.html
// http://doc.spip.org/@balise_POPULARITE_dist
function balise_POPULARITE_dist ($p) {
$_popularite = champ_sql('popularite', $p);
$p->code = "(ceil(min(100, 100 * $_popularite
$p->interdire_scripts = false;
// Le code produit est trompeur, car les modeles ne fournissent pas Pile[0].
// On produit un appel a _request si on ne l'a pas, mais c'est inexact:
// l'absence peut etre due a une faute de frappe dans le contexte inclus.
define('CODE_PAGINATION',
'%s($Numrows["%s"]["grand_total"],
%s,
isset($Pile[0][%4$s])?$Pile[0][%4$s]:intval(_request(%4$s)),
%5$s, %6$s, %7$s, %8$s, array(%9$s))');
// http://www.spip.net/fr_article3367.html
// http://doc.spip.org/@balise_PAGINATION_dist
$b = $p->nom_boucle ? $p->nom_boucle : $p->descr['id_mere'];
// s'il n'y a pas de nom de boucle, on ne peut pas paginer
$msg = array('zbug_champ_hors_boucle',
);
erreur_squelette($msg, $p);
return $p;
// s'il n'y a pas de mode_partie, c'est qu'on se trouve
// dans un boucle recursive ou qu'on a oublie le critere {pagination}
if (!$p->boucles[$b]->mode_partie) {
if (!$p->boucles[$b]->table_optionnelle) {
$msg = array('zbug_pagination_sans_critere',
);
erreur_squelette($msg, $p);
}
return $p;
}
$__modele = interprete_argument_balise(1,$p);
if ($p->param) {
$params = $p->param;
array_shift($params);
// a priori true
// si false, le compilo va bloquer sur des syntaxes avec un filtre sans argument qui suit la balise
// si true, les arguments simples (sans truc=chose) vont degager
$code_contexte = argumenter_inclure($params, true, $p, $p->boucles, $p->id_boucle, false);
$code_contexte = implode(',',$code_contexte);
} else $code_contexte = '';
$connect = $p->boucles[$b]->sql_serveur;
$pas = $p->boucles[$b]->total_parties;
$f_pagination = chercher_filtre('pagination');
$type = $p->boucles[$b]->modificateur['debut_nom'];
$modif = ($type[0]!=="'") ? "'debut'.$type"
: ("'debut" .substr($type,1));
$p->code = sprintf(CODE_PAGINATION, $f_pagination,$b, $type, $modif, $pas, $liste, ($__modele ? $__modele : "''"), _q($connect), $code_contexte);
$p->boucles[$b]->numrows = true;
// N'afficher que l'ancre de la pagination (au-dessus, par exemple, alors
// http://doc.spip.org/@balise_ANCRE_PAGINATION_dist
if ($f = charger_fonction('PAGINATION', 'balise', true))
return $f($p, $liste='false');
else return NULL; // ou une erreur ?
}
// equivalent a #TOTAL_BOUCLE sauf pour les boucles paginees, ou elle
// indique le nombre total d'articles repondant aux criteres hors pagination
// http://doc.spip.org/@balise_GRAND_TOTAL_dist
function balise_GRAND_TOTAL_dist($p) {
$b = $p->nom_boucle ? $p->nom_boucle : $p->descr['id_mere'];
if ($b === '' || !isset($p->boucles[$b])) {
$msg = array('zbug_champ_hors_boucle',
);
erreur_squelette($msg, $p);
} else {
$p->code = "(isset(\$Numrows['$b']['grand_total'])
? \$Numrows['$b']['grand_total'] : \$Numrows['$b']['total'])";
// Reference a l'URL de la page courante
// Attention dans un INCLURE() ou une balise dynamique on n'a pas le droit de
// mettre en cache #SELF car il peut correspondre a une autre page (attaque XSS)
// (Dans ce cas faire <INCLURE{self=#SELF}> pour differencier les caches.)
// http://www.spip.net/@self
// http://doc.spip.org/@balise_SELF_dist
function balise_SELF_dist($p) {
$p->code = 'self()';
$p->interdire_scripts = false;
//
// #CHEMIN{fichier} -> find_in_path(fichier)
//
// http://doc.spip.org/@balise_CHEMIN_dist
function balise_CHEMIN_dist($p) {
$arg = interprete_argument_balise(1,$p);
if (!$arg) {
$msg = array('zbug_balise_sans_argument', array('balise' => ' CHEMIN'));
erreur_squelette($msg, $p);
$p->code = 'find_in_path(' . $arg .')';
#$p->interdire_scripts = true;
return $p;
}
function balise_CHEMIN_IMAGE_dist($p) {
$arg = interprete_argument_balise(1,$p);
if (!$arg) {
$msg = array('zbug_balise_sans_argument', array('balise' => ' CHEMIN_IMAGE'));
erreur_squelette($msg, $p);
} else $p->code = 'chemin_image(' . $arg .')';
// #ENV
// l'"environnement", id est le $contexte (ou $contexte_inclus)
// en standard on applique |entites_html, mais si vous utilisez
// [(#ENV*{toto})] il *faut* vous assurer vous-memes de la securite
// anti-javascript (par exemple en filtrant avec |safehtml)
// La syntaxe #ENV{toto, rempl} renverra 'rempl' si $toto est vide
//
// Si le tableau est vide on renvoie '' (utile pour #SESSION)
//
// http://doc.spip.org/@balise_ENV_dist
function balise_ENV_dist($p, $src = NULL) {
// le tableau de base de la balise (cf #META ci-dessous)
esj
a validé
$_nom = interprete_argument_balise(1,$p);
$_sinon = interprete_argument_balise(2,$p);
esj
a validé
// cas de #ENV sans argument : on retourne le serialize() du tableau
// une belle fonction [(#ENV|affiche_env)] serait pratique
? ('(is_array($a = ('.$src.')) ? serialize($a) : "")')
: '@serialize($Pile[0])';
} else {
// admet deux arguments : nom de variable, valeur par defaut si vide
? ('is_array($a = ('.$src.')) ? $a['.$_nom.'] : ""')
: ('@$Pile[0][' . $_nom . ']');
$p->code = 'sinon('.
#$p->interdire_scripts = true;
esj
a validé
Fil
a validé
cerdic
a validé
/**
* #CONFIG retourne lire_config()
* les reglages du site
*
* Par exemple #CONFIG{gerer_trad} donne 'oui' ou 'non' selon le reglage
* Le 3eme argument permet de controler la serialisation du resultat
* (mais ne sert que pour le depot 'meta') qui doit parfois deserialiser
*
* ex: |in_array{#CONFIG{toto,#ARRAY,1}}.
*
* Ceci n'affecte pas d'autres depots et |in_array{#CONFIG{toto/,#ARRAY}} sera equivalent
* #CONFIG{/tablemeta/champ,defaut} lit la valeur de 'champ' dans la table des meta 'tablemeta'
*
* @param Object $p Arbre syntaxique du compilo
* @return Object
*/
cerdic
a validé
if (!$arg = interprete_argument_balise(1,$p)) {
$arg = "''";
}
$_sinon = interprete_argument_balise(2,$p);
$_unserialize = sinon(interprete_argument_balise(3,$p),"false");
$p->code = '(include_spip(\'inc/config\')?lire_config(' . $arg . ',' .
($_sinon && $_sinon != "''" ? $_sinon : 'null') . ',' . $_unserialize . "):'')";
cerdic
a validé
return $p;
cerdic
a validé
function balise_CONNECT_dist($p) {
$p->code = '($connect ? $connect : NULL)';
$p->interdire_scripts = false;
return $p;
}
//
// #SESSION
// Cette balise est un tableau des donnees du visiteur (nom, email etc)
// Si elle est invoquee, elle leve un drapeau dans le fichier cache, qui
// permet a public/cacher d'invalider le cache si le visiteur suivant n'a
// pas la meme session
function balise_SESSION_dist($p) {
$p->descr['session'] = true;
$f = function_exists('balise_ENV')
? 'balise_ENV'
: 'balise_ENV_dist';
$p = $f($p, '$GLOBALS["visiteur_session"]');
//
// #SESSION_SET{x,y}
// Ajoute x=y dans la session du visiteur
function balise_SESSION_SET_dist($p) {
$_nom = interprete_argument_balise(1,$p);
$_val = interprete_argument_balise(2,$p);
if (!$_nom OR !$_val) {
$err_b_s_a = array('zbug_balise_sans_argument', array('balise' => 'SESSION_SET'));
erreur_squelette($err_b_s_a, $p);
} else $p->code = '(include_spip("inc/session") AND session_set('.$_nom.','.$_val.'))';
$p->interdire_scripts = false;
return $p;
}
//
// #EVAL{...}
// evalue un code php ; a utiliser avec precaution :-)
//
// rq: #EVAL{code} produit eval('return code;')
// mais si le code est une expression sans balise, on se dispense
// de passer par une construction si compliquee, et le code est
// passe tel quel (entre parentheses, et protege par interdire_scripts)
// Exemples : #EVAL**{6+9} #EVAL**{_DIR_IMG_PACK} #EVAL{'date("Y-m-d")'}
// #EVAL{'str_replace("r","z", "roger")'} (attention les "'" sont interdits)
// http://doc.spip.org/@balise_EVAL_dist
function balise_EVAL_dist($p) {
$php = interprete_argument_balise(1,$p);
if ($php) {
# optimisation sur les #EVAL{une expression sans #BALISE}
# attention au commentaire "// x signes" qui precede
if (preg_match(",^([[:space:]]*//[^\n]*\n)'([^']+)'$,ms",
$php,$r))
$p->code = /* $r[1]. */'('.$r[2].')';
else
$p->code = "eval('return '.$php.';')";
} else {
$msg = array('zbug_balise_sans_argument', array('balise' => ' EVAL'));
erreur_squelette($msg, $p);
}
return $p;
}
// #CHAMP_SQL{x} renvoie la valeur du champ sql 'x'
// permet de recuperer par exemple un champ notes dans une table sql externe
// (impossible via #NOTES qui est une balise calculee)
// ne permet pas de passer une expression pour x qui ne peut etre qu'un texte statique !
function balise_CHAMP_SQL_dist($p){
if ($p->param
AND isset($p->param[0][1][0])
AND $champ = ($p->param[0][1][0]->texte))
$p->code = champ_sql($champ, $p);
else {
$err_b_s_a = array('zbug_balise_sans_argument', array('balise' => ' URL_'));
erreur_squelette($err_b_s_a, $p);
}
#$p->interdire_scripts = true;
return $p;
}
// #VAL{x} renvoie 'x' (permet d'appliquer un filtre a une chaine)
// Attention #VAL{1,2} renvoie '1', indiquer #VAL{'1,2'}
// http://doc.spip.org/@balise_VAL_dist
function balise_VAL_dist($p){
$p->code = interprete_argument_balise(1,$p);
if (!strlen($p->code))
$p->code = "''";
marcimat
a validé
$p->interdire_scripts = false;
return $p;
}
// #NOOP est un alias pour regler #948, ne pas documenter
// http://doc.spip.org/@balise_NOOP_dist
function balise_NOOP_dist($p) { return balise_VAL_dist($p); }
//
// #REM
// pour les remarques : renvoie toujours ''
//
// http://doc.spip.org/@balise_REM_dist
function balise_REM_dist($p) {
$p->code="''";
$p->interdire_scripts = false;
return $p;
}
// #HTTP_HEADER
// pour les entetes de retour http
// Ne fonctionne pas sur les INCLURE !
// #HTTP_HEADER{Content-Type: text/css}
// http://doc.spip.org/@balise_HTTP_HEADER_dist
$header = interprete_argument_balise(1,$p);
if (!$header) {
$err_b_s_a = array('zbug_balise_sans_argument', array('balise' => 'HTTP_HEADER'));
erreur_squelette($err_b_s_a, $p);
} else $p->code = "'<'.'?php header(\"' . "
. $header
. " . '\"); ?'.'>'";
$p->interdire_scripts = false;
return $p;
}
// Filtre a appliquer a l'ensemble de la page une fois calculee
// (filtrage fait au niveau du squelette, et sans s'appliquer aux <INCLURE>)
function balise_FILTRE_dist($p) {
if ($p->param) {
$args = array();
foreach ($p->param as $i => $ignore)
$args[] = interprete_argument_balise($i+1,$p);
.'?php header("X-Spip-Filtre: \'.'
. " . '\"); ?'.'>'";
$p->interdire_scripts = false;
return $p;
}
}
//
// #CACHE
// definit la duree de vie ($delais) du squelette
// #CACHE{24*3600}
// parametre(s) supplementaire(s) :
// #CACHE{24*3600, cache-client} autorise gestion du IF_MODIFIED_SINCE
// #CACHE{24*3600, statique} ne respecte pas l'invalidation par modif de la base
// (mais s'invalide tout de meme a l'expiration du delai)
// par defaut cache-client => statique
// cf. ecrire/public/cacher.php
// http://doc.spip.org/@balise_CACHE_dist
if ($p->param) {
$duree = valeur_numerique($p->param[0][1][0]->texte);
// noter la duree du cache dans un entete proprietaire
$code = '\'<'.'?php header("X-Spip-Cache: '
. $duree
. '"); ?'.'>\'';
// Remplir le header Cache-Control
// cas #CACHE{0}
if ($duree == 0)
$code .= '.\'<'
.'?php header("Cache-Control: no-store, no-cache, must-revalidate"); ?'
.'><'
.'?php header("Pragma: no-cache"); ?'
.'>\'';
// recuperer les parametres suivants
$i = 1;
while (isset($p->param[0][++$i])) {
$pa = ($p->param[0][$i][0]->texte);
if ($pa == 'cache-client'
AND $duree > 0) {
$code .= '.\'<'.'?php header("Cache-Control: max-age='
. $duree
. '"); ?'.'>\'';
// il semble logique, si on cache-client, de ne pas invalider
$pa = 'statique';
}
if ($pa == 'statique'
AND $duree > 0)
$code .= '.\'<'.'?php header("X-Spip-Statique: oui"); ?'.'>\'';
}
} else $code = "''";
$p->code = $code;
}
//
// #INSERT_HEAD
// pour permettre aux plugins d'inserer des styles, js ou autre
// dans l'entete sans modification du squelette
//
// http://doc.spip.org/@balise_INSERT_HEAD_dist
function balise_INSERT_HEAD_dist($p) {
$p->code = "pipeline('insert_head','<!-- insert_head -->')";
.'?php header("X-Spip-Filtre: \'.'
.'\'compacte_head\''
. " . '\"); ?'.'>'";
return $p;
}
//
// #INCLURE statique
// l'inclusion est realisee au calcul du squelette, pas au service
// ainsi le produit du squelette peut etre utilise en entree de filtres a suivre
// on peut faire un #INCLURE{fichier} sans squelette
// (Incompatible avec les balises dynamiques)
// http://doc.spip.org/@balise_INCLUDE_dist
function balise_INCLUDE_dist($p) {
if(function_exists('balise_INCLURE'))
return balise_INCLURE($p);
else
return balise_INCLURE_dist($p);
}
// http://doc.spip.org/@balise_INCLURE_dist
function balise_INCLURE_dist($p) {
$id_boucle = $p->id_boucle;
// la lang n'est pas passe de facon automatique par argumenter
// mais le sera pas recuperer_fond, sauf si etoile=>true est passe
// en option
$_contexte = argumenter_inclure($p->param, true, $p, $p->boucles, $id_boucle, false, false);
// erreur de syntaxe = fond absent
// (2 messages d'erreur SPIP pour le prix d'un, mais pas d'erreur PHP
if (!$_contexte) $contexte = array();
if (isset($_contexte['fond'])) {
$f = $_contexte['fond'];
// toujours vrai :
if (preg_match('/^.fond.\s*=>(.*)$/s', $f, $r)) {
$f = $r[1];
unset($_contexte['fond']);
} else spip_log("compilation de #INCLURE a revoir");
// #INCLURE{doublons}
if (isset($_contexte['doublons'])) {
$_contexte['doublons'] = "'doublons' => \$doublons";
}
// Critere d'inclusion {env} (et {self} pour compatibilite ascendante)
if (isset($_contexte['env'])
|| isset($_contexte['self'])
) {
$flag_env = true;
unset($_contexte['env']);
} else $flag_env = false;
esj
a validé
$_options = array();
if (isset($_contexte['ajax'])) {
$_options[] = "'ajax'=>true";
unset($_contexte['ajax']);
}
esj
a validé
if ($p->etoile) $_options[] = "'etoile'=>true";
$_options[] = "'compil'=>array(" . memoriser_contexte_compil($p) .")";
$_l = 'array(' . join(",\n\t", $_contexte) .')';
if ($flag_env) $_l = "array_merge(\$Pile[0],$_l)";
$p->code = sprintf(CODE_RECUPERER_FOND, $f, $_l, join(',',$_options),"''");
} elseif (!isset($_contexte[1])) {
$msg = array('zbug_balise_sans_argument', array('balise' => ' INCLURE'));
erreur_squelette($msg, $p);
} else $p->code = '(($c = find_in_path(' . $_contexte[1] . ')) ? spip_file_get_contents($c) : "")';
$p->interdire_scripts = false; // la securite est assuree par recuperer_fond
return $p;
}
// Inclure un modele : #MODELE{modele, params}
function balise_MODELE_dist($p) {
$_contexte = argumenter_inclure($p->param, true, $p, $p->boucles, $p->id_boucle, false);
// erreur de syntaxe = fond absent
// (2 messages d'erreur SPIP pour le prix d'un, mais pas d'erreur PHP
if (!$_contexte) $contexte = array();
if (!isset($_contexte[1])) {
$msg = array('zbug_balise_sans_argument', array('balise' => ' MODELE'));
erreur_squelette($msg, $p);
} else {
$nom = $_contexte[1];
unset($_contexte[1]);
if (preg_match("/^\s*'[^']*'/s", $nom))
$nom = "'modeles/" . substr($nom,1);
else $nom = "'modeles/' . $nom";
// Incoherence dans la syntaxe du contexte. A revoir.
// Reserver la cle primaire de la boucle courante si elle existe
if (isset($p->boucles[$p->id_boucle]->primary)) {
$primary = $p->boucles[$p->id_boucle]->primary;
if (!strpos($primary,',')) {
$id = champ_sql($primary, $p);
$_contexte[] = "'$primary'=>".$id;
$_contexte[] = "'id'=>".$id;
$_contexte[] = "'recurs'=>(++\$recurs)";
$connect = '';
if (isset($p->boucles[$p->id_boucle]))
$connect = $p->boucles[$p->id_boucle]->sql_serveur;
$_options = memoriser_contexte_compil($p);
$_options = "'compil'=>array($_options), 'trim'=>true"