Fix MP4 (H264 + AAC) video files being needlessly re-encoded (#13239)
This commit is contained in:
parent
57d98b20f2
commit
abd8394880
2 changed files with 29 additions and 5 deletions
|
@ -5,12 +5,20 @@ module Paperclip
|
|||
# to check when uploaded videos are actually gifv's
|
||||
class VideoTranscoder < Paperclip::Processor
|
||||
def make
|
||||
meta = ::Av.cli.identify(@file.path)
|
||||
movie = FFMPEG::Movie.new(@file.path)
|
||||
actual_options = options
|
||||
passthrough_options = actual_options[:passthrough_options]
|
||||
actual_options = passthrough_options[:options] if passthrough?(movie, passthrough_options)
|
||||
|
||||
attachment.instance.type = MediaAttachment.types[:gifv] unless meta[:audio_encode]
|
||||
options[:format] = File.extname(attachment.instance.file_file_name)[1..-1] if options[:keep_same_format]
|
||||
attachment.instance.type = MediaAttachment.types[:gifv] unless movie.audio_codec
|
||||
|
||||
Paperclip::Transcoder.make(file, options, attachment)
|
||||
Paperclip::Transcoder.make(file, actual_options, attachment)
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def passthrough?(movie, options)
|
||||
options && options[:video_codec_whitelist].include?(movie.video_codec) && options[:audio_codec_whitelist].include?(movie.audio_codec)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue