diff options
author | Aleksander Machniak <alec@alec.pl> | 2013-05-29 19:36:33 +0200 |
---|---|---|
committer | Aleksander Machniak <alec@alec.pl> | 2013-05-29 19:36:33 +0200 |
commit | d0962105043df3521cd07fbac80344a09b46124d (patch) | |
tree | 62955f3358ebbe575464d49e39bc7ad03780b716 | |
parent | 335ecfe6eb953ea3ac9138c9235268fc1464002e (diff) |
Fix connection to posgtres db using unix socket (#1489132)
-rw-r--r-- | CHANGELOG | 1 | ||||
-rw-r--r-- | program/lib/Roundcube/rcube_db_pgsql.php | 34 |
2 files changed, 35 insertions, 0 deletions
@@ -1,6 +1,7 @@ CHANGELOG Roundcube Webmail =========================== +- Fix connection to posgtres db using unix socket (#1489132) - Implemented shared cache (rcube_cache_shared) - Fix handling of comma when adding contact from contacts widget (#1489107) - Fix bug where a message was opened in both preview pane and new window on double-click (#1489122) diff --git a/program/lib/Roundcube/rcube_db_pgsql.php b/program/lib/Roundcube/rcube_db_pgsql.php index adfd2207b..90adf4bad 100644 --- a/program/lib/Roundcube/rcube_db_pgsql.php +++ b/program/lib/Roundcube/rcube_db_pgsql.php @@ -130,4 +130,38 @@ class rcube_db_pgsql extends rcube_db return isset($this->variables[$varname]) ? $this->variables[$varname] : $default; } + /** + * Returns PDO DSN string from DSN array + * + * @param array $dsn DSN parameters + * + * @return string DSN string + */ + protected function dsn_string($dsn) + { + $params = array(); + $result = 'pgsql:'; + + if ($dsn['hostspec']) { + $params[] = 'host=' . $dsn['hostspec']; + } + else if ($dsn['socket']) { + $params[] = 'host=' . $dsn['socket']; + } + + if ($dsn['port']) { + $params[] = 'port=' . $dsn['port']; + } + + if ($dsn['database']) { + $params[] = 'dbname=' . $dsn['database']; + } + + if (!empty($params)) { + $result .= implode(';', $params); + } + + return $result; + } + } |