source: spip-zone/_plugins_/mediatheque/action/editer_document.php @ 48093

Last change on this file since 48093 was 48093, checked in by rastapopoulos@…, 10 years ago

Pouvoir appeler des actions depuis n'importe où en passant l'argument explicitement.

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