move db connection process to seperate file

This commit is contained in:
2025-01-11 01:23:36 +01:00
parent bda62c508e
commit e4e88caaa7
2 changed files with 49 additions and 33 deletions

View File

@@ -2,11 +2,8 @@ package main
import ( import (
"crowsnest/internal/model/database" "crowsnest/internal/model/database"
"database/sql"
"fmt"
"log" "log"
"net/http" "net/http"
"os"
_ "github.com/lib/pq" _ "github.com/lib/pq"
) )
@@ -16,35 +13,9 @@ type App struct {
} }
func main() { func main() {
// collect environement variables db, err := database.DbConnection()
dbPass := os.Getenv("DB_PASS")
if dbPass == "" {
log.Fatal("empty DB_PASS")
}
dbHost := os.Getenv("DB_HOST")
if dbHost == "" {
log.Fatal("empty DB_HOST")
}
dbPort := os.Getenv("DB_PORT")
if dbPort == "" {
dbPort = "5432"
}
dbUser := os.Getenv("DB_USER")
if dbUser == "" {
dbUser = "postgres"
}
dbName := os.Getenv("DB_NAME")
// connect to database
databaseURL := fmt.Sprintf("user=%s password=%s dbname=%s host=%s port=%s sslmode=disable",
dbUser, dbPass, dbName, dbHost, dbPort)
db, err := sql.Open("postgres", databaseURL)
if err != nil { if err != nil {
log.Fatal(err) log.Fatal("failed to connect to database due to", err.Error())
}
defer db.Close()
if err = db.Ping(); err != nil {
log.Fatal(err)
} }
// define app // define app
@@ -54,10 +25,10 @@ func main() {
// start web server // start web server
server := http.Server{ server := http.Server{
Addr: ":8080", Addr: ":80",
Handler: app.routes(), Handler: app.routes(),
} }
log.Println("server started, listening on :8080") log.Println("server started, listening on :80")
server.ListenAndServe() server.ListenAndServe()
} }

View File

@@ -0,0 +1,45 @@
package database
import (
"database/sql"
"errors"
"fmt"
"os"
)
// Will try to connect to the database defined by the env variables. If the
// connection fails a error will be returned. Ensure that the returned sql.DB
// object is closed after use.
func DbConnection() (*sql.DB, error) {
// collect environement variables
dbPass := os.Getenv("DB_PASS")
if dbPass == "" {
return nil, errors.New("empty env. variable DB_PASS")
}
dbHost := os.Getenv("DB_HOST")
if dbHost == "" {
return nil, errors.New("empty env. variable DB_HOST")
}
dbPort := os.Getenv("DB_PORT")
if dbPort == "" {
dbPort = "5432"
}
dbUser := os.Getenv("DB_USER")
if dbUser == "" {
dbUser = "postgres"
}
dbName := os.Getenv("DB_NAME")
// connect to database
databaseURL := fmt.Sprintf("user=%s password=%s dbname=%s host=%s port=%s sslmode=disable",
dbUser, dbPass, dbName, dbHost, dbPort)
db, err := sql.Open("postgres", databaseURL)
if err != nil {
return nil, err
}
if err = db.Ping(); err != nil {
return nil, err
}
return db, nil
}