1
Fork 0
photoview/api/database/migration_faces.go

212 lines
5.5 KiB
Go

package database
import (
"fmt"
"github.com/photoview/photoview/api/graphql/models"
// "github.com/pkg/errors"
"gorm.io/gorm"
)
// Migrate face groups
func migrate_face_preview(db *gorm.DB) error {
// err = db.Transaction(func(tx *gorm.DB) error {
var facegroup models.FaceGroup
fmt.Println("Got here")
rows, err := db.Model(&models.FaceGroup{}).Rows()
if err != nil {
return err
}
for rows.Next() {
db.ScanRows(rows, &facegroup)
if err := db.Model(&facegroup).Update("preview_image_face", &facegroup.ImageFaces[0]).Error; err != nil {
return err
}
// fmt.Println(product)
}
// if err := r.Database.Model(&album).Update("cover_id", coverID).Error; err != nil {
// return nil, err
// }
// faceGroupColumns, err := db.Migrator().ColumnTypes(&models.FaceGroup{})
// if err != nil {
// return err
// }
// err = db.Transaction(func(tx *gorm.DB) error {
// for _, faceCol := range faceGroupColumns {
// if faceCol.Name() == "preview_image_face" {
//
//
// switch exifCol.DatabaseTypeName() {
// case "double", "numeric", "real":
// // correct type, do nothing
// default:
// // do migration
// if err := migrate_exif_fields_exposure(db); err != nil {
// return err
// }
// }
// }
//
// if exifCol.Name() == "flash" {
// switch exifCol.DatabaseTypeName() {
// case "double", "numeric", "real":
// // correct type, do nothing
// default:
// // do migration
// if err := migrate_exif_fields_flash(db); err != nil {
// return err
// }
// }
// }
// }
// if err := db.AutoMigrate(&models.MediaEXIF{}); err != nil {
// return errors.Wrap(err, "failed to auto migrate media_exif after exposure conversion")
// }
//
// return nil
// })
// if err != nil {
// return err
// }
return nil
}
// func migrate_exif_fields_exposure(db *gorm.DB) error {
// log.Println("Migrating `media_exif.exposure` from string to double")
//
// err := db.Transaction(func(tx *gorm.DB) error {
//
// if err := tx.Exec("UPDATE media_exif SET exposure = NULL WHERE exposure = ''").Error; err != nil {
// return errors.Wrapf(err, "convert flash attribute empty values to NULL")
// }
//
// type exifModel struct {
// ID int `gorm:"primarykey"`
// Exposure *string
// }
// var results []exifModel
//
// return tx.Model(&exifModel{}).Table("media_exif").Where("exposure LIKE '%/%'").FindInBatches(&results, 100, func(tx *gorm.DB, batch int) error {
// for _, result := range results {
//
// if result.Exposure == nil {
// continue
// }
//
// frac := strings.Split(*result.Exposure, "/")
// if len(frac) != 2 {
// return errors.Errorf("failed to convert exposure value (%s) expected format x/y", frac)
// }
//
// numerator, err := strconv.ParseFloat(frac[0], 64)
// if err != nil {
// return err
// }
//
// denominator, err := strconv.ParseFloat(frac[1], 64)
// if err != nil {
// return err
// }
//
// decimalValue := numerator / denominator
// *result.Exposure = fmt.Sprintf("%f", decimalValue)
// }
//
// tx.Save(&results)
//
// return nil
// }).Error
// })
//
// if err != nil {
// return errors.Wrap(err, "migrating `media_exif.exposure` failed")
// }
//
// return nil
// }
//
// func migrate_exif_fields_flash(db *gorm.DB) error {
// log.Println("Migrating `media_exif.flash` from string to int")
//
// err := db.Transaction(func(tx *gorm.DB) error {
//
// if err := tx.Exec("UPDATE media_exif SET flash = NULL WHERE flash = ''").Error; err != nil {
// return errors.Wrapf(err, "convert flash attribute empty values to NULL")
// }
//
// type exifModel struct {
// ID int `gorm:"primarykey"`
// Flash *string
// }
// var results []exifModel
//
// var flashDescriptions = map[int]string{
// 0x0: "No Flash",
// 0x1: "Fired",
// 0x5: "Fired, Return not detected",
// 0x7: "Fired, Return detected",
// 0x8: "On, Did not fire",
// 0x9: "On, Fired",
// 0xD: "On, Return not detected",
// 0xF: "On, Return detected",
// 0x10: "Off, Did not fire",
// 0x14: "Off, Did not fire, Return not detected",
// 0x18: "Auto, Did not fire",
// 0x19: "Auto, Fired",
// 0x1D: "Auto, Fired, Return not detected",
// 0x1F: "Auto, Fired, Return detected",
// 0x20: "No flash function",
// 0x30: "Off, No flash function",
// 0x41: "Fired, Red-eye reduction",
// 0x45: "Fired, Red-eye reduction, Return not detected",
// 0x47: "Fired, Red-eye reduction, Return detected",
// 0x49: "On, Red-eye reduction",
// 0x4D: "On, Red-eye reduction, Return not detected",
// 0x4F: "On, Red-eye reduction, Return detected",
// 0x50: "Off, Red-eye reduction",
// 0x58: "Auto, Did not fire, Red-eye reduction",
// 0x59: "Auto, Fired, Red-eye reduction",
// 0x5D: "Auto, Fired, Red-eye reduction, Return not detected",
// 0x5F: "Auto, Fired, Red-eye reduction, Return detected",
// }
//
// return tx.Model(&exifModel{}).Table("media_exif").Where("flash IS NOT NULL").FindInBatches(&results, 100, func(tx *gorm.DB, batch int) error {
// for _, result := range results {
//
// if result.Flash == nil {
// continue
// }
//
// for index, name := range flashDescriptions {
// if *result.Flash == name {
// *result.Flash = fmt.Sprintf("%d", index)
// break
// }
// }
// }
//
// tx.Save(&results)
//
// return nil
// }).Error
// })
//
// if err != nil {
// return errors.Wrap(err, "migrating `media_exif.flash` failed")
// }
//
// return nil
// }