summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEugen Rochko <eugen@zeonfederated.com>2019-06-20 10:52:36 +0200
committerGitHub <noreply@github.com>2019-06-20 10:52:36 +0200
commit8f23726918fd8ded18ce9e55e6199df87abcc7cf (patch)
tree136a343e791b418fd35354cebc00bca4aecef50f
parent7696f77245c2302787d239da50248385b3292a5e (diff)
Fix converted media being saved with original extension and mime type (#11130)
-rw-r--r--app/models/concerns/attachmentable.rb2
-rw-r--r--app/models/media_attachment.rb8
-rw-r--r--config/application.rb1
-rw-r--r--lib/paperclip/type_corrector.rb19
4 files changed, 26 insertions, 4 deletions
diff --git a/app/models/concerns/attachmentable.rb b/app/models/concerns/attachmentable.rb
index de4cf877577..f4e37f1e67a 100644
--- a/app/models/concerns/attachmentable.rb
+++ b/app/models/concerns/attachmentable.rb
@@ -1,6 +1,6 @@
# frozen_string_literal: true
-require 'mime/types'
+require 'mime/types/columnar'
module Attachmentable
extend ActiveSupport::Concern
diff --git a/app/models/media_attachment.rb b/app/models/media_attachment.rb
index 5ca218411a5..ae94ce68a15 100644
--- a/app/models/media_attachment.rb
+++ b/app/models/media_attachment.rb
@@ -70,12 +70,14 @@ class MediaAttachment < ApplicationRecord
AUDIO_STYLES = {
original: {
format: 'ogg',
+ content_type: 'audio/ogg',
convert_options: {},
},
}.freeze
VIDEO_FORMAT = {
format: 'mp4',
+ content_type: 'video/mp4',
convert_options: {
output: {
'loglevel' => 'fatal',
@@ -189,11 +191,11 @@ class MediaAttachment < ApplicationRecord
if f.file_content_type == 'image/gif'
[:gif_transcoder, :blurhash_transcoder]
elsif VIDEO_MIME_TYPES.include?(f.file_content_type)
- [:video_transcoder, :blurhash_transcoder]
+ [:video_transcoder, :blurhash_transcoder, :type_corrector]
elsif AUDIO_MIME_TYPES.include?(f.file_content_type)
- [:transcoder]
+ [:transcoder, :type_corrector]
else
- [:lazy_thumbnail, :blurhash_transcoder]
+ [:lazy_thumbnail, :blurhash_transcoder, :type_corrector]
end
end
end
diff --git a/config/application.rb b/config/application.rb
index 74006f5fa32..4534ede4976 100644
--- a/config/application.rb
+++ b/config/application.rb
@@ -10,6 +10,7 @@ require_relative '../app/lib/exceptions'
require_relative '../lib/paperclip/lazy_thumbnail'
require_relative '../lib/paperclip/gif_transcoder'
require_relative '../lib/paperclip/video_transcoder'
+require_relative '../lib/paperclip/type_corrector'
require_relative '../lib/mastodon/snowflake'
require_relative '../lib/mastodon/version'
require_relative '../lib/devise/ldap_authenticatable'
diff --git a/lib/paperclip/type_corrector.rb b/lib/paperclip/type_corrector.rb
new file mode 100644
index 00000000000..0b0c10a56e9
--- /dev/null
+++ b/lib/paperclip/type_corrector.rb
@@ -0,0 +1,19 @@
+# frozen_string_literal: true
+
+require 'mime/types/columnar'
+
+module Paperclip
+ class TypeCorrector < Paperclip::Processor
+ def make
+ target_extension = options[:format]
+ extension = File.extname(attachment.instance.file_file_name)
+
+ return @file unless options[:style] == :original && target_extension && extension != target_extension
+
+ attachment.instance.file_content_type = options[:content_type] || attachment.instance.file_content_type
+ attachment.instance.file_file_name = File.basename(attachment.instance.file_file_name, '.*') + '.' + target_extension
+
+ @file
+ end
+ end
+end