dbUtil.php 5.42 KB
<?php
/**
* Installer Database Control.
*
* KnowledgeTree Community Edition
* Document Management Made Simple
* Copyright (C) 2008,2009 KnowledgeTree Inc.
* Portions copyright The Jam Warehouse Software (Pty) Limited
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License version 3 as published by the
* Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License
* along with this program.  If not, see <http://www.gnu.org/licenses/>.
*
* You can contact KnowledgeTree Inc., PO Box 7775 #87847, San Francisco,
* California 94120-7775, or email info@knowledgetree.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU General Public License version 3.
*
* In accordance with Section 7(b) of the GNU General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "Powered by
* KnowledgeTree" logo and retain the original copyright notice. If the display of the
* logo is not reasonably feasible for technical reasons, the Appropriate Legal Notices
* must display the words "Powered by KnowledgeTree" and retain the original
* copyright notice.
*
* @copyright 2008-2009, KnowledgeTree Inc.
* @license GNU General Public License version 3
* @author KnowledgeTree Team
* @package Installer
* @version Version 0.1
*/
class dbUtil {
	/**
	* Host
	*
	* @author KnowledgeTree Team
	* @access protected
	* @var string 
	*/
	protected $dbhost = '';
	
	/**
	* Host
	*
	* @author KnowledgeTree Team
	* @access protected
	* @var string 
	*/
	protected $dbname = '';
	
	/**
	* Host
	*
	* @author KnowledgeTree Team
	* @access protected
	* @var string 
	*/
	protected $dbuname = '';

	/**
	* Host
	*
	* @author KnowledgeTree Team
	* @access protected
	* @var string 
	*/
	protected $dbpassword = '';
	
	/**
	* Host
	*
	* @author KnowledgeTree Team
	* @access protected
	* @var object mysql connection
	*/
	protected $dbconnection = '';
	
	/**
	* Any errors encountered
	*
	* @author KnowledgeTree Team
	* @access protected
	* @var string 
	*/
	protected $error = '';
	
	/**
	* Constructs database connection object
	*
	* @author KnowledgeTree Team
	* @access public
 	*/
	public function __construct() {
	}
	
	/** 
	 * Connect to a MySQL database
	 * 
	 * @param string $dhost host
	 * @param string $duname database username
	 * @param string $dpassword database password
	 * @access public
	 * @return boolean
  	*/
	public function dbUtil($dhost = 'localhost', $duname, $dpassword, $dbname = '') {
		$this->dbhost = $dhost;
		$this->dbuname = $duname;
		$this->dbpassword = $dpassword;
		$this->dbconnection = mysql_connect($dhost, $duname, $dpassword);
		if($dbname != '') {
			$this->setDb($dbname);
			$this->useBD($dbname);
		}
  		if($this->dbconnection)
  			return $this->dbconnection;
  		else {
  			$this->error = mysql_error();
  			return false;
  		}
	}
	
	/**
	* Choose a database to use
	*
	* @param string $dbname name of the database
	* @access public
	* @return boolean
	*/
	public function useBD($dbname) {
		if($dbname != '') {
			$this->setDb($dbname);
		}
		
		if(mysql_select_db($this->dbname))
			return true;
		else {
			$this->error = mysql_error();
			return false;
		}
	}
	
	public function setDb($dbname) {
		$this->dbname = $dbname;
	}
	
   /**
    * Query the database.
    * 
    * @param $query the sql query.
    * @access public
    * @return object The result of the query.
    */
    public function query($query)
    {
      $result = mysql_query($query);
		if($result) {
			return $result;
		} else {
			$this->error = mysql_error();
			return false;
		}
    }

   /**
    * Do the same as query.
    * 
    * @param $query the sql query.
    * @access public
    * @return boolean
    */
    public function execute($query) {
      $result = mysql_query($query);
		if($result) {
			return true;
		} else {
			$this->error = mysql_error();
			return false;
		}
    }
    
	/** 
	* Convenience method for mysql_fetch_object().
	* 
	* @param $result The resource returned by query().
	* @access public
	* @return object An object representing a data row.
	*/
    public function fetchNextObject($result = NULL) {
	      if ($result == NULL || mysql_num_rows($result) < 1)
	        return NULL;
	      else
	        return mysql_fetch_object($result);
    }

	/** 
	* Convenience method for mysql_fetch_assoc().
	* 
	* @param $result The resource returned by query().
	* @access public
	* @return array Returns an associative array of strings.
	*/
    public function fetchAssoc($result = NULL) {
    	$r = array();
	      if ($result == NULL || mysql_num_rows($result) < 1)
	        return NULL;
	      else {
   			while ($row = mysql_fetch_assoc($result)) {
   				$r[] = $row;
   			}
   			return $r;
	      }
    }
    
   	/**
   	 * Close the connection with the database server.
   	 * 
     * @param none.
     * @access public
     * @return void.
     */
    public function close() {
      mysql_close();
    }

   	/**
   	 * Get database errors.
   	 * 
     * @param none.
     * @access public
     * @return string.
     */
    public function getErrors() {
    	return $this->error;
    }
}
?>