-
Notifications
You must be signed in to change notification settings - Fork 0
/
Db.php
96 lines (88 loc) · 3.07 KB
/
Db.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
<?php
namespace Colibri\Database;
use Colibri\Pattern\Helper;
/**
* Instantiates and Stores all connections.
*/
class Db extends Helper
{
/**
* @var array
*/
private static $config = [];
/**
* @var array<IDb>
*/
private static $connection = [];
/**
* First of all you need to set a config for your connections.
* В первую очередь вам нужно установить кофиг для ваших подключений.
*
* @param array $config
*
* @return array
*
* @throws DbException
*/
public static function setConfig(array $config)
{
if ( ! isset($config['connection'])) {
throw new DbException('can`t find `connection` parameter in database config');
}
$connection = &$config['connection'];
if ( ! isset($connection['default'])) {
throw new DbException('can`t find `default` parameter in database config');
}
$default = &$connection['default'];
if ( ! is_string($default) || empty($connection[$default])) {
throw new DbException('parameter `default` must be string and contain contains name of default connection. So given section `' .
$default .
'` must present in database config');
}
return self::$config = $config;
}
/**
* Returns existing connection by config name or instantiate new one.
* Вазвращает существующее подключение по имени из конига или создаёт новое.
*
* @param string $name connection name defined in config
*
* @return AbstractDb\DriverInterface
*
* @throws DbException
*/
public static function connection($name = 'default')
{
$name = $name == 'default' ? self::$config['connection']['default'] : $name;
return isset(self::$connection[$name])
? self::$connection[$name]
: self::$connection[$name] = self::createForConnection($name);
}
/**
* Создает экземпляр класса используя настройки установленные ::setConfig()
* Creates instance of connection using configuration that was set by ::setConfig().
*
* @param string $name
*
* @return AbstractDb\DriverInterface Объект базы данных
*
* @throws DbException
*/
private static function createForConnection($name)
{
$config = &self::$config['connection'][$name];
switch ($config['type']) {
case Type::MYSQL:
return new Concrete\MySQL(new Concrete\MySQL\Connection(
$config['host'],
$config['user'],
$config['password'],
$config['database'],
$config['persistent']
));
case Type::POSTGRESQL:
default:
throw new DbException("can`t create database: this db type ({$config['type']}) not supported");
}
}
}