Fix attachment not being re-downloaded even if file is not stored (#12125)
Change the behaviour of remotable concern. Previously, it would skip downloading an attachment if the stored remote URL is identical to the new one. Now it would not be skipped if the attachment is not actually currently stored by Paperclip.
This commit is contained in:
		| @ -1,10 +1,11 @@ | ||||
| # frozen_string_literal: true | ||||
|  | ||||
| Paperclip.options[:read_timeout] = 60 | ||||
|  | ||||
| Paperclip.interpolates :filename do |attachment, style| | ||||
|   return attachment.original_filename if style == :original | ||||
|   [basename(attachment, style), extension(attachment, style)].delete_if(&:blank?).join('.') | ||||
|   if style == :original | ||||
|     attachment.original_filename | ||||
|   else | ||||
|     [basename(attachment, style), extension(attachment, style)].delete_if(&:blank?).join('.') | ||||
|   end | ||||
| end | ||||
|  | ||||
| Paperclip::Attachment.default_options.merge!( | ||||
| @ -24,17 +25,21 @@ if ENV['S3_ENABLED'] == 'true' | ||||
|     storage: :s3, | ||||
|     s3_protocol: s3_protocol, | ||||
|     s3_host_name: s3_hostname, | ||||
|  | ||||
|     s3_headers: { | ||||
|       'X-Amz-Multipart-Threshold' => ENV.fetch('S3_MULTIPART_THRESHOLD') { 15.megabytes }.to_i, | ||||
|       'Cache-Control' => 'public, max-age=315576000, immutable', | ||||
|     }, | ||||
|  | ||||
|     s3_permissions: ENV.fetch('S3_PERMISSION') { 'public-read' }, | ||||
|     s3_region: s3_region, | ||||
|  | ||||
|     s3_credentials: { | ||||
|       bucket: ENV['S3_BUCKET'], | ||||
|       access_key_id: ENV['AWS_ACCESS_KEY_ID'], | ||||
|       secret_access_key: ENV['AWS_SECRET_ACCESS_KEY'], | ||||
|     }, | ||||
|  | ||||
|     s3_options: { | ||||
|       signature_version: ENV.fetch('S3_SIGNATURE_VERSION') { 'v4' }, | ||||
|       http_open_timeout: 5, | ||||
| @ -49,6 +54,7 @@ if ENV['S3_ENABLED'] == 'true' | ||||
|       endpoint: ENV['S3_ENDPOINT'], | ||||
|       force_path_style: true | ||||
|     ) | ||||
|  | ||||
|     Paperclip::Attachment.default_options[:url] = ':s3_path_url' | ||||
|   end | ||||
|  | ||||
| @ -74,6 +80,7 @@ elsif ENV['SWIFT_ENABLED'] == 'true' | ||||
|       openstack_region: ENV['SWIFT_REGION'], | ||||
|       openstack_cache_ttl: ENV.fetch('SWIFT_CACHE_TTL') { 60 }, | ||||
|     }, | ||||
|  | ||||
|     fog_directory: ENV['SWIFT_CONTAINER'], | ||||
|     fog_host: ENV['SWIFT_OBJECT_URL'], | ||||
|     fog_public: true | ||||
| @ -82,7 +89,7 @@ else | ||||
|   Paperclip::Attachment.default_options.merge!( | ||||
|     storage: :filesystem, | ||||
|     use_timestamp: true, | ||||
|     path: (ENV['PAPERCLIP_ROOT_PATH'] || ':rails_root/public/system') + '/:class/:attachment/:id_partition/:style/:filename', | ||||
|     url: (ENV['PAPERCLIP_ROOT_URL'] || '/system') + '/:class/:attachment/:id_partition/:style/:filename', | ||||
|     path: ENV.fetch('PAPERCLIP_ROOT_PATH', ':rails_root/public/system') + '/:class/:attachment/:id_partition/:style/:filename', | ||||
|     url: ENV.fetch('PAPERCLIP_ROOT_URL', '/system') + '/:class/:attachment/:id_partition/:style/:filename', | ||||
|   ) | ||||
| end | ||||
|  | ||||
		Reference in New Issue
	
	Block a user