view includes/class.dataaccess.php @ 64:d4f26e9767bf

Filtrage via Akismet du spam. Suite aux nombreuses attaques de spammers sur le blog, j'ai du chercher une solution efficace permettant d'y faire face. La solution la plus efficace que j'ai pour le moment, c'est Akismet, qui semble ne pas avoir trop de faux positifs (je n'en ai pas encore eu un seul). Il est necessaire de creer un compte sur WordPress.com pour obtenir une clef permettant d'utiliser le service, c'est totalement gratuit.
author Franck Deroche <webmaster@defr.org>
date Tue, 11 Mar 2008 08:16:11 -0700
parents d0b737b2b398
children 0071e5744311
line wrap: on
line source
<?php
class DataAccess {
  var $host;
  var $user;
  var $pass;
  var $db;
  var $link;
  var $connOpen;
  var $results;
  var $queries;
  var $_nbQueries;
  
  function DataAccess($host=DB_HOST, $user=DB_USER, $pass=DB_PASSWORD, $db=DB_NAME) {
   $this->host=$host;
   $this->user=$user;
   $this->pass=$pass;
   $this->db = $db;
   $this->connOpen = 0;
   $this->_nbQueries = 0;
   $this->queries = array();
   $this->results = array();
   $this->Connect();
 }
 
  function Connect() {
   if($this->connOpen == 0) {
     $this->link = mysql_connect($this->host, $this->user, $this->pass);
     mysql_select_db($this->db, $this->link);
   }
   $this->connOpen++;
  }
  
  function Query($query, $id=0) {
   $this->_nbQueries++;
   $this->queries[$id]=$query;
   $this->Connect();
   $this->results[$id]=mysql_query($this->queries[$id], $this->link);
   $this->Close();
   if(@$num_rows=mysql_num_rows($this->results[$id]))
	return $num_rows;
   return 0;
  }
  
  function debugQuery($query, $id=0) {
  $rv = $this->Query($query, $id);
  if(mysql_errno() !== 0)
	echo("<span class='menu'>\n Query : {$query}<br />\n MySQL Answer : " . mysql_error() . "</span>");
  return $rv;
  }
  
  function GetRow($id=0) {
   if(@$row=mysql_fetch_array($this->results[$id])) {
    return $row;
   }
   return 0;    
  }
  
  function Close() {
   $this->connOpen--;
   if($this->connOpen == 0) {
    mysql_close($this->link);
   }
  }
  
  function getNbQueries() {
	return $this->_nbQueries;
  }
  
  function formatDate($timestamp, $decallage=2, $pattern='d/m/Y H:i:s') {
   return gmdate($pattern, $timestamp + $decallage * 3600);
  }
}
?>