PageRenderTime 58ms CodeModel.GetById 9ms RepoModel.GetById 1ms app.codeStats 0ms

/_plugins_/spipBB/dev/2_1_0/formulaires/moderation_forum.php

https://bitbucket.org/pombredanne/spip-zone-treemap
PHP | 318 lines | 215 code | 42 blank | 61 comment | 43 complexity | be4af82c0e0d528d910cfe2b83a55971 MD5 | raw file
  1. <?php
  2. /***************************************************************************\
  3. * SPIP, Systeme de publication pour l'internet *
  4. * *
  5. * Copyright (c) 2001-2010 *
  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. function formulaires_moderation_forum_charger_dist(
  12. $titre, $table, $type, $script,
  13. $id_rubrique, $id_forum, $id_article, $id_breve, $id_syndic,
  14. $ajouter_mot, $ajouter_groupe, $afficher_texte, $url_param_retour) {
  15. // exiger l'authentification des posteurs pour les forums sur abo
  16. if ($type == "abo") {
  17. if (!$GLOBALS["visiteur_session"]['statut']) {
  18. return array(
  19. 'action' => '', #ne sert pas dans ce cas, on la vide pour mutualiser le cache
  20. 'editable'=>false,
  21. 'login_forum_abo'=>' ',
  22. 'inscription' => generer_url_public('identifiants', 'lang='.$GLOBALS['spip_lang']),
  23. 'oubli' => generer_url_public('spip_pass','lang='.$GLOBALS['spip_lang'],true),
  24. );
  25. }
  26. }
  27. // Tableau des valeurs servant au calcul d'une signature de securite.
  28. // Elles seront placees en Input Hidden pour que inc/forum_insert
  29. // recalcule la meme chose et verifie l'identite des resultats.
  30. // Donc ne pas changer la valeur de ce tableau entre le calcul de
  31. // la signature et la fabrication des Hidden
  32. // Faire attention aussi a 0 != ''
  33. // id_rubrique est parfois passee pour les articles, on n'en veut pas
  34. $ids = array();
  35. if ($id_rubrique > 0 AND ($id_article OR $id_breve OR $id_syndic))
  36. $id_rubrique = 0;
  37. foreach (array('id_article', 'id_breve', 'id_forum', 'id_rubrique', 'id_syndic') as $o) {
  38. $ids[$o] = ($x = intval($$o)) ? $x : '';
  39. }
  40. // ne pas mettre '', sinon le squelette n'affichera rien.
  41. $previsu = ' ';
  42. // au premier appel (pas de Post-var nommee "retour_forum")
  43. // memoriser eventuellement l'URL de retour pour y revenir apres
  44. // envoi du message ; aux appels suivants, reconduire la valeur.
  45. // Initialiser aussi l'auteur
  46. if ($retour_forum = rawurldecode(_request('retour')))
  47. $retour_forum = str_replace('&var_mode=recalcul','',$retour_forum);
  48. else {
  49. // par defaut, on veut prendre url_forum(), mais elle ne sera connue
  50. // qu'en sortie, on inscrit donc une valeur absurde ("!")
  51. $retour_forum = "!";
  52. // sauf si on a passe un parametre en argument (exemple : {#SELF})
  53. if ($url_param_retour)
  54. $retour_forum = str_replace('&amp;', '&', $url_param_retour);
  55. $retour_forum = rawurlencode($retour_forum);
  56. }
  57. if (_request('retour_forum')){
  58. $arg = forum_fichier_tmp(join('', $ids));
  59. $securiser_action = charger_fonction('securiser_action', 'inc');
  60. // on sait que cette fonction est dans le fichier associe
  61. $hash = calculer_action_auteur("ajout_forum-$arg");
  62. }
  63. // pour les hidden
  64. $script_hidden = "";
  65. foreach ($ids as $id => $v)
  66. $script_hidden .= "<input type='hidden' name='$id' value='$v' />";
  67. $script_hidden .= "<input type='hidden' name='arg' value='$arg' />";
  68. $script_hidden .= "<input type='hidden' name='hash' value='$hash' />";
  69. $script_hidden .= "<input type='hidden' name='verif_".substr($hash,0,32)."' value='ok' />";
  70. $script_hidden .= "<input type='hidden' name='afficher_texte' value='$afficher_texte' />";
  71. $script_hidden .= "<input type='hidden' name='retour_forum' value='$retour_forum' />";
  72. // l'ajout de documents est-il autorise ?
  73. // cf. verifier.php
  74. if ($formats = forum_documents_acceptes()) {
  75. include_spip('inc/securiser_action');
  76. $cle_ajouter_document = calculer_cle_action('ajouter-document-'.join('-',array_map('intval',$ids)));
  77. }
  78. return array(
  79. 'modere' => (($type != 'pri') ? '' : ' '),
  80. 'nom_site' => '',
  81. 'table' => $table,
  82. 'texte' => '',
  83. 'config' => array('afficher_barre' => ($GLOBALS['meta']['forums_afficher_barre']!='non'?' ':'')),
  84. 'titre' => str_replace('~', ' ', extraire_multi($titre)),
  85. 'action' => $script, # ce sur quoi on fait le action='...'
  86. '_hidden' => $script_hidden, # pour les variables hidden
  87. 'url_site' => "http://",
  88. 'cle_ajouter_document' => $cle_ajouter_document,
  89. 'formats_documents_forum' => $formats,
  90. 'ajouter_document' => $_FILES['ajouter_document']['name'],
  91. 'nobot' => _request('nobot'),
  92. 'ajouter_groupe' => $ajouter_groupe,
  93. 'ajouter_mot' => (is_array($ajouter_mot) ? $ajouter_mot : array($ajouter_mot)),
  94. 'id_forum' => $id_forum, // passer id_forum au formulaire pour lui permettre d'afficher a quoi l'internaute repond
  95. '_sign'=>implode('_',$ids)
  96. );
  97. }
  98. // Une securite qui nous protege contre :
  99. // - les doubles validations de forums (derapages humains ou des brouteurs)
  100. // - les abus visant a mettre des forums malgre nous sur un article (??)
  101. // On installe un fichier temporaire dans _DIR_TMP (et pas _DIR_CACHE
  102. // afin de ne pas bugguer quand on vide le cache)
  103. // Le lock est leve au moment de l'insertion en base (inc-messforum)
  104. // Ce systeme n'est pas fonctionnel pour les forums sans previsu (notamment
  105. // si $afficher_texte = 'non')
  106. // http://doc.spip.org/@forum_fichier_tmp
  107. function forum_fichier_tmp($arg)
  108. {
  109. # astuce : mt_rand pour autoriser les hits simultanes
  110. while (($alea = time() + @mt_rand()) + intval($arg)
  111. AND @file_exists($f = _DIR_TMP."forum_$alea.lck"))
  112. {};
  113. spip_touch ($f);
  114. # et maintenant on purge les locks de forums ouverts depuis > 4 h
  115. if ($dh = @opendir(_DIR_TMP))
  116. while (($file = @readdir($dh)) !== false)
  117. if (preg_match('/^forum_([0-9]+)\.lck$/', $file)
  118. AND (time()-@filemtime(_DIR_TMP.$file) > 4*3600))
  119. spip_unlink(_DIR_TMP.$file);
  120. return $alea;
  121. }
  122. function formulaires_moderation_forum_verifier_dist(
  123. $titre, $table, $type, $script,
  124. $id_rubrique, $id_forum, $id_article, $id_breve, $id_syndic,
  125. $ajouter_mot, $ajouter_groupe, $afficher_texte, $url_param_retour)
  126. {
  127. include_spip('inc/acces');
  128. include_spip('inc/texte');
  129. include_spip('inc/forum');
  130. include_spip('inc/session');
  131. include_spip('base/abstract_sql');
  132. $erreurs = array();
  133. // desactiver id_rubrique si un id_article ou autre existe dans le contexte
  134. if ($id_article OR $id_breve OR $id_forum OR $id_syndic)
  135. $id_rubrique = 0;
  136. // stocker un eventuel document dans un espace temporaire
  137. // portant la cle du formulaire ; et ses metadonnees avec
  138. if (!isset($GLOBALS['visiteur_session']['tmp_forum_document']))
  139. session_set('tmp_forum_document',
  140. sous_repertoire(_DIR_TMP,'documents_forum').md5(uniqid(rand())));
  141. $tmp = $GLOBALS['visiteur_session']['tmp_forum_document'];
  142. $doc = &$_FILES['ajouter_document'];
  143. if (isset($_FILES['ajouter_document'])
  144. AND $_FILES['ajouter_document']['tmp_name']) {
  145. // securite :
  146. // verifier si on possede la cle (ie on est autorise a poster)
  147. // (sinon tant pis) ; cf. charger.php pour la definition de la cle
  148. if (_request('cle_ajouter_document') != calculer_cle_action($a = "ajouter-document-$id_article-$id_breve-$id_forum-$id_rubrique-$id_syndic")) {
  149. $erreurs['document_forum'] = _T('public:documents_interdits_forum')
  150. . "ajouter-document-$id_article-$id_breve-$id_forum-$id_rubrique-$id_syndic"
  151. .", "
  152. ._request('cle_ajouter_document')
  153. ;
  154. unset($_FILES['ajouter_document']);
  155. } else {
  156. include_spip('inc/ajouter_documents');
  157. list($extension,$doc['name']) = fixer_extension_document($doc);
  158. $acceptes = forum_documents_acceptes();
  159. if (!in_array($extension, $acceptes)) {
  160. # normalement on n'arrive pas ici : pas d'upload si aucun format
  161. if (!$formats = join(', ',$acceptes))
  162. $formats = '-'; //_L('aucun');
  163. $erreurs['document_forum'] = _T('public:formats_acceptes', array('formats' => $formats));
  164. }
  165. else {
  166. include_spip('inc/getdocument');
  167. if (!deplacer_fichier_upload($doc['tmp_name'], $tmp.'.bin'))
  168. $erreurs['document_forum'] = _T('copie_document_impossible');
  169. # else if (...)
  170. # verifier le type_document autorise
  171. # retailler eventuellement les photos
  172. }
  173. // si ok on stocke les meta donnees, sinon on efface
  174. if (isset($erreurs['document_forum'])) {
  175. spip_unlink($tmp.'.bin');
  176. unset ($_FILES['ajouter_document']);
  177. } else {
  178. $doc['tmp_name'] = $tmp.'.bin';
  179. ecrire_fichier($tmp.'.txt', serialize($doc));
  180. }
  181. }
  182. }
  183. // restaurer le document uploade au tour precedent
  184. else if (file_exists($tmp.'.bin')) {
  185. if (_request('supprimer_document_ajoute')) {
  186. spip_unlink($tmp.'.bin');
  187. spip_unlink($tmp.'.txt');
  188. } else if (lire_fichier($tmp.'.txt', $meta))
  189. $doc = @unserialize($meta);
  190. }
  191. if (strlen($texte = _request('texte')) < 10
  192. AND !$ajouter_mot AND $GLOBALS['meta']['forums_texte'] == 'oui')
  193. $erreurs['texte'] = _T('forum_attention_dix_caracteres');
  194. else if (defined('_FORUM_LONGUEUR_MAXI')
  195. AND _FORUM_LONGUEUR_MAXI > 0
  196. AND strlen($texte) > _FORUM_LONGUEUR_MAXI)
  197. $erreurs['texte'] = _T('forum_attention_trop_caracteres',
  198. array(
  199. 'compte' => strlen($texte),
  200. 'max' => _FORUM_LONGUEUR_MAXI
  201. ));
  202. if (strlen($titre=_request('titre')) < 3
  203. AND $GLOBALS['meta']['forums_titre'] == 'oui')
  204. $erreurs['titre'] = _T('forum_attention_trois_caracteres');
  205. if (!count($erreurs) AND !_request('confirmer_previsu_forum')){
  206. if ($afficher_texte != 'non') {
  207. $previsu = inclure_previsu($texte, $titre, _request('url_site'), _request('nom_site'), _request('ajouter_mot'), $doc,
  208. $id_rubrique, $id_forum, $id_article, $id_breve, $id_syndic);
  209. $erreurs['previsu'] = $previsu;
  210. }
  211. }
  212. return $erreurs;
  213. }
  214. function forum_documents_acceptes()
  215. {
  216. $formats = trim($GLOBALS['meta']['formats_documents_forum']);
  217. if (!$formats) return array();
  218. if ($formats !== '*')
  219. $formats = array_filter(preg_split(',[^a-zA-Z0-9/+_],', $formats));
  220. else {
  221. include_spip('base/typedoc');
  222. $formats = array_keys($GLOBALS['tables_mime']);
  223. }
  224. sort($formats);
  225. return $formats;
  226. }
  227. // http://doc.spip.org/@inclure_previsu
  228. function inclure_previsu($texte,$titre, $url_site, $nom_site, $ajouter_mot, $doc,
  229. $id_rubrique, $id_forum, $id_article, $id_breve, $id_syndic) {
  230. global $table_des_traitements;
  231. $bouton = _T('forum_message_definitif');
  232. include_spip('public/assembler');
  233. include_spip('public/composer');
  234. // appliquer les traitements de #TEXTE a la previsu
  235. // comme on voit c'est complique... y a peut-etre plus simple ?
  236. // recuperer les filtres eventuels de 'mes_fonctions.php' sur les balises
  237. include_spip('public/parametrer');
  238. $evaltexte = isset($table_des_traitements['TEXTE']['forums'])
  239. ? $table_des_traitements['TEXTE']['forums']
  240. : $table_des_traitements['TEXTE'][0];
  241. $evaltexte = '$tmptexte = '.str_replace('%s', '$texte', $evaltexte).';';
  242. // evaluer...
  243. eval($evaltexte);
  244. // supprimer les <form> de la previsualisation
  245. // (sinon on ne peut pas faire <cadre>...</cadre> dans les forums)
  246. return preg_replace("@<(/?)form\b@ism",
  247. '<\1div',
  248. inclure_balise_dynamique(array('formulaires/inc-forum_previsu',
  249. 0,
  250. array(
  251. 'titre' => safehtml(typo($titre)),
  252. 'texte' => $tmptexte,
  253. 'notes' => safehtml(calculer_notes()),
  254. 'url_site' => vider_url($url_site),
  255. 'nom_site' => safehtml(typo($nom_site)),
  256. 'ajouter_mot' => (is_array($ajouter_mot) ? $ajouter_mot : array($ajouter_mot)),
  257. 'ajouter_document' => $doc,
  258. 'erreur' => $erreur,
  259. 'bouton' => $bouton,
  260. 'id_rubrique' => $id_rubrique,
  261. 'id_forum' => $id_forum,
  262. 'id_article' => $id_article,
  263. 'id_breve' => $id_breve,
  264. 'id_syndic' => $id_syndic
  265. )
  266. ), false));
  267. }
  268. function formulaires_moderation_forum_traiter_dist() {
  269. // le formulaire forum n'est jamais traite en ajax car il s'acheve par une redirection vers
  270. // la bonne page qui doit etre reaffichee dans son ensemble
  271. refuser_traiter_formulaire_ajax();
  272. $forum_insert = charger_fonction('forum_insert', 'inc');
  273. list($redirect,$id_forum) = $forum_insert();
  274. return array('redirect'=>$redirect,'id_forum'=>$id_forum);
  275. }
  276. ?>