| // +----------------------------------------------------------------------+ // // $Id: OptionsMDB2.php 320703 2011-12-08 22:08:40Z danielc $ require_once 'Tree/Common.php'; /** * this class additionally retreives a DB connection and saves it * in the property "dbh" * * @package Tree * @access public * @author Wolfram Kriesing * */ class Tree_OptionsMDB2 extends Tree_Common { /** * @var object */ var $dbh; // {{{ Tree_OptionsMDB2() /** * this constructor sets the options, since i normally need this and * in case the constructor doesnt need to do anymore i already have * it done :-) * * @version 02/01/08 * @access public * @author Wolfram Kriesing * @param boolean true if loggedIn */ function Tree_OptionsMDB2($dsn, $options = array()) { $res = $this->_connectDB($dsn); if (PEAR::isError($res)) { return $res; } $this->dbh->setFetchmode(MDB2_FETCHMODE_ASSOC); // do options afterwards since it overrules $this->Tree_Options($options); } // }}} // {{{ _connectDB() /** * Connect to database by using the given DSN string * * @author copied from PEAR::Auth, Martin Jansen, slightly modified * @access private * @param string DSN string * @return mixed Object on error, otherwise bool */ function _connectDB($dsn) { // only include the db if one really wants to connect require_once 'MDB2.php'; if (is_string($dsn) || is_array($dsn)) { $this->dbh = MDB2::Connect($dsn); } else { if (MDB2::isConnection($dsn)) { $this->dbh = $dsn; } else { if (is_object($dsn) && MDB2::isError($dsn)) { return new MDB2_Error($dsn->code, PEAR_ERROR_DIE); } return new PEAR_Error( 'The given dsn was not valid in file '. __FILE__ . ' at line ' . __LINE__, 41, PEAR_ERROR_RETURN, null, null ); } } if (MDB2::isError($this->dbh)) { return new MDB2_Error($this->dbh->code, PEAR_ERROR_DIE); } return true; } // }}} }