Base Flutter Project
This commit is contained in:
40
internal/db/db.go
Normal file
40
internal/db/db.go
Normal file
@@ -0,0 +1,40 @@
|
||||
package db
|
||||
|
||||
import (
|
||||
"gorm.io/driver/sqlite"
|
||||
"gorm.io/gorm"
|
||||
)
|
||||
|
||||
func OpenDB(data) *gorm.DB {
|
||||
database, _ := gorm.Open(sqlite.Open("./db/imagini.db"), &gorm.Config{
|
||||
PrepareStmt: true,
|
||||
})
|
||||
|
||||
// Initialize Database
|
||||
database.AutoMigrate(&ServerSetting{})
|
||||
database.AutoMigrate(&User{})
|
||||
database.AutoMigrate(&MediaItem{})
|
||||
database.AutoMigrate(&Tag{})
|
||||
database.AutoMigrate(&Album{})
|
||||
|
||||
return database
|
||||
}
|
||||
|
||||
func ItemsFromAlbum(userID int, albumID int) []MediaItem {
|
||||
database, _ := gorm.Open(sqlite.Open("./db/imagini.db"), &gorm.Config{})
|
||||
database.Raw(`
|
||||
SELECT
|
||||
MediaItems.*
|
||||
FROM
|
||||
MediaAlbums
|
||||
INNER JOIN MediaItems ON MediaAlbums.mediaID = MediaItems.mediaID
|
||||
WHERE MediaAlbums.albumID = ? AND MediaItems.userID = ?`, albumID, userID)
|
||||
return nil
|
||||
}
|
||||
|
||||
func ItemsFromTags(userID int, tagID int) []MediaItem {
|
||||
return nil
|
||||
}
|
||||
|
||||
func IndexMediaItems(newItems []MediaItem) {
|
||||
}
|
||||
45
internal/db/models.go
Normal file
45
internal/db/models.go
Normal file
@@ -0,0 +1,45 @@
|
||||
package db
|
||||
|
||||
import (
|
||||
"gorm.io/gorm"
|
||||
"time"
|
||||
)
|
||||
|
||||
type ServerSetting struct {
|
||||
gorm.Model
|
||||
Name string
|
||||
Description string
|
||||
Value string
|
||||
}
|
||||
|
||||
type User struct {
|
||||
gorm.Model
|
||||
Name string
|
||||
Email string
|
||||
AuthType string
|
||||
Salt string
|
||||
HashedPWSalt string
|
||||
MediaItems []MediaItem
|
||||
}
|
||||
|
||||
type MediaItem struct {
|
||||
gorm.Model
|
||||
User User
|
||||
EXIFDate time.Time
|
||||
Latitude string
|
||||
Longitude string
|
||||
MediaType uint
|
||||
RelPath string
|
||||
Tags []Tag `gorm:"many2many:media_tags;"`
|
||||
Albums []Album `gorm:"many2many:media_albums;"`
|
||||
}
|
||||
|
||||
type Tag struct {
|
||||
gorm.Model
|
||||
Name string
|
||||
}
|
||||
|
||||
type Album struct {
|
||||
gorm.Model
|
||||
Name string
|
||||
}
|
||||
Reference in New Issue
Block a user