diff --git a/program/lib/Roundcube/rcube_db.php b/program/lib/Roundcube/rcube_db.php index 510d00173..8c5bc1905 100644 --- a/program/lib/Roundcube/rcube_db.php +++ b/program/lib/Roundcube/rcube_db.php @@ -149,10 +149,6 @@ class rcube_db $dsn_string = $this->dsn_string($dsn); $dsn_options = $this->dsn_options($dsn); - if ($this->db_pconn) { - $dsn_options[PDO::ATTR_PERSISTENT] = true; - } - // Connect try { // with this check we skip fatal error on PDO object creation @@ -1271,6 +1267,18 @@ class rcube_db { $result = array(); + if ($this->db_pconn) { + $result[PDO::ATTR_PERSISTENT] = true; + } + + if (!empty($dsn['prefetch'])) { + $result[PDO::ATTR_PREFETCH] = (int) $dsn['prefetch']; + } + + if (!empty($dsn['timeout'])) { + $result[PDO::ATTR_TIMEOUT] = (int) $dsn['timeout']; + } + return $result; } diff --git a/program/lib/Roundcube/rcube_db_mysql.php b/program/lib/Roundcube/rcube_db_mysql.php index b013341f0..ee2194fbf 100644 --- a/program/lib/Roundcube/rcube_db_mysql.php +++ b/program/lib/Roundcube/rcube_db_mysql.php @@ -118,7 +118,7 @@ class rcube_db_mysql extends rcube_db */ protected function dsn_options($dsn) { - $result = array(); + $result = parent::dsn_options($dsn); if (!empty($dsn['key'])) { $result[PDO::MYSQL_ATTR_SSL_KEY] = $dsn['key'];