Mercurial > defr > DualBlog
view admin_xml.php @ 59:caef2b6e5690
Necessaire pour IE ! Le tag est sinon vide et se retrouve compacté
J'avais modifie ca pour rendre le validateur HTML5 content, mais, ce n'est
pas vraiment une bonne idee, car sinon le parser XML voit un tag vide,
et par consequent lorsqu'il prepare la sortie, il produit un <script />
qu'IE est incapable de gerer correctement.
author | Franck Deroche <webmaster@defr.org> |
---|---|
date | Tue, 19 Feb 2008 02:54:58 -0800 |
parents | 629389204276 |
children |
line wrap: on
line source
<?php require("classes.php"); $Req = new Requete(); $Data = new DataAccess; header("Content-Type: application/xml; charset=utf-8"); $doc = new DOMDocument('1.0', 'utf-8'); $root = $doc->createElementNS('http://defr.org/2005/blog-post', 'post'); $doc->appendChild($root); $mode = $Req->get('mode', 'GET', 'get'); $type = $Req->get('type', 'GET', 'post'); $id = $Req->get('id'); $root->appendChild($doc->createElement('id', $id)); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'debug', var_export($Req, true))); switch($mode . '-' . $type) { case 'edit-post': $nvTitre = $Req->get('title'); $nvContenu = $Req->get('content'); $nvMood = $Req->get('mood'); $Data->Query (" UPDATE Mess SET Titre='{$nvTitre}', Message='{$nvContenu}', Emot='{$nvMood}' WHERE num_mess={$id} "); // Récuperation des nouveaux tags à appliquer $arTags = TextUtils::splitTags($Req->get('tags')); // Récuperation des anciens tags $Data->Query (" SELECT T.idTag, T.Tag FROM Lien_Tags_Posts L LEFT JOIN Tags T ON L.idTag = T.idTag WHERE L.idMess = {$id} "); $oldTags = array(); while(0 !== ($row = $Data->GetRow())) { $oldTags[] = $row['Tag']; $mapOld[$row['Tag']] = $row['idTag']; } // Calcul des différences $tagsSupprimes = array_diff($oldTags, $arTags); $tagsAjoutes = array_diff($arTags, $oldTags); // Suppression des tags non affectés if(is_array($tagsSupprimes)) { foreach($tagsSupprimes as $tagSuppr) { $supprIDs .= $mapOld[$tagSuppr] . ','; } $Data->Query (" DELETE FROM Lien_Tags_Posts WHERE idMess={$id} AND idTag IN ({$supprIDs}0) "); } // Ajout des tags ajoutés if(is_array($tagsAjoutes)) { foreach($tagsAjoutes as $tagAj) { $n = $Data->Query("SELECT idTag FROM Tags WHERE Tag='{$tagAj}'"); if($n == 0) { // Si le tag n'existe pas, on le crée $Data->Query("INSERT INTO Tags SET Tag='{$tagAj}'"); $Data->Query("SELECT idTag FROM Tags WHERE Tag='{$tagAj}'"); } $row = $Data->GetRow(); $Data->Query (" INSERT INTO Lien_Tags_Posts SET idMess={$id}, idTag={$row['idTag']} "); } } case 'get-post': $Data->Query (" SELECT Titre, Message, Emot FROM Mess WHERE num_mess={$id} "); $row = $Data->GetRow(); $titre_CDATA = $doc->createCDATASection($row['Titre']); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'titre', $row['Titre'])); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'contenu', $row['Message'])); $root->appendChild($doc->createElement('mood', $row['Emot'])); // Obtention des tags $Data->Query (" SELECT T.idTag, T.Tag FROM Lien_Tags_Posts L LEFT JOIN Tags T ON L.idTag = T.idTag WHERE L.idMess = {$id} "); while(0 !== ($row = $Data->GetRow())) $root->appendChild($doc->createElement('tag', $row['Tag'])); break; case 'edit-brouillon': $nvTitre = $Req->get('title'); $nvContenu = $Req->get('content'); $Data->Query (" UPDATE Brouillons SET Titre='{$nvTitre}', Contenu='{$nvContenu}' WHERE id_brouillon={$id} "); case 'get-brouillon': $Data->Query (" SELECT Titre, Contenu FROM Brouillons WHERE id_brouillon={$id} "); $row = $Data->GetRow(); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'titre', $row['Titre'])); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'contenu', $row['Contenu'])); break; } echo $doc->saveXML(); ?>