[SPIP] +spip v3.0.17
[lhc/web/clavette_www.git] / www / plugins-dist / urls_etendues / action / editer_url.php
diff --git a/www/plugins-dist/urls_etendues/action/editer_url.php b/www/plugins-dist/urls_etendues/action/editer_url.php
new file mode 100644 (file)
index 0000000..ba4cc95
--- /dev/null
@@ -0,0 +1,203 @@
+<?php
+
+/***************************************************************************\
+ *  SPIP, Systeme de publication pour l'internet                           *
+ *                                                                         *
+ *  Copyright (c) 2001-2014                                                *
+ *  Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James  *
+ *                                                                         *
+ *  Ce programme est un logiciel libre distribue sous licence GNU/GPL.     *
+ *  Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne.   *
+\***************************************************************************/
+
+if (!defined("_ECRIRE_INC_VERSION")) return;
+
+function action_editer_url_dist() {
+
+       // Rien a faire ici pour le moment
+       #$securiser_action = charger_fonction('securiser_action', 'inc');
+       #$arg = $securiser_action();
+
+}
+
+
+function url_nettoyer($titre,$longueur_maxi,$longueur_min=0,$separateur='-',$filtre=''){
+
+       $titre = supprimer_tags(supprimer_numero(extraire_multi($titre)));
+       $url = translitteration(corriger_caracteres($titre));
+
+       if ($filtre)
+               $url = $filtre($url);
+
+       // on va convertir tous les caracteres de ponctuation et espaces
+       // a l'exception de l'underscore (_), car on veut le conserver dans l'url
+       $url = str_replace('_', chr(7), $url);
+       $url = @preg_replace(',[[:punct:][:space:]]+,u', ' ', $url);
+       $url = str_replace(chr(7), '_', $url);
+
+       // S'il reste trop de caracteres non latins, les gerer comme wikipedia
+       // avec rawurlencode :
+       if (preg_match_all(",[^a-zA-Z0-9 _]+,", $url, $r, PREG_SET_ORDER)) {
+               foreach ($r as $regs) {
+                       $url = substr_replace($url, rawurlencode($regs[0]),
+                               strpos($url, $regs[0]), strlen($regs[0]));
+               }
+       }
+
+       // S'il reste trop peu, renvoyer vide
+       if (strlen($url) < $longueur_min)
+               return '';
+
+       // Sinon couper les mots et les relier par des $separateur
+       $mots = preg_split(",[^a-zA-Z0-9_%]+,", $url);
+       $url = '';
+       foreach ($mots as $mot) {
+               if (!strlen($mot)) continue;
+               $url2 = $url.$separateur.$mot;
+
+               // Si on depasse $longueur_maxi caracteres, s'arreter
+               // ne pas compter 3 caracteres pour %E9 mais un seul
+               $long = preg_replace(',%.,', '', $url2);
+               if (strlen($long) > $longueur_maxi) {
+                       break;
+               }
+
+               $url = $url2;
+       }
+       $url = substr($url, 1);
+
+       // On enregistre en utf-8 dans la base
+       $url = rawurldecode($url);
+
+       if (strlen($url) < $longueur_min)
+               return '';
+       return $url;
+}
+
+function url_insert(&$set,$confirmer,$separateur){
+       $has_parent = true;
+       # assurer la coherence des champs techniques si non fournis
+       if (!isset($set['id_parent'])){
+               $has_parent = false;
+               $set['id_parent'] = 0;
+       }
+       if (!isset($set['segments']))
+               $set['segments'] = count(explode('/',$set['url']));
+       $perma = false;
+       if (isset($set['perma']) AND $set['perma']){
+               unset($set['perma']);
+               $perma = true;
+       }
+       $redate = true;
+
+       # le separateur ne peut pas contenir de /
+       if (strpos($separateur,'/')!==false)
+               $separateur = "-";
+
+       // Si l'insertion echoue, c'est une violation d'unicite.
+       $where_urllike = 'url LIKE '.url_sql_quote_like($set['url'])." AND NOT(type=".sql_quote($set['type'])." AND id_objet=".intval($set['id_objet']).")";
+       $where_thisurl = $where_urllike.($has_parent?" AND id_parent=".intval($set['id_parent']):"");
+       if (
+               // si pas de parent defini, il faut que cette url soit unique, independamment de id_parent
+               // il faut utiliser un LIKE pour etre case unsensitive en sqlite
+         (!$has_parent AND sql_countsel("spip_urls",$where_urllike))
+               OR @sql_insertq('spip_urls', $set) <= 0) {
+
+               // On veut chiper une ancienne adresse ou prendre celle d'un repertoire deja present?
+               if (
+                       (!is_dir(_DIR_RACINE.$set['url']) AND !file_exists(_DIR_RACINE.$set['url']))
+                       // un vieux url
+                       AND $vieux = sql_fetsel('*', 'spip_urls', $where_thisurl,'','perma DESC')
+                       // qui n'est pas permanente
+                       AND !$vieux['perma']
+                 // et dont l'objet a une url plus recente
+                 AND $courant = sql_fetsel('*', 'spip_urls',
+                         'type='.sql_quote($vieux['type']).' AND id_objet='.sql_quote($vieux['id_objet'])
+                         .' AND url<>'.sql_quote($set['url'])
+                         .' AND date>'.sql_quote($vieux['date']), '', 'date DESC', 1)
+                 ) {
+                       if ($confirmer AND !_request('ok2')) {
+                               die ("Vous voulez chiper l'URL de l'objet ".$courant['type']." "
+                                       . $courant['id_objet']." qui a maintenant l'url "
+                                       . $courant['url']);
+                       }
+                       $where_thisurl = "url=".sql_quote($vieux['url'])." AND id_parent=".intval($vieux['id_parent']);
+                       // si oui on le chipe
+                       sql_updateq('spip_urls', $set, $where_thisurl);
+                       sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s')), $where_thisurl);
+                       spip_log("reattribue url ".$vieux['url']
+                               ." de ".$vieux['type']."#".$vieux['id_objet']." (parent ".$vieux['id_parent'].")"
+                               ." A ".$set['type']."#".$set['id_objet']." (parent ".$set['id_parent'].")","urls"._LOG_INFO_IMPORTANTE);
+               }
+
+               // Sinon
+               else {
+
+                       // Soit c'est un Come Back d'une ancienne url propre de l'objet
+                       // Soit c'est un vrai conflit. Rajouter l'ID jusqu'a ce que ca passe,
+                       // mais se casser avant que ca ne casse.
+
+                       // il peut etre du a un changement de casse de l'url simplement
+                       // pour ce cas, on reecrit systematiquement l'url en plus d'actualiser la date
+                       $where = "type=".sql_quote($set['type'])
+                                                        ." AND id_objet=".intval($set['id_objet'])
+                                                        ." AND id_parent=".intval($set['id_parent'])
+                                                        ." AND url LIKE ";
+                       if (
+                               !is_dir(_DIR_RACINE.$set['url']) AND !file_exists(_DIR_RACINE.$set['url'])
+                               AND sql_countsel('spip_urls', $where  .url_sql_quote_like($set['url']))) {
+                               sql_updateq('spip_urls', array('url'=>$set['url'], 'date' => date('Y-m-d H:i:s')), $where  .url_sql_quote_like($set['url']));
+                               spip_log("reordonne ".$set['type']." ".$set['id_objet'],"urls");
+                               $redate = false;
+                       }
+                       else {
+                               $set['url'] .= $separateur.$set['id_objet'];
+                               if (strlen($set['url']) > 200)
+                                       //serveur out ? retourner au mieux
+                                       return false;
+                               elseif (sql_countsel('spip_urls', $where . url_sql_quote_like($set['url']))) {
+                                       sql_updateq('spip_urls', array('url'=>$set['url'], 'date' => date('Y-m-d H:i:s')), $where .url_sql_quote_like($set['url']));
+                                       $redate = false;
+                               }
+                               else {
+                                       // remettre id_parent et perma comme il faut si besoin
+                                       if (!$has_parent) unset($set['id_parent']);
+                                       if ($perma) $set['perma'] = true;
+                                       return url_insert($set, $confirmer, $separateur);
+                               }
+                       }
+               }
+       }
+
+       $where_thisurl = 'url='.sql_quote($set['url'])." AND id_parent=".intval($set['id_parent']); // maj
+       if ($redate)
+               sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s')), $where_thisurl);
+
+       // si url perma, poser le flag sur la seule url qu'on vient de mettre
+       if ($perma)
+               sql_update('spip_urls', array('perma' => "($where_thisurl)"), "type=".sql_quote($set['type'])." AND id_objet=".intval($set['id_objet']));
+       
+       spip_log("Creation de l'url propre '" . $set['url'] . "' pour ".$set['type']." ".$set['id_objet']." (parent ".$set['id_parent']." perma ".($perma?"1":"0").")","urls");
+       return true;
+}
+
+function url_sql_quote_like($url){
+       return sql_quote(str_replace(array("%","_"),array("\\%","\\_"),$url))." ESCAPE ".sql_quote('\\');
+}
+
+function url_verrouiller($objet,$id_objet,$url){
+       $where = "id_objet=".intval($id_objet)." AND type=".sql_quote($objet);
+       $where .= " AND url=".sql_quote($url);
+
+       // pour verrouiller une url, on fixe sa date dans le futur, dans 10 ans
+       sql_updateq('spip_urls', array('date' => date('Y-m-d H:i:s',time()+10*365.25*24*3600)), $where);
+}
+
+function url_delete($objet,$id_objet,$url=""){
+       $where = "id_objet=".intval($id_objet)." AND type=".sql_quote($objet);
+       if (strlen($url))
+               $where .= " AND url=".sql_quote($url);
+
+       sql_delete("spip_urls",$where);
+}
+?>