Thomas Bruederli
2013-06-05 42de33c7dee0dc48e54d317eefd4dac18c317e42
program/lib/Roundcube/rcube_db_pgsql.php
@@ -53,19 +53,20 @@
    /**
     * Return correct name for a specific database sequence
     *
     * @param string $sequence Secuence name
     * @param string $table Table name
     *
     * @return string Translated sequence name
     */
    protected function sequence_name($sequence)
    protected function sequence_name($table)
    {
        $rcube = rcube::get_instance();
        // Note: we support only one sequence per table
        // Note: The sequence name must be <table_name>_seq
        $sequence = $table . '_seq';
        $rcube    = rcube::get_instance();
        // return sequence name if configured
        $config_key = 'db_sequence_'.$sequence;
        if ($name = $rcube->config->get($config_key)) {
            return $name;
        if ($prefix = $rcube->config->get('db_prefix')) {
            return $prefix . $sequence;
        }
        return $sequence;
@@ -129,4 +130,38 @@
        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;
    }
}