3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
6 * Copyright (c) 2001-2016 *
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;
15 // http://code.spip.net/@action_editer_signature_dist
16 function action_editer_signature_dist($arg=null) {
19 $securiser_action = charger_fonction('securiser_action', 'inc');
20 $arg = $securiser_action();
23 // si id_signature n'est pas un nombre, c'est une creation
24 // mais on verifie qu'on a toutes les donnees qu'il faut.
25 if (!$id_signature = intval($arg)) {
26 $id_petition = _request('id_petition');
29 $id_signature = signature_inserer($id_petition);
32 // Enregistre l'envoi dans la BD
33 if ($id_signature > 0)
34 $err = signature_modifier($id_signature);
36 return array($id_signature,$err);
40 * Mettre a jour une signature existante
42 * @param int $id_signature
46 function signature_modifier($id_signature, $set=null) {
49 include_spip('inc/modifier');
50 $c = collecter_requests(
53 "nom_email","ad_email",
54 "nom_site","url_site","message","statut"
57 array('statut','id_petition','date_time'),
58 // donnees eventuellement fournies
62 if ($err = objet_modifier_champs('signature', $id_signature,
64 'nonvide' => array('nom_email' => _T('info_sans_titre'))
69 // Modification de statut
70 $c = collecter_requests(array('statut','id_petition','date_time'),array(),$set);
71 $err .= signature_instituer($id_signature, $c);
77 * Inserer une signature en base
78 * @param int $id_petition
81 function signature_inserer($id_petition) {
83 // Si $id_petition vaut 0 ou n'est pas definie, echouer
84 if (!$id_petition = intval($id_petition))
88 'id_petition' => $id_petition,
90 'date_time' => date('Y-m-d H:i:s'));
92 // Envoyer aux plugins
93 $champs = pipeline('pre_insertion',
96 'table' => 'spip_signatures',
102 $id_signature = sql_insertq("spip_signatures", $champs);
104 pipeline('post_insertion',
107 'table' => 'spip_signatures',
108 'id_objet' => $id_signature
114 return $id_signature;
118 // $c est un array ('statut', 'id_petition' = changement de petition)
119 // il n'est pas autoriser de deplacer une signature
120 // http://code.spip.net/@signature_instituer
121 function signature_instituer($id_signature, $c, $calcul_rub=true) {
123 include_spip('inc/autoriser');
124 include_spip('inc/modifier');
126 $row = sql_fetsel("S.statut, S.date_time, P.id_article", "spip_signatures AS S JOIN spip_petitions AS P ON S.id_petition=P.id_petition", "S.id_signature=".intval($id_signature));
127 $statut_ancien = $statut = $row['statut'];
128 $date_ancienne = $date = $row['date_time'];
131 $d = isset($c['date_time'])?
$c['date_time']:null;
132 $s = isset($c['statut'])?
$c['statut']:$statut;
134 // cf autorisations dans inc/signature_instituer
135 if ($s != $statut OR ($d AND $d != $date)) {
136 $statut = $champs['statut'] = $s;
138 // En cas de publication, fixer la date a "maintenant"
139 // sauf si $c commande autre chose
140 // ou si l'signature est deja date dans le futur
141 // En cas de proposition d'un signature (mais pas depublication), idem
142 if ($champs['statut'] == 'publie') {
144 $champs['date_time'] = $date = $d;
146 $champs['date_time'] = $date = date('Y-m-d H:i:s');
148 // on peut redater une signature qu'on relance
150 $champs['date_time'] = $date = $d;
153 // Envoyer aux plugins
154 $champs = pipeline('pre_edition',
157 'table' => 'spip_signatures',
158 'id_objet' => $id_signature,
159 'action'=>'instituer',
160 'statut_ancien' => $statut_ancien,
166 if (!count($champs)) return;
168 // Envoyer les modifs.
169 sql_updateq('spip_signatures',$champs,'id_signature='.intval($id_signature));
171 // Invalider les caches
172 include_spip('inc/invalideur');
173 suivre_invalideur("id='signature/$id_signature'");
174 suivre_invalideur("id='article/".$row['id_article']."'");
177 pipeline('post_edition',
180 'table' => 'spip_signatures',
181 'id_objet' => $id_signature,
182 'action'=>'instituer',
183 'statut_ancien' => $statut_ancien,
190 if ($notifications = charger_fonction('notifications', 'inc')) {
191 $notifications('instituersignature', $id_signature,
192 array('statut' => $statut, 'statut_ancien' => $statut_ancien, 'date'=>$date)
196 return ''; // pas d'erreur
201 * Pour eviter le recours a un verrou (qui bloque l'acces a la base),
202 * on commence par inserer systematiquement la signature
203 * puis on demande toutes celles ayant la propriete devant etre unique
204 * (mail ou site). S'il y en a plus qu'une on les retire sauf la premiere
205 * En cas d'acces concurrents il y aura des requetes de retraits d'elements
206 * deja detruits. Bizarre ? C'est mieux que de bloquer!
208 * http://code.spip.net/@signature_entrop
210 * @param string $where
213 function signature_entrop($where)
216 $where .= " AND statut='publie'";
217 $res = sql_select('id_signature', 'spip_signatures', $where,'',"date_time desc");
218 $n = sql_count($res);
220 while($r=sql_fetch($res))
221 $entrop[]=$r['id_signature'];
222 // garder la premiere signature
223 array_shift($entrop);
228 sql_delete('spip_signatures', sql_in('id_signature', $entrop));
235 function revision_signature($id_signature, $c=false) {
236 return signature_modifier($id_signature,$c);