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

Last change on this file since 125427 was 104327, checked in by spip.franck@…, 4 years ago

code.spip est maintenant en https, donc, j'ajoute le "s" à http

File size: 10.8 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// https://code.spip.net/@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_objet" => $id_article), array("id_objet = ".(0-$id_auteur),"objet='article'"));
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// https://code.spip.net/@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// https://code.spip.net/@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' => date('Y-m-d H:i:s'),//'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// https://code.spip.net/@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        $row = sql_fetsel("statut, date, id_rubrique", "spip_articles", "id_article=$id_article");
154        $id_rubrique = $row['id_rubrique'];
155        $statut_ancien = $statut = $row['statut'];
156        //$date_ancienne = $date = $row['date'];
157        $date_ancienne = $date = $row['date'];
158        $champs = array();
159       
160        $d = isset($c['date'])?$c['date']:null;
161        $s = isset($c['statut'])?$c['statut']:$statut;
162
163        // cf autorisations dans inc/instituer_article
164        //if ($s != $statut OR ($d AND $d != $date)) {
165        if ($s != $statut OR ($d AND $d != $date)) {
166                if (autoriser('publierdans', 'rubrique', $id_rubrique))
167                        $statut = $champs['statut'] = $s;
168                else if (autoriser('modifier', 'article', $id_article) AND $s != 'publie')
169                        $statut = $champs['statut'] = $s;
170                else
171                        spip_log("editer_article $id_article refus " . join(' ', $c));
172
173                // En cas de publication, fixer la date a "maintenant"
174                // sauf si $c commande autre chose
175                // En cas de proposition d'un article (mais pas depublication), idem
176                //modif plugin gerer_date remplace
177                if ($champs['statut'] == 'publie'
178                 OR $champs['statut'] == 'prop' OR $champs['statut'] == 'prepa' )
179                        {
180                        if (!is_null($d))
181                                $champs['date'] = $date = $d;
182                        else {
183                                $champs['date'] = $date;//$date = date('Y-m-d H:i:s');
184                        }
185                }
186        }
187
188        // Verifier que la rubrique demandee existe et est differente
189        // de la rubrique actuelle
190        if ($id_parent = $c['id_parent']
191        AND $id_parent != $id_rubrique
192        AND (sql_fetsel('1', "spip_rubriques", "id_rubrique=$id_parent"))) {
193                $champs['id_rubrique'] = $id_parent;
194
195                // si l'article etait publie
196                // et que le demandeur n'est pas admin de la rubrique
197                // repasser l'article en statut 'propose'.
198                if ($statut == 'publie'
199                AND !autoriser('publierdans', 'rubrique', $id_rubrique))
200                        $champs['statut'] = 'prop';
201        }
202
203
204        // Envoyer aux plugins
205        $champs = pipeline('pre_edition',
206                array(
207                        'args' => array(
208                                'table' => 'spip_articles',
209                                'id_objet' => $id_article,
210                                'action'=>'instituer'
211                        ),
212                        'data' => $champs
213                )
214        );
215
216        if (!count($champs)) return;
217
218        // Envoyer les modifs.
219
220        editer_article_heritage($id_article, $id_rubrique, $statut_ancien, $champs, $calcul_rub);
221
222        // Invalider les caches
223        include_spip('inc/invalideur');
224        suivre_invalideur("id='id_article/$id_article'");
225
226        if ($date) {
227                $t = strtotime($date);
228                $p = @$GLOBALS['meta']['date_prochain_postdate'];
229                if ($t > time() AND (!$p OR ($t < $p))) {
230                        ecrire_meta('date_prochain_postdate', $t);
231                }
232        }
233
234        // Pipeline
235        pipeline('post_edition',
236                array(
237                        'args' => array(
238                                'table' => 'spip_articles',
239                                'id_objet' => $id_article,
240                                'action'=>'instituer'
241                        ),
242                        'data' => $champs
243                )
244        );
245
246        // Notifications
247        if ($notifications = charger_fonction('notifications', 'inc')) {
248                $notifications('instituerarticle', $id_article,
249                        array('statut' => $statut, 'statut_ancien' => $statut_ancien, 'date'=>$date)
250                );
251        }
252
253        return ''; // pas d'erreur
254}
255
256// fabrique la requete de modification de l'article, avec champs herites
257
258// https://code.spip.net/@editer_article_heritage
259function editer_article_heritage($id_article, $id_rubrique, $statut, $champs, $cond=true) {
260
261        // Si on deplace l'article
262        //  changer aussi son secteur et sa langue (si heritee)
263        if (isset($champs['id_rubrique'])) {
264
265                $row_rub = sql_fetsel("id_secteur, lang", "spip_rubriques", "id_rubrique=".sql_quote($champs['id_rubrique']));
266
267                $langue = $row_rub['lang'];
268                $champs['id_secteur'] = $row_rub['id_secteur'];
269                if (sql_fetsel('1', 'spip_articles', "id_article=$id_article AND langue_choisie<>'oui' AND lang<>" . sql_quote($langue))) {
270                        $champs['lang'] = $langue;
271                }
272        }
273
274        if (!$champs) return;
275
276        sql_updateq('spip_articles', $champs, "id_article=$id_article");
277
278        // Changer le statut des rubriques concernees
279
280        if ($cond) {
281                include_spip('inc/rubriques');
282                $postdate = ($GLOBALS['meta']["post_dates"] == "non" AND isset($champs['date']) AND (strtotime($champs['date']) < time()))?$champs['date']:false;
283                calculer_rubriques_if($id_rubrique, $champs, $statut, $postdate);
284        }
285}
286
287//
288// Reunit les textes decoupes parce que trop longs
289//
290
291// https://code.spip.net/@trop_longs_articles
292function trop_longs_articles() {
293        if (is_array($plus = _request('texte_plus'))) {
294                foreach ($plus as $n=>$t) {
295                        $plus[$n] = preg_replace(",<!--SPIP-->[\n\r]*,","", $t);
296                }
297                set_request('texte', join('',$plus) . _request('texte'));
298        }
299}
300
301// Poser un lien de traduction vers un article de reference
302// https://code.spip.net/@article_referent
303function article_referent ($id_article, $c) {
304
305        if (!$c = intval($c['lier_trad'])) return;
306
307        // selectionner l'article cible, qui doit etre different de nous-meme,
308        // et quitter s'il n'existe pas
309        $id_lier = sql_getfetsel('id_trad', 'spip_articles', "id_article=$c AND NOT(id_article=$id_article)");
310
311        if ($id_lier === NULL)
312        {
313                spip_log("echec lien de trad vers article incorrect ($lier_trad)");
314                return '&trad_err=1';
315        }
316
317        // $id_lier est le numero du groupe de traduction
318        // Si l'article vise n'est pas deja traduit, son identifiant devient
319        // le nouvel id_trad de ce nouveau groupe et on l'affecte aux deux
320        // articles
321        if ($id_lier == 0) {
322                sql_updateq("spip_articles", array("id_trad" => $c), "id_article IN ($c, $id_article)");
323        }
324        // sinon ajouter notre article dans le groupe
325        else {
326                sql_updateq("spip_articles", array("id_trad" => $id_lier), "id_article = $id_article");
327        }
328
329        return ''; // pas d'erreur
330}
331
332
333
334// obsolete, utiliser revision_article dans inc/modifier
335// https://code.spip.net/@revisions_articles
336function revisions_articles ($id_article, $c=false) {
337        include_spip('inc/modifier');
338        return revision_article($id_article,$c);
339}
340
341
342?>
Note: See TracBrowser for help on using the repository browser.