view admin.php @ 72:217f56e6bc77

Si on arrive pas à vérifier le commentaire via Akismet, on l'affichera Le comportement précédent n'était pas réellement défini pour le cas ou l'authentification auprès d'Akismet ne se fait pas correctement, c'est maintenant réparé.
author Franck Deroche <webmaster@defr.org>
date Thu, 20 Mar 2008 19:47:11 +0100
parents d67a65183100
children d9490757a111
line wrap: on
line source
<?php
 if(!is_null($_SERVER['HTTP_ACCEPT']) && stristr($_SERVER['HTTP_ACCEPT'], 'application/xhtml+xml'))
  header('Content-Type: application/xhtml+xml; charset=UTF-8');
 else
  header('Content-Type: text/html; charset=UTF-8');

 include("classes.php");
 $Data=new DataAccess;
 $Req = new Requete;
 
 $mode = $Req->get('mode');
 switch($mode) {
	case 'nvBrouillon':
	$nvTitre = $Req->get('Titre', 'POST');
	$nvContenu = $Req->get('Contenu', 'POST');
	$Data->debugQuery("INSERT INTO Brouillons SET Titre='{$nvTitre}', Contenu='{$nvContenu}'");
	break;
	
	case 'nvTache':
	$nvThing = $Req->get('Tache');
	$Data->Query("INSERT INTO ToDo SET Thing='{$nvThing}'");
	break;
	
	case 'nvPost':
	 $id = $Req->get('id', 'POST');
	 $versionAc = $Req->get('versionAc', 'POST');
	 $newVersion = $Req->get('newVersion', 'POST');
	 $mood = $Req->get('mood', 'POST');
	 $tbAddress = $Req->get('tb', 'POST');
	 if($versionAc == 'Version 10' && $newVersion != 'Nouvelle version ?' && !empty($newVersion))
		$version = $newVersion;
	 else
		$version = $versionAc;
	 $Data->Query("SELECT * FROM Brouillons WHERE id_brouillon={$id}");
	 $row = $Data->GetRow();
	 $row['Titre'] = addslashes($row['Titre']);
	 $row['Contenu'] = addslashes($row['Contenu']);
	 $datePost = gmdate("Y-m-d H:i:s", time() + 3600);
	 $Data->Query("
	  INSERT INTO Mess(Titre, DatePost, num_version, Message, Emot) 
	  VALUES('{$row['Titre']}', '{$datePost}', '{$version}', '{$row['Contenu']}', '{$mood}')");
	 $Data->Query("DELETE FROM Brouillons WHERE id_brouillon={$id}");
	 $Data->Query("SELECT num_mess, Message FROM Mess ORDER BY num_mess DESC LIMIT 0, 1");
	 $id_row = $Data->GetRow();
	 // Gestion des tags
	 $arTags = TextUtils::SplitTags($Req->get('Tags'));
	 foreach($arTags 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_tag = $Data->GetRow();
	    $Data->Query
	    ("
		INSERT INTO Lien_Tags_Posts 
		SET idMess={$id_row['num_mess']}, idTag={$row_tag['idTag']}
	    ");
	 }
	 // Génération de trackbacks
	 if(!empty($tbAddress) && substr($tbAddress, 0, 4)=='http') {
		$ar_tbAddress = parse_url($tbAddress);
		if(!array_key_exists('port', $ar_tbAddress)) $ar_tbAddress['port'] = 80;
		if(!array_key_exists('path', $ar_tbAddress)) $ar_tbAddress['path'] = '/';
		if(array_key_exists('query', $ar_tbAddress)) $ar_tbAddress['query'] = '?' . $ar_tbAddress['query'];
		$fp = fsockopen($ar_tbAddress['host'], $ar_tbAddress['port'], $errno, $errstr, 15);
		if($fp) {
			$genToSend = "POST {$ar_tbAddress['path']}{$ar_tbAddress['query']} HTTP/1.0\r\n";
			$genToSend .= "Host: {$ar_tbAddress['host']}\r\n";
			$genToSend .= "Content-Type: application/x-www-form-urlencoded \n";
			
			// Essai de récuperation de l'encodage...Envoie en iso si pas d'indication d'UTF...
			$argToSend = "__info=1";
			$toSend = $genToSend . "Content-Length: " . strlen($argToSend) . "\n\n";
			$toSend .= $argToSend;
			fwrite($fp, $toSend);
			while(!feof($fp))
				$result .= fgets($fp, 128);
			fclose($fp);
			if(!preg_match('/<encoding>(UTF-8|utf-8)<\/encoding>/msU',$result)) {
				$row['Titre'] = utf8_decode($row['Titre']);
				$row['Message'] = utf8_decode($row['Message']);
			}
			
			$fp = fsockopen($ar_tbAddress['host'], $ar_tbAddress['port'], $errno, $errstr, 15);
			$argToSend = "title=" . htmlentities(urlencode($row['Titre'])) . "&blog_name=Dual+Blog";
			$argToSend .= "&url=" . BLOG_URL . "/posts/{$id_row['num_mess']}&excerpt=" 
								. htmlentities(urlencode(substr(strip_tags($id_row['Message']), 0, 255) . "..."));

			$toSend = $genToSend . "Content-Length: " . strlen($argToSend) . "\n\n";
			$toSend .= $argToSend;
			echo("<![CDATA[");
			fwrite($fp, $toSend);
			while (!feof($fp)) {
				echo fgets($fp, 128);
			}
			echo("]]>");
			fclose($fp);
		}
	}
	 break;
 }
?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">

<html xmlns='http://www.w3.org/1999/xhtml'>
<head>
 <title>Administration : Conception &amp; Design</title>
 <link rel='StyleSheet' type='Text/CSS' href='css/admin.css' />
 <script type='text/javascript' src='admin.js'>/* Die IE, diiie */</script> 
</head>

<body>
 <h3>Administration de Dual Blog</h3>
<ul id='Menu'>
 <li><div id='Brouillons'>Brouillons</div></li>
 <li><div id='Posts'>Posts publiés</div></li>
 <li><div id='Designs'>Designs</div></li>
 <li><div id='ToDo'>To-Do</div></li>
</ul>
<div id='GestPosts'>
<ul>
<?php
 $Data->Connect();
 $Data->Query("SELECT * FROM Mess ORDER BY num_version, num_mess DESC LIMIT 0, 10");
 $versionAc="";
 $i=0;
 $ar_Version = array();
 while(0!==($val=$Data->GetRow())) {
  if($val['num_version']!=$versionAc) {
	if($i!=0) echo("</ul>\n</li>");
	echo("  <li>{$val['num_version']} :\n    <ul>");
	$versionAc=$val['num_version'];
	$ar_Version[] = $versionAc;
	$i++;
  }
  $Titre=TextUtils::EnsureUTF8($val['Titre']);
  echo("
  \t  <li>{$Titre}<span class='Admin'><a href='#id={$val['num_mess']}'>Editer</a>  --  <a href='#id={$val['num_mess']}'>Supprimer</a>  --  <a href='?id={$val['num_mess']}'>Gérer les commentaires</a></span></li>");
 }
 if($i > 0) echo("\n    </ul>\n  </li>\n");
?>
</ul>
</div>

<div id='GestDesigns'>
<ul>
 <li class='Add'><a href='#'>Ajouter un nouveau design au weblog</a></li>
 <li>Modifier les designs déja existants</li>
</ul>
</div>

<div id='GestBrouillons'>
 <ul>
  <li class='Add'><a href='#'>Ajouter un nouveau brouillon</a>
  <form method='post' action='admin.php'>
   <div>
   <input type='hidden' name='mode' value='nvBrouillon' />
   <input type='text' name='Titre' value='Titre' />
   <textarea name='Contenu' rows='10' cols='30'></textarea>
   <input type='submit' value='Valider ce brouillon' />
   </div>
  </form>
  </li>
<?
   $Data->Query("SELECT * FROM Brouillons ORDER BY id_brouillon DESC");
   while(0!==($val=$Data->GetRow())) {
	echo("
   <li>{$val['Titre']}  <span class='Admin'><a href='#id={$val['id_brouillon']}'>Editer</a>  --  <a href='#id={$val['id_brouillon']}'>Publier</a>  --  <a href='?id={$val['id_brouillon']}'>Supprimer</a></span></li>");
   }
?>
  </ul>
</div>

<div id='GestToDo'>
<ul>
 <li class='Add'><a href='#'>Ajouter une nouvelle tâche</a>
 <form method='post' action='admin.php'>
  <div>
  <input type='hidden' name='mode' value='nvTache' />
  <input type='text' name='Tache' />
  <input type='submit' value='Ajouter cette tâche' />
  </div>
 </form></li>
 <?php
  $Data->Query("SELECT * FROM ToDo ORDER By num_thing DESC");
  while(0!==($val=$Data->GetRow())) {
    echo("
  <li>{$val['Thing']} <span class='Admin'><a href='#'>Fait</a>  --  <a href='#'>Editer</a>  --  <a href='#'>Supprimer</a></span></li>");
  }
  $Data->Close();
?>
</ul>
</div>

<form method='post' action='#' id='editPost'>
 <div>
   <input type='hidden' name='mode' value='editBrouillon' />
   <p><input type='text' name='Titre' value='Titre' /></p>
   <p><textarea name='Contenu' rows='10' cols='30'></textarea></p>
   <p><select name='mood' id='mood'>
<?php
		$handle = opendir('mood');
		while($file = readdir($handle))
		{
		    if(strlen($file) > 3 && substr($file, -3) == 'png')
		    {
			  $short = substr($file, 0, -4);
			  echo("\t\t<option value='$short'><img src='mood/25/$file' alt='' />" . $short . "</option>\n");
		    }
		}
		closedir($handle);
?>
   </select></p>
   <p><input type='text' name='Tags' value='Tags' /></p>
   <input type='button' name='Save' value='Sauver la modification' /> 
 </div>
</form>

<form method='post' action='admin.php' id='whichVersion'>
 <div>
 <!--a onclick='javascript:hidePubForm()'>Hide</a-->
 <input type='hidden' name='mode' value='nvPost' />
 <input type='hidden' name='id' />
 <fieldset>
	<legend>Catégorie du post</legend>
	<label for='vAc'>Pour poster le post dans une catégorie déja existante, veuillez la choisir dans la liste ci-dessous :<br /></label>
	<select name='versionAc' id='vAc'>
	  <option>Version 10</option>
	  <option>DeFr.org news</option>
	</select>
	<label for='nvCat'><br />Pour poster le post dans une catégorie n'existant pas encore, veuillez
	entrer son nom : <br /></label>
	<input type='text' name='newVersion' id='nvCat' value='Nouvelle version ?' />
 </fieldset>
 <fieldset>
	  <legend>Tags</legend>
	  <label for='Tags'>Histoire d'organiser les posts, et de pouvoir filtrer par centres d'interet, veuillez
	  préciser les <em>tags</em> à attribuer à ce post :<br /></label>
	  <input type='text' name='Tags' id='Tags' />
 </fieldset>
 <fieldset>
	  <legend>Mood / Emots</legend>
	  <label for='mood'>Pour assurer un minimum d'attrait aux posts, et leur attribuer un aspect graphique
	  sympathique, veuillez selectionner une emoticone pour le post, dans la liste suivante :<br /></label>
	  <select name='mood' id='mood'>
<?php
		$handle = opendir('mood');
		while($file = readdir($handle))
		{
		    if(strlen($file) > 3 && substr($file, -3) == 'png')
		    {
			  $short = substr($file, 0, -4);
			  echo("\t\t\t<option value='$short'><img src='mood/25/$file' alt='' />" . $short . "</option>\n");
		    }
		}
		closedir($handle);
?>
	  </select>
 </fieldset>
 <fieldset>
	<legend>Trackback</legend>
	<label for='tb'>Pour effectuer un trackback vers un autre post, rentrer son URL :<br /></label>
	<input type='text' name='tb' id='tb' value='TrackBack ?' />
 </fieldset>
 <fieldset>
	<legend>Publication</legend>
	<label id='pubComment' for='pubButton' />
	<input type='submit' name="pubButton" id="pubButton" value='Publier' />
 </fieldset>
</div>
</form>

<div id='Infos'>
Administration de Dual Blog - Par DeFr - Icones &copy; David Lanham - The IconFactory -
Valide <a href="http://validator.w3.org/check?uri=referer">XHTML 1.1</a> et <a href='http://jigsaw.w3.org/css-validator/check/referer'>CSS 3</a>
</div>
</body>
</html>