// VulcanizeDB // Copyright © 2022 Vulcanize // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public License for more details. // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . package postgres import ( "fmt" "strings" "time" ) // DriverType to explicitly type the kind of sql driver we are using type DriverType string const ( PGX DriverType = "PGX" SQLX DriverType = "SQLX" Unknown DriverType = "Unknown" ) // DefaultConfig are default parameters for connecting to a Postgres sql var DefaultConfig = Config{ Hostname: "localhost", Port: 8076, DatabaseName: "vulcanize_testing", Username: "vdbm", Password: "password", Driver: "PGX", } // ResolveDriverType resolves a DriverType from a provided string func ResolveDriverType(str string) (DriverType, error) { switch strings.ToLower(str) { case "pgx", "pgxpool": return PGX, nil case "sqlx": return SQLX, nil default: return Unknown, fmt.Errorf("unrecognized driver type string: %s", str) } } // Config holds params for a Postgres db type Config struct { // conn string params Hostname string Port int DatabaseName string Username string Password string // conn settings MaxConns int MaxIdle int MinConns int MaxConnIdleTime time.Duration MaxConnLifetime time.Duration ConnTimeout time.Duration // driver type Driver DriverType } // DbConnectionString constructs and returns the connection string from the config func (c Config) DbConnectionString() string { if len(c.Username) > 0 && len(c.Password) > 0 { return fmt.Sprintf("postgresql://%s:%s@%s:%d/%s?sslmode=disable", c.Username, c.Password, c.Hostname, c.Port, c.DatabaseName) } if len(c.Username) > 0 && len(c.Password) == 0 { return fmt.Sprintf("postgresql://%s@%s:%d/%s?sslmode=disable", c.Username, c.Hostname, c.Port, c.DatabaseName) } return fmt.Sprintf("postgresql://%s:%d/%s?sslmode=disable", c.Hostname, c.Port, c.DatabaseName) }