1
0
Fork 0
mirror of https://github.com/thomiceli/opengist.git synced 2025-01-25 15:20:36 +00:00
opengist/internal/db/db.go

92 lines
1.8 KiB
Go
Raw Normal View History

2023-09-03 00:30:57 +02:00
package db
2023-03-14 16:22:52 +01:00
import (
"errors"
"slices"
"strings"
msqlite "github.com/glebarez/go-sqlite"
"github.com/glebarez/sqlite"
2023-06-09 15:25:41 +02:00
"github.com/rs/zerolog/log"
"github.com/thomiceli/opengist/internal/config"
2023-03-14 16:22:52 +01:00
"gorm.io/gorm"
"gorm.io/gorm/logger"
)
var db *gorm.DB
2023-09-17 00:59:47 +02:00
func Setup(dbPath string, sharedCache bool) error {
2023-03-14 16:22:52 +01:00
var err error
2023-06-09 15:25:41 +02:00
journalMode := strings.ToUpper(config.C.SqliteJournalMode)
2023-03-14 16:22:52 +01:00
if !slices.Contains([]string{"DELETE", "TRUNCATE", "PERSIST", "MEMORY", "WAL", "OFF"}, journalMode) {
2023-06-09 15:25:41 +02:00
log.Warn().Msg("Invalid SQLite journal mode: " + journalMode)
}
2023-09-17 00:59:47 +02:00
sharedCacheStr := ""
if sharedCache {
sharedCacheStr = "&cache=shared"
}
if db, err = gorm.Open(sqlite.Open(dbPath+"?_fk=true&_journal_mode="+journalMode+sharedCacheStr), &gorm.Config{
2023-03-14 16:22:52 +01:00
Logger: logger.Default.LogMode(logger.Silent),
}); err != nil {
return err
}
2023-06-21 18:19:17 +02:00
if err = db.SetupJoinTable(&Gist{}, "Likes", &Like{}); err != nil {
return err
}
if err = db.SetupJoinTable(&User{}, "Liked", &Like{}); err != nil {
return err
}
if err = db.AutoMigrate(&User{}, &Gist{}, &SSHKey{}, &AdminSetting{}); err != nil {
2023-03-14 16:22:52 +01:00
return err
}
2023-09-17 02:55:17 +02:00
if err = ApplyMigrations(db); err != nil {
return err
}
// Default admin setting values
return initAdminSettings(map[string]string{
SettingDisableSignup: "0",
SettingRequireLogin: "0",
SettingDisableLoginForm: "0",
SettingDisableGravatar: "0",
})
2023-03-14 16:22:52 +01:00
}
2023-09-17 00:59:47 +02:00
func Close() error {
sqlDB, err := db.DB()
if err != nil {
return err
}
return sqlDB.Close()
}
2023-03-14 16:22:52 +01:00
func CountAll(table interface{}) (int64, error) {
var count int64
err := db.Model(table).Count(&count).Error
return count, err
}
func IsUniqueConstraintViolation(err error) bool {
var sqliteErr *msqlite.Error
if errors.As(err, &sqliteErr) && sqliteErr.Code() == 2067 {
return true
}
return false
}
2023-12-16 01:27:00 +01:00
func Ping() error {
sql, err := db.DB()
if err != nil {
return err
}
return sql.Ping()
}