editer_document.php 8.4 KB

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