[SPIP] v3.2.1-->v3.2.3
[lhc/web/www.git] / www / plugins-dist / petitions / action / editer_petition.php
1 <?php
2
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
5 * *
6 * Copyright (c) 2001-2019 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
8 * *
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 \***************************************************************************/
12
13 /**
14 * Gestion de l'action editer_petition
15 *
16 * @package SPIP\Petitions\Actions
17 **/
18
19 if (!defined("_ECRIRE_INC_VERSION")) {
20 return;
21 }
22
23 function action_editer_petition_dist($arg = null) {
24
25 if (is_null($arg)) {
26 $securiser_action = charger_fonction('securiser_action', 'inc');
27 $arg = $securiser_action();
28 }
29
30 // si id_petition n'est pas un nombre, c'est une creation
31 // mais on verifie qu'on a toutes les donnees qu'il faut.
32 if (!$id_petition = intval($arg)) {
33 $id_article = _request('id_article');
34 if (!($id_article)) {
35 include_spip('inc/headers');
36 redirige_url_ecrire();
37 }
38 $id_petition = petition_inserer($id_article);
39 }
40
41 // Enregistre l'envoi dans la BD
42 if ($id_petition > 0) {
43 $err = petition_modifier($id_petition);
44 }
45
46 return array($id_petition, $err);
47 }
48
49 /**
50 * Mettre à jour une petition existante
51 *
52 * @param int $id_petition
53 * @param array $set
54 * @return string
55 */
56 function petition_modifier($id_petition, $set = null) {
57 $err = '';
58
59 include_spip('inc/modifier');
60 $c = collecter_requests(
61 // white list
62 array(
63 "email_unique",
64 "site_obli",
65 "site_unique",
66 "message",
67 "texte"
68 ),
69 // black list
70 array('statut', 'id_article'),
71 // donnees eventuellement fournies
72 $set
73 );
74
75 if ($err = objet_modifier_champs('petition', $id_petition,
76 array(
77 'data' => $set,
78 ),
79 $c)
80 ) {
81 return $err;
82 }
83
84 // changement d'article ou de statut ?
85 $c = collecter_requests(array('statut', 'id_article'), array(), $set);
86 $err .= petition_instituer($id_petition, $c);
87
88 return $err;
89 }
90
91 /**
92 * Insérer une petition en base
93 *
94 * @param int $id_article
95 * Identifiant de l'article recevant la pétition
96 * @param array|null $set
97 * @return int
98 * Identifiant de la pétition
99 */
100 function petition_inserer($id_article, $set = null) {
101
102 // Si id_article vaut 0 ou n'est pas definie, echouer
103 if (!$id_article = intval($id_article)) {
104 return 0;
105 }
106
107 $champs = array(
108 'id_article' => $id_article,
109 );
110
111 if ($set) {
112 $champs = array_merge($champs, $set);
113 }
114
115 // Envoyer aux plugins
116 $champs = pipeline('pre_insertion',
117 array(
118 'args' => array(
119 'table' => 'spip_petitions',
120 ),
121 'data' => $champs
122 )
123 );
124
125 $id_petition = sql_insertq("spip_petitions", $champs);
126
127 pipeline('post_insertion',
128 array(
129 'args' => array(
130 'table' => 'spip_petitions',
131 'id_objet' => $id_petition
132 ),
133 'data' => $champs
134 )
135 );
136
137 return $id_petition;
138 }
139
140
141 /**
142 * Institution d'une pétition
143 *
144 * @param int $id_petition
145 * Identifiant de la pétition
146 * @param array $c
147 * Liste des champs à modifier
148 * @return string|null
149 */
150 function petition_instituer($id_petition, $c) {
151
152 include_spip('inc/autoriser');
153 include_spip('inc/modifier');
154
155 $row = sql_fetsel("id_article,statut", "spip_petitions", "id_petition=" . intval($id_petition));
156 $statut_ancien = $statut = $row['statut'];
157 #$date_ancienne = $date = $row['date_time'];
158 $champs = array();
159
160 $s = isset($c['statut']) ? $c['statut'] : $statut;
161
162 // cf autorisations dans inc/petition_instituer
163 if ($s != $statut /*OR ($d AND $d != $date)*/) {
164 $statut = $champs['statut'] = $s;
165
166 // En cas de publication, fixer la date a "maintenant"
167 // sauf si $c commande autre chose
168 // ou si l'petition est deja date dans le futur
169 // En cas de proposition d'un petition (mais pas depublication), idem
170 /*
171 if ($champs['statut'] == 'publie') {
172 if ($d)
173 $champs['date_time'] = $date = $d;
174 else
175 $champs['date_time'] = $date = date('Y-m-d H:i:s');
176 }*/
177 }
178
179 // Envoyer aux plugins
180 $champs = pipeline('pre_edition',
181 array(
182 'args' => array(
183 'table' => 'spip_petitions',
184 'id_objet' => $id_petition,
185 'action' => 'instituer',
186 'statut_ancien' => $statut_ancien,
187 ),
188 'data' => $champs
189 )
190 );
191
192 if (!count($champs)) {
193 return;
194 }
195
196 // Envoyer les modifs.
197 sql_updateq('spip_petitions', $champs, 'id_petition=' . intval($id_petition));
198
199 // Invalider les caches
200 include_spip('inc/invalideur');
201 suivre_invalideur("id='petition/$id_petition'");
202 suivre_invalideur("id='article/" . $row['id_article'] . "'");
203
204 // Pipeline
205 pipeline('post_edition',
206 array(
207 'args' => array(
208 'table' => 'spip_petitions',
209 'id_objet' => $id_petition,
210 'action' => 'instituer',
211 'statut_ancien' => $statut_ancien,
212 ),
213 'data' => $champs
214 )
215 );
216
217 // Notifications
218 if ($notifications = charger_fonction('notifications', 'inc')) {
219 $notifications('instituerpetition', $id_petition,
220 array('statut' => $statut, 'statut_ancien' => $statut_ancien)
221 );
222 }
223
224 return ''; // pas d'erreur
225 }
226
227 // https://code.spip.net/@revision_petition
228 function revision_petition($id_petition, $c = null) {
229 return petition_modifier($id_petition, $c);
230 }