diff options
author | Joas Schilling <coding@schilljs.com> | 2018-04-19 12:49:36 +0200 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2018-04-19 12:49:36 +0200 |
commit | 78ee3abb786eea385b3149279ba6d8903d8a7b1a (patch) | |
tree | 5dce50c8b8b27526e18d7c9cd5ce30bf9814f847 /lib/private/DB | |
parent | 8f7a0af9515a6441b692719310c3e02832d9de65 (diff) | |
download | nextcloud-server-78ee3abb786eea385b3149279ba6d8903d8a7b1a.tar.gz nextcloud-server-78ee3abb786eea385b3149279ba6d8903d8a7b1a.zip |
Move regex to a function and add tests
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/private/DB')
-rw-r--r-- | lib/private/DB/ConnectionFactory.php | 35 |
1 files changed, 24 insertions, 11 deletions
diff --git a/lib/private/DB/ConnectionFactory.php b/lib/private/DB/ConnectionFactory.php index f5b8a9d3c2f..9fc2ed42c33 100644 --- a/lib/private/DB/ConnectionFactory.php +++ b/lib/private/DB/ConnectionFactory.php @@ -193,17 +193,7 @@ class ConnectionFactory { $connectionParams['path'] = $dataDir . '/' . $name . '.db'; } else { $host = $this->config->getValue('dbhost', ''); - $matches = []; - if (preg_match('/^(.*):([^\]:]+)$/', $host, $matches)) { - // Host variable carries a port or socket. - $host = $matches[1]; - if (is_numeric($matches[2])) { - $connectionParams['port'] = (int) $matches[2]; - } else { - $connectionParams['unix_socket'] = $matches[2]; - } - } - $connectionParams['host'] = $host; + $connectionParams = array_merge($connectionParams, $this->splitHostFromPortAndSocket($host)); $connectionParams['dbname'] = $name; } @@ -233,4 +223,27 @@ class ConnectionFactory { return $connectionParams; } + + /** + * @param string $host + * @return array + */ + protected function splitHostFromPortAndSocket($host): array { + $params = [ + 'host' => $host, + ]; + + $matches = []; + if (preg_match('/^(.*):([^\]:]+)$/', $host, $matches)) { + // Host variable carries a port or socket. + $params['host'] = $matches[1]; + if (is_numeric($matches[2])) { + $params['port'] = (int) $matches[2]; + } else { + $params['unix_socket'] = $matches[2]; + } + } + + return $params; + } } |