You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When raise_on_open_redirects is enabled in Rails config, redirect_to now raises UnsafeRedirectError in case the host of the redirect location does not match that of the current request. It's ordinarily possible when using redirect_to to specify allow_other_host: true to prevent this error from being raised in situations where UnsafeRedirectError did not need to be raised.
However, if the location param is used, it isn't possible to do this - the redirect path is expected as a single variable.
But this causes a regression in that I'm reliant on respond_with's handling of an invalid record, particularly the error flash.
I'm happy to look into a fix for this myself, but I could perhaps do with some guidance. I think all we might need is to pluck allow_other_host from options and pass this into this call, but we may have room to afford ourselves something more flexible than that.
The text was updated successfully, but these errors were encountered:
Afraid not, sorry – the instance where our code was falling foul of UnsafeRedirectError with respond_with was a one-off that we decided against fixing a couple of weeks after I raised this issue.
For what it's worth, I had the same issue, and I cheesed it like so, which I reproduce for others out there who just need a quick fix.
classUsers::SessionsController < Devise::SessionsControllerdefcreatesuperrescueActionController::Redirecting::UnsafeRedirectError# you can probably omit the status bit # if you're not part of the turbo team.redirect_to(after_sign_in_path_for(resource),allow_other_host: true,status: :see_other)endend
When
raise_on_open_redirects
is enabled in Rails config,redirect_to
now raisesUnsafeRedirectError
in case the host of the redirect location does not match that of the current request. It's ordinarily possible when usingredirect_to
to specifyallow_other_host: true
to prevent this error from being raised in situations whereUnsafeRedirectError
did not need to be raised.However, if the
location
param is used, it isn't possible to do this - the redirect path is expected as a single variable.This does not work:
I also attempted this:
But this causes a regression in that I'm reliant on
respond_with
's handling of an invalid record, particularly the error flash.I'm happy to look into a fix for this myself, but I could perhaps do with some guidance. I think all we might need is to pluck
allow_other_host
fromoptions
and pass this into this call, but we may have room to afford ourselves something more flexible than that.The text was updated successfully, but these errors were encountered: