1
0
mirror of https://github.com/jbranchaud/til synced 2026-01-03 15:18:01 +00:00
Files
til/rails/order-matters-for-rescue-from-blocks.md

37 lines
1.2 KiB
Markdown

# Order Matters For `rescue_from` Blocks
In a Rails controller, you can declare any number of [`rescue_from`
blocks](https://api.rubyonrails.org/classes/ActiveSupport/Rescuable/ClassMethods.html)
for capturing and responding to execeptions that are raised by your
application.
```ruby
class BooksController < BaseController
rescue_from ForbiddenAction do |e|
render json: { error: e.message }.to_json, status: 403
end
rescue_from StandardError do |e|
render json: { error: e.message }.to_json, status: 500
end
def index
# ...
raise ForbiddenAction, "Which rescue_from is this going to hit?"
end
end
```
The potential problem with above is the ordering of the two `rescue_from`
blocks. Assume that `ForbiddenAction` is a subclass of the `StandardError`
class -- this is likely the case for exceptions you declare in your app. The
top `rescue_from` will never get hit because everything that subclasses
`StandardError` will be trapped by the bottom `rescue_from`.
These `rescue_from` blocks are applied bottom-up. That means you have to
consider the class hierarchy when structuring your code. In the above code
example, if we flip the two of them around, we will then get what we are
expecting.