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
|
|
|
|
}
|
|
|
|
|
2019-02-11 06:39:21 +00:00
|
|
|
videoFile, err := ffmpeg.NewVideoFile(instance.StaticPaths.FFProbe, 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"
|
2019-02-14 22:53:32 +00:00
|
|
|
}
|