spip_nursit/ecrire/balise/url_.php

391 lines
10 KiB
PHP
Raw Normal View History

2023-06-01 15:30:12 +00:00
<?php
/***************************************************************************\
* SPIP, Systeme de publication pour l'internet *
* *
* Copyright (c) 2001-2019 *
* 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. *
\***************************************************************************/
/**
* Fonctions génériques pour les balises `#URL_XXXX`
*
* Les balises `URL_$type` sont génériques, sauf quelques cas particuliers.
*
* @package SPIP\Core\Compilateur\Balises
**/
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}
/**
* Génère le code compilé des balises d'URL
*
* Utilise le premier paramètre de la balise d'URL comme identifiant d'objet
* s'il est donné, sinon le prendra dans un champ d'une boucle englobante.
*
* @uses generer_generer_url_arg()
* @param string $type
* Type d'objet
* @param Champ $p
* Pile au niveau de la balise
* @return string
* Code compilé
**/
function generer_generer_url($type, $p) {
$_id = interprete_argument_balise(1, $p);
if (!$_id) {
$primary = id_table_objet($type);
$_id = champ_sql($primary, $p);
}
return generer_generer_url_arg($type, $p, $_id);
}
/**
* Génère le code compilé des balises d'URL (en connaissant l'identifiant)
*
* - Si ces balises sont utilisées pour la base locale,
* production des appels à `generer_url_entite(id-courant, entite)`
* - Si la base est externe et sous SPIP, on produit
*
* - l'URL de l'objet si c'est une pièce jointe, ou sinon
* - l'URL du site local appliqué sur l'objet externe,
* ce qui permet de le voir à travers les squelettes du site local
*
* On communique le type-url distant à `generer_url_entite` mais il ne sert pas
* car rien ne garantit que le .htaccess soit identique. À approfondir.
*
* @see generer_url_entite()
*
* @param string $type
* Type d'objet
* @param Champ $p
* Pile au niveau de la balise
* @param string $_id
* Code compilé permettant d'obtenir l'identifiant de l'objet
* @return string
* Code compilé
**/
function generer_generer_url_arg($type, $p, $_id) {
if ($s = trouver_nom_serveur_distant($p)) {
// si une fonction de generation des url a ete definie pour ce connect l'utiliser
if (function_exists($f = 'generer_generer_url_' . $s)) {
return $f($type, $_id, $s);
}
if (!$GLOBALS['connexions'][strtolower($s)]['spip_connect_version']) {
return null;
}
$s = _q($s);
# exception des urls de documents sur un serveur distant...
if ($type == 'document') {
return
"quete_meta('adresse_site', $s) . '/' .\n\t" .
"quete_meta('dir_img', $s) . \n\t" .
"quete_fichier($_id,$s)";
}
$s = ", '', '', $s, quete_meta('type_urls', $s)";
} else {
$s = ", '', '', true";
}
return "urlencode_1738(generer_url_entite($_id, '$type'$s))";
}
/**
* Compile la balise générique `#URL_xxx` qui génère l'URL d'un objet
*
* S'il existe une fonction spécifique de calcul d'URL pour l'objet demandé,
* tel que `balise_URL_ARTICLE_dist()`, la fonction l'utilisera. Sinon,
* on calcule une URL de façon générique.
*
* @balise
* @uses generer_generer_url()
* @example
* ```
* #URL_ARTICLE
* #URL_ARTICLE{3}
* ```
* @param Champ $p
* Pile au niveau de la balise
* @return Champ
* Pile complétée par le code à générer
*/
function balise_URL__dist($p) {
$nom = $p->nom_champ;
if ($nom === 'URL_') {
$msg = array('zbug_balise_sans_argument', array('balise' => ' URL_'));
erreur_squelette($msg, $p);
$p->interdire_scripts = false;
return $p;
} elseif ($f = charger_fonction($nom, 'balise', true)) {
return $f($p);
} else {
$nom = strtolower($nom);
$code = generer_generer_url(substr($nom, 4), $p);
$code = champ_sql($nom, $p, $code);
$p->code = $code;
if (!$p->etoile) {
$p->code = "vider_url($code)";
}
$p->interdire_scripts = false;
return $p;
}
}
/**
* Compile la balise `#URL_ARTICLE` qui génère l'URL d'un article
*
* Retourne l'URL (locale) d'un article mais retourne dans le cas
* d'un article syndiqué (boucle SYNDIC_ARTICLES), son URL distante d'origine.
*
* @balise
* @uses generer_generer_url()
* @link http://www.spip.net/3963
* @example
* ```
* #URL_ARTICLE
* #URL_ARTICLE{3}
* ```
* @param Champ $p
* Pile au niveau de la balise
* @return Champ
* Pile complétée par le code à générer
*/
function balise_URL_ARTICLE_dist($p) {
// Cas particulier des boucles (SYNDIC_ARTICLES)
if ($p->type_requete == 'syndic_articles') {
$code = champ_sql('url', $p);
} else {
$code = generer_generer_url('article', $p);
}
$p->code = $code;
if (!$p->etoile) {
$p->code = "vider_url($code)";
}
$p->interdire_scripts = false;
return $p;
}
/**
* Compile la balise `#URL_SITE` qui génère l'URL d'un site ou de cas spécifiques
*
* Génère une URL spécifique si la colonne SQL `url_site` est trouvée
* (par exemple lien hypertexte d'un article), sinon l'URL d'un site syndiqué
*
* @balise
* @uses generer_generer_url()
* @see calculer_url()
* @link http://www.spip.net/3861
*
* @param Champ $p
* Pile au niveau de la balise
* @return Champ
* Pile complétée par le code à générer
*/
function balise_URL_SITE_dist($p) {
$code = champ_sql('url_site', $p);
if (strpos($code, '@$Pile[0]') !== false) {
$code = generer_generer_url('site', $p);
if ($code === null) {
return null;
}
} else {
if (!$p->etoile) {
$code = "calculer_url($code,'','url', \$connect)";
}
}
$p->code = $code;
$p->interdire_scripts = false;
return $p;
}
// Autres balises URL_*, qui ne concernent pas une table
// (historique)
/**
* Compile la balise `#URL_SITE_SPIP` qui retourne l'URL du site
* telle que définie dans la configuration
*
* @balise
* @link http://www.spip.net/4623
*
* @param Champ $p
* Pile au niveau de la balise
* @return Champ
* Pile complétée par le code à générer
*/
function balise_URL_SITE_SPIP_dist($p) {
$p->code = "sinon(\$GLOBALS['meta']['adresse_site'],'.')";
$p->code = "spip_htmlspecialchars(" . $p->code . ")";
$p->interdire_scripts = false;
return $p;
}
/**
* Compile la balise `#URL_PAGE` qui retourne une URL de type « page »
*
* - `#URL_PAGE{nom}` génère l'url pour la page `nom`
* - `#URL_PAGE{nom,param=valeur}` génère l'url pour la page `nom` avec des paramètres
* - `#URL_PAGE` sans argument retourne l'URL courante.
* - `#URL_PAGE*` retourne l'URL sans convertir les `&` en `&amp;`
*
* @balise
* @link http://www.spip.net/4630
* @see generer_url_public()
* @example
* ```
* #URL_PAGE{backend} produit ?page=backend
* #URL_PAGE{backend,id_rubrique=1} est équivalent à
* [(#URL_PAGE{backend}|parametre_url{id_rubrique,1})]
* ```
*
* @param Champ $p
* Pile au niveau de la balise
* @return Champ
* Pile complétée par le code à générer
*/
function balise_URL_PAGE_dist($p) {
$code = interprete_argument_balise(1, $p);
$args = interprete_argument_balise(2, $p);
if ($args == null) {
$args = "''";
}
if ($s = trouver_nom_serveur_distant($p)) {
// si une fonction de generation des url a ete definie pour ce connect l'utiliser
// elle devra aussi traiter le cas derogatoire type=page
if (function_exists($f = 'generer_generer_url_' . $s)) {
if ($args and $args !== "''") {
$code .= ", $args";
}
$code = $f('page', $code, $s);
$p->code = $code;
return $p;
}
$s = 'connect=' . addslashes($s);
$args = (($args and $args !== "''") ? "$args . '&$s'" : "'$s'");
}
if (!$code) {
$noentities = $p->etoile ? "'&'" : '';
$code = "url_de_base() . preg_replace(',^./,', '', self($noentities))";
} else {
if (!$args) {
$args = "''";
}
$noentities = $p->etoile ? ", true" : '';
$code = "generer_url_public($code, $args$noentities)";
}
$p->code = $code;
spip_log("Calcul url page : connect vaut $s ca donne :" . $p->code . " args $args", _LOG_INFO);
#$p->interdire_scripts = true;
return $p;
}
/**
* Compile la balise `#URL_ECRIRE` qui retourne une URL d'une page de l'espace privé
*
* - `#URL_ECRIRE{nom}` génère l'url pour la page `nom` de l'espace privé
* - `#URL_ECRIRE{nom,param=valeur}` génère l'url pour la page `nom` avec des paramètres
* - `#URL_ECRIRE` génère l'url pour la page d'accueil de l'espace privé
* - `#URL_ECRIRE*` retourne l'URL sans convertir les `&` en `&amp;`
*
* @balise
* @link http://www.spip.net/5566
* @see generer_url_ecrire()
* @example
* ```
* #URL_ECRIRE{rubriques} -> ecrire/?exec=rubriques
* ```
*
* @param Champ $p
* Pile au niveau de la balise
* @return Champ
* Pile complétée par le code à générer
*/
function balise_URL_ECRIRE_dist($p) {
$code = interprete_argument_balise(1, $p);
if (!$code) {
$fonc = "''";
} else {
$fonc = $code;
$args = interprete_argument_balise(2, $p);
if ($args === null) {
$args = "''";
}
$noentities = $p->etoile ? ", true" : '';
if (($args != "''") or $noentities) {
$fonc .= ",$args$noentities";
}
}
$p->code = 'generer_url_ecrire(' . $fonc . ')';
$p->interdire_scripts = false;
return $p;
}
/**
* Compile la balise `#URL_ACTION_AUTEUR` qui retourne une URL d'action
* sécurisée pour l'auteur en cours
*
* La balise accepte 3 paramètres. Les 2 premiers sont obligatoires :
*
* - le nom de l'action
* - l'argument transmis à l'action (une chaîne de caractère)
* - une éventuelle URL de redirection qui sert une fois l'action réalisée
*
* @balise
* @see generer_action_auteur()
* @example
* `#URL_ACTION_AUTEUR{converser,arg,redirect}` pourra produire
* `ecrire/?action=converser&arg=arg&hash=xxx&redirect=redirect`
*
* @param Champ $p
* Pile au niveau de la balise
* @return Champ
* Pile complétée par le code à générer
*/
function balise_URL_ACTION_AUTEUR_dist($p) {
$p->descr['session'] = true;
$p->code = interprete_argument_balise(1, $p);
$args = interprete_argument_balise(2, $p);
if ($args != "''" && $args !== null) {
$p->code .= "," . $args;
}
$redirect = interprete_argument_balise(3, $p);
if ($redirect != "''" && $redirect !== null) {
if ($args == "''" || $args === null) {
$p->code .= ",''";
}
$p->code .= "," . $redirect;
}
$p->code = "generer_action_auteur(" . $p->code . ")";
$p->interdire_scripts = false;
return $p;
}