2019-01-12 12:43:06 -05:00
|
|
|
<?php
|
|
|
|
/** @license MIT
|
|
|
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
|
|
|
* See LICENSE and AUTHORS files for details */
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2021-04-14 11:17:01 -04:00
|
|
|
|
2019-08-25 13:19:11 -04:00
|
|
|
namespace JKingWeb\Arsse\Test\DatabaseDrivers;
|
2019-01-12 12:43:06 -05:00
|
|
|
|
|
|
|
use JKingWeb\Arsse\Arsse;
|
|
|
|
|
|
|
|
trait MySQLPDO {
|
2022-01-11 17:54:02 -05:00
|
|
|
use MySQLCommon;
|
|
|
|
|
2019-01-12 12:43:06 -05:00
|
|
|
protected static $implementation = "PDO MySQL";
|
|
|
|
protected static $backend = "MySQL";
|
|
|
|
protected static $dbResultClass = \JKingWeb\Arsse\Db\PDOResult::class;
|
|
|
|
protected static $dbStatementClass = \JKingWeb\Arsse\Db\MySQL\PDOStatement::class;
|
|
|
|
protected static $dbDriverClass = \JKingWeb\Arsse\Db\MySQL\PDODriver::class;
|
|
|
|
protected static $stringOutput = true;
|
2020-03-01 15:16:50 -05:00
|
|
|
|
2019-01-12 12:43:06 -05:00
|
|
|
public static function dbInterface() {
|
|
|
|
try {
|
|
|
|
$dsn = [];
|
|
|
|
$params = [
|
|
|
|
'charset' => "utf8mb4",
|
2020-03-01 15:16:50 -05:00
|
|
|
'host' => Arsse::$conf->dbMySQLHost,
|
|
|
|
'port' => Arsse::$conf->dbMySQLPort,
|
|
|
|
'dbname' => Arsse::$conf->dbMySQLDb,
|
2019-01-12 12:43:06 -05:00
|
|
|
];
|
|
|
|
foreach ($params as $k => $v) {
|
|
|
|
$dsn[] = "$k=$v";
|
|
|
|
}
|
|
|
|
$dsn = "mysql:".implode(";", $dsn);
|
2019-01-13 23:17:19 -05:00
|
|
|
$d = new \PDO($dsn, Arsse::$conf->dbMySQLUser, Arsse::$conf->dbMySQLPass, [
|
2020-03-01 15:16:50 -05:00
|
|
|
\PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION,
|
2022-01-11 17:54:02 -05:00
|
|
|
\PDO::ATTR_STRINGIFY_FETCHES => true,
|
2019-01-13 23:17:19 -05:00
|
|
|
\PDO::MYSQL_ATTR_MULTI_STATEMENTS => false,
|
|
|
|
]);
|
|
|
|
foreach (\JKingWeb\Arsse\Db\MySQL\PDODriver::makeSetupQueries() as $q) {
|
|
|
|
$d->exec($q);
|
|
|
|
}
|
|
|
|
return $d;
|
2019-01-12 12:43:06 -05:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|