render json: { error: 'This action is not allowed' }, status: 403
end
- rescue_from Mastodon::RaceConditionError, Seahorse::Client::NetworkingError, Stoplight::Error::RedLight do
+ rescue_from Seahorse::Client::NetworkingError do |e|
+ Rails.logger.warn "Storage server error: #{e}"
+ render json: { error: 'There was a temporary problem serving your request, please try again' }, status: 503
+ end
+
+ rescue_from Mastodon::RaceConditionError, Stoplight::Error::RedLight do
render json: { error: 'There was a temporary problem serving your request, please try again' }, status: 503
end
rescue_from Mastodon::RateLimitExceededError, with: :too_many_requests
rescue_from HTTP::Error, OpenSSL::SSL::SSLError, with: :internal_server_error
- rescue_from Mastodon::RaceConditionError, Seahorse::Client::NetworkingError, Stoplight::Error::RedLight, ActiveRecord::SerializationFailure, with: :service_unavailable
+ rescue_from Mastodon::RaceConditionError, Stoplight::Error::RedLight, ActiveRecord::SerializationFailure, with: :service_unavailable
+
+ rescue_from Seahorse::Client::NetworkingError do |e|
+ Rails.logger.warn "Storage server error: #{e}"
+ service_unavailable
+ end
before_action :store_current_location, except: :raise_not_found, unless: :devise_controller?
before_action :require_functional!, if: :user_signed_in?
emoji ||= CustomEmoji.new(domain: @account.domain, shortcode: shortcode, uri: uri)
emoji.image_remote_url = image_url
emoji.save
- rescue Seahorse::Client::NetworkingError
- nil
+ rescue Seahorse::Client::NetworkingError => e
+ Rails.logger.warn "Error storing emoji: #{e}"
end
def process_attachments
media_attachment.save
rescue Mastodon::UnexpectedResponseError, HTTP::TimeoutError, HTTP::ConnectionError, OpenSSL::SSL::SSLError
RedownloadMediaWorker.perform_in(rand(30..600).seconds, media_attachment.id)
- rescue Seahorse::Client::NetworkingError
- nil
+ rescue Seahorse::Client::NetworkingError => e
+ Rails.logger.warn "Error storing media attachment: #{e}"
end
end
io.write(buffer)
end
end
- rescue Errno::ENOENT, Seahorse::Client::NetworkingError
- Rails.logger.warn "Could not backup file #{filename}: file not found"
+ rescue Errno::ENOENT, Seahorse::Client::NetworkingError => e
+ Rails.logger.warn "Could not backup file #{filename}: #{e}"
end
end