. */ /** * Custom Doctrine connection adapter for oracle * * @package Doctrine * @subpackage Adapter * @author Konsta Vesterinen * @author vadik56 * @author Miloslav Kmet * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link www.phpdoctrine.org * @since 1.0 * @version $Revision$ */ class Doctrine_Adapter_Oracle implements Doctrine_Adapter_Interface{ /** * execution mode */ protected $executeMode = OCI_COMMIT_ON_SUCCESS; /** * Resource representing connection to database */ protected $connection = false; protected $attributes = array(Doctrine::ATTR_DRIVER_NAME => "oci8", Doctrine::ATTR_ERRMODE => Doctrine::ERRMODE_SILENT); /** * User-provided configuration. * * Basic keys are: * * username => (string) Connect to the database as this username. * password => (string) Password associated with the username. * dbname => Either the name of the local Oracle instance, or the * name of the entry in tnsnames.ora to which you want to connect. * * @var array */ protected $config = array('dbname' => null, 'username' => null, 'password' => null, 'charset' => null); /** * Doctrine Oracle adapter constructor * * * $conn = new Doctrine_Adapter_Oracle(array('dbname'=>'db','username'=>'usr','password'=>'pass')); * * * @param string $name * @return void */ public function __construct($config = array()) { if ( ! isset($config['password']) || ! isset($config['username'])) { throw new Doctrine_Adapter_Exception('config array must have at least a username and a password'); } $this->config['username'] = $config['username']; $this->config['password'] = $config['password']; $this->config['dbname'] = $config['dbname']; $this->config['charset'] = $config['charset']; } /** * Connect to a database * @throws Doctrine_Adapter_Exception * @return void */ private function connect() { $this->connection = @oci_connect($this->config['username'], $this->config['password'], $this->config['dbname'], $this->config['charset']); if ($this->connection === false) { throw new Doctrine_Adapter_Exception(sprintf("Unable to Connect to :'%s' as '%s'", $this->config['dbname'], $this->config['username'])); } } /** * Prepare a query statement * * @param string $query Query to prepare * @return Doctrine_Adapter_Statement_Oracle $stmt prepared statement */ public function prepare($query) { if ($this->connection ===false) { $this->connect(); } $stmt = new Doctrine_Adapter_Statement_Oracle($this, $query, $this->executeMode); return $stmt; } /** * Execute query and return results as statement object * * @param string $query * @return Doctrine_Adapter_Statement_Oracle $stmt */ public function query($query) { if ($this->connection ===false) { $this->connect(); } $stmt = new Doctrine_Adapter_Statement_Oracle($this, $query, $this->executeMode); $stmt->execute(); return $stmt; } /** * Quote a value for the dbms * * @param string $input * @return string $quoted */ public function quote($input) { return "'" . str_replace("'","''",$input) . "'"; } /** * Execute a raw sql statement * * @param string $statement * @return void */ public function exec($statement) { if ($this->connection ===false) { $this->connect(); } $stmt = new Doctrine_Adapter_Statement_Oracle($this, $statement, $this->executeMode); $stmt->execute(); $count = $stmt->rowCount(); return $count; } /** * Get the id of the last inserted record * * @return integer $id */ public function lastInsertId() { throw new Exception("unsupported"); } /** * Begin a transaction * * @return boolean */ public function beginTransaction() { $this->_executeMode = OCI_DEFAULT; return true; } /** * Commit a transaction * * @return void */ public function commit() { if ($this->connection ===false) { $this->connect(); } return @oci_commit($this->connection); } /** * Rollback a transaction * * @return boolean */ public function rollBack() { if ($this->connection ===false) { $this->connect(); } return @oci_rollback($this->connection); } /** * Set connection attribute * * @param integer $attribute * @param mixed $value the value of given attribute * @return boolean Returns TRUE on success or FALSE on failure. */ public function setAttribute($attribute, $value) { switch ($attribute) { case Doctrine::ATTR_DRIVER_NAME: //TODO throw an error since driver name can not be changed case Doctrine::ATTR_ERRMODE: break; case Doctrine::ATTR_CASE: if ($value == Doctrine::CASE_NATURAL) { break; } else { throw new Doctrine_Adapter_Exception("Unsupported Option for ATTR_CASE: $value"); } default: throw new Doctrine_Adapter_Exception("Unsupported Attribute: $attribute"); return false; } $this->attributes[$attribute] = $value; return true; } /** * Retrieve a statement attribute * * @param integer $attribute * @see Doctrine::ATTR_* constants * @return mixed the attribute value */ public function getAttribute($attribute) { return $this->attributes[$attribute]; } /** * Returns established OCI connection handler * * @return resource OCI connection handler */ public function getConnection() { return $this->connection; } public function errorCode() { if (is_resource($this->connection)) { $error = @oci_error($this->connection); } else { $error = @oci_error(); } return $error['code']; } public function errorInfo() { if (is_resource($this->connection)) { $error = @oci_error($this->connection); } else { $error = @oci_error(); } return $error['message']; } }