2020-10-21 21:47:42 -07:00
package config
2020-06-22 20:11:56 -05:00
import (
"errors"
"fmt"
"os"
2021-01-07 22:45:29 -08:00
"os/exec"
"strings"
2021-01-11 18:31:15 -08:00
log "github.com/sirupsen/logrus"
2021-01-07 22:45:29 -08:00
"golang.org/x/mod/semver"
2020-06-22 20:11:56 -05:00
)
2020-11-13 00:14:59 +01:00
// verifyFFMpegPath verifies that the path exists, is a file, and is executable.
2020-10-21 21:47:42 -07:00
func verifyFFMpegPath ( path string ) error {
2020-06-22 20:11:56 -05:00
stat , err := os . Stat ( path )
if os . IsNotExist ( err ) {
return errors . New ( "ffmpeg path does not exist" )
}
if err != nil {
return fmt . Errorf ( "error while verifying the ffmpeg path: %s" , err . Error ( ) )
}
if stat . IsDir ( ) {
return errors . New ( "ffmpeg path can not be a folder" )
}
mode := stat . Mode ( )
//source: https://stackoverflow.com/a/60128480
if mode & 0111 == 0 {
return errors . New ( "ffmpeg path is not executable" )
}
2021-01-07 22:45:29 -08:00
cmd := exec . Command ( path )
out , err := cmd . CombinedOutput ( )
2021-01-16 17:26:35 -08:00
if err != nil {
return fmt . Errorf ( "unable to determine the version of your ffmpeg installation at %s. you may experience issues with video." , path )
}
2021-01-07 22:45:29 -08:00
response := string ( out )
if response == "" {
return fmt . Errorf ( "unable to determine the version of your ffmpeg installation at %s. you may experience issues with video." , path )
}
responseComponents := strings . Split ( response , " " )
2021-01-11 18:31:15 -08:00
if len ( responseComponents ) < 3 {
log . Debugf ( "unable to determine the version of your ffmpeg installation at %s. you may experience issues with video." , path )
return nil
}
2021-01-07 22:45:29 -08:00
fullVersionString := responseComponents [ 2 ]
2021-01-11 18:31:15 -08:00
2021-01-07 22:45:29 -08:00
versionString := "v" + strings . Split ( fullVersionString , "-" ) [ 0 ]
2021-01-11 18:31:15 -08:00
// Some builds of ffmpeg have wierd build numbers that we can't parse
if ! semver . IsValid ( versionString ) {
log . Debugf ( "unable to determine if ffmpeg version %s is recent enough. if you experience issues with video you may want to look into updating" , fullVersionString )
return nil
}
if semver . Compare ( versionString , FfmpegSuggestedVersion ) == - 1 {
2021-01-08 16:09:00 -08:00
return fmt . Errorf ( "your %s version of ffmpeg at %s may be older than the suggested version of %s. you may experience issues with video." , versionString , path , FfmpegSuggestedVersion )
2021-01-07 22:45:29 -08:00
}
2020-06-22 20:11:56 -05:00
return nil
}