45 lines
1000 B
Go
Raw Permalink Normal View History

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-12-04 17:27:49 -08:00
if err := db.AutoMigrate(
&model.Submission{},
&model.Script{},
&model.ScriptPolicy{},
); err != nil {
2024-11-26 18:30:58 -05:00
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
}