66 lines
1.3 KiB
Go
66 lines
1.3 KiB
Go
package database
|
|
|
|
import (
|
|
"log"
|
|
"net/url"
|
|
"os"
|
|
|
|
"github.com/pkg/errors"
|
|
"github.com/viktorstrate/photoview/api/graphql/models"
|
|
|
|
"gorm.io/driver/mysql"
|
|
"gorm.io/gorm"
|
|
"gorm.io/gorm/logger"
|
|
)
|
|
|
|
// SetupDatabase connects to the database using environment variables
|
|
func SetupDatabase() (*gorm.DB, error) {
|
|
|
|
address, err := url.Parse(os.Getenv("MYSQL_URL"))
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "Could not parse mysql url")
|
|
}
|
|
|
|
if address.String() == "" {
|
|
return nil, errors.New("Environment variable MYSQL_URL missing, exiting")
|
|
}
|
|
|
|
queryValues := address.Query()
|
|
queryValues.Add("multiStatements", "true")
|
|
queryValues.Add("parseTime", "true")
|
|
|
|
address.RawQuery = queryValues.Encode()
|
|
|
|
log.Printf("Connecting to database: %s", address)
|
|
|
|
config := gorm.Config{}
|
|
|
|
// Enable database debug logging
|
|
config.Logger = logger.Default.LogMode(logger.Info)
|
|
|
|
db, err := gorm.Open(mysql.Open(address.String()), &config)
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "could not connect to database")
|
|
}
|
|
|
|
// TODO: Add connection retries
|
|
|
|
return db, nil
|
|
}
|
|
|
|
func MigrateDatabase(db *gorm.DB) error {
|
|
|
|
db.AutoMigrate(
|
|
&models.User{},
|
|
&models.AccessToken{},
|
|
&models.SiteInfo{},
|
|
&models.Media{},
|
|
&models.MediaURL{},
|
|
&models.Album{},
|
|
&models.MediaEXIF{},
|
|
&models.VideoMetadata{},
|
|
)
|
|
|
|
return nil
|
|
}
|