mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-15 04:12:41 +00:00
45 lines
1.7 KiB
PHP
45 lines
1.7 KiB
PHP
|
<?php
|
||
|
/** @license MIT
|
||
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
||
|
* See LICENSE and AUTHORS files for details */
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
namespace JKingWeb\Arsse\TestCase\DatabaseDrivers;
|
||
|
|
||
|
use JKingWeb\Arsse\Arsse;
|
||
|
use JKingWeb\Arsse\Db\Driver;
|
||
|
|
||
|
trait PostgreSQLPDO {
|
||
|
protected static $implementation = "PDO PostgreSQL";
|
||
|
protected static $backend = "PostgreSQL";
|
||
|
protected static $dbResultClass = \JKingWeb\Arsse\Db\PDOResult::class;
|
||
|
protected static $dbStatementClass = \JKingWeb\Arsse\Db\PostgreSQL\PDOStatement::class;
|
||
|
protected static $dbDriverClass = \JKingWeb\Arsse\Db\PostgreSQL\PDODriver::class;
|
||
|
protected static $stringOutput = false;
|
||
|
|
||
|
public static function dbInterface() {
|
||
|
$connString = \JKingWeb\Arsse\Db\PostgreSQL\Driver::makeConnectionString(true, Arsse::$conf->dbPostgreSQLUser, Arsse::$conf->dbPostgreSQLPass, Arsse::$conf->dbPostgreSQLDb, Arsse::$conf->dbPostgreSQLHost, Arsse::$conf->dbPostgreSQLPort, "");
|
||
|
try {
|
||
|
$d = new \PDO("pgsql:".$connString, Arsse::$conf->dbPostgreSQLUser, Arsse::$conf->dbPostgreSQLPass, [\PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION]);
|
||
|
} catch (\Throwable $e) {
|
||
|
return;
|
||
|
}
|
||
|
foreach (\JKingWeb\Arsse\Db\PostgreSQL\PDODriver::makeSetupQueries(Arsse::$conf->dbPostgreSQLSchema) as $q) {
|
||
|
$d->exec($q);
|
||
|
}
|
||
|
return $d;
|
||
|
}
|
||
|
|
||
|
public static function dbTableList($db): array {
|
||
|
return PostgreSQL::dbTableList($db);
|
||
|
}
|
||
|
|
||
|
public static function dbTruncate($db, array $afterStatements = []) {
|
||
|
PostgreSQL::dbTruncate($db, $afterStatements);
|
||
|
}
|
||
|
|
||
|
public static function dbRaze($db, array $afterStatements = []) {
|
||
|
PostgreSQL::dbRaze($db, $afterStatements);
|
||
|
}
|
||
|
}
|