PageRenderTime 41ms CodeModel.GetById 20ms RepoModel.GetById 0ms app.codeStats 0ms

/spip/ecrire/action/editer_url.php

https://github.com/eyeswebcrea/espace-couture-sittler.fr
PHP | 154 lines | 102 code | 22 blank | 30 comment | 19 complexity | 8a55f20ef2b84622516297bd924671b3 MD5 | raw file
Possible License(s): LGPL-2.1, GPL-3.0
  1. <?php
  2. /***************************************************************************\
  3. * SPIP, Systeme de publication pour l'internet *
  4. * *
  5. * Copyright (c) 2001-2011 *
  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. if (!defined('_TRANSLITTERER_URL')) define('_TRANSLITTERER_URL', true);
  19. $titre = supprimer_tags(supprimer_numero(extraire_multi($titre)));
  20. $url = corriger_caracteres($titre);
  21. if (_TRANSLITTERER_URL) $url = translitteration($url);
  22. if ($filtre)
  23. $url = $filtre($url);
  24. // on va convertir tous les caracteres de ponctuation et espaces
  25. // a l'exception de l'underscore (_), car on veut le conserver dans l'url
  26. $url = str_replace('_', chr(7), $url);
  27. $url = @preg_replace(',[[:punct:][:space:]]+,u', ' ', $url);
  28. $url = str_replace(chr(7), '_', $url);
  29. // S'il reste trop de caracteres non latins, les gerer comme wikipedia
  30. // avec rawurlencode :
  31. if (_TRANSLITTERER_URL && preg_match_all(",[^a-zA-Z0-9 _]+,", $url, $r, PREG_SET_ORDER)) {
  32. foreach ($r as $regs) {
  33. $url = substr_replace($url, rawurlencode($regs[0]),
  34. strpos($url, $regs[0]), strlen($regs[0]));
  35. }
  36. }
  37. // S'il reste trop peu, renvoyer vide
  38. if (strlen($url) < $longueur_min)
  39. return '';
  40. // Sinon couper les mots et les relier par des $separateur
  41. if (_TRANSLITTERER_URL) $mots = preg_split(",[^a-zA-Z0-9_%]+,", $url);
  42. else $mots = preg_split(",[\s]+,", $url);
  43. $url = '';
  44. foreach ($mots as $mot) {
  45. if (!strlen($mot)) continue;
  46. $url2 = $url.$separateur.$mot;
  47. // Si on depasse $longueur_maxi caracteres, s'arreter
  48. // ne pas compter 3 caracteres pour %E9 mais un seul
  49. $long = preg_replace(',%.,', '', $url2);
  50. if (strlen($long) > $longueur_maxi) {
  51. break;
  52. }
  53. $url = $url2;
  54. }
  55. $url = substr($url, 1);
  56. // On enregistre en utf-8 dans la base
  57. $url = rawurldecode($url);
  58. if (strlen($url) < $longueur_min)
  59. return '';
  60. return $url;
  61. }
  62. function url_insert(&$set,$confirmer,$separateur){
  63. // Si l'insertion echoue, c'est une violation d'unicite.
  64. if (@sql_insertq('spip_urls', $set) <= 0) {
  65. // On veut chiper une ancienne adresse ?
  66. if (
  67. // un vieux url
  68. $vieux = sql_fetsel('*', 'spip_urls', 'url='.sql_quote($set['url']))
  69. // l'objet a une url plus recente
  70. AND $courant = sql_fetsel('*', 'spip_urls',
  71. 'type='.sql_quote($vieux['type']).' AND id_objet='.sql_quote($vieux['id_objet'])
  72. .' AND date>'.sql_quote($vieux['date']), '', 'date DESC', 1
  73. )) {
  74. if ($confirmer AND !_request('ok2')) {
  75. die ("Vous voulez chiper l'URL de l'objet ".$courant['type']." "
  76. . $courant['id_objet']." qui a maintenant l'url "
  77. . $courant['url']);
  78. }
  79. // si oui on le chipe
  80. sql_updateq('spip_urls', $set, 'url='.sql_quote($set['url']));
  81. sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s')), 'url='.sql_quote($set['url']));
  82. }
  83. // Sinon
  84. else
  85. // Soit c'est un Come Back d'une ancienne url propre de l'objet
  86. // Soit c'est un vrai conflit. Rajouter l'ID jusqu'a ce que ca passe,
  87. // mais se casser avant que ca ne casse.
  88. // il peut etre du a un changement de casse de l'url simplement
  89. // pour ce cas, on reecrit systematiquement l'url en plus d'actualiser la date
  90. do {
  91. $where = "type=".sql_quote($set['type'])." AND id_objet=".intval($set['id_objet'])." AND url=";
  92. if (sql_countsel('spip_urls', $where .sql_quote($set['url']))) {
  93. sql_updateq('spip_urls', array('url'=>$set['url'], 'date' => date('Y-m-d H:i:s')), $where .sql_quote($set['url']));
  94. spip_log("reordonne ".$set['type']." ".$set['id_objet']);
  95. return true;
  96. }
  97. else {
  98. $set['url'] .= $separateur.$set['id_objet'];
  99. if (strlen($set['url']) > 200)
  100. //serveur out ? retourner au mieux
  101. return false;
  102. elseif (sql_countsel('spip_urls', $where . sql_quote($set['url']))) {
  103. sql_updateq('spip_urls', array('url'=>$set['url'], 'date' => date('Y-m-d H:i:s')), 'url='.sql_quote($set['url']));
  104. return true;
  105. }
  106. }
  107. } while (@sql_insertq('spip_urls', $set) <= 0);
  108. }
  109. sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s')), 'url='.sql_quote($set['url']));
  110. spip_log("Creation de l'url propre '" . $set['url'] . "' pour ".$set['type']." ".$set['id_objet']);
  111. return true;
  112. }
  113. function url_verrouiller($objet,$id_objet,$url){
  114. $where = "id_objet=".intval($id_objet)." AND type=".sql_quote($objet);
  115. $where .= " AND url=".sql_quote($url);
  116. // pour verrouiller une url, on fixe sa date dans le futur, dans 10 ans
  117. sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s',time()+10*365.25*24*3600)), $where);
  118. }
  119. function url_delete($objet,$id_objet,$url=""){
  120. $where = "id_objet=".intval($id_objet)." AND type=".sql_quote($objet);
  121. if (strlen($url))
  122. $where .= " AND url=".sql_quote($url);
  123. sql_delete("spip_urls",$where);
  124. }
  125. ?>