Interactive/pkg/internal/database/source.go

32 lines
780 B
Go
Raw Normal View History

2024-02-01 15:26:17 +00:00
package database
import (
"fmt"
2024-11-02 05:41:11 +00:00
"git.solsynth.dev/hydrogen/interactive/pkg/internal/gap"
"git.solsynth.dev/hypernet/nexus/pkg/nex/cruda"
2024-02-01 15:26:17 +00:00
"github.com/rs/zerolog/log"
"github.com/samber/lo"
"github.com/spf13/viper"
"gorm.io/driver/postgres"
"gorm.io/gorm"
"gorm.io/gorm/logger"
)
var C *gorm.DB
func NewGorm() error {
2024-11-02 05:41:11 +00:00
dsn, err := cruda.NewCrudaConn(gap.Nx).AllocDatabase("interactive")
if err != nil {
return fmt.Errorf("failed to alloc database from nexus: %v", err)
}
2024-02-01 15:26:17 +00:00
C, err = gorm.Open(postgres.Open(dsn), &gorm.Config{Logger: logger.New(&log.Logger, logger.Config{
2024-02-01 15:26:17 +00:00
Colorful: true,
IgnoreRecordNotFoundError: true,
2024-03-22 16:41:32 +00:00
LogLevel: lo.Ternary(viper.GetBool("debug.database"), logger.Info, logger.Silent),
2024-02-01 15:26:17 +00:00
})})
return err
}