2025-11-05 16:47:38 +08:00

40 lines
812 B
Go

package data
import (
"database/sql"
"fmt"
"sync"
legacycfg "weatherstation/internal/config"
_ "github.com/lib/pq"
)
var (
dbOnce sync.Once
dbInst *sql.DB
)
// DB returns a shared Postgres connection opened using legacy internal/config.
func DB() *sql.DB {
dbOnce.Do(func() {
cfg := legacycfg.GetConfig().Database
connStr := fmt.Sprintf(
"host=%s port=%d user=%s password=%s dbname=%s sslmode=%s",
cfg.Host, cfg.Port, cfg.User, cfg.Password, cfg.DBName, cfg.SSLMode,
)
d, err := sql.Open("postgres", connStr)
if err != nil {
panic(fmt.Errorf("open DB failed: %w", err))
}
if err := d.Ping(); err != nil {
panic(fmt.Errorf("ping DB failed: %w", err))
}
dbInst = d
})
if dbInst == nil {
panic("database not initialized: check config and drivers")
}
return dbInst
}