1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/spip_ynh.git synced 2024-09-03 20:25:59 +02:00
spip_ynh/sources/plugins-dist/urls_etendues/urls/html.php
2016-01-02 16:34:42 +01:00

107 lines
3.8 KiB
PHP

<?php
/***************************************************************************\
* SPIP, Systeme de publication pour l'internet *
* *
* Copyright (c) 2001-2014 *
* 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. *
\***************************************************************************/
/*
- Comment utiliser ce jeu d'URLs ?
Recopiez le fichier "htaccess.txt" du repertoire de base du site SPIP sous
le sous le nom ".htaccess" (attention a ne pas ecraser d'autres reglages
que vous pourriez avoir mis dans ce fichier) ; si votre site est en
"sous-repertoire", vous devrez aussi editer la ligne "RewriteBase" ce fichier.
Les URLs definies seront alors redirigees vers les fichiers de SPIP.
Dans les pages de configuration, choisissez 'html' comme type d'url
SPIP calculera alors ses liens sous la forme "article123.html".
Note : si le fichier htaccess.txt se revele trop "puissant", car trop
generique, et conduit a des problemes (en lien par exemple avec d'autres
applications installees dans votre repertoire, a cote de SPIP), vous
pouvez l'editer pour ne conserver que la partie concernant les URLS 'html'.
*/
if (!defined("_ECRIRE_INC_VERSION")) return; // securiser
# donner un exemple d'url pour le formulaire de choix
define('URLS_HTML_EXEMPLE', 'article12.html');
// http://code.spip.net/@_generer_url_html
function _generer_url_html($type, $id, $args='', $ancre='') {
if ($generer_url_externe = charger_fonction("generer_url_$type",'urls',true)) {
$url = $generer_url_externe($id, $args, $ancre);
if (NULL != $url) return $url;
}
return _DIR_RACINE . $type . $id . '.html' . ($args ? "?$args" : '') .($ancre ? "#$ancre" : '');
}
// retrouver les parametres d'une URL dite "html"
// http://code.spip.net/@urls_html_dist
function urls_html_dist($i, $entite, $args='', $ancre='') {
if (is_numeric($i))
return _generer_url_html($entite, $i, $args, $ancre);
// recuperer les &debut_xx;
if (is_array($args))
$contexte = $args;
else
parse_str($args,$contexte);
// traiter les injections du type domaine.org/spip.php/cestnimportequoi/ou/encore/plus/rubrique23
if ($GLOBALS['profondeur_url']>0 AND $entite=='sommaire'){
return array(array(),'404');
}
$url = $i;
// voir s'il faut recuperer le id_* implicite et les &debut_xx;
include_spip('inc/urls');
$r = nettoyer_url_page($i, $contexte);
if ($r) {
array_pop($r); // nettoyer_url_page renvoie un argument de plus inutile ici
// il n'est pas necessaire de forcer le fond en 4eme arg car l'url n'est pas query string
// sauf si pas de fond connu
if ($entite)
array_pop($r);
return $r;
}
/*
* Le bloc qui suit sert a faciliter les transitions depuis
* le mode 'urls-propres' vers les modes 'urls-standard' et 'url-html'
* Il est inutile de le recopier si vous personnalisez vos URLs
* et votre .htaccess
*/
// Si on est revenu en mode html, mais c'est une ancienne url_propre
// on ne redirige pas, on assume le nouveau contexte (si possible)
$url_propre = isset($url)
? $url
: (isset($_SERVER['REDIRECT_url_propre'])
? $_SERVER['REDIRECT_url_propre']
: (isset($_ENV['url_propre'])
? $_ENV['url_propre']
: ''
));
if ($url_propre) {
if ($GLOBALS['profondeur_url']<=0)
$urls_anciennes = charger_fonction('propres','urls');
else
$urls_anciennes = charger_fonction('arbo','urls');
return $urls_anciennes($url_propre, $entite, $contexte);
}
/* Fin du bloc compatibilite url-propres */
}
?>