b304d925bbc4affb15534bc082c1a253c4800fd7
[lhc/web/www.git] / www / plugins-dist / urls_etendues / action / editer_url.php
1 <?php
2
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
5 * *
6 * Copyright (c) 2001-2013 *
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 if (!defined("_ECRIRE_INC_VERSION")) return;
14
15 function action_editer_url_dist() {
16
17 // Rien a faire ici pour le moment
18 #$securiser_action = charger_fonction('securiser_action', 'inc');
19 #$arg = $securiser_action();
20
21 }
22
23
24 function url_nettoyer($titre,$longueur_maxi,$longueur_min=0,$separateur='-',$filtre=''){
25
26 $titre = supprimer_tags(supprimer_numero(extraire_multi($titre)));
27 $url = translitteration(corriger_caracteres($titre));
28
29 if ($filtre)
30 $url = $filtre($url);
31
32 // on va convertir tous les caracteres de ponctuation et espaces
33 // a l'exception de l'underscore (_), car on veut le conserver dans l'url
34 $url = str_replace('_', chr(7), $url);
35 $url = @preg_replace(',[[:punct:][:space:]]+,u', ' ', $url);
36 $url = str_replace(chr(7), '_', $url);
37
38 // S'il reste trop de caracteres non latins, les gerer comme wikipedia
39 // avec rawurlencode :
40 if (preg_match_all(",[^a-zA-Z0-9 _]+,", $url, $r, PREG_SET_ORDER)) {
41 foreach ($r as $regs) {
42 $url = substr_replace($url, rawurlencode($regs[0]),
43 strpos($url, $regs[0]), strlen($regs[0]));
44 }
45 }
46
47 // S'il reste trop peu, renvoyer vide
48 if (strlen($url) < $longueur_min)
49 return '';
50
51 // Sinon couper les mots et les relier par des $separateur
52 $mots = preg_split(",[^a-zA-Z0-9_%]+,", $url);
53 $url = '';
54 foreach ($mots as $mot) {
55 if (!strlen($mot)) continue;
56 $url2 = $url.$separateur.$mot;
57
58 // Si on depasse $longueur_maxi caracteres, s'arreter
59 // ne pas compter 3 caracteres pour %E9 mais un seul
60 $long = preg_replace(',%.,', '', $url2);
61 if (strlen($long) > $longueur_maxi) {
62 break;
63 }
64
65 $url = $url2;
66 }
67 $url = substr($url, 1);
68
69 // On enregistre en utf-8 dans la base
70 $url = rawurldecode($url);
71
72 if (strlen($url) < $longueur_min)
73 return '';
74 return $url;
75 }
76
77 function url_insert(&$set,$confirmer,$separateur){
78 # assurer la coherence des champs techniques si non fournis
79 if (!isset($set['id_parent']))
80 $set['id_parent'] = 0;
81 if (!isset($set['segments']))
82 $set['segments'] = count(explode('/',$set['url']));
83 $perma = false;
84 if (isset($set['perma']) AND $set['perma']){
85 unset($set['perma']);
86 $perma = true;
87 }
88 $redate = true;
89
90 # le separateur ne peut pas contenir de /
91 if (strpos($separateur,'/')!==false)
92 $separateur = "-";
93
94 // Si l'insertion echoue, c'est une violation d'unicite.
95 $where_thisurl = 'url='.sql_quote($set['url'])." AND id_parent=".intval($set['id_parent']);
96 if (@sql_insertq('spip_urls', $set) <= 0) {
97
98 // On veut chiper une ancienne adresse ou prendre celle d'un repertoire deja present?
99 if ((!is_dir($set['url']) AND !file_exists($set['url'])) AND
100 // un vieux url
101 $vieux = sql_fetsel('*', 'spip_urls', $where_thisurl)
102 // l'objet a une url plus recente
103 AND $courant = sql_fetsel('*', 'spip_urls',
104 'type='.sql_quote($vieux['type']).' AND id_objet='.sql_quote($vieux['id_objet'])
105 .' AND date>'.sql_quote($vieux['date']), '', 'date DESC', 1
106 )) {
107 if ($confirmer AND !_request('ok2')) {
108 die ("Vous voulez chiper l'URL de l'objet ".$courant['type']." "
109 . $courant['id_objet']." qui a maintenant l'url "
110 . $courant['url']);
111 }
112 // si oui on le chipe
113 sql_updateq('spip_urls', $set, $where_thisurl);
114 sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s')), $where_thisurl);
115 }
116
117 // Sinon
118 else {
119
120 // Soit c'est un Come Back d'une ancienne url propre de l'objet
121 // Soit c'est un vrai conflit. Rajouter l'ID jusqu'a ce que ca passe,
122 // mais se casser avant que ca ne casse.
123
124 // il peut etre du a un changement de casse de l'url simplement
125 // pour ce cas, on reecrit systematiquement l'url en plus d'actualiser la date
126 do {
127 $where = "type=".sql_quote($set['type'])
128 ." AND id_objet=".intval($set['id_objet'])
129 ." AND id_parent=".intval($set['id_parent'])
130 ." AND url=";
131 if (!is_dir($set['url']) && !file_exists($set['url']) && sql_countsel('spip_urls', $where .sql_quote($set['url']))) {
132 sql_updateq('spip_urls', array('url'=>$set['url'], 'date' => date('Y-m-d H:i:s')), $where .sql_quote($set['url']));
133 spip_log("reordonne ".$set['type']." ".$set['id_objet']);
134 $redate = false;
135 continue;
136 }
137 else {
138 $set['url'] .= $separateur.$set['id_objet'];
139 if (strlen($set['url']) > 200)
140 //serveur out ? retourner au mieux
141 return false;
142 elseif (sql_countsel('spip_urls', $where . sql_quote($set['url']))) {
143 sql_updateq('spip_urls', array('url'=>$set['url'], 'date' => date('Y-m-d H:i:s')), $where .sql_quote($set['url']));
144 $redate = false;
145 continue;
146 }
147 }
148 } while ($redate AND @sql_insertq('spip_urls', $set) <= 0);
149
150 }
151 }
152
153 $where_thisurl = 'url='.sql_quote($set['url'])." AND id_parent=".intval($set['id_parent']); // maj
154 if ($redate)
155 sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s')), $where_thisurl);
156
157 // si url perma, poser le flag sur la seule url qu'on vient de mettre
158 if ($perma)
159 sql_update('spip_urls', array('perma' => "($where_thisurl)"), "type=".sql_quote($set['type'])." AND id_objet=".intval($set['id_objet']));
160
161 spip_log("Creation de l'url propre '" . $set['url'] . "' pour ".$set['type']." ".$set['id_objet']." (parent ".$set['id_parent']." perma $perma)");
162 return true;
163 }
164
165 function url_verrouiller($objet,$id_objet,$url){
166 $where = "id_objet=".intval($id_objet)." AND type=".sql_quote($objet);
167 $where .= " AND url=".sql_quote($url);
168
169 // pour verrouiller une url, on fixe sa date dans le futur, dans 10 ans
170 sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s',time()+10*365.25*24*3600)), $where);
171 }
172
173 function url_delete($objet,$id_objet,$url=""){
174 $where = "id_objet=".intval($id_objet)." AND type=".sql_quote($objet);
175 if (strlen($url))
176 $where .= " AND url=".sql_quote($url);
177
178 sql_delete("spip_urls",$where);
179 }
180 ?>