navidrome/persistence/db_sql/sql.go

75 lines
1.4 KiB
Go
Raw Normal View History

2020-01-12 23:32:06 +01:00
package db_sql
import (
"os"
"path"
"sync"
"github.com/astaxie/beego/orm"
"github.com/cloudsonic/sonic-server/conf"
"github.com/cloudsonic/sonic-server/log"
_ "github.com/mattn/go-sqlite3"
)
var once sync.Once
func Db() orm.Ormer {
once.Do(func() {
2020-01-13 15:06:11 +01:00
dbPath := conf.Sonic.DbPath
if dbPath == ":memory:" {
dbPath = "file::memory:?cache=shared"
} else {
err := os.MkdirAll(conf.Sonic.DbPath, 0700)
if err != nil {
panic(err)
}
dbPath = path.Join(conf.Sonic.DbPath, "sqlite.db")
2020-01-12 23:32:06 +01:00
}
2020-01-13 15:06:11 +01:00
err := initORM(dbPath)
2020-01-12 23:32:06 +01:00
if err != nil {
panic(err)
}
log.Debug("Opening SQLite DB from: " + dbPath)
})
return orm.NewOrm()
}
func WithTx(block func(orm.Ormer) error) error {
o := orm.NewOrm()
err := o.Begin()
if err != nil {
return err
}
err = block(o)
if err != nil {
err2 := o.Rollback()
if err2 != nil {
return err2
}
return err
}
err2 := o.Commit()
if err2 != nil {
return err2
}
return nil
}
func initORM(dbPath string) error {
orm.Debug = true
orm.RegisterModel(new(Artist))
2020-01-13 00:55:55 +01:00
orm.RegisterModel(new(Album))
2020-01-13 00:36:19 +01:00
orm.RegisterModel(new(MediaFile))
2020-01-13 03:28:47 +01:00
orm.RegisterModel(new(ArtistInfo))
2020-01-13 14:35:12 +01:00
orm.RegisterModel(new(Checksum))
2020-01-13 03:46:40 +01:00
orm.RegisterModel(new(Property))
2020-01-13 03:59:06 +01:00
orm.RegisterModel(new(Playlist))
2020-01-12 23:32:06 +01:00
err := orm.RegisterDataBase("default", "sqlite3", dbPath)
if err != nil {
panic(err)
}
return orm.RunSyncdb("default", false, true)
}