<?php class Sphinx { private $link; private $prefix; public function __construct($hostname, $username, $password, $database, $prefix = NULL) { list($host, $port) = explode(":", $hostname); try { $this->link = new PDO("mysql:host=$host;port=$port;dbname=$database;charset=" . DB_CHARSET, $username, $password); } catch(PDOException $exception) { exit('Error: ' . $exception->getMessage() . " on database: $database<br />"); } $this->affected = 0; } public function select_db($database) { } public function query($sql, $arr = array()) { $query = new stdClass(); $query->error = 1; $query->errmsg = "Error"; $query->query = $sql; $query->total_found = 0; $time_start = microtime(true); $i = 0; $data = array(); $s = $this->link->prepare($sql); if(!$s) { return $query; } if(!$s->execute($arr)) { syslog(LOG_INFO, $s->errorInfo()[2]); } $this->affected = $s->rowCount(); $R = $s->fetchAll(); while(list ($k, $v) = each($R)){ $data[$i] = $v; $i++; } $query->row = isset($data[0]) ? $data[0] : array(); $query->rows = $data; $query->num_rows = $i; $query->error = 0; $query->errmsg = ""; unset($data); $time_end = microtime(true); $query->exec_time = $time_end - $time_start; // Use the commented out line if you still have sphinx 2.0.x // and use select * from in model/search/search.php in line 232 $meta = $this->link->prepare("SHOW META LIKE 'total_found'"); //$meta = $this->link->prepare("SHOW META"); $meta->execute(); $R = $meta->fetchAll(); while(list ($k, $v) = each($R)){ if($v[0] == "total_found") { $query->total_found = $v[1]; } } if(LOG_LEVEL >= NORMAL) { syslog(LOG_INFO, sprintf("sphinx query: '%s' in %.2f s, %d hits, %d total found", $query->query, $query->exec_time, $query->num_rows, $query->total_found)); } $session = Registry::get('session'); $sphx_query = ''; $b = preg_split("/\ ORDER\ /", $query->query); $a = preg_split("/\ WHERE\ /", $b[0]); if(isset($a[1])) { $sphx_query = preg_replace("/\'/", "\'", $a[1]); } $session->set("sphx_query", $sphx_query); return $query; } public function countAffected() { return mysql_affected_rows($this->link); } public function getLastId() { return mysql_insert_id($this->link); } public function __destruct() { } }