mirror of
https://github.com/stashapp/stash.git
synced 2025-12-06 08:26:00 +01:00
* Move BackupDatabase and AnonymiseDatabase to internal/manager * Rename config.Instance to config.Config * Rename FFMPEG * Rework manager and initialization process * Fix Makefile * Tweak phasher * Fix config races * Fix setup error not clearing
55 lines
1.2 KiB
Go
55 lines
1.2 KiB
Go
package manager
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/stashapp/stash/pkg/hash/videophash"
|
|
"github.com/stashapp/stash/pkg/logger"
|
|
"github.com/stashapp/stash/pkg/models"
|
|
)
|
|
|
|
type GeneratePhashTask struct {
|
|
repository models.Repository
|
|
File *models.VideoFile
|
|
Overwrite bool
|
|
fileNamingAlgorithm models.HashAlgorithm
|
|
}
|
|
|
|
func (t *GeneratePhashTask) GetDescription() string {
|
|
return fmt.Sprintf("Generating phash for %s", t.File.Path)
|
|
}
|
|
|
|
func (t *GeneratePhashTask) Start(ctx context.Context) {
|
|
if !t.required() {
|
|
return
|
|
}
|
|
|
|
hash, err := videophash.Generate(instance.FFMpeg, t.File)
|
|
if err != nil {
|
|
logger.Errorf("error generating phash: %s", err.Error())
|
|
logErrorOutput(err)
|
|
return
|
|
}
|
|
|
|
r := t.repository
|
|
if err := r.WithTxn(ctx, func(ctx context.Context) error {
|
|
hashValue := int64(*hash)
|
|
t.File.Fingerprints = t.File.Fingerprints.AppendUnique(models.Fingerprint{
|
|
Type: models.FingerprintTypePhash,
|
|
Fingerprint: hashValue,
|
|
})
|
|
|
|
return r.File.Update(ctx, t.File)
|
|
}); err != nil && ctx.Err() == nil {
|
|
logger.Errorf("Error setting phash: %v", err)
|
|
}
|
|
}
|
|
|
|
func (t *GeneratePhashTask) required() bool {
|
|
if t.Overwrite {
|
|
return true
|
|
}
|
|
|
|
return t.File.Fingerprints.Get(models.FingerprintTypePhash) == nil
|
|
}
|