summaryrefslogtreecommitdiffstats
path: root/lib/paperclip/image_extractor.rb
diff options
context:
space:
mode:
authorEugen Rochko <eugen@zeonfederated.com>2020-06-30 23:58:02 +0200
committerGitHub <noreply@github.com>2020-06-30 23:58:02 +0200
commit7aaf2b44ec698fd4f20b927fcac7edc0394a2647 (patch)
tree036b96777e1f525b2b76aab36204dee30cfa3345 /lib/paperclip/image_extractor.rb
parent65506bac3f3fe233b5b7b3241020bd74eb5c9259 (diff)
Fix remote files not using Content-Type header, streaming (#14184)
Diffstat (limited to 'lib/paperclip/image_extractor.rb')
-rw-r--r--lib/paperclip/image_extractor.rb45
1 files changed, 25 insertions, 20 deletions
diff --git a/lib/paperclip/image_extractor.rb b/lib/paperclip/image_extractor.rb
index 114852e8b97..f5a54d1a5cd 100644
--- a/lib/paperclip/image_extractor.rb
+++ b/lib/paperclip/image_extractor.rb
@@ -4,28 +4,10 @@ require 'mime/types/columnar'
module Paperclip
class ImageExtractor < Paperclip::Processor
- IMAGE_EXTRACTION_OPTIONS = {
- convert_options: {
- output: {
- 'loglevel' => 'fatal',
- vf: 'scale=\'min(400\, iw):min(400\, ih)\':force_original_aspect_ratio=decrease',
- }.freeze,
- }.freeze,
- format: 'png',
- time: -1,
- file_geometry_parser: FastGeometryParser,
- }.freeze
-
def make
return @file unless options[:style] == :original
- image = begin
- begin
- Paperclip::Transcoder.make(file, IMAGE_EXTRACTION_OPTIONS.dup, attachment)
- rescue Paperclip::Error, ::Av::CommandError
- nil
- end
- end
+ image = extract_image_from_file!
unless image.nil?
begin
@@ -36,7 +18,7 @@ module Paperclip
# to make sure it's cleaned up
begin
- FileUtils.rm(image)
+ image.close(true)
rescue Errno::ENOENT
nil
end
@@ -45,5 +27,28 @@ module Paperclip
@file
end
+
+ private
+
+ def extract_image_from_file!
+ ::Av.logger = Paperclip.logger
+
+ cli = ::Av.cli
+ dst = Tempfile.new([File.basename(@file.path, '.*'), '.png'])
+ dst.binmode
+
+ cli.add_source(@file.path)
+ cli.add_destination(dst.path)
+ cli.add_output_param loglevel: 'fatal'
+
+ begin
+ cli.run
+ rescue Cocaine::ExitStatusError
+ dst.close(true)
+ return nil
+ end
+
+ dst
+ end
end
end