]> cat aescling's git repositories - mastodon.git/commitdiff
Detect extname from Content-Type (#7733)
authorYamagishi Kazutoshi <ykzts@desire.sh>
Mon, 4 Jun 2018 16:58:36 +0000 (01:58 +0900)
committerEugen Rochko <eugen@zeonfederated.com>
Mon, 4 Jun 2018 16:58:36 +0000 (18:58 +0200)
app/models/concerns/remotable.rb

index c17f04776019aa2eb6f7a40ef0137a28b3c67e1b..dc2e12b67c5ffce82cec8042c09f5418fb0b4809 100644 (file)
@@ -24,14 +24,16 @@ module Remotable
           Request.new(:get, url).perform do |response|
             next if response.code != 200
 
-            matches  = response.headers['content-disposition']&.match(/filename="([^"]*)"/)
-            filename = matches.nil? ? parsed_url.path.split('/').last : matches[1]
+            content_type = parse_content_type(response.headers['content-type'])
+            extname      = detect_extname_from_content_type(content_type)
+
+            if extname.nil?
+              matches  = response.headers['content-disposition']&.match(/filename="([^"]*)"/)
+              filename = matches.nil? ? parsed_url.path.split('/').last : matches[1]
+              extname  = filename.nil? ? '' : File.extname(filename)
+            end
+
             basename = SecureRandom.hex(8)
-            extname = if filename.nil?
-                        ''
-                      else
-                        File.extname(filename)
-                      end
 
             send("#{attachment_name}=", StringIO.new(response.body_with_limit(limit)))
             send("#{attachment_name}_file_name=", basename + extname)
@@ -57,4 +59,22 @@ module Remotable
       end
     end
   end
+
+  private
+
+  def detect_extname_from_content_type(content_type)
+    return if content_type.nil?
+
+    type = MIME::Types[content_type].first
+
+    return if type.nil?
+
+    type.extensions.first
+  end
+
+  def parse_content_type(content_type)
+    return if content_type.nil?
+
+    content_type.split(/\s*;\s*/).first
+  end
 end