garm/database/sql/sql.go

53 lines
861 B
Go
Raw Normal View History

2022-04-25 00:03:26 +00:00
package sql
import (
"context"
"garm/config"
"garm/database/common"
"garm/util"
2022-04-25 00:03:26 +00:00
"github.com/pkg/errors"
"gorm.io/gorm"
)
func NewSQLDatabase(ctx context.Context, cfg config.Database) (common.Store, error) {
conn, err := util.NewDBConn(cfg)
if err != nil {
return nil, errors.Wrap(err, "creating DB connection")
}
db := &sqlDatabase{
conn: conn,
ctx: ctx,
cfg: cfg,
}
if err := db.migrateDB(); err != nil {
return nil, errors.Wrap(err, "migrating database")
}
return db, nil
}
type sqlDatabase struct {
conn *gorm.DB
ctx context.Context
cfg config.Database
}
func (s *sqlDatabase) migrateDB() error {
if err := s.conn.AutoMigrate(
&Tag{},
&Pool{},
&Repository{},
&Organization{},
2022-04-26 20:29:58 +00:00
&Address{},
2022-05-03 19:49:14 +00:00
&InstanceStatusUpdate{},
2022-04-26 20:29:58 +00:00
&Instance{},
2022-04-28 16:13:20 +00:00
&ControllerInfo{},
&User{},
2022-04-25 00:03:26 +00:00
); err != nil {
return err
}
return nil
}