I am trying to redirect request if authorization is failed for it. I have following code:
class ValidateRequest extends Request{
public function authorize(){
// some logic here...
return false;
}
public function rules(){ /* ... */}
public function failedAuthorization() {
return redirect('safepage');
}
}
By default I am redirected to the 403 error page, but I would like to specify some specific route. I noticed that method failedAuthorization()
is run, but redirect()
method does not work...
Previously this code worked well with Laravel 5.1 but I used forbiddenResponse()
method to redirect wrong request. How can I fix it with new LTS version?
You can do through a middleware/policy i think. I don't know if you can do it from the validation.
You can override the function from FormRequest like this below:
And redirect where you want.
Looks like it is impossible to
redirect()
directly from the customValidateRequest
class. The only solution that I found is create custom exception and than handle it in the Handler class. So, now it works with following code:app/Requests/ValidateRequest.php
app/Exceptions/NotAuthorizedException.php
and app/Exceptions/Handler.php
So, it works, but much more slower than I expected... Simple measuring shows that handling and redirecting take 2.1 s, but with Laravel 5.1 the same action (and the same code) takes only 0.3 s
Adding
NotAuthorizedException::class
to the$dontReport
property does not help at all...Update
It runs much more faster with php 7.2, it takes 0.7 s