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