2020-08-06 01:21:14 +00:00
|
|
|
package manager
|
|
|
|
|
|
|
|
import (
|
2021-01-18 01:23:20 +00:00
|
|
|
"context"
|
2020-08-06 01:21:14 +00:00
|
|
|
"errors"
|
|
|
|
|
|
|
|
"github.com/spf13/viper"
|
|
|
|
"github.com/stashapp/stash/pkg/logger"
|
|
|
|
"github.com/stashapp/stash/pkg/manager/config"
|
|
|
|
"github.com/stashapp/stash/pkg/models"
|
|
|
|
)
|
|
|
|
|
2021-01-18 01:23:20 +00:00
|
|
|
func setInitialMD5Config(txnManager models.TransactionManager) {
|
2020-08-06 01:21:14 +00:00
|
|
|
// if there are no scene files in the database, then default the
|
|
|
|
// VideoFileNamingAlgorithm config setting to oshash and calculateMD5 to
|
|
|
|
// false, otherwise set them to true for backwards compatibility purposes
|
2021-01-18 01:23:20 +00:00
|
|
|
var count int
|
|
|
|
if err := txnManager.WithReadTxn(context.TODO(), func(r models.ReaderRepository) error {
|
|
|
|
var err error
|
|
|
|
count, err = r.Scene().Count()
|
|
|
|
return err
|
|
|
|
}); err != nil {
|
2020-08-06 01:21:14 +00:00
|
|
|
logger.Errorf("Error while counting scenes: %s", err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
usingMD5 := count != 0
|
|
|
|
defaultAlgorithm := models.HashAlgorithmOshash
|
|
|
|
|
|
|
|
if usingMD5 {
|
|
|
|
defaultAlgorithm = models.HashAlgorithmMd5
|
|
|
|
}
|
|
|
|
|
|
|
|
viper.SetDefault(config.VideoFileNamingAlgorithm, defaultAlgorithm)
|
|
|
|
viper.SetDefault(config.CalculateMD5, usingMD5)
|
|
|
|
|
|
|
|
if err := config.Write(); err != nil {
|
|
|
|
logger.Errorf("Error while writing configuration file: %s", err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ValidateVideoFileNamingAlgorithm validates changing the
|
|
|
|
// VideoFileNamingAlgorithm configuration flag.
|
|
|
|
//
|
|
|
|
// If setting VideoFileNamingAlgorithm to MD5, then this function will ensure
|
|
|
|
// that all checksum values are set on all scenes.
|
|
|
|
//
|
|
|
|
// Likewise, if VideoFileNamingAlgorithm is set to oshash, then this function
|
|
|
|
// will ensure that all oshash values are set on all scenes.
|
2021-01-18 01:23:20 +00:00
|
|
|
func ValidateVideoFileNamingAlgorithm(txnManager models.TransactionManager, newValue models.HashAlgorithm) error {
|
2020-08-06 01:21:14 +00:00
|
|
|
// if algorithm is being set to MD5, then all checksums must be present
|
2021-01-18 01:23:20 +00:00
|
|
|
return txnManager.WithReadTxn(context.TODO(), func(r models.ReaderRepository) error {
|
|
|
|
qb := r.Scene()
|
|
|
|
if newValue == models.HashAlgorithmMd5 {
|
|
|
|
missingMD5, err := qb.CountMissingChecksum()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-06 01:21:14 +00:00
|
|
|
|
2021-01-18 01:23:20 +00:00
|
|
|
if missingMD5 > 0 {
|
|
|
|
return errors.New("some checksums are missing on scenes. Run Scan with calculateMD5 set to true")
|
|
|
|
}
|
|
|
|
} else if newValue == models.HashAlgorithmOshash {
|
|
|
|
missingOSHash, err := qb.CountMissingOSHash()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-08-06 01:21:14 +00:00
|
|
|
|
2021-01-18 01:23:20 +00:00
|
|
|
if missingOSHash > 0 {
|
|
|
|
return errors.New("some oshash values are missing on scenes. Run Scan to populate")
|
|
|
|
}
|
2020-08-06 01:21:14 +00:00
|
|
|
}
|
|
|
|
|
2021-01-18 01:23:20 +00:00
|
|
|
return nil
|
|
|
|
})
|
2020-08-06 01:21:14 +00:00
|
|
|
}
|