misuzu/src/DB.php

46 lines
1.2 KiB
PHP
Raw Normal View History

2018-10-05 11:06:39 +02:00
<?php
2019-09-29 00:38:39 +02:00
namespace Misuzu;
2018-10-05 11:06:39 +02:00
2019-12-13 21:37:17 +01:00
use PDO;
2019-09-29 00:38:39 +02:00
use Misuzu\Database\Database;
2019-03-04 21:25:20 +01:00
2019-09-29 00:38:39 +02:00
final class DB {
private static $instance;
2019-05-07 10:08:27 +02:00
2019-12-13 21:37:17 +01:00
public const ATTRS = [
PDO::ATTR_CASE => PDO::CASE_NATURAL,
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_ORACLE_NULLS => PDO::NULL_NATURAL,
PDO::ATTR_STRINGIFY_FETCHES => false,
PDO::ATTR_EMULATE_PREPARES => false,
PDO::MYSQL_ATTR_INIT_COMMAND => "
SET SESSION
sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION',
time_zone = '+00:00';
",
];
2019-09-29 00:38:39 +02:00
public static function init(...$args) {
self::$instance = new Database(...$args);
2019-05-07 10:08:27 +02:00
}
2019-09-29 00:38:39 +02:00
public static function __callStatic(string $name, array $args) {
return self::$instance->{$name}(...$args);
}
2019-09-29 00:38:39 +02:00
public static function buildDSN(array $vars): string {
$dsn = ($vars['driver'] ?? 'mysql') . ':';
2019-09-29 00:38:39 +02:00
foreach($vars as $key => $value) {
if($key === 'driver' || $key === 'username' || $key === 'password')
continue;
if($key === 'database')
$key = 'dbname';
2019-09-29 00:38:39 +02:00
$dsn .= $key . '=' . $value . ';';
}
2019-09-29 00:38:39 +02:00
return $dsn;
}
2018-10-05 11:06:39 +02:00
}