2020-03-09 00:56:18 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Paperclip
|
|
|
|
module AttachmentExtensions
|
2021-05-05 20:44:01 +03:00
|
|
|
def meta
|
|
|
|
instance_read(:meta)
|
|
|
|
end
|
|
|
|
|
2020-03-09 00:56:18 +02:00
|
|
|
# We overwrite this method to support delayed processing in
|
|
|
|
# Sidekiq. Since we process the original file to reduce disk
|
|
|
|
# usage, and we still want to generate thumbnails straight
|
|
|
|
# away, it's the only style we need to exclude
|
|
|
|
def process_style?(style_name, style_args)
|
2020-06-29 14:56:55 +03:00
|
|
|
if style_name == :original && instance.respond_to?(:delay_processing_for_attachment?) && instance.delay_processing_for_attachment?(name)
|
2020-03-09 00:56:18 +02:00
|
|
|
false
|
|
|
|
else
|
|
|
|
style_args.empty? || style_args.include?(style_name)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-27 00:29:08 +03:00
|
|
|
def storage_schema_version
|
|
|
|
instance_read(:storage_schema_version) || 0
|
|
|
|
end
|
|
|
|
|
|
|
|
def assign_attributes
|
|
|
|
super
|
|
|
|
instance_write(:storage_schema_version, 1)
|
|
|
|
end
|
|
|
|
|
2020-03-26 02:56:41 +02:00
|
|
|
def variant?(other_filename)
|
|
|
|
return true if original_filename == other_filename
|
|
|
|
return false if original_filename.nil?
|
|
|
|
|
2021-01-10 01:32:01 +02:00
|
|
|
formats = styles.values.filter_map(&:format)
|
2020-03-26 02:56:41 +02:00
|
|
|
|
|
|
|
return false if formats.empty?
|
|
|
|
|
|
|
|
other_extension = File.extname(other_filename)
|
|
|
|
|
|
|
|
formats.include?(other_extension.delete('.')) && File.basename(other_filename, other_extension) == File.basename(original_filename, File.extname(original_filename))
|
|
|
|
end
|
2020-09-11 16:16:29 +03:00
|
|
|
|
|
|
|
def default_url(style_name = default_style)
|
|
|
|
@url_generator.for_as_default(style_name)
|
|
|
|
end
|
2020-12-15 13:55:29 +02:00
|
|
|
|
|
|
|
STOPLIGHT_THRESHOLD = 10
|
|
|
|
STOPLIGHT_COOLDOWN = 30
|
|
|
|
|
|
|
|
# We overwrite this method to put a circuit breaker around
|
|
|
|
# calls to object storage, to stop hitting APIs that are slow
|
|
|
|
# to respond or don't respond at all and as such minimize the
|
|
|
|
# impact of object storage outages on application throughput
|
|
|
|
def save
|
|
|
|
Stoplight('object-storage') { super }.with_threshold(STOPLIGHT_THRESHOLD).with_cool_off_time(STOPLIGHT_COOLDOWN).with_error_handler do |error, handle|
|
|
|
|
if error.is_a?(Seahorse::Client::NetworkingError)
|
|
|
|
handle.call(error)
|
|
|
|
else
|
|
|
|
raise error
|
|
|
|
end
|
|
|
|
end.run
|
|
|
|
end
|
2020-03-09 00:56:18 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
Paperclip::Attachment.prepend(Paperclip::AttachmentExtensions)
|