diff options
author | Eugen <eugen@zeonfederated.com> | 2016-10-09 12:45:22 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-10-09 12:45:22 +0200 |
commit | 52d7f862d365acfd4eacbe448238699d9662708d (patch) | |
tree | 2617899b531ea73d1480ae65079613840165d3cf /app/models | |
parent | f40843d6808578ae4315d2c60b2b1878f10edd2f (diff) | |
parent | 35de03fbe31fa4b04c02386b698143563e2b229f (diff) |
Merge pull request #87 from vayan/feature/strip-exif-data-from-images
Strip exif data from uploaded images
Diffstat (limited to 'app/models')
-rw-r--r-- | app/models/media_attachment.rb | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/app/models/media_attachment.rb b/app/models/media_attachment.rb index e2cbe397e..678968ce8 100644 --- a/app/models/media_attachment.rb +++ b/app/models/media_attachment.rb @@ -5,7 +5,10 @@ class MediaAttachment < ApplicationRecord belongs_to :account, inverse_of: :media_attachments belongs_to :status, inverse_of: :media_attachments - has_attached_file :file, styles: -> (f) { f.instance.image? ? { small: '510x680>' } : { small: { convert_options: { output: { vf: 'scale="min(510\, iw):min(680\, ih)":force_original_aspect_ratio=decrease' } }, format: 'png', time: 1 } } }, processors: -> (f) { f.video? ? [:transcoder] : [:thumbnail] } + has_attached_file :file, + styles: -> (f) { file_styles f }, + processors: -> (f) { f.video? ? [:transcoder] : [:thumbnail] }, + convert_options: { all: "-strip" } validates_attachment_content_type :file, content_type: IMAGE_MIME_TYPES + VIDEO_MIME_TYPES validates_attachment_size :file, less_than: 4.megabytes @@ -30,4 +33,26 @@ class MediaAttachment < ApplicationRecord def type image? ? 'image' : 'video' end + +private + def self.file_styles(f) + if f.instance.image? + { + original: '100%', + small: '510x680>' + } + else + { + small: { + convert_options: { + output: { + vf: 'scale="min(510\, iw):min(680\, ih)":force_original_aspect_ratio=decrease' + } + }, + format: 'png', + time: 1 + } + } + end + end end |