[SPIP] ~v3.0.20-->v3.0.25
[lhc/web/clavette_www.git] / www / plugins-dist / urls_etendues / urls / html.php
1 <?php
2
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
5 * *
6 * Copyright (c) 2001-2016 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
8 * *
9 * Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
10 * Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
11 \***************************************************************************/
12
13 /*
14
15 - Comment utiliser ce jeu d'URLs ?
16
17 Recopiez le fichier "htaccess.txt" du repertoire de base du site SPIP sous
18 le sous le nom ".htaccess" (attention a ne pas ecraser d'autres reglages
19 que vous pourriez avoir mis dans ce fichier) ; si votre site est en
20 "sous-repertoire", vous devrez aussi editer la ligne "RewriteBase" ce fichier.
21 Les URLs definies seront alors redirigees vers les fichiers de SPIP.
22
23 Dans les pages de configuration, choisissez 'html' comme type d'url
24
25 SPIP calculera alors ses liens sous la forme "article123.html".
26
27 Note : si le fichier htaccess.txt se revele trop "puissant", car trop
28 generique, et conduit a des problemes (en lien par exemple avec d'autres
29 applications installees dans votre repertoire, a cote de SPIP), vous
30 pouvez l'editer pour ne conserver que la partie concernant les URLS 'html'.
31
32 */
33
34 if (!defined("_ECRIRE_INC_VERSION")) return; // securiser
35
36 # donner un exemple d'url pour le formulaire de choix
37 define('URLS_HTML_EXEMPLE', 'article12.html');
38
39 // http://code.spip.net/@_generer_url_html
40 function _generer_url_html($type, $id, $args='', $ancre='') {
41 if ($generer_url_externe = charger_fonction("generer_url_$type",'urls',true)) {
42 $url = $generer_url_externe($id, $args, $ancre);
43 if (NULL != $url) return $url;
44 }
45
46 return _DIR_RACINE . $type . $id . '.html' . ($args ? "?$args" : '') .($ancre ? "#$ancre" : '');
47 }
48
49 // retrouver les parametres d'une URL dite "html"
50 // http://code.spip.net/@urls_html_dist
51 function urls_html_dist($i, $entite, $args='', $ancre='') {
52
53 if (is_numeric($i))
54 return _generer_url_html($entite, $i, $args, $ancre);
55
56 // recuperer les &debut_xx;
57 if (is_array($args))
58 $contexte = $args;
59 else
60 parse_str($args,$contexte);
61
62
63 // traiter les injections du type domaine.org/spip.php/cestnimportequoi/ou/encore/plus/rubrique23
64 if ($GLOBALS['profondeur_url']>0 AND $entite=='sommaire'){
65 return array(array(),'404');
66 }
67 $url = $i;
68
69 // voir s'il faut recuperer le id_* implicite et les &debut_xx;
70 include_spip('inc/urls');
71 $r = nettoyer_url_page($i, $contexte);
72 if ($r) {
73 array_pop($r); // nettoyer_url_page renvoie un argument de plus inutile ici
74 // il n'est pas necessaire de forcer le fond en 4eme arg car l'url n'est pas query string
75 // sauf si pas de fond connu
76 if ($entite)
77 array_pop($r);
78 return $r;
79 }
80
81 /*
82 * Le bloc qui suit sert a faciliter les transitions depuis
83 * le mode 'urls-propres' vers les modes 'urls-standard' et 'url-html'
84 * Il est inutile de le recopier si vous personnalisez vos URLs
85 * et votre .htaccess
86 */
87 // Si on est revenu en mode html, mais c'est une ancienne url_propre
88 // on ne redirige pas, on assume le nouveau contexte (si possible)
89 $url_propre = isset($url)
90 ? $url
91 : (isset($_SERVER['REDIRECT_url_propre'])
92 ? $_SERVER['REDIRECT_url_propre']
93 : (isset($_ENV['url_propre'])
94 ? $_ENV['url_propre']
95 : ''
96 ));
97 if ($url_propre) {
98 if ($GLOBALS['profondeur_url']<=0)
99 $urls_anciennes = charger_fonction('propres','urls');
100 else
101 $urls_anciennes = charger_fonction('arbo','urls');
102 return $urls_anciennes($url_propre, $entite, $contexte);
103 }
104 /* Fin du bloc compatibilite url-propres */
105 }
106
107 ?>