Files
vt/utils/db.go
2026-01-22 17:39:04 +01:00

43 lines
1.1 KiB
Go

package utils
// Keep (used in cmd/api/main.go)
// Database utilities for GORM
// using PostgreSQL driver and OpenTelemetry tracing
import (
"log/slog"
"os"
"git.kocoder.xyz/kocoded/vt/model"
"gorm.io/driver/postgres"
"gorm.io/gorm"
"gorm.io/plugin/opentelemetry/tracing"
)
func NewDB(logger *slog.Logger) *gorm.DB {
db, err := gorm.Open(postgres.Open(os.Getenv("DB_DSN")), &gorm.Config{})
if err != nil {
logger.Error("Error connecting to the Database", "error", err)
}
if err := db.Use(tracing.NewPlugin()); err != nil {
panic(err)
}
err = db.SetupJoinTable(model.Ansprechpartner{}, "Firmen", model.FirmaAnsprechpartner{})
if err != nil {
logger.Error("Error setting up Join Tables", "error", err)
}
err = db.SetupJoinTable(model.Firma{}, "Ansprechpartner", model.FirmaAnsprechpartner{})
if err != nil {
logger.Error("Error setting up Join Tables", "error", err)
}
err = db.AutoMigrate(&model.Mandant{}, &model.User{}, &model.Ansprechpartner{}, &model.FirmaAnsprechpartner{}, &model.Firma{}, &model.Projekt{}, &model.Task{})
if err != nil {
logger.Error("Error setting up Join Tables", "error", err)
}
return db
}