-
Notifications
You must be signed in to change notification settings - Fork 64
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Exception when rendering breadcrumbs on Laravel 404 error page #38
Comments
Hmm... it's not immediately clear why this would be happening, I'll need to try and recreate this. The obvious issue is somehow the breadcrumb for Can you show me how you're calling |
I'm not able to repro this. You'll need to post additional source code. |
Here's some more, hope this helps! app.blade.php (which is extended on the show blade template & 404 template)
web.php section
The model's default route key name is a slug, it probably doesn't matter but I wanted to mention it anyway! Using Laravel version 8.7.5 & breadcrumbs version 7.0.1. Let me know if there's anything specific you want to see, it is doing this on every page that has route parameters that 404s looking at my failing tests. (I don't have any routes with parameters that don't use implicit binding) |
Thanks. Was able to repro. Will need to look into this. Edit: Issue specifically relates to 404s on named routes. laravel-breadcrumbs/src/Manager.php Lines 241 to 243 in 0a14e87
|
Ok, after thinking over this for awhile, I've decided to close out this issue without implementing a fix. Technically, the package is doing the correct behavior. If your controller were to fire with the same parameters being passed breadcrumbs, it, too, would throw a similar exception.
While messy, it seems to me that this variability should be handled at the breadcrumb definition level.
There's a reason why the default Laravel error pages don't have any app-related data on them because that just introduces additional points of failure. There is a workaround that could help you avoid this. Whenever Laravel renders an error page, it passes an
Now, breadcrumbs will be entirely missing whenever an error is rendered. This makes sense to me, since breadcrumbs often pull data from models and the database which could cause a stack overflow. Please voice any counterarguments, but for now I'm considering this an anti-pattern to the package. |
I'm also running into the same problem, but the issue doesn't come from being a 404 otherwise the I'm using Adding mixed parameters with cases to each breadcrumb route would be really really bad, first because it's cumbersome and long to write and second because we loose autocompletion (it could be typed Where it is inadequate, is that laravel doesn't run the controller if there is a model required to run the controller that is missing What could be done is maybe some Reflection on the closure to fail to |
I have found a more reliable workaround Adding this in the top of the ExceptionHandler's render method
To bypass the breadcrumbs with whatever you want in case of an error This might be worth documenting |
When overriding the default 404 template with a template that uses breadcrumbs in the view, and navigating to a implictly bound route that 404's you encounter the following error:
Here's the relevant breadcrumbs
Would you happen to know the best way to resolve this? Going to look into it myself too. :)
The text was updated successfully, but these errors were encountered: