8b6cc36f7ac77d6f77acb5ca830620621b7236ec
[velocampus/web/www.git] / www / ecrire / urls / html.php
1 <?php
2
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
5 * *
6 * Copyright (c) 2001-2014 *
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;
35
36 define('URLS_HTML_EXEMPLE', 'article12.html');
37
38 // http://doc.spip.org/@_generer_url_html
39 function _generer_url_html($type, $id, $args='', $ancre='') {
40 if ($generer_url_externe = charger_fonction("generer_url_$type",'urls',true)) {
41 $url = $generer_url_externe($id, $args, $ancre);
42 if (NULL != $url) return $url;
43 }
44
45 if ($type == 'document') {
46 include_spip('inc/documents');
47 return generer_url_document_dist($id, $args, $ancre);
48 }
49
50 return _DIR_RACINE . $type . $id . '.html' . ($args ? "?$args" : '') .($ancre ? "#$ancre" : '');
51 }
52
53 // retrouver les parametres d'une URL dite "html"
54 // http://doc.spip.org/@urls_html_dist
55 function urls_html_dist($i, $entite, $args='', $ancre='') {
56
57 if (is_numeric($i))
58 return _generer_url_html($entite, $i, $args, $ancre);
59
60 // recuperer les &debut_xx;
61 if (is_array($args))
62 $contexte = $args;
63 else
64 parse_str($args,$contexte);
65
66 // traiter les injections du type domaine.org/spip.php/cestnimportequoi/ou/encore/plus/rubrique23
67 if ($GLOBALS['profondeur_url']>0 AND $entite=='sommaire'){
68 return array(array(),'404');
69 }
70 $url = $i;
71
72 // voir s'il faut recuperer le id_* implicite et les &debut_xx;
73 include_spip('inc/urls');
74 $r = nettoyer_url_page($i, $contexte);
75 if ($r) {
76 array_pop($r); // nettoyer_url_page renvoie un argument de plus inutile ici
77 // il n'est pas necessaire de forcer le fond en 4eme arg car l'url n'est pas query string
78 // sauf si pas de fond connu
79 if ($entite)
80 array_pop($r);
81 return $r;
82 }
83
84 /*
85 * Le bloc qui suit sert a faciliter les transitions depuis
86 * le mode 'urls-propres' vers les modes 'urls-standard' et 'url-html'
87 * Il est inutile de le recopier si vous personnalisez vos URLs
88 * et votre .htaccess
89 */
90 // Si on est revenu en mode html, mais c'est une ancienne url_propre
91 // on ne redirige pas, on assume le nouveau contexte (si possible)
92 $url_propre = isset($url)
93 ? $url
94 : (isset($_SERVER['REDIRECT_url_propre'])
95 ? $_SERVER['REDIRECT_url_propre']
96 : (isset($_ENV['url_propre'])
97 ? $_ENV['url_propre']
98 : ''
99 ));
100 if ($url_propre) {
101 if ($GLOBALS['profondeur_url']<=0)
102 $urls_anciennes = charger_fonction('propres','urls');
103 else
104 $urls_anciennes = charger_fonction('arbo','urls');
105 return $urls_anciennes($url_propre, $entite, $contexte);
106 }
107 /* Fin du bloc compatibilite url-propres */
108 }
109
110 ?>