mirror of
https://github.com/Karaka-Management/phpOMS.git
synced 2026-01-11 17:58:41 +00:00
118 lines
3.3 KiB
PHP
Executable File
118 lines
3.3 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* Jingga
|
|
*
|
|
* PHP Version 8.1
|
|
*
|
|
* @package phpOMS\DataStorage\Database\Connection
|
|
* @copyright Dennis Eichhorn
|
|
* @license OMS License 2.0
|
|
* @version 1.0.0
|
|
* @link https://jingga.app
|
|
*/
|
|
declare(strict_types=1);
|
|
|
|
namespace phpOMS\DataStorage\Database\Connection;
|
|
|
|
use phpOMS\DataStorage\Database\DatabaseStatus;
|
|
use phpOMS\DataStorage\Database\DatabaseType;
|
|
use phpOMS\DataStorage\Database\Query\Grammar\PostgresGrammar;
|
|
use phpOMS\DataStorage\Database\Schema\Grammar\PostgresGrammar as PostgresSchemaGrammar;
|
|
|
|
/**
|
|
* Database handler.
|
|
*
|
|
* Handles the database connection.
|
|
* Implementing wrapper functions for multiple databases is planned (far away).
|
|
*
|
|
* @package phpOMS\DataStorage\Database\Connection
|
|
* @license OMS License 2.0
|
|
* @link https://jingga.app
|
|
* @since 1.0.0
|
|
*/
|
|
final class PostgresConnection extends ConnectionAbstract
|
|
{
|
|
/**
|
|
* Object constructor.
|
|
*
|
|
* Creates the database object and overwrites all default values.
|
|
*
|
|
* @param array{db:string, host?:string, port?:int, login?:string, password?:string, database:string} $dbdata the basic database information for establishing a connection
|
|
*
|
|
* @since 1.0.0
|
|
*/
|
|
public function __construct(array $dbdata)
|
|
{
|
|
$this->type = DatabaseType::PGSQL;
|
|
$this->grammar = new PostgresGrammar();
|
|
$this->schemaGrammar = new PostgresSchemaGrammar();
|
|
|
|
if (isset($dbdata['datetimeformat'])) {
|
|
$this->grammar->setDateTimeFormat($dbdata['datetimeformat']);
|
|
$this->schemaGrammar->setDateTimeFormat($dbdata['datetimeformat']);
|
|
}
|
|
|
|
$this->dbdata = $dbdata;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function connect(?array $dbdata = null) : void
|
|
{
|
|
if ($this->status === DatabaseStatus::OK) {
|
|
return;
|
|
}
|
|
|
|
$this->dbdata = $dbdata ?? $this->dbdata;
|
|
|
|
if (!isset($this->dbdata['db'], $this->dbdata['host'], $this->dbdata['port'], $this->dbdata['database'], $this->dbdata['login'], $this->dbdata['password'])
|
|
|| !DatabaseType::isValidValue($this->dbdata['db'])
|
|
) {
|
|
$this->status = DatabaseStatus::FAILURE;
|
|
$this->dbdata['password'] = '****';
|
|
|
|
return;
|
|
}
|
|
|
|
$this->close();
|
|
|
|
try {
|
|
$this->con = new \PDO($this->dbdata['db'] . ':host=' . $this->dbdata['host'] . ';port=' . $this->dbdata['port'] . ';dbname=' . $this->dbdata['database'], $this->dbdata['login'], $this->dbdata['password']);
|
|
$this->con->setAttribute(\PDO::ATTR_EMULATE_PREPARES, false);
|
|
$this->con->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
|
|
|
|
$this->status = DatabaseStatus::OK;
|
|
} catch (\PDOException $_) {
|
|
$this->con = new NullPDO();
|
|
$this->status = DatabaseStatus::MISSING_DATABASE;
|
|
} finally {
|
|
$this->dbdata['password'] = '****';
|
|
}
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function beginTransaction() : void
|
|
{
|
|
$this->con->beginTransaction();
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function rollBack() : void
|
|
{
|
|
$this->con->rollBack();
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function commit() : void
|
|
{
|
|
$this->con->commit();
|
|
}
|
|
}
|