This repository has been archived on 2023-11-13. You can view files and clone it, but cannot push or open issues or pull requests.
imagini/internal/db/db.go

87 lines
2.2 KiB
Go
Raw Normal View History

2021-01-16 22:00:17 +00:00
package db
2021-01-06 19:36:09 +00:00
import (
2021-01-08 02:45:59 +00:00
"path"
"gorm.io/gorm"
2021-01-10 00:44:02 +00:00
"gorm.io/gorm/logger"
2021-01-08 02:45:59 +00:00
"gorm.io/driver/sqlite"
2021-01-12 22:06:27 +00:00
log "github.com/sirupsen/logrus"
2021-01-08 02:45:59 +00:00
"reichard.io/imagini/internal/config"
2021-01-10 00:44:02 +00:00
"reichard.io/imagini/internal/models"
2021-01-06 19:36:09 +00:00
)
2021-01-16 22:00:17 +00:00
type DBManager struct {
db *gorm.DB
}
func NewMgr(c *config.Config) *DBManager {
2021-01-10 00:44:02 +00:00
gormConfig := &gorm.Config{
PrepareStmt: true,
Logger: logger.Default.LogMode(logger.Silent),
}
2021-01-16 22:00:17 +00:00
// Create manager
dbm := &DBManager{}
2021-01-06 19:36:09 +00:00
2021-01-08 02:45:59 +00:00
if c.DBType == "SQLite" {
dbLocation := path.Join(c.ConfigPath, "imagini.db")
2021-01-16 22:00:17 +00:00
dbm.db, _ = gorm.Open(sqlite.Open(dbLocation), gormConfig)
2021-01-08 02:45:59 +00:00
} else {
2021-01-12 22:06:27 +00:00
log.Fatal("Unsupported Database")
2021-01-08 02:45:59 +00:00
}
2021-01-06 19:36:09 +00:00
2021-01-12 22:06:27 +00:00
// Initialize database
2021-01-16 22:00:17 +00:00
dbm.db.AutoMigrate(&models.ServerSetting{})
2021-01-18 04:56:56 +00:00
dbm.db.AutoMigrate(&models.Device{})
2021-01-16 22:00:17 +00:00
dbm.db.AutoMigrate(&models.User{})
dbm.db.AutoMigrate(&models.MediaItem{})
dbm.db.AutoMigrate(&models.Tag{})
dbm.db.AutoMigrate(&models.Album{})
2021-01-12 22:06:27 +00:00
// Determine whether to bootstrap
var count int64
2021-01-16 22:00:17 +00:00
dbm.db.Model(&models.User{}).Count(&count)
2021-01-12 22:06:27 +00:00
if count == 0 {
2021-01-16 22:00:17 +00:00
dbm.bootstrapDatabase()
2021-01-12 22:06:27 +00:00
}
2021-01-16 22:00:17 +00:00
return dbm
2021-01-06 19:36:09 +00:00
}
2021-01-16 22:00:17 +00:00
func (dbm *DBManager) bootstrapDatabase() {
2021-01-12 22:06:27 +00:00
log.Info("[query] Bootstrapping database.")
2021-01-16 22:00:17 +00:00
err := dbm.CreateUser(models.User{
2021-01-12 22:06:27 +00:00
Username: "admin",
Password: "admin",
AuthType: "Local",
})
if err != nil {
log.Fatal("[query] Unable to bootstrap database.")
}
}
2021-01-16 22:00:17 +00:00
func (dbm *DBManager) ItemsFromAlbum(user models.User, album models.Album) []models.MediaItem {
2021-01-10 00:44:02 +00:00
var mediaItems []models.MediaItem
2021-01-08 02:45:59 +00:00
// db.Table("media_albums").
// Select("media_item.*").
// Joins("INNER JOIN media_items ON media_albums.ID = media_items.Albums").
// Where("media_albums.album_id = ? AND media_items.User = ?", albumID, userID).
2021-01-16 22:00:17 +00:00
dbm.db.
2021-01-08 02:45:59 +00:00
//Where("album = ? AND user = ?", albumID, userID).
Find(&mediaItems)
return mediaItems
// db.Raw(`
// SELECT
// MediaItems.*
// FROM
// MediaAlbums
// INNER JOIN MediaItems ON MediaAlbums.mediaID = MediaItems.mediaID
// WHERE MediaAlbums.albumID = ? AND MediaItems.userID = ?`, albumID, userID)
2021-01-06 19:36:09 +00:00
}