annotate comment.php @ 32:4cea8b128fdd

Possibilité de choisir des templates différents en fonction du type de sortie. Le fichier templates.conf permet d'associer à chaque type de sortie (correspondant à une section du fichier INI) des templates pour le squelette, les posts et les commentaires. Il est possible de définir virtuellement une infinité de type de sorties différents, pour le moment seul de quoi obtenir un flux Atom a été ajouté. Pour changer le type de sortie, il faut passer en GET au script appellant un paramètre outputType. Si le paramètre reçu ne correspondant à aucun des types de sorties définis dans templates.conf, alors on prend du xhtml par défaut.
author Franck Deroche <webmaster@defr.org>
date Mon, 05 Nov 2007 09:06:46 +0100
parents 2d98421d43da
children c6508503269a
rev   line source
webmaster@0 1 <?php
webmaster@16 2 require_once("classes.php");
webmaster@16 3 $sk = Factory::getSkeleton();
webmaster@0 4 $id = $_GET['id'];
webmaster@16 5 $Data = Factory::getDB();
webmaster@0 6 $Req = new Requete;
webmaster@16 7
webmaster@16 8
webmaster@16 9 // Enregistrement éventuel d'un commentaire dans la base de données
webmaster@0 10 $Auteur=$Req->get('Auteur');
webmaster@0 11 $Adresse=$Req->get('Adresse');
webmaster@0 12 $AdresseMail = $Req->get('AdresseMail');
webmaster@0 13 $Comment=$Req->get('Comment');
webmaster@0 14 $DateComment=gmdate("Y-m-d H:i:s", time() + 3600*2);
webmaster@24 15
webmaster@24 16 // Si on essaie d'ajouter un commentaire et que la graine n'est pas bonne
webmaster@24 17 if(!empty($Comment) && $_SESSION['commentSeed'] != $Req->get('seed'))
webmaster@24 18 die("L'ajout de commentaire doit se faire à partir du formulaire de ce blog");
webmaster@24 19
webmaster@0 20 if(!is_null($Auteur) && $Auteur!='Votre Nom' && $Auteur != $Adresse && !empty($Comment)) {
webmaster@0 21 // Prévention d'un "cassage" par ajout d'un commentaire incorrectement formaté
webmaster@0 22 $ip = $_SERVER['REMOTE_ADDR'];
webmaster@0 23 $Auteur = str_replace(array('<', '>'), array('&lt;', '&gt;'), $Auteur);
webmaster@0 24 if(DOMDocument::loadXML('<comment>' . $Comment . '</comment>')) {
webmaster@0 25 $Data->debugQuery("
webmaster@0 26 INSERT INTO Commentaires(MessId, Auteur, Adresse, AdresseMail, Comment, DateComment, ip)
webmaster@0 27 VALUES({$id}, '{$Auteur}', '{$Adresse}', '{$AdresseMail}', '{$Comment}', '{$DateComment}', '{$ip}')
webmaster@0 28 ");
webmaster@0 29 $Data->Query("UPDATE Mess SET NbCommentaires=NbCommentaires+1 WHERE num_mess={$id}");
webmaster@0 30 mail('webmaster+blogcomment@defr.org', 'Nouveau commentaire sur de ' . $Auteur, $Auteur . " vient de mettre en ligne le commentaire suivant: \n" . wordwrap($Comment, 70));
webmaster@0 31 }
webmaster@0 32 else {
webmaster@0 33 $infos = 'Votre commentaire doit etre fait de XML valide pour apparaitre.';
webmaster@0 34 }
webmaster@0 35 }
webmaster@0 36
webmaster@16 37 // Ajout du post au squelette
webmaster@0 38 $Data->Query("SELECT * FROM Mess WHERE num_mess = {$id}");
webmaster@0 39 $row = $Data->GetRow();
webmaster@16 40 $post = new Post($row);
webmaster@16 41 $sk->addBlogPost($post->format());
webmaster@16 42
webmaster@22 43 // On définit le titre
webmaster@22 44 $sk->setTitle($row['Titre'] . ' - Dual Blog');
webmaster@22 45
webmaster@16 46 // Récupération des commentaires
webmaster@1 47 $Data->Query("SELECT * FROM Commentaires Where MessId={$id} AND Visible=1 ORDER BY num_comm");
webmaster@0 48 $defaultGravatar = urlencode("http://defr.org/Misc/NoGravatar.png");
webmaster@0 49 while(0 !== ($row = $Data->GetRow())) {
webmaster@32 50 $commentTpl = new Template(Skeleton::getTemplateFile('comment'));
webmaster@16 51 $dateFormatee = strftime(" à %Hh%M le <span class='Date'>%A %d %B %Y</span>", strtotime($row['DateComment']));
webmaster@16 52 $AdresseMail = $row['AdresseMail'];
webmaster@16 53 $grav_id = md5($AdresseMail);
webmaster@23 54 $grav_url = 'http://www.gravatar.com/avatar.php?gravatar_id=' . $grav_id . '&size=50&default=' . $defaultGravatar;
webmaster@16 55 $Comment = nl2br($row['Comment']);
webmaster@16 56 $Comment = str_replace(" & ", " &amp; ", $Comment);
webmaster@16 57 $commentFrag = $commentTpl->getDocumentFragment();
webmaster@16 58 $commentFrag->appendXML($Comment);
webmaster@16 59 $params = array(
webmaster@16 60 '#gravatar@src' => $grav_url,
webmaster@30 61 '#auteur@href' => $post->getURL() . '#c' . $row['num_comm'],
webmaster@16 62 '#auteur@name' => 'c' . $row['num_comm'],
webmaster@16 63 '#auteur' => $row['Auteur'],
webmaster@16 64 'commentDate' => $dateFormatee,
webmaster@32 65 'commentNumber' => $row['num_comm'],
webmaster@16 66 'comment' => $commentFrag,
webmaster@16 67 );
webmaster@16 68 if(stristr($row['Adresse'], 'http://')) {
webmaster@16 69 $params['#auteur@href'] = $row['Adresse'];
webmaster@16 70 }
webmaster@32 71 $commentTpl->setParams(array_merge($post->getTplParams(), $params));
webmaster@16 72 $sk->addBlogPost($commentTpl);
webmaster@0 73 }
webmaster@16 74
webmaster@24 75 // Génération de la graine (cette dernière permet de s'assurer
webmaster@24 76 // que l'essai d'ajout de commentaire provient bien de ce
webmaster@24 77 // formulaire, et en conséquence devrait permettre de réduire
webmaster@24 78 // le spam.
webmaster@24 79 $seed = md5(time() . 'DualBlog');
webmaster@24 80 $_SESSION['commentSeed'] = $seed;
webmaster@24 81
webmaster@24 82 // Ajout du formulaire d'enregistrement de commentaires
webmaster@16 83 $commentForm = new Template('commentForm.xml');
webmaster@24 84 $commentForm->setParams(array('#Seed@value' => $seed));
webmaster@31 85 $sk->setParams(array('commentForm' => $commentForm));
webmaster@16 86
webmaster@16 87 echo $sk;
webmaster@0 88 ?>