Refactored thumbnail generation with configurable timeout and in-sycn with video transcoding
This commit is contained in:
parent
7fa7a38167
commit
8727285bc5
5 changed files with 57 additions and 32 deletions
23
app/app.go
23
app/app.go
|
@ -241,6 +241,8 @@ func (a *App) uploadHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
a.Library.Paths[collection].Path,
|
a.Library.Paths[collection].Path,
|
||||||
fmt.Sprintf("%s.mp4", shortuuid.New()),
|
fmt.Sprintf("%s.mp4", shortuuid.New()),
|
||||||
)
|
)
|
||||||
|
thumbFn1 := fmt.Sprintf("%s.jpg", strings.TrimSuffix(tf.Name(), filepath.Ext(tf.Name())))
|
||||||
|
thumbFn2 := fmt.Sprintf("%s.jpg", strings.TrimSuffix(vf, filepath.Ext(vf)))
|
||||||
|
|
||||||
// TODO: Use a proper Job Queue and make this async
|
// TODO: Use a proper Job Queue and make this async
|
||||||
if err := utils.RunCmd(
|
if err := utils.RunCmd(
|
||||||
|
@ -260,6 +262,27 @@ func (a *App) uploadHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := utils.RunCmd(
|
||||||
|
a.Config.Thumbnailer.Timeout,
|
||||||
|
"mt",
|
||||||
|
"-b",
|
||||||
|
"-s",
|
||||||
|
"-n", "1",
|
||||||
|
tf.Name(),
|
||||||
|
); err != nil {
|
||||||
|
err := fmt.Errorf("error generating thumbnail: %w", err)
|
||||||
|
log.Error(err)
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := os.Rename(thumbFn1, thumbFn2); err != nil {
|
||||||
|
err := fmt.Errorf("error renaming generated thumbnail: %w", err)
|
||||||
|
log.Error(err)
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
if err := os.Rename(tf.Name(), vf); err != nil {
|
if err := os.Rename(tf.Name(), vf); err != nil {
|
||||||
err := fmt.Errorf("error renaming transcoded video: %w", err)
|
err := fmt.Errorf("error renaming transcoded video: %w", err)
|
||||||
log.Error(err)
|
log.Error(err)
|
||||||
|
|
|
@ -7,10 +7,11 @@ import (
|
||||||
|
|
||||||
// Config settings for main App.
|
// Config settings for main App.
|
||||||
type Config struct {
|
type Config struct {
|
||||||
Library []*PathConfig `json:"library"`
|
Library []*PathConfig `json:"library"`
|
||||||
Server *ServerConfig `json:"server"`
|
Server *ServerConfig `json:"server"`
|
||||||
Transcoder *TranscoderConfig `json:"transcoder"`
|
Thumbnailer *ThumbnailerConfig `json:"thumbnailer"`
|
||||||
Feed *FeedConfig `json:"feed"`
|
Transcoder *TranscoderConfig `json:"transcoder"`
|
||||||
|
Feed *FeedConfig `json:"feed"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// PathConfig settings for media library path.
|
// PathConfig settings for media library path.
|
||||||
|
@ -27,6 +28,11 @@ type ServerConfig struct {
|
||||||
UploadPath string `json:"upload_path"`
|
UploadPath string `json:"upload_path"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ThumbnailerConfig settings for Transcoder
|
||||||
|
type ThumbnailerConfig struct {
|
||||||
|
Timeout int `json:"timeout"`
|
||||||
|
}
|
||||||
|
|
||||||
// TranscoderConfig settings for Transcoder
|
// TranscoderConfig settings for Transcoder
|
||||||
type TranscoderConfig struct {
|
type TranscoderConfig struct {
|
||||||
Timeout int `json:"timeout"`
|
Timeout int `json:"timeout"`
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -11,8 +11,11 @@
|
||||||
"store_path": "tube.db",
|
"store_path": "tube.db",
|
||||||
"upload_path": "uploads"
|
"upload_path": "uploads"
|
||||||
},
|
},
|
||||||
|
"thumbnailer": {
|
||||||
|
"timeout": 60
|
||||||
|
},
|
||||||
"transcoder": {
|
"transcoder": {
|
||||||
"timeout": 120
|
"timeout": 300
|
||||||
},
|
},
|
||||||
"feed": {
|
"feed": {
|
||||||
"external_url": "",
|
"external_url": "",
|
||||||
|
|
|
@ -9,9 +9,7 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/apex/log"
|
|
||||||
"github.com/dhowden/tag"
|
"github.com/dhowden/tag"
|
||||||
|
|
||||||
"github.com/wybiral/tube/utils"
|
"github.com/wybiral/tube/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -80,21 +78,16 @@ func ParseVideo(p *Path, name string) (*Video, error) {
|
||||||
if pic != nil {
|
if pic != nil {
|
||||||
v.Thumb = pic.Data
|
v.Thumb = pic.Data
|
||||||
v.ThumbType = pic.MIMEType
|
v.ThumbType = pic.MIMEType
|
||||||
} else if utils.CmdExists("mt") {
|
} else {
|
||||||
thumbFn := fmt.Sprintf("%s.jpg", strings.TrimSuffix(pth, filepath.Ext(pth)))
|
thumbFn := fmt.Sprintf("%s.jpg", strings.TrimSuffix(pth, filepath.Ext(pth)))
|
||||||
if !utils.FileExists(thumbFn) {
|
if utils.FileExists(thumbFn) {
|
||||||
if err := utils.RunCmd(30, "mt", "-b", "-s", "-n", "1", pth); err != nil {
|
data, err := ioutil.ReadFile(fmt.Sprintf("%s.jpg", strings.TrimSuffix(pth, filepath.Ext(pth))))
|
||||||
err := fmt.Errorf("error generating thumbnail: %w", err)
|
if err != nil {
|
||||||
log.Error(err.Error())
|
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
v.Thumb = data
|
||||||
|
v.ThumbType = "image/jpeg"
|
||||||
}
|
}
|
||||||
data, err := ioutil.ReadFile(fmt.Sprintf("%s.jpg", strings.TrimSuffix(pth, filepath.Ext(pth))))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
v.Thumb = data
|
|
||||||
v.ThumbType = "image/jpeg"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return v, nil
|
return v, nil
|
||||||
|
|
Loading…
Reference in a new issue