Mercurial > defr > DualBlog
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); } } ?>