stash/pkg/manager/task_generate_preview.go

55 lines
1.4 KiB
Go
Raw Normal View History

2019-02-10 05:30:54 +00:00
package manager
import (
2019-02-14 23:42:52 +00:00
"github.com/stashapp/stash/pkg/ffmpeg"
"github.com/stashapp/stash/pkg/logger"
"github.com/stashapp/stash/pkg/models"
"github.com/stashapp/stash/pkg/utils"
2019-02-10 05:30:54 +00:00
"sync"
)
type GeneratePreviewTask struct {
Scene models.Scene
}
func (t *GeneratePreviewTask) Start(wg *sync.WaitGroup) {
2019-02-10 20:15:36 +00:00
defer wg.Done()
2019-02-10 05:30:54 +00:00
videoFilename := t.videoFilename()
imageFilename := t.imageFilename()
2019-02-10 20:15:36 +00:00
if t.doesPreviewExist(t.Scene.Checksum) {
2019-02-10 05:30:54 +00:00
return
}
videoFile, err := ffmpeg.NewVideoFile(instance.FFProbePath, t.Scene.Path)
2019-02-10 05:30:54 +00:00
if err != nil {
logger.Errorf("error reading video file: %s", err.Error())
return
}
generator, err := NewPreviewGenerator(*videoFile, videoFilename, imageFilename, instance.Paths.Generated.Screenshots)
if err != nil {
logger.Errorf("error creating preview generator: %s", err.Error())
return
}
if err := generator.Generate(); err != nil {
logger.Errorf("error generating preview: %s", err.Error())
return
}
}
2019-02-10 20:15:36 +00:00
func (t *GeneratePreviewTask) doesPreviewExist(sceneChecksum string) bool {
videoExists, _ := utils.FileExists(instance.Paths.Scene.GetStreamPreviewPath(sceneChecksum))
imageExists, _ := utils.FileExists(instance.Paths.Scene.GetStreamPreviewImagePath(sceneChecksum))
2019-02-10 05:30:54 +00:00
return videoExists && imageExists
}
func (t *GeneratePreviewTask) videoFilename() string {
return t.Scene.Checksum + ".mp4"
}
func (t *GeneratePreviewTask) imageFilename() string {
return t.Scene.Checksum + ".webp"
}