source: spip-zone/_plugins_/gerer_date/200/action/editer_article.php @ 28930

Last change on this file since 28930 was 23100, checked in by yaquoi@…, 12 years ago

gerer_date de publications

File size: 10.3 KB
Line 
1<?php
2
3/***************************************************************************\
4 *  SPIP, Systeme de publication pour l'internet                           *
5 *                                                                         *
6 *  Copyright (c) 2001-2008                                                *
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
13if (!defined("_ECRIRE_INC_VERSION")) return;
14
15// http://doc.spip.org/@action_editer_article_dist
16function action_editer_article_dist() {
17
18        $securiser_action = charger_fonction('securiser_action', 'inc');
19        $arg = $securiser_action();
20
21        // si id_article n'est pas un nombre, c'est une creation
22        // mais on verifie qu'on a toutes les donnees qu'il faut.
23        if (!$id_article = intval($arg)) {
24                $id_parent = _request('id_parent');
25                $id_auteur = $GLOBALS['visiteur_session']['id_auteur'];
26                if (!($id_parent AND $id_auteur)) {
27                        include_spip('inc/headers');
28                        redirige_url_ecrire();
29                }
30                if (($id_article = insert_article($id_parent)) > 0)
31               
32                # cf. GROS HACK ecrire/inc/getdocument
33                # rattrapper les documents associes a cet article nouveau
34                # ils ont un id = 0-id_auteur
35
36                        sql_updateq("spip_documents_liens", array("id_article" => $id_article), "id_article = ".(0-$id_auteur));
37        } 
38
39        // Enregistre l'envoi dans la BD
40        if ($id_article > 0) $err = articles_set($id_article);
41
42        if (_request('redirect')) {
43                $redirect = parametre_url(urldecode(_request('redirect')),
44                        'id_article', $id_article, '&') . $err;
45       
46                include_spip('inc/headers');
47                redirige_par_entete($redirect);
48        }
49        else 
50                return array($id_article,$err);
51}
52
53// Appelle toutes les fonctions de modification d'un article
54// $err est de la forme '&trad_err=1'
55// http://doc.spip.org/@articles_set
56function articles_set($id_article) {
57        $err = '';
58
59        // unifier $texte en cas de texte trop long
60        trop_longs_articles();
61
62        $c = array();
63        foreach (array(
64                'surtitre', 'titre', 'soustitre', 'descriptif',
65                'nom_site', 'url_site', 'chapo', 'texte', 'ps'
66        ) as $champ)
67                $c[$champ] = _request($champ);
68
69        if (_request('changer_virtuel') == 'oui') {
70                $r = _request('virtuel');
71                $c['chapo'] = (strlen($r) ? '='.$r : '');
72        }
73
74        include_spip('inc/modifier');
75        revision_article($id_article, $c);
76
77        // Modification de statut, changement de rubrique ?
78        $c = array();
79        foreach (array(
80                'date', 'statut', 'id_parent'
81        ) as $champ)
82                $c[$champ] = _request($champ);
83        $err .= instituer_article($id_article, $c);
84
85        // Un lien de trad a prendre en compte
86        $err .= article_referent($id_article, array('lier_trad' => _request('lier_trad')));
87
88        return $err;
89}
90
91// http://doc.spip.org/@insert_article
92function insert_article($id_rubrique) {
93
94
95        // Si id_rubrique vaut 0 ou n'est pas definie, creer l'article
96        // dans la premiere rubrique racine
97        if (!$id_rubrique = intval($id_rubrique)) {
98                $row = sql_fetsel("id_rubrique, id_secteur, lang", "spip_rubriques", "id_parent=0",'', '0+titre,titre', "1");
99                $id_rubrique = $row['id_rubrique'];
100        } else $row = sql_fetsel("lang, id_secteur", "spip_rubriques", "id_rubrique=$id_rubrique");
101
102        $id_secteur = $row['id_secteur'];
103        $lang_rub = $row['lang'];
104
105        // La langue a la creation : si les liens de traduction sont autorises
106        // dans les rubriques, on essaie avec la langue de l'auteur,
107        // ou a defaut celle de la rubrique
108        // Sinon c'est la langue de la rubrique qui est choisie + heritee
109        if ($GLOBALS['meta']['multi_articles'] == 'oui') {
110                lang_select($GLOBALS['visiteur_session']['lang']);
111                if (in_array($GLOBALS['spip_lang'],
112                explode(',', $GLOBALS['meta']['langues_multilingue']))) {
113                        $lang = $GLOBALS['spip_lang'];
114                        $choisie = 'oui';
115                }
116        }
117
118        if (!$lang) {
119                $choisie = 'non';
120                $lang = $lang_rub ? $lang_rub : $GLOBALS['meta']['langue_site'];
121        }
122
123        $id_article = sql_insertq("spip_articles", array(
124                'id_rubrique' => $id_rubrique,
125                'id_secteur' =>  $id_secteur,
126                'statut' =>  'prepa',
127                'date' => 'NOW()',
128                'accepter_forum' => 
129                        substr($GLOBALS['meta']['forums_publics'],0,3),
130                'lang' => $lang,
131                'langue_choisie' =>$choisie));
132
133        // controler si le serveur n'a pas renvoye une erreur
134        if ($id_article > 0) 
135                sql_insertq('spip_auteurs_articles', array('id_auteur' => $GLOBALS['visiteur_session']['id_auteur'], 'id_article' => $id_article));;
136
137        return $id_article;
138}
139
140
141// $c est un array ('statut', 'id_parent' = changement de rubrique)
142//
143// statut et rubrique sont lies, car un admin restreint peut deplacer
144// un article publie vers une rubrique qu'il n'administre pas
145// http://doc.spip.org/@instituer_article
146function instituer_article($id_article, $c, $calcul_rub=true) {
147
148        include_spip('inc/autoriser');
149        include_spip('inc/rubriques');
150        include_spip('inc/modifier');
151
152        $row = sql_fetsel("statut, id_rubrique", "spip_articles", "id_article=$id_article");
153        $id_rubrique = $row['id_rubrique'];
154        $statut_ancien = $statut = $row['statut'];
155        $champs = array();
156        $date = $c['date'];
157
158        $s = $c['statut'];
159
160        // cf autorisations dans inc/instituer_article
161        if ($s AND $s != $statut) {
162                if (autoriser('publierdans', 'rubrique', $id_rubrique))
163                        $statut = $champs['statut'] = $s;
164                else if (autoriser('modifier', 'article', $id_article) AND $s != 'publie')
165                        $statut = $champs['statut'] = $s;
166                else
167                        spip_log("editer_article $id_article refus " . join(' ', $c));
168
169                // En cas de publication, fixer la date a "maintenant"
170                // sauf si $c commande autre chose
171                // En cas de proposition d'un article (mais pas depublication), idem MODIF PLUGIN
172                if (!$champs['statut'] == 'publie'
173                OR (!$champs['statut'] == 'prop'
174                        AND !in_array($statut_ancien, array('publie', 'prop'))
175                )) {
176                        if (!is_null($date))
177                                $champs['date'] = $date;
178                        else {
179                                # on prend la date de MySQL pour eviter un decalage cf. #975
180                                $d = sql_fetsel('NOW() AS d');
181                                $champs['date'] = $d['d'];
182                        }
183                }
184        }
185
186        // Verifier que la rubrique demandee existe et est differente
187        // de la rubrique actuelle
188        if ($id_parent = $c['id_parent']
189        AND $id_parent != $id_rubrique
190        AND (sql_fetsel('1', "spip_rubriques", "id_rubrique=$id_parent"))) {
191                $champs['id_rubrique'] = $id_parent;
192
193                // si l'article etait publie
194                // et que le demandeur n'est pas admin de la rubrique
195                // repasser l'article en statut 'propose'.
196                if ($statut == 'publie'
197                AND !autoriser('publierdans', 'rubrique', $id_rubrique))
198                        $champs['statut'] = 'prop';
199        }
200
201
202        // Envoyer aux plugins
203        $champs = pipeline('pre_edition',
204                array(
205                        'args' => array(
206                                'table' => 'spip_articles',
207                                'id_objet' => $id_article
208                        ),
209                        'data' => $champs
210                )
211        );
212
213        if (!count($champs)) return;
214
215        // Envoyer les modifs.
216
217        editer_article_heritage($id_article, $id_rubrique, $statut_ancien, $champs, $calcul_rub);
218
219        // Invalider les caches
220        include_spip('inc/invalideur');
221        suivre_invalideur("id='id_article/$id_article'");
222
223        if ($date) {
224                $t = strtotime($date);
225                $p = @$GLOBALS['meta']['date_prochain_postdate'];
226                if ($t > time() AND (!$p OR ($t < $p))) {
227                        ecrire_meta('date_prochain_postdate', $t);
228                }
229        }
230
231        // Pipeline
232        pipeline('post_edition',
233                array(
234                        'args' => array(
235                                'table' => 'spip_articles',
236                                'id_objet' => $id_article
237                        ),
238                        'data' => $champs
239                )
240        );
241
242        // Notifications
243        if ($notifications = charger_fonction('notifications', 'inc')) {
244                $notifications('instituerarticle', $id_article,
245                        array('statut' => $statut, 'statut_ancien' => $statut_ancien)
246                );
247        }
248
249        return ''; // pas d'erreur
250}
251
252// fabrique la requete de modification de l'article, avec champs herites
253
254// http://doc.spip.org/@editer_article_heritage
255function editer_article_heritage($id_article, $id_rubrique, $statut, $champs, $cond=true) {
256
257        // Si on deplace l'article
258        //  changer aussi son secteur et sa langue (si heritee)
259        if (isset($champs['id_rubrique'])) {
260
261                $row_rub = sql_fetsel("id_secteur, lang", "spip_rubriques", "id_rubrique=".sql_quote($champs['id_rubrique']));
262
263                $langue = $row_rub['lang'];
264                $champs['id_secteur'] = $row_rub['id_secteur'];
265                if (sql_fetsel('1', 'spip_articles', "id_article=$id_article AND langue_choisie<>'oui' AND lang<>" . sql_quote($langue))) {
266                        $champs['lang'] = $langue;
267                }
268        }
269
270        if (!$champs) return;
271
272        sql_updateq('spip_articles', $champs, "id_article=$id_article");
273
274        // Changer le statut des rubriques concernees
275
276        if ($cond) {
277                include_spip('inc/rubriques');
278                calculer_rubriques_if($id_rubrique, $champs, $statut);
279        }
280}
281
282//
283// Reunit les textes decoupes parce que trop longs
284//
285
286// http://doc.spip.org/@trop_longs_articles
287function trop_longs_articles() {
288        if (is_array($plus = _request('texte_plus'))) {
289                foreach ($plus as $n=>$t) {
290                        $plus[$n] = preg_replace(",<!--SPIP-->[\n\r]*,","", $t);
291                }
292                set_request('texte', join('',$plus) . _request('texte'));
293        }
294}
295
296// Poser un lien de traduction vers un article de reference
297// http://doc.spip.org/@article_referent
298function article_referent ($id_article, $c) {
299
300        if (!$c = intval($c['lier_trad'])) return;
301
302        // selectionner l'article cible, qui doit etre different de nous-meme,
303        // et quitter s'il n'existe pas
304        $id_lier = sql_getfetsel('id_trad', 'spip_articles', "id_article=$c AND NOT(id_article=$id_article)");
305
306        if ($id_lier === NULL)
307        {
308                spip_log("echec lien de trad vers article incorrect ($lier_trad)");
309                return '&trad_err=1';
310        }
311
312        // $id_lier est le numero du groupe de traduction
313        // Si l'article vise n'est pas deja traduit, son identifiant devient
314        // le nouvel id_trad de ce nouveau groupe et on l'affecte aux deux
315        // articles
316        if ($id_lier == 0) {
317                sql_updateq("spip_articles", array("id_trad" => $c), "id_article IN ($c, $id_article)");
318        }
319        // sinon ajouter notre article dans le groupe
320        else {
321                sql_updateq("spip_articles", array("id_trad" => $id_lier), "id_article = $id_article");
322        }
323
324        return ''; // pas d'erreur
325}
326
327
328
329// obsolete, utiliser revision_article dans inc/modifier
330// http://doc.spip.org/@revisions_articles
331function revisions_articles ($id_article, $c=false) {
332        include_spip('inc/modifier');
333        return revision_article($id_article,$c);
334}
335
336
337?>
Note: See TracBrowser for help on using the repository browser.