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)
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