view includes/class.dataaccess.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 e4e880f786d4
children ec0c926a78a6
line wrap: on
line source
<?php
class DataAccess {
  var $host;
  var $user;
  var $pass;
  var $db;
  var $arResult;
  var $query;
  var $connOpen;
  var $_nbQueries;
  
  var $infos; // Cache contenant les informations sur le visiteur
  
  function DataAccess($host=DB_HOST, $user=DB_USER, $pass=DB_PASSWORD) {
   $this->host=$host;
   $this->user=$user;
   $this->pass=$pass;
   $this->_nbQueries = 0;
   $this->Connect();
 }
 
  function Connect($db=DB_NAME) {
   if($this->connOpen == 1) return;
   $this->db=$db;
   $this->connOpen=1;
   mysql_connect($this->host, $this->user, $this->pass);
   mysql_select_db($this->db);
  }
  
  function Query($query, $id=0) {
   $this->query=$query;
   if($this->connOpen != 1) $this->Connect();
   $this->arResult[$id]=mysql_query($this->query);
   if($this->connOpen != 1) $this->Close();
   if(@$num_rows=mysql_num_rows($this->arResult[$id]))
	return $num_rows;
   else
	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_assoc($this->arResult[$id])) {
    foreach($row as $key => $value)
        $row_utf[$key]=$this->utf8_ensure($value);
    return $row_utf;
   }
   return 0; 
  }
  
  function GetRawRow($id=0) {
   if(@$row=mysql_fetch_array($this->arResult[$id])) {
    return $row;
   }
   return 0;    
  }
  
  function Close() {
   $this->connOpen=0;
   mysql_close();
  }
  
  function getNbQueries() {
	return $this->_nbQueries;
  }
  
  function formatDate($timestamp, $decallage=2, $pattern='d/m/Y H:i:s') {
   return gmdate($pattern, $timestamp + $decallage * 3600);
  }
  
  function seems_utf8($Str) {
     for ($i=0; $i<strlen($Str)/10 || $i < 100; $i++) {
	if (ord($Str[$i]) < 0x80) continue; # 0bbbbbbb
	elseif ((ord($Str[$i]) & 0xE0) == 0xC0) $n=1; # 110bbbbb
	elseif ((ord($Str[$i]) & 0xF0) == 0xE0) $n=2; # 1110bbbb
	elseif ((ord($Str[$i]) & 0xF8) == 0xF0) $n=3; # 11110bbb
	elseif ((ord($Str[$i]) & 0xFC) == 0xF8) $n=4; # 111110bb
	elseif ((ord($Str[$i]) & 0xFE) == 0xFC) $n=5; # 1111110b
	else return false; # Does not match any model
	for ($j=0; $j<$n; $j++) { # n bytes matching 10bbbbbb follow ?
		if ((++$i == strlen($Str)) || ((ord($Str[$i]) & 0xC0) != 0x80))
		return false;
	}
     }
     return true;
  }
  
  function utf8_ensure($Str) {
   return $this->seems_utf8($Str)?$Str:utf8_encode($Str);
  }
  
}
?>