9d75ace8c84bf66090ff6ae62fe163344eee6535
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
6 * Copyright (c) 2001-2016 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
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 \***************************************************************************/
13 if (!defined('_ECRIRE_INC_VERSION')) {
19 * Action editer_document
24 function action_editer_document_dist($arg = null) {
27 $securiser_action = charger_fonction('securiser_action', 'inc');
28 $arg = $securiser_action();
31 // Envoi depuis le formulaire de creation d'un document
32 if (!$id_document = intval($arg)) {
33 $id_document = document_inserer();
40 $err = document_modifier($id_document);
42 return array($id_document, $err);
46 * Creer un nouveau document
48 * @param int $id_parent
49 * inutilise, pas de parent pour les documents
50 * @param array|null $set
53 function document_inserer($id_parent = null, $set = null) {
61 $champs = array_merge($champs, $set);
64 // Envoyer aux plugins
69 'table' => 'spip_documents',
74 $id_document = sql_insertq('spip_documents', $champs);
79 'table' => 'spip_documents',
80 'id_objet' => $id_document
91 * Enregistre une revision de document.
92 * $set est un contenu (par defaut on prend le contenu via _request())
94 * @param int $id_document
95 * @param array|null $set
98 function document_modifier($id_document, $set = null) {
100 include_spip('inc/modifier');
101 include_spip('inc/filtres');
104 $champs = collecter_requests(
106 objet_info('document', 'champs_editables'),
108 array('parents', 'ajout_parents'),
109 // donnees eventuellement fournies
117 // Si le document est publie, invalider les caches et demander sa reindexation
118 $t = sql_getfetsel('statut', 'spip_documents', 'id_document=' . intval($id_document));
119 if ($t == 'publie') {
120 $invalideur = "id='id_document/$id_document'";
124 $ancien_fichier = '';
125 // si le fichier est modifie, noter le nom de l'ancien pour faire le menage
126 if (isset($champs['fichier'])) {
127 $ancien_fichier = sql_getfetsel('fichier', 'spip_documents', 'id_document=' . intval($id_document));
130 if ($err = objet_modifier_champs(
135 'invalideur' => $invalideur,
136 'indexation' => $indexation
143 // nettoyer l'ancien fichier si necessaire
144 if (isset($champs['fichier']) // un plugin a pu interdire la modif du fichier en virant le champ
145 and $champs['fichier']
146 and $ancien_fichier // on avait bien note le nom du fichier avant la modif
147 and $ancien_fichier !== $champs['fichier'] // et il a ete modifie
148 and !tester_url_absolue($ancien_fichier)
149 and @file_exists
($f = get_spip_doc($ancien_fichier))
154 // Changer le statut du document ?
155 // le statut n'est jamais fixe manuellement mais decoule de celui des objets lies
156 $champs = collecter_requests(array('parents', 'ajouts_parents'), array(), $set);
157 if (document_instituer($id_document, $champs)) {
159 // Post-modifications
162 // Invalider les caches
163 include_spip('inc/invalideur');
164 suivre_invalideur("id='id_document/$id_document'");
170 * determiner le statut d'un document : prepa/publie
171 * si on trouve un element joint sans champ statut ou avec un statut='publie' alors le doc est publie aussi
173 * @param int $id_document
174 * @param array $champs
177 function document_instituer($id_document, $champs = array()) {
179 $statut = isset($champs['statut']) ?
$champs['statut'] : null;
180 $date_publication = isset($champs['date_publication']) ?
$champs['date_publication'] : null;
181 if (isset($champs['parents'])) {
182 medias_revision_document_parents($id_document, $champs['parents']);
184 if (isset($champs['ajout_parents'])) {
185 medias_revision_document_parents($id_document, $champs['ajout_parents'], true);
188 $row = sql_fetsel('statut,date_publication', 'spip_documents', 'id_document='.intval($id_document));
189 $statut_ancien = $row['statut'];
190 $date_publication_ancienne = $row['date_publication'];
192 /* Autodetermination du statut si non fourni */
193 if (is_null($statut)) {
196 $trouver_table = charger_fonction('trouver_table', 'base');
199 'spip_documents_liens',
200 "objet!='document' AND id_document=" . intval($id_document)
202 // On aura 19 jours 3h14 et 7 secondes pour corriger en 2038 (limitation de la représentation POSIX du temps sur les 32 bits)
203 $date_publication = strtotime('2038-01-01 00:00:00');
204 include_spip('base/objets');
205 while ($row = sql_fetch($res)) {
207 // cas particulier des rubriques qui sont publiees des qu'elles contiennent un document !
208 $row['objet'] == 'rubrique'
209 // ou si objet publie selon sa declaration
210 or objet_test_si_publie($row['objet'], $row['id_objet'])
213 $date_publication = 0;
215 } // si pas publie, et article, il faut checker la date de post-publi eventuelle
216 elseif ($row['objet'] == 'article'
217 and $row2 = sql_fetsel(
220 'id_article=' . intval($row['id_objet']) . " AND statut='publie'"
224 $date_publication = min($date_publication, strtotime($row2['date']));
227 $date_publication = date('Y-m-d H:i:s', $date_publication);
228 if ($statut == 'publie' and $statut_ancien == 'publie' and $date_publication == $date_publication_ancienne) {
231 if ($statut != 'publie' and $statut_ancien != 'publie' and $statut_ancien != '0') {
235 if ($statut !== $statut_ancien
236 or $date_publication != $date_publication_ancienne
240 array('statut' => $statut, 'date_publication' => $date_publication),
241 'id_document=' . intval($id_document)
243 if ($statut !== $statut_ancien) {
244 $publier_rubriques = sql_allfetsel(
246 'spip_documents_liens',
247 "objet='rubrique' AND id_document=" . intval($id_document)
249 if (count($publier_rubriques)) {
250 include_spip('inc/rubriques');
251 foreach ($publier_rubriques as $r) {
252 calculer_rubriques_if($r['id_objet'], array('statut' => $statut), $statut_ancien, false);
263 * Revision des parents d'un document
264 * chaque parent est liste au format objet|id_objet
266 * @param int $id_document
267 * @param array $parents
270 function medias_revision_document_parents($id_document, $parents = null, $ajout = false) {
271 include_spip('inc/autoriser');
273 if (!is_array($parents)) {
277 $insertions = array();
278 $objets_parents = array(); // array('article'=>array(12,23))
280 // au format objet|id_objet
281 foreach ($parents as $p) {
282 $p = explode('|', $p);
283 if (preg_match('/^[a-z0-9_]+$/i', $objet = $p[0])
284 and $p[1] = intval($p[1])
286 $objets_parents[$p[0]][] = $p[1];
290 include_spip('action/editer_liens');
292 $liens = objet_trouver_liens(array('document' => $id_document), '*');
293 $deja_parents = array();
294 // si ce n'est pas un ajout, il faut supprimer les liens actuels qui ne sont pas dans $objets_parents
296 foreach ($liens as $k => $lien) {
297 if (!isset($objets_parents[$lien['objet']]) or !in_array($lien['id_objet'], $objets_parents[$lien['objet']])) {
298 if (autoriser('dissocierdocuments', $lien['objet'], $lien['id_objet'])) {
299 objet_dissocier(array('document' => $id_document), array($lien['objet'] => $lien['id_objet']));
303 $deja_parents[$lien['objet']][] = $lien['id_objet'];
308 // 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
309 foreach ($objets_parents as $objet => $ids) {
310 foreach ($ids as $k => $id) {
312 isset($deja_parents[$objet])
313 and in_array($id, $deja_parents[$objet])
315 or !autoriser('associerdocuments', $objet, $id)
317 unset($objets_parents[$objet][$k]);
321 objet_associer(array('document' => $id_document), $objets_parents);
325 // Fonctions Dépréciées
326 // --------------------
329 * Insertion d'un document
331 * @deprecated Utiliser document_inserer()
332 * @see document_inserer()
333 * @return int Identifiant du nouveau document
335 function insert_document() {
336 return document_inserer();
340 * Modification d'un document
342 * @deprecated Utiliser document_modifier()
343 * @see document_modifier()
344 * @param int $id_document Identifiant du document
345 * @param array|bool $set
347 function document_set($id_document, $set = false) {
348 return document_modifier($id_document, $set);
352 * Insituer un document
354 * @deprecated Utiliser document_instituer()
355 * @see document_instituer()
356 * @param int $id_document Identifiant du document
357 * @param array $champs
359 function instituer_document($id_document, $champs = array()) {
360 return document_instituer($id_document, $champs);
364 * Réviser un document
366 * @deprecated Utiliser document_modifier()
367 * @see document_modifier()
368 * @param int $id_document Identifiant du document
371 function revision_document($id_document, $c = false) {
372 return document_modifier($id_document, $c);