mirror of
https://github.com/torrentpier/torrentpier-lts.git
synced 2025-03-01 15:21:02 +03:00
256 lines
6.3 KiB
PHP
256 lines
6.3 KiB
PHP
<?php
|
|
/**
|
|
* Zend Framework (http://framework.zend.com/)
|
|
*
|
|
* @link http://github.com/zendframework/zf2 for the canonical source repository
|
|
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
|
*/
|
|
|
|
namespace Zend\Db\Adapter\Driver\Mysqli;
|
|
|
|
use Zend\Db\Adapter\Driver\AbstractConnection;
|
|
use Zend\Db\Adapter\Exception;
|
|
|
|
class Connection extends AbstractConnection
|
|
{
|
|
/**
|
|
* @var Mysqli
|
|
*/
|
|
protected $driver = null;
|
|
|
|
/**
|
|
* @var \mysqli
|
|
*/
|
|
protected $resource = null;
|
|
|
|
/**
|
|
* Constructor
|
|
*
|
|
* @param array|mysqli|null $connectionInfo
|
|
* @throws \Zend\Db\Adapter\Exception\InvalidArgumentException
|
|
*/
|
|
public function __construct($connectionInfo = null)
|
|
{
|
|
if (is_array($connectionInfo)) {
|
|
$this->setConnectionParameters($connectionInfo);
|
|
} elseif ($connectionInfo instanceof \mysqli) {
|
|
$this->setResource($connectionInfo);
|
|
} elseif (null !== $connectionInfo) {
|
|
throw new Exception\InvalidArgumentException('$connection must be an array of parameters, a mysqli object or null');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param Mysqli $driver
|
|
* @return self
|
|
*/
|
|
public function setDriver(Mysqli $driver)
|
|
{
|
|
$this->driver = $driver;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function getCurrentSchema()
|
|
{
|
|
if (!$this->isConnected()) {
|
|
$this->connect();
|
|
}
|
|
|
|
/** @var $result \mysqli_result */
|
|
$result = $this->resource->query('SELECT DATABASE()');
|
|
$r = $result->fetch_row();
|
|
|
|
return $r[0];
|
|
}
|
|
|
|
/**
|
|
* Set resource
|
|
*
|
|
* @param \mysqli $resource
|
|
* @return self
|
|
*/
|
|
public function setResource(\mysqli $resource)
|
|
{
|
|
$this->resource = $resource;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function connect()
|
|
{
|
|
if ($this->resource instanceof \mysqli) {
|
|
return $this;
|
|
}
|
|
|
|
// localize
|
|
$p = $this->connectionParameters;
|
|
|
|
// given a list of key names, test for existence in $p
|
|
$findParameterValue = function (array $names) use ($p) {
|
|
foreach ($names as $name) {
|
|
if (isset($p[$name])) {
|
|
return $p[$name];
|
|
}
|
|
}
|
|
|
|
return;
|
|
};
|
|
|
|
$hostname = $findParameterValue(array('hostname', 'host'));
|
|
$username = $findParameterValue(array('username', 'user'));
|
|
$password = $findParameterValue(array('password', 'passwd', 'pw'));
|
|
$database = $findParameterValue(array('database', 'dbname', 'db', 'schema'));
|
|
$port = (isset($p['port'])) ? (int) $p['port'] : null;
|
|
$socket = (isset($p['socket'])) ? $p['socket'] : null;
|
|
|
|
$this->resource = new \mysqli();
|
|
$this->resource->init();
|
|
|
|
if (!empty($p['driver_options'])) {
|
|
foreach ($p['driver_options'] as $option => $value) {
|
|
if (is_string($option)) {
|
|
$option = strtoupper($option);
|
|
if (!defined($option)) {
|
|
continue;
|
|
}
|
|
$option = constant($option);
|
|
}
|
|
$this->resource->options($option, $value);
|
|
}
|
|
}
|
|
|
|
$this->resource->real_connect($hostname, $username, $password, $database, $port, $socket);
|
|
|
|
if ($this->resource->connect_error) {
|
|
throw new Exception\RuntimeException(
|
|
'Connection error',
|
|
null,
|
|
new Exception\ErrorException($this->resource->connect_error, $this->resource->connect_errno)
|
|
);
|
|
}
|
|
|
|
if (!empty($p['charset'])) {
|
|
$this->resource->set_charset($p['charset']);
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function isConnected()
|
|
{
|
|
return ($this->resource instanceof \mysqli);
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function disconnect()
|
|
{
|
|
if ($this->resource instanceof \mysqli) {
|
|
$this->resource->close();
|
|
}
|
|
$this->resource = null;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function beginTransaction()
|
|
{
|
|
if (!$this->isConnected()) {
|
|
$this->connect();
|
|
}
|
|
|
|
$this->resource->autocommit(false);
|
|
$this->inTransaction = true;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function commit()
|
|
{
|
|
if (!$this->isConnected()) {
|
|
$this->connect();
|
|
}
|
|
|
|
$this->resource->commit();
|
|
$this->inTransaction = false;
|
|
$this->resource->autocommit(true);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function rollback()
|
|
{
|
|
if (!$this->isConnected()) {
|
|
throw new Exception\RuntimeException('Must be connected before you can rollback.');
|
|
}
|
|
|
|
if (!$this->inTransaction) {
|
|
throw new Exception\RuntimeException('Must call beginTransaction() before you can rollback.');
|
|
}
|
|
|
|
$this->resource->rollback();
|
|
$this->resource->autocommit(true);
|
|
$this->inTransaction = false;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*
|
|
* @throws Exception\InvalidQueryException
|
|
*/
|
|
public function execute($sql)
|
|
{
|
|
if (!$this->isConnected()) {
|
|
$this->connect();
|
|
}
|
|
|
|
if ($this->profiler) {
|
|
$this->profiler->profilerStart($sql);
|
|
}
|
|
|
|
$resultResource = $this->resource->query($sql);
|
|
|
|
if ($this->profiler) {
|
|
$this->profiler->profilerFinish($sql);
|
|
}
|
|
|
|
// if the returnValue is something other than a mysqli_result, bypass wrapping it
|
|
if ($resultResource === false) {
|
|
throw new Exception\InvalidQueryException($this->resource->error);
|
|
}
|
|
|
|
$resultPrototype = $this->driver->createResult(($resultResource === true) ? $this->resource : $resultResource);
|
|
|
|
return $resultPrototype;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function getLastGeneratedValue($name = null)
|
|
{
|
|
return $this->resource->insert_id;
|
|
}
|
|
}
|