[SPIP] ~v3.0.20-->v3.0.25
[lhc/web/clavette_www.git] / www / plugins-dist / medias / action / editer_document.php
1 <?php
2
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
5 * *
6 * Copyright (c) 2001-2016 *
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
13 if (!defined("_ECRIRE_INC_VERSION")) return;
14
15
16 /**
17 * Action editer_document
18 *
19 * @param int $arg
20 * @return array
21 */
22 function action_editer_document_dist($arg=null) {
23
24 if (is_null($arg)){
25 $securiser_action = charger_fonction('securiser_action', 'inc');
26 $arg = $securiser_action();
27 }
28
29 // Envoi depuis le formulaire de creation d'un document
30 if (!$id_document = intval($arg)) {
31 $id_document = document_inserer();
32 }
33
34 if (!$id_document)
35 return array(0,''); // erreur
36
37 $err = document_modifier($id_document);
38
39 return array($id_document,$err);
40 }
41
42 /**
43 * Creer un nouveau document
44 *
45 * @return int
46 */
47 function document_inserer() {
48
49 $champs = array(
50 'statut' => 'prop',
51 'date' => 'NOW()',
52 );
53
54 // Envoyer aux plugins
55 $champs = pipeline('pre_insertion',
56 array(
57 'args' => array(
58 'table' => 'spip_documents',
59 ),
60 'data' => $champs
61 )
62 );
63 $id_document = sql_insertq("spip_documents", $champs);
64 pipeline('post_insertion',
65 array(
66 'args' => array(
67 'table' => 'spip_documents',
68 'id_objet' => $id_document
69 ),
70 'data' => $champs
71 )
72 );
73
74 return $id_document;
75 }
76
77
78 /**
79 * Enregistre une revision de document.
80 * $set est un contenu (par defaut on prend le contenu via _request())
81 *
82 * @param int $id_document
83 * @param array|bool $set
84 */
85 function document_modifier($id_document, $set=false) {
86
87 include_spip('inc/modifier');
88 include_spip('inc/filtres');
89
90 // champs normaux
91 $champs = collecter_requests(
92 // white list
93 objet_info('document','champs_editables'),
94 // black list
95 array('parents', 'ajout_parents'),
96 // donnees eventuellement fournies
97 $set
98 );
99
100
101 $invalideur = "";
102 $indexation = false;
103
104 // Si le document est publie, invalider les caches et demander sa reindexation
105 $t = sql_getfetsel("statut", "spip_documents", 'id_document='.intval($id_document));
106 if ($t == 'publie') {
107 $invalideur = "id='id_document/$id_document'";
108 $indexation = true;
109 }
110
111 $ancien_fichier = "";
112 // si le fichier est modifie, noter le nom de l'ancien pour faire le menage
113 if (isset($champs['fichier'])){
114 $ancien_fichier = sql_getfetsel('fichier','spip_documents','id_document='.intval($id_document));
115 }
116
117 if ($err = objet_modifier_champs('document', $id_document,
118 array(
119 'invalideur' => $invalideur,
120 'indexation' => $indexation
121 ),
122 $champs))
123 return $err;
124
125 // nettoyer l'ancien fichier si necessaire
126 if ($champs['fichier'] // un plugin a pu interdire la modif du fichier en virant le champ
127 AND $ancien_fichier // on avait bien note le nom du fichier avant la modif
128 AND $ancien_fichier!==$champs['fichier'] // et il a ete modifie
129 AND !tester_url_absolue($ancien_fichier)
130 AND @file_exists($f = get_spip_doc($ancien_fichier)))
131 spip_unlink($f);
132
133 // Changer le statut du document ?
134 // le statut n'est jamais fixe manuellement mais decoule de celui des objets lies
135 $champs = collecter_requests(array('parents','ajouts_parents'),array(),$set);
136 if(document_instituer($id_document,$champs)) {
137
138 //
139 // Post-modifications
140 //
141
142 // Invalider les caches
143 include_spip('inc/invalideur');
144 suivre_invalideur("id='id_document/$id_document'");
145 }
146
147 }
148
149
150 /**
151 * determiner le statut d'un document : prepa/publie
152 * si on trouve un element joint sans champ statut ou avec un statut='publie' alors le doc est publie aussi
153 *
154 * @param int $id_document
155 * @param array $champs
156 * @return bool
157 */
158 function document_instituer($id_document,$champs=array()){
159
160 $statut=isset($champs['statut'])?$champs['statut']:null;
161 $date_publication = isset($champs['date_publication'])?$champs['date_publication']:null;
162 if (isset($champs['parents']))
163 medias_revision_document_parents($id_document,$champs['parents']);
164 if (isset($champs['ajout_parents']))
165 medias_revision_document_parents($id_document,$champs['ajout_parents'],true);
166
167 $row = sql_fetsel("statut,date_publication", "spip_documents", "id_document=$id_document");
168 $statut_ancien = $row['statut'];
169 $date_publication_ancienne = $row['date_publication'];
170
171 /* Autodetermination du statut si non fourni */
172 if (is_null($statut)){
173 $statut = 'prepa';
174
175 $trouver_table = charger_fonction('trouver_table','base');
176 $res = sql_select('id_objet,objet','spip_documents_liens',"objet!='document' AND id_document=".intval($id_document));
177 // dans 10 ans, ca nous fera un bug a corriger vers 2018
178 // penser a ouvrir un ticket d'ici la :p
179 $date_publication=time()+10*365*24*3600;
180 include_spip('base/objets');
181 while($row = sql_fetch($res)){
182 if (
183 // cas particulier des rubriques qui sont publiees des qu'elles contiennent un document !
184 $row['objet']=='rubrique'
185 // ou si objet publie selon sa declaration
186 OR objet_test_si_publie($row['objet'],$row['id_objet'])){
187 $statut = 'publie';
188 $date_publication=0;
189 continue;
190 }
191 // si pas publie, et article, il faut checker la date de post-publi eventuelle
192 elseif ($row['objet']=='article'
193 AND $row2 = sql_fetsel('date','spip_articles','id_article='.intval($row['id_objet'])." AND statut='publie'")){
194 $statut = 'publie';
195 $date_publication = min($date_publication,strtotime($row2['date']));
196 }
197 }
198 $date_publication = date('Y-m-d H:i:s',$date_publication);
199 if ($statut=='publie' AND $statut_ancien=='publie' AND $date_publication==$date_publication_ancienne)
200 return false;
201 if ($statut!='publie' AND $statut_ancien!='publie' AND $statut_ancien!='0')
202 return false;
203 }
204 if ($statut!==$statut_ancien
205 OR $date_publication!=$date_publication_ancienne){
206 sql_updateq('spip_documents',array('statut'=>$statut,'date_publication'=>$date_publication),'id_document='.intval($id_document));
207 if ($statut!==$statut_ancien){
208 $publier_rubriques = sql_allfetsel('id_objet','spip_documents_liens',"objet='rubrique' AND id_document=".intval($id_document));
209 if (count($publier_rubriques)){
210 include_spip('inc/rubriques');
211 foreach($publier_rubriques as $r)
212 calculer_rubriques_if($r['id_objet'],array('statut'=>$statut),$statut_ancien,false);
213 }
214 }
215 return true;
216 }
217 return false;
218 }
219
220
221 /**
222 * Revision des parents d'un document
223 * chaque parent est liste au format objet|id_objet
224 *
225 * @param int $id_document
226 * @param array $parents
227 * @param bool $ajout
228 */
229 function medias_revision_document_parents($id_document, $parents=null, $ajout=false){
230 if (!is_array($parents))
231 return;
232
233 $insertions = array();
234 $objets_parents = array(); // array('article'=>array(12,23))
235
236 // au format objet|id_objet
237 foreach($parents as $p){
238 $p = explode('|',$p);
239 if (preg_match('/^[a-z0-9_]+$/i', $objet=$p[0])
240 AND $p[1]=intval($p[1])){ // securite
241 $objets_parents[$p[0]][] = $p[1];
242 }
243 }
244
245 include_spip('action/editer_liens');
246 // les liens actuels
247 $liens = objet_trouver_liens(array('document'=>$id_document),'*');
248 $deja_parents = array();
249 // si ce n'est pas un ajout, il faut supprimer les liens actuels qui ne sont pas dans $objets_parents
250 if (!$ajout){
251 foreach($liens as $k=>$lien)
252 if (!isset($objets_parents[$lien['objet']]) OR !in_array($lien['id_objet'],$objets_parents[$lien['objet']])) {
253 if (autoriser('dissocierdocuments',$lien['objet'],$lien['id_objet'])){
254 objet_dissocier(array('document'=>$id_document),array($lien['objet']=>$lien['id_objet']));
255 }
256 unset($liens[$k]);
257 }
258 else $deja_parents[$lien['objet']][] = $lien['id_objet'];
259 }
260
261 // trier les objets à traiter : ne pas prendre en compte ceux qui sont déjà associés ou qu'on n'a pas le droit d'associer
262 foreach ($objets_parents as $objet => $ids) {
263 foreach ($ids as $k => $id) {
264 if ((
265 isset($deja_parents[$objet])
266 and in_array($id, $deja_parents[$objet])
267 )
268 or !autoriser('associerdocuments', $objet, $id)
269 ) {
270 unset($objets_parents[$objet][$k]);
271 }
272 }
273 }
274 objet_associer(array('document'=>$id_document),$objets_parents);
275
276 }
277
278
279 // obsoletes
280 function insert_document() {
281 return document_inserer();
282 }
283 function document_set($id_document, $set=false) {
284 return document_modifier($id_document, $set);
285 }
286 function instituer_document($id_document,$champs=array()){
287 return document_instituer($id_document,$champs);
288 }
289 function revision_document($id_document, $c=false) {
290 return document_modifier($id_document,$c);
291 }
292
293 ?>