ff182110a904adfc73b5302b1c5cba46f16dd3fe
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 \***************************************************************************/
14 * Gestion de l'action editer_breve
16 * @package SPIP\Breves\Actions
18 if (!defined('_ECRIRE_INC_VERSION')) {
23 * Action d'édition d'une brève dans la base de données dont
24 * l'identifiant est donné en paramètre de cette fonction ou
25 * en argument de l'action sécurisée
27 * Si aucun identifiant n'est donné, on crée alors une nouvelle brève.
29 * @param null|int $arg
30 * Identifiant de la brève. En absence utilise l'argument
31 * de l'action sécurisée.
33 * Liste : identifiant de la brève, texte d'erreur éventuel
35 function action_editer_breve_dist($arg = null) {
38 $securiser_action = charger_fonction('securiser_action', 'inc');
39 $arg = $securiser_action();
42 // Envoi depuis le formulaire d'edition d'une breve
43 if (!$id_breve = intval($arg)) {
44 $id_breve = breve_inserer(_request('id_parent'));
51 $err = breve_modifier($id_breve);
53 return array($id_breve, $err);
58 * Insertion d'une brève dans une rubrique
60 * @pipeline_appel pre_insertion
61 * @pipeline_appel post_insertion
63 * @param int $id_rubrique
64 * Identifiant de la rubrique
65 * @param array|null $set
67 * Identifiant de la nouvelle brève.
69 function breve_inserer($id_rubrique, $set = null) {
71 include_spip('inc/rubriques');
73 // Si id_rubrique vaut 0 ou n'est pas definie, creer la breve
74 // dans la premiere rubrique racine
75 if (!$id_rubrique = intval($id_rubrique)) {
76 $id_rubrique = sql_getfetsel('id_rubrique', 'spip_rubriques', 'id_parent=0', '', '0+titre,titre', '1');
79 // La langue a la creation : c'est la langue de la rubrique
80 $row = sql_fetsel('lang, id_secteur', 'spip_rubriques', 'id_rubrique='.intval($id_rubrique));
82 $id_rubrique = $row['id_secteur']; // garantir la racine
85 'id_rubrique' => $id_rubrique,
87 'date_heure' => date('Y-m-d H:i:s'),
89 'langue_choisie' => 'non'
93 $champs = array_merge($champs, $set);
96 // Envoyer aux plugins
101 'table' => 'spip_breves',
106 $id_breve = sql_insertq('spip_breves', $champs);
111 'table' => 'spip_breves',
112 'id_objet' => $id_breve
123 * Modifier une brève en base
125 * @param int $id_breve
126 * Identifiant de la brève à modifier
127 * @param array|null $set
128 * Couples (colonne => valeur) de données à modifier.
129 * En leur absence, on cherche les données dans les champs éditables
130 * qui ont été postés (via _request())
131 * @return string|null
132 * Chaîne vide si aucune erreur,
133 * Null si aucun champ à modifier,
134 * Chaîne contenant un texte d'erreur sinon.
136 function breve_modifier($id_breve, $set = null) {
138 include_spip('inc/modifier');
139 $c = collecter_requests(
141 array('titre', 'texte', 'lien_titre', 'lien_url'),
143 array('id_parent', 'statut'),
144 // donnees eventuellement fournies
151 // Si la breve est publiee, invalider les caches et demander sa reindexation
152 $t = sql_getfetsel('statut', 'spip_breves', 'id_breve='.intval($id_breve));
153 if ($t == 'publie') {
154 $invalideur = "id='breve/$id_breve'";
158 if ($err = objet_modifier_champs(
163 'nonvide' => array('titre' => _T('breves:titre_nouvelle_breve') . ' ' . _T('info_numero_abbreviation') . $id_breve),
164 'invalideur' => $invalideur,
165 'indexation' => $indexation
172 $c = collecter_requests(array('id_parent', 'statut'), array(), $set);
173 $err = breve_instituer($id_breve, $c);
180 * Instituer une brève : modifier son statut ou son parent
182 * @pipeline_appel pre_insertion
183 * @pipeline_appel post_insertion
185 * @param int $id_breve
186 * Identifiant de la brève
188 * Couples (colonne => valeur) des données à instituer
189 * @return string|null
190 * Null si aucun champ à modifier, chaîne vide sinon.
192 function breve_instituer($id_breve, $c) {
195 // Changer le statut de la breve ?
196 $row = sql_fetsel('statut, id_rubrique,lang, langue_choisie', 'spip_breves', 'id_breve=' . intval($id_breve));
197 $id_rubrique = $row['id_rubrique'];
199 $statut_ancien = $statut = $row['statut'];
200 $langue_old = $row['lang'];
201 $langue_choisie_old = $row['langue_choisie'];
203 if (isset($c['statut'])
205 and $c['statut'] != $statut
206 and autoriser('publierdans', 'rubrique', $id_rubrique)
208 $statut = $champs['statut'] = $c['statut'];
211 // Changer de rubrique ?
212 // Verifier que la rubrique demandee est a la racine et differente
213 // de la rubrique actuelle
215 isset($c['id_parent'])
216 and $id_parent = intval($c['id_parent'])
217 and $id_parent != $id_rubrique
218 and (null !== ($lang = sql_getfetsel(
221 'id_parent=0 AND id_rubrique=' . intval($id_parent)
224 $champs['id_rubrique'] = $id_parent;
225 // - changer sa langue (si heritee)
226 if ($langue_choisie_old != 'oui') {
227 if ($lang != $langue_old) {
228 $champs['lang'] = $lang;
231 // si la breve est publiee
232 // et que le demandeur n'est pas admin de la rubrique
233 // repasser la breve en statut 'prop'.
234 if ($statut == 'publie') {
235 if (!autoriser('publierdans', 'rubrique', $id_parent)) {
236 $champs['statut'] = $statut = 'prop';
241 // Envoyer aux plugins
246 'table' => 'spip_breves',
247 'id_objet' => $id_breve,
248 'action' => 'instituer',
249 'statut_ancien' => $statut_ancien,
259 sql_updateq('spip_breves', $champs, 'id_breve=' . intval($id_breve));
262 // Post-modifications
265 // Invalider les caches
266 include_spip('inc/invalideur');
267 suivre_invalideur("id='breve/$id_breve'");
269 // Au besoin, changer le statut des rubriques concernees
270 include_spip('inc/rubriques');
271 calculer_rubriques_if($id_rubrique, $champs, $statut_ancien);
278 'table' => 'spip_breves',
279 'id_objet' => $id_breve,
280 'action' => 'instituer',
281 'statut_ancien' => $statut_ancien,
289 if ($notifications = charger_fonction('notifications', 'inc')) {
290 $notifications('instituerbreve', $id_breve,
291 array('statut' => $statut, 'statut_ancien' => $statut_ancien)
295 return ''; // pas d'erreur
299 // Fonctions Dépréciées
300 // --------------------
303 * Insertion d'une brève dans une rubrique
305 * @deprecated Utiliser breve_inserer()
306 * @see breve_inserer()
308 * @param int $id_rubrique
309 * Identifiant de la rubrique
311 * Identifiant de la nouvelle brève.
313 function insert_breve($id_rubrique) {
314 return breve_inserer($id_rubrique);
318 * Créer une révision de brève
320 * @deprecated Utiliser breve_modifier()
321 * @see breve_modifier()
323 * @param int $id_breve
324 * Identifiant de la brève à modifier
325 * @param array|null $set
326 * Couples (colonne => valeur) de données à modifier.
327 * En leur absence, on cherche les données dans les champs éditables
328 * qui ont été postés (via _request())
329 * @return string|null
330 * Chaîne vide si aucune erreur,
331 * Null si aucun champ à modifier,
332 * Chaîne contenant un texte d'erreur sinon.
334 function revisions_breves($id_breve, $set = false) {
335 return breve_modifier($id_breve, $set);