Add retry for failed media downloads and tootctl media refresh (#11775)
				
					
				
			This commit is contained in:
		@@ -4,7 +4,7 @@ module Remotable
 | 
			
		||||
  extend ActiveSupport::Concern
 | 
			
		||||
 | 
			
		||||
  class_methods do
 | 
			
		||||
    def remotable_attachment(attachment_name, limit)
 | 
			
		||||
    def remotable_attachment(attachment_name, limit, suppress_errors: true)
 | 
			
		||||
      attribute_name  = "#{attachment_name}_remote_url".to_sym
 | 
			
		||||
      method_name     = "#{attribute_name}=".to_sym
 | 
			
		||||
      alt_method_name = "reset_#{attachment_name}!".to_sym
 | 
			
		||||
@@ -22,7 +22,7 @@ module Remotable
 | 
			
		||||
 | 
			
		||||
        begin
 | 
			
		||||
          Request.new(:get, url).perform do |response|
 | 
			
		||||
            next if response.code != 200
 | 
			
		||||
            raise Mastodon::UnexpectedResponseError, response unless (200...300).cover?(response.code)
 | 
			
		||||
 | 
			
		||||
            content_type = parse_content_type(response.headers.get('content-type').last)
 | 
			
		||||
            extname      = detect_extname_from_content_type(content_type)
 | 
			
		||||
@@ -41,11 +41,11 @@ module Remotable
 | 
			
		||||
 | 
			
		||||
            self[attribute_name] = url if has_attribute?(attribute_name)
 | 
			
		||||
          end
 | 
			
		||||
        rescue HTTP::TimeoutError, HTTP::ConnectionError, OpenSSL::SSL::SSLError, Paperclip::Errors::NotIdentifiedByImageMagickError, Addressable::URI::InvalidURIError, Mastodon::HostValidationError, Mastodon::LengthValidationError => e
 | 
			
		||||
        rescue Mastodon::UnexpectedResponseError, HTTP::TimeoutError, HTTP::ConnectionError, OpenSSL::SSL::SSLError => e
 | 
			
		||||
          Rails.logger.debug "Error fetching remote #{attachment_name}: #{e}"
 | 
			
		||||
          raise e unless suppress_errors
 | 
			
		||||
        rescue Paperclip::Errors::NotIdentifiedByImageMagickError, Addressable::URI::InvalidURIError, Mastodon::HostValidationError, Mastodon::LengthValidationError, Paperclip::Error, Mastodon::DimensionsValidationError => e
 | 
			
		||||
          Rails.logger.debug "Error fetching remote #{attachment_name}: #{e}"
 | 
			
		||||
          nil
 | 
			
		||||
        rescue Paperclip::Error, Mastodon::DimensionsValidationError => e
 | 
			
		||||
          Rails.logger.debug "Error processing remote #{attachment_name}: #{e}"
 | 
			
		||||
          nil
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user