validateConnUri($connUri); $strcnn = $this->createPdoConnStr($connUri); $this->createPdoInstance($strcnn, $preOptions, $postOptions); } protected function createPdoInstance($pdoConnectionString, $preOptions = null, $postOptions = null) { // Create Connection $this->instance = new PDO( $pdoConnectionString, $this->connectionUri->getUsername(), $this->connectionUri->getPassword(), (array) $preOptions ); $this->connectionUri = $this->connectionUri->withScheme($this->instance->getAttribute(PDO::ATTR_DRIVER_NAME)); $this->setPdoDefaultParams($postOptions); } /** * @param Uri $connUri * @param string $scheme * @throws NotAvailableException */ protected function validateConnUri($connUri, $scheme = null) { $this->connectionUri = $connUri; if (!defined('PDO::ATTR_DRIVER_NAME')) { throw new NotAvailableException("Extension 'PDO' is not loaded"); } if (empty($scheme)) { $scheme = $connUri->getScheme(); } if (!extension_loaded('pdo_' . strtolower($scheme))) { throw new NotAvailableException("Extension 'pdo_" . strtolower($connUri->getScheme()) . "' is not loaded"); } if ($connUri->getQueryPart(self::STATEMENT_CACHE) == "true") { $this->useStmtCache = true; } } protected function setPdoDefaultParams($postOptions = []) { // Set Specific Attributes $this->instance->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $this->instance->setAttribute(PDO::ATTR_CASE, PDO::CASE_LOWER); foreach ((array) $postOptions as $key => $value) { $this->instance->setAttribute($key, $value); } } protected function createPdoConnStr(Uri $connUri) { $host = $connUri->getHost(); if (empty($host)) { return $connUri->getScheme() . ":" . $connUri->getPath(); } $database = preg_replace('~^/~', '', $connUri->getPath()); if (!empty($database)) { $database = ";dbname=$database"; } $strcnn = $connUri->getScheme() . ":" . "host=" . $connUri->getHost() . $database; if ($connUri->getPort() != "") { $strcnn .= ";port=" . $connUri->getPort(); } $query = $connUri->getQuery(); $queryArr = explode('&', $query); foreach ($queryArr as $value) { if ((strpos($value, self::DONT_PARSE_PARAM . "=") === false) && (strpos($value, self::STATEMENT_CACHE . "=") === false)) { $strcnn .= ";" . $value; } } return $strcnn; } public function __destruct() { $this->stmtCache = null; $this->instance = null; } /** * @param string $sql * @param array $array * @return PDOStatement */ protected function getDBStatement($sql, $array = null) { if (is_null($this->connectionUri->getQueryPart(self::DONT_PARSE_PARAM))) { list($sql, $array) = SqlBind::parseSQL($this->connectionUri, $sql, $array); } if ($this->useStmtCache) { if ($this->getMaxStmtCache() > 0 && !isset($this->stmtCache[$sql])) { $this->stmtCache[$sql] = $this->instance->prepare($sql); if ($this->getCountStmtCache() > $this->getMaxStmtCache()) { //Kill old cache to get waste memory array_shift($this->stmtCache); } } $stmt = $this->stmtCache[$sql]; } else { $stmt = $this->instance->prepare($sql); } if (!empty($array)) { foreach ($array as $key => $value) { $stmt->bindValue(":" . SqlBind::keyAdj($key), $value); } } return $stmt; } public function getIterator($sql, $params = null) { $stmt = $this->getDBStatement($sql, $params); $stmt->execute(); return new DbIterator($stmt); } public function getScalar($sql, $array = null) { $stmt = $this->getDBStatement($sql, $array); $stmt->execute(); $scalar = $stmt->fetchColumn(); $stmt->closeCursor(); return $scalar; } public function getAllFields($tablename) { $fields = array(); $statement = $this->instance->query( SqlHelper::createSafeSQL( "select * from @@table where 0=1", [ "@@table" => $tablename ] ) ); $fieldLength = $statement->columnCount(); for ($i = 0; $i < $fieldLength; $i++) { $fld = $statement->getColumnMeta($i); $fields[] = strtolower($fld ["name"]); } return $fields; } public function beginTransaction() { $this->instance->beginTransaction(); } public function commitTransaction() { $this->instance->commit(); } public function rollbackTransaction() { $this->instance->rollBack(); } public function execute($sql, $array = null) { $stmt = $this->getDBStatement($sql, $array); $result = $stmt->execute(); if ($this->isSupportMultRowset()) { // Check error do { // This loop is only to throw an error (if exists) // in case of execute multiple queries } while ($stmt->nextRowset()); } return $result; } public function executeAndGetId($sql, $array = null) { return $this->getDbHelper()->executeAndGetInsertedId($this, $sql, $array); } /** * @return PDO */ public function getDbConnection() { return $this->instance; } public function getAttribute($name) { $this->instance->getAttribute($name); } public function setAttribute($name, $value) { $this->instance->setAttribute($name, $value); } public function getDbHelper() { if (empty($this->dbHelper)) { $this->dbHelper = Factory::getDbFunctions($this->connectionUri); } return $this->dbHelper; } public function getUri() { return $this->connectionUri; } /** * @return bool */ public function isSupportMultRowset() { return $this->supportMultRowset; } /** * @param bool $multipleRowSet */ public function setSupportMultRowset($multipleRowSet) { $this->supportMultRowset = $multipleRowSet; } /** * @return int */ public function getMaxStmtCache() { return $this->maxStmtCache; } public function getCountStmtCache() { return count($this->stmtCache); } /** * @param int $maxStmtCache */ public function setMaxStmtCache($maxStmtCache) { $this->maxStmtCache = $maxStmtCache; } } __halt_compiler();----SIGNATURE:----vCSv2u6JKLPS+84/XSjE3duQ/yHIAoPWZrxGgo8cQfBUA3YWvwDrU5NJ/qB09ZGgLOpAz8oLEncd4+npD1BcLvpB8+nWuZR5WPTMWBEzaZEV5ah0FsNdTz5wcxrrmciTNRolEd2e4BPafcWajrQMJRM6UDOp1Oj3KAVI+6s8mUm79kSJtXSnPUy2y0HLMig/T3NlpY9/mUnmQXlFE2XGKUUFIGz4ULm0bnKrqc4OtJpQr57T+eNoPALOSJr0DAntdw3/B6/afCQszxt3nONrbn/sM3yOa6wwjnrtEotS9YBL8bdYMkR0+N8FonoZ0DlZURuFnfIxiL3GkW5M87L0hilKTjLQ5TCaoF4RjwChB01J5yEu+9QYVThBu6276/Vmd9TpK/VMgQGEm7utZAjgKrWMaRYNLby5+JF+MCKJ3moY38/jKZRmFlb8L98EV/RXLmpAJVQk+bKLHAY+sWrkfiW4X22Pm26oKgetBgW/LaC62MrZy+3XB3thE2uALJzlEdhPNqwCUPuP+kKgTkmbVJLqyS1CHYJlg8cIiK43f2lMVlJ5Au/jTHOu8jhuyUE+ip0QkQnm5IVub0h1u8l2Wk3AppYaE7LiFfbtwKZCy9aLSPFbKtwFUVMMGpr4LurWkmvjlmaur9oAjb5nPlCt3EiwB0CYY5bwhUW/ehHsO+E=----ATTACHMENT:----MzY3NjY0NDg0NDUyNDE4NiAxMTYyNTU0NjAzMTU1MjEgMjYzMzQ4NDY5OTg2NzIwNQ==