3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
6 * Copyright (c) 2001-2014 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
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 \***************************************************************************/
13 if (!defined('_ECRIRE_INC_VERSION')) return;
16 // http://doc.spip.org/@action_editer_auteurs_dist
17 function action_editer_auteurs_dist() {
19 $securiser_action = charger_fonction('securiser_action', 'inc');
20 $arg = $securiser_action();
21 $redirect = urldecode(_request('redirect'));
22 if ($script = _request('script'))
23 $redirect = parametre_url($redirect,'script',$script,'&');
24 if ($titre = _request('titre'))
25 $redirect = parametre_url($redirect,'titre',$titre,'&');
27 if (preg_match(",^\W*(\d+)\W(\w*)\W-(\d+)$,", $arg, $r)) {
28 supprimer_auteur_et_rediriger($r[2], $r[1], $r[3], parametre_url($redirect,'type',$r[2],'&'));
30 elseif (preg_match(",^\W*(\d+)\W(\w*)\W(\d+)$,", $arg, $r)) {
31 ajouter_auteur_et_rediriger($r[2], $r[1], $r[3], parametre_url($redirect,'type',$r[2],'&'));
33 elseif (preg_match(",^\W*(\d+)\W(\w*)$,", $arg, $r)) {
34 list(,$id, $type) = $r;
35 $idom = "auteur_$type" . "_$id" . '_new';
36 $nouv_auteur = intval(_request($idom));
38 ajouter_auteur_et_rediriger($type, $id, $nouv_auteur, parametre_url($redirect,'type',$type,'&'));
39 } else if ($cherche = _request('cherche_auteur')) {
40 if ($p = strpos($redirect, '#')) {
41 $ancre = substr($redirect,$p);
42 $redirect = substr($redirect,0,$p);
44 $redirect = parametre_url($redirect,'type',$type,'&');
45 $res = rechercher_auteurs($cherche);
49 # Bingo. Signaler le choix fait.
50 ajouter_auteur_et_rediriger($type, $id, $res[0], "$redirect&ids=" . $res[0] . "&cherche_auteur=" . rawurlencode($cherche) . $ancre);
51 # Trop vague. Le signaler.
53 redirige_par_entete("$redirect&cherche_auteur=$cherche&ids=-1" . $ancre);
55 # Recherche vide (mais faite). Le signaler
56 redirige_par_entete("$redirect&cherche_auteur=$cherche&ids=" . $ancre);
58 # renvoyer un formulaire de choix
59 redirige_par_entete("$redirect&cherche_auteur=$cherche&ids=" . join(',',$res) . $ancre);
61 } else redirige_par_entete("$redirect&ids=-1");
62 } else spip_log("action_editer_auteur: $arg pas compris");
65 // http://doc.spip.org/@supprimer_auteur_et_rediriger
66 function supprimer_auteur_et_rediriger($type, $id, $id_auteur, $redirect)
68 $jointure = table_jointure('auteur', $type);
69 if (preg_match(',^[a-z]*$,',$type)){
70 sql_delete("spip_{$jointure}", "id_auteur=".sql_quote($id_auteur)." AND id_{$type}=".sql_quote($id));
72 // Notifications, gestion des revisions, reindexation...
73 pipeline('post_edition',
76 'operation' => 'supprimer_auteur',
77 'table' => table_objet_sql($type),
85 if ($redirect) redirige_par_entete($redirect);
88 // http://doc.spip.org/@ajouter_auteur_et_rediriger
89 function ajouter_auteur_et_rediriger($type, $id, $id_auteur, $redirect)
91 $jointure = table_jointure('auteur', $type);
92 if (preg_match(',^[a-z]*$,',$type)){
93 $res = sql_fetsel("id_$type", "spip_{$jointure}", "id_auteur=" . sql_quote($id_auteur) . " AND id_{$type}=" . $id);
95 sql_insertq("spip_{$jointure}",
96 array('id_auteur' => $id_auteur,
99 // Notifications, gestion des revisions, reindexation...
100 pipeline('post_edition',
103 'operation' => 'ajouter_auteur',
104 'table' => table_objet_sql($type),
112 if ($redirect) redirige_par_entete($redirect);
115 // http://doc.spip.org/@rechercher_auteurs
116 function rechercher_auteurs($cherche_auteur)
118 include_spip('inc/mots');
119 include_spip('inc/charsets'); // pour tranlitteration
120 $result = sql_select("id_auteur, nom", "spip_auteurs");
121 $table_auteurs = array();
122 $table_ids = array();
123 while ($row = sql_fetch($result)) {
124 $table_auteurs[] = $row["nom"];
125 $table_ids[] = $row["id_auteur"];
127 return mots_ressemblants($cherche_auteur, $table_auteurs, $table_ids);