2021-01-03 17:28:31 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @copyright 2020 Christoph Wurst <christoph@winzerhof-wurst.at>
|
|
|
|
*
|
|
|
|
* @author 2020 Christoph Wurst <christoph@winzerhof-wurst.at>
|
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* 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 Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OC\DB;
|
|
|
|
|
2021-01-12 14:24:36 +03:00
|
|
|
use Doctrine\DBAL\Exception;
|
2021-01-03 17:28:31 +03:00
|
|
|
use Doctrine\DBAL\Platforms\AbstractPlatform;
|
|
|
|
use Doctrine\DBAL\Schema\Schema;
|
2021-01-12 14:24:36 +03:00
|
|
|
use OC\DB\Exceptions\DbalException;
|
2021-01-03 17:28:31 +03:00
|
|
|
use OCP\DB\IPreparedStatement;
|
|
|
|
use OCP\DB\IResult;
|
|
|
|
use OCP\DB\QueryBuilder\IQueryBuilder;
|
|
|
|
use OCP\IDBConnection;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adapts the public API to our internal DBAL connection wrapper
|
|
|
|
*/
|
|
|
|
class ConnectionAdapter implements IDBConnection {
|
|
|
|
|
|
|
|
/** @var Connection */
|
|
|
|
private $inner;
|
|
|
|
|
|
|
|
public function __construct(Connection $inner) {
|
|
|
|
$this->inner = $inner;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getQueryBuilder(): IQueryBuilder {
|
|
|
|
return $this->inner->getQueryBuilder();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function prepare($sql, $limit = null, $offset = null): IPreparedStatement {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return new PreparedStatement(
|
|
|
|
$this->inner->prepare($sql, $limit, $offset)
|
|
|
|
);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function executeQuery(string $sql, array $params = [], $types = []): IResult {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return new ResultAdapter(
|
|
|
|
$this->inner->executeQuery($sql, $params, $types)
|
|
|
|
);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function executeUpdate(string $sql, array $params = [], array $types = []): int {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return $this->inner->executeUpdate($sql, $params, $types);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function executeStatement($sql, array $params = [], array $types = []): int {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return $this->inner->executeStatement($sql, $params, $types);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function lastInsertId(string $table): int {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return (int)$this->inner->lastInsertId($table);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function insertIfNotExist(string $table, array $input, array $compare = null) {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return $this->inner->insertIfNotExist($table, $input, $compare);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function insertIgnoreConflict(string $table, array $values): int {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return $this->inner->insertIgnoreConflict($table, $values);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function setValues($table, array $keys, array $values, array $updatePreconditionValues = []): int {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return $this->inner->setValues($table, $keys, $values, $updatePreconditionValues);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function lockTable($tableName): void {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
$this->inner->lockTable($tableName);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function unlockTable(): void {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
$this->inner->unlockTable();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function beginTransaction(): void {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
$this->inner->beginTransaction();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function inTransaction(): bool {
|
|
|
|
return $this->inner->inTransaction();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function commit(): void {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
$this->inner->commit();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function rollBack(): void {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
$this->inner->rollBack();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getError(): string {
|
|
|
|
return $this->inner->getError();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function errorCode() {
|
|
|
|
return $this->inner->errorCode();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function errorInfo() {
|
|
|
|
return $this->inner->errorInfo();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function connect(): bool {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return $this->inner->connect();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function close(): void {
|
|
|
|
$this->inner->close();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function quote($input, $type = IQueryBuilder::PARAM_STR) {
|
|
|
|
return $this->inner->quote($input, $type);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @todo we are leaking a 3rdparty type here
|
|
|
|
*/
|
|
|
|
public function getDatabasePlatform(): AbstractPlatform {
|
|
|
|
return $this->inner->getDatabasePlatform();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function dropTable(string $table): void {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
$this->inner->dropTable($table);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function tableExists(string $table): bool {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return $this->inner->tableExists($table);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function escapeLikeParameter(string $param): string {
|
|
|
|
return $this->inner->escapeLikeParameter($param);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function supports4ByteText(): bool {
|
|
|
|
return $this->inner->supports4ByteText();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @todo leaks a 3rdparty type
|
|
|
|
*/
|
|
|
|
public function createSchema(): Schema {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
return $this->inner->createSchema();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function migrateToSchema(Schema $toSchema): void {
|
2021-01-12 14:24:36 +03:00
|
|
|
try {
|
|
|
|
$this->inner->migrateToSchema($toSchema);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
throw DbalException::wrap($e);
|
|
|
|
}
|
2021-01-03 17:28:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getInner(): Connection {
|
|
|
|
return $this->inner;
|
|
|
|
}
|
|
|
|
}
|