2024-11-26 13:36:40 -08:00
|
|
|
package gormstore
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2024-11-26 18:30:58 -05:00
|
|
|
"git.itzana.me/strafesnet/maps-service/pkg/datastore"
|
|
|
|
"git.itzana.me/strafesnet/maps-service/pkg/model"
|
2024-11-26 13:36:40 -08:00
|
|
|
"git.itzana.me/strafesnet/utils/logger"
|
|
|
|
log "github.com/sirupsen/logrus"
|
2024-11-26 18:30:58 -05:00
|
|
|
"github.com/urfave/cli/v2"
|
2024-11-26 13:36:40 -08:00
|
|
|
"gorm.io/driver/postgres"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
)
|
|
|
|
|
2024-11-26 18:30:58 -05:00
|
|
|
func New(ctx *cli.Context) (datastore.Datastore, error) {
|
|
|
|
db, err := gorm.Open(
|
|
|
|
postgres.Open(
|
|
|
|
fmt.Sprintf(
|
2024-11-26 16:06:43 -08:00
|
|
|
"host=%s user=%s password=%s dbname=%s port=%d",
|
2024-11-26 18:30:58 -05:00
|
|
|
ctx.String("pg-host"),
|
|
|
|
ctx.String("pg-user"),
|
|
|
|
ctx.String("pg-password"),
|
|
|
|
ctx.String("pg-db"),
|
|
|
|
ctx.Int("pg-port")),
|
|
|
|
), &gorm.Config{
|
|
|
|
Logger: logger.New(),
|
|
|
|
})
|
2024-11-26 13:36:40 -08:00
|
|
|
if err != nil {
|
2024-11-26 18:30:58 -05:00
|
|
|
log.WithError(err).Errorln("failed to connect to database")
|
2024-11-26 13:36:40 -08:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2024-11-26 15:59:52 -08:00
|
|
|
if ctx.Bool("migrate") {
|
2024-11-26 18:30:58 -05:00
|
|
|
if err := db.AutoMigrate(&model.Submission{}); err != nil {
|
|
|
|
log.WithError(err).Errorln("database migration failed")
|
2024-11-26 13:36:40 -08:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-11-26 18:30:58 -05:00
|
|
|
return &Gormstore{db}, nil
|
2024-11-26 13:36:40 -08:00
|
|
|
}
|