Files
gocryptotrader/cmd/dbseed/database.go
Adrian Gallagher f5faca2eb2 linter: Enable gofumpt and run against codebase (#1848)
* linter: Enable gofumpt and run against codebase

* Address shazbert's nits

* gofumpt: Fix issues after rebase
2025-03-18 10:23:16 +11:00

63 lines
1.7 KiB
Go

package main
import (
"errors"
"fmt"
"github.com/thrasher-corp/gocryptotrader/config"
"github.com/thrasher-corp/gocryptotrader/database"
dbPSQL "github.com/thrasher-corp/gocryptotrader/database/drivers/postgres"
dbsqlite3 "github.com/thrasher-corp/gocryptotrader/database/drivers/sqlite3"
"github.com/thrasher-corp/gocryptotrader/database/repository"
"github.com/thrasher-corp/sqlboiler/boil"
"github.com/urfave/cli/v2"
)
var dbConn *database.Instance
func load(c *cli.Context) error {
var conf config.Config
err := conf.LoadConfig(c.String("config"), true)
if err != nil {
return err
}
if !conf.Database.Enabled {
return database.ErrDatabaseSupportDisabled
}
err = openDBConnection(c, &conf.Database)
if err != nil {
return err
}
drv := repository.GetSQLDialect()
if drv == database.DBSQLite || drv == database.DBSQLite3 {
fmt.Printf("Database file: %s\n", conf.Database.Database)
} else {
fmt.Printf("Connected to: %s\n", conf.Database.Host)
}
return nil
}
func openDBConnection(c *cli.Context, cfg *database.Config) (err error) {
if c.IsSet("verbose") {
boil.DebugMode = true
}
if cfg.Driver == database.DBPostgreSQL {
dbConn, err = dbPSQL.Connect(cfg)
if err != nil {
return fmt.Errorf("database failed to connect: %v, some features that utilise a database will be unavailable", err)
}
return nil
} else if cfg.Driver == database.DBSQLite || cfg.Driver == database.DBSQLite3 {
dbConn, err = dbsqlite3.Connect(cfg.Database)
if err != nil {
return fmt.Errorf("database failed to connect: %v, some features that utilise a database will be unavailable", err)
}
return nil
}
return errors.New("no connection established")
}