editer_url.php 7.5 KB

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