source: spip-zone/_core_/plugins/medias/action/editer_document.php @ 43779

Last change on this file since 43779 was 43779, checked in by cedric@…, 9 years ago

PHPDoc

File size: 7.3 KB
Line 
1<?php
2
3/***************************************************************************\
4 *  SPIP, Systeme de publication pour l'internet                           *
5 *                                                                         *
6 *  Copyright (c) 2001-2011                                                *
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
16/**
17 * Action editer_document
18 *
19 * @return unknown
20 */
21function action_editer_document_dist() {
22
23        $securiser_action = charger_fonction('securiser_action', 'inc');
24        $arg = $securiser_action();
25
26        // Envoi depuis le formulaire de creation d'un document
27        if (!$id_document = intval($arg)) {
28                $id_document = insert_document();
29        }
30
31        if ($id_document = intval($id_document)) {
32                document_set($id_document);
33        }
34        // Erreur
35        else{
36                include_spip('inc/headers');
37                redirige_url_ecrire();
38        }
39
40        if (_request('redirect')) {
41                $redirect = parametre_url(urldecode(_request('redirect')),
42                        'id_document', $id_document, '&');
43                       
44                include_spip('inc/headers');
45                redirige_par_entete($redirect);
46        }
47        else 
48                return array($id_document,'');
49}
50
51/**
52 * Creer un nouveau document
53 *
54 * @return unknown
55 */
56function insert_document() {
57
58        $champs = array(
59                'statut' => 'prop',
60                'date' => 'NOW()',
61        );
62
63        // Envoyer aux plugins
64        $champs = pipeline('pre_insertion',
65                array(
66                        'args' => array(
67                                'table' => 'spip_documents',
68                        ),
69                        'data' => $champs
70                )
71        );
72        $id_document = sql_insertq("spip_documents", $champs);
73       
74        return $id_document;
75}
76
77
78/**
79 * Enregistre une revision de document.
80 * $c est un contenu (par defaut on prend le contenu via _request())
81 *
82 * @param int $id_document
83 * @param array $c
84 */
85function document_set ($id_document, $c=false) {
86
87        // champs normaux
88        $champs = array();
89        foreach (array(
90                'titre', 'descriptif', 'date', 'taille', 'largeur','hauteur','mode','credits',
91                'fichier','distant','extension', 'id_vignette',
92          ) as $champ)
93                if (($a = _request($champ,$c)) !== null)
94                        $champs[$champ] = $a;
95
96        // Si le document est publie, invalider les caches et demander sa reindexation
97        $t = sql_getfetsel("statut", "spip_documents", 'id_document='.intval($id_document));
98        if ($t == 'publie') {
99                $invalideur = "id='id_document/$id_document'";
100                $indexation = true;
101        }
102       
103        $ancien_fichier = "";
104        // si le fichier est modifie, noter le nom de l'ancien pour faire le menage
105        if (isset($champs['fichier'])){
106                $ancien_fichier = sql_getfetsel('fichier','spip_documents','id_document='.intval($id_document));
107        }
108
109        include_spip('inc/modifier');
110        modifier_contenu('document', $id_document,
111                array(
112                        'invalideur' => $invalideur,
113                        'indexation' => $indexation
114                ),
115                $champs);
116
117        // nettoyer l'ancien fichier si necessaire
118        if ($champs['fichier'] // un plugin a pu interdire la modif du fichier en virant le champ
119         AND $ancien_fichier // on avait bien note le nom du fichier avant la modif
120         AND $ancien_fichier!==$champs['fichier'] // et il a ete modifie
121         AND @file_exists($f = get_spip_doc($ancien_fichier)))
122                spip_unlink($f);
123
124        // Changer le statut du document ?
125        // le statut n'est jamais fixe manuellement mais decoule de celui des objets lies
126        if(instituer_document($id_document,array('parents'=>_request('parents',$c),'ajout_parents'=>_request('ajout_parents',$c)))) {
127
128                //
129                // Post-modifications
130                //
131       
132                // Invalider les caches
133                include_spip('inc/invalideur');
134                suivre_invalideur("id='id_document/$id_document'");     
135        }
136
137}
138
139
140/**
141 * determiner le statut d'un document : prepa/publie
142 * si on trouve un element joint sans champ statut ou avec un statut='publie' alors le doc est publie aussi
143 *
144 * @param int $id_document
145 */
146function instituer_document($id_document,$champs=array()){
147       
148        $statut=isset($champs['statut'])?$champs['statut']:null;
149        $date_publication = isset($champs['date_publication'])?$champs['date_publication']:null;
150        if (isset($champs['parents']))
151                medias_revision_document_parents($id_document,$champs['parents']);
152        if (isset($champs['ajout_parents']))
153                medias_revision_document_parents($id_document,$champs['ajout_parents'],true);
154       
155        $row = sql_fetsel("statut,date_publication", "spip_documents", "id_document=$id_document");
156        $statut_ancien = $row['statut'];
157        $date_publication_ancienne = $row['date_publication'];
158        if (is_null($statut)){
159                $statut = 'prepa';
160       
161                $trouver_table = charger_fonction('trouver_table','base');
162                $res = sql_select('id_objet,objet','spip_documents_liens','id_document='.intval($id_document));
163                // dans 10 ans, ca nous fera un bug a corriger vers 2018
164                // penser a ouvrir un ticket d'ici la :p
165                $date_publication=time()+10*365*24*3600;
166                while($row = sql_fetch($res)){
167                        $table = table_objet_sql($row['objet']);
168                        $desc = $trouver_table($table);
169                        // si pas de champ statut, c'est un objet publie, donc c'est bon
170                        if (!isset($desc['field']['statut'])){
171                                $statut = 'publie';
172                                $date_publication=0;
173                                continue;
174                        }
175                        $id_table = id_table_objet($row['objet']);
176                        $row2 = sql_fetsel('statut'.($table=='spip_articles'?",date":""),$table,$id_table.'='.intval($row['id_objet']));
177                        if ($row2['statut']=='publie'){
178                                $statut = 'publie';
179                                // si ce n'est pas un article, c'est donc deja publie, on met la date a 0
180                                if (!$row2['date']){
181                                        $date_publication=0;
182                                        continue;
183                                }
184                                else {
185                                        $date_publication = min($date_publication,strtotime($row2['date']));
186                                }
187                        }
188                }
189                $date_publication = date('Y-m-d H:i:s',$date_publication);
190                if ($statut=='publie' AND $statut_ancien=='publie' AND $date_publie==$date_publication_ancienne)
191                        return false;
192                if ($statut!='publie' AND $statut_ancien!='publie' AND $statut_ancien!='0')
193                        return false;
194        }
195        if ($statut!==$statut_ancien
196        OR $date_publication!=$date_publication_ancienne){
197                sql_updateq('spip_documents',array('statut'=>$statut,'date_publication'=>$date_publication),'id_document='.intval($id_document));
198                return true;
199        }
200        return false;
201}
202
203
204/**
205 * Revision des parents d'un document
206 * chaque parent est liste au format objet|id_objet
207 *
208 * @param unknown_type $id_document
209 * @param unknown_type $parents
210 */
211function medias_revision_document_parents($id_document, $parents=null, $ajout=false){
212        if (!is_array($parents))
213                return;
214       
215        $insertions = array();
216        $cond = array();
217        // au format objet|id_objet
218        foreach($parents as $p){
219                $p = explode('|',$p);
220                if (preg_match('/^[a-z0-9_]+$/i', $objet=$p[0])){ // securite
221                        $insertions[] = array('id_document'=>$id_document,'objet'=>$p[0],'id_objet'=>$p[1]);
222                        $cond[] = "(id_objet=".intval($p[1])." AND objet=".sql_quote($p[0]).")";
223                }
224        }
225        if (!$ajout){
226                // suppression des parents obsoletes
227                $cond_notin = "id_document=".intval($id_document).(count($cond)?" AND NOT(".implode(") AND NOT(",$cond).")":"");
228                #$cond_in = "id_document=".intval($id_document).(count($cond)?" AND (".implode(" OR (",$cond).")":"");
229                sql_delete("spip_documents_liens", $cond_notin);
230        }
231
232        foreach($insertions as $ins){
233                if (!sql_countsel('spip_documents_liens','id_document='.intval($ins['id_document'])." AND id_objet=".intval($ins['id_objet'])." AND objet=".sql_quote($ins['objet'])))
234                        sql_insertq('spip_documents_liens',$ins);
235        }
236}
237?>
Note: See TracBrowser for help on using the repository browser.