-
Notifications
You must be signed in to change notification settings - Fork 254
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
Add full support for implicit route model binding #315
Conversation
…se instead of a collection
After some (very naive) load testing of this approach, it looks like the performance hit is significant. It depends on the number of models in the app, not the number of routes—if hundreds of routes bind the same model, that model only gets booted and instantiated once, but if an app has a hundred models, they'll all get booted and instantiated even if they're only bound to one or two routes each, which can add up quickly. 'Caching' Ziggy's output like this PR does works but feels hacky. At the very least we'll want to make sure we're never doing it in local environments. |
I found a way around booting every model, so now we only boot the ones that don't use the default This appears to add about 1-4ms to the response time per model in the app that does use a custom route key and is not already being booted for the current request (i.e. models not bound to the current route). Update: in addition to this change, replacing the collection mapping with |
… and remove check for getRouteKey method
This PR adds support for implicit route model binding. It builds on #307, which added support for custom scoped route model bindings defined directly in the route pattern.
When generating Ziggy's list of routes, we'll now resolve all route model bindings and pass them to Ziggy's javascript output. This lays the foundation for making Ziggy's detection of 'model' objects passed in as route parameters way simpler and more powerful. Right now we're sniffing for an
id
property (or a custom binding key if the parameter is scoped), but this only works for models with the route keyid
—after this PR, we'll be able to use every model's actual route key name.Given this model and route...
...Ziggy's
namedRoutes
will now contain an entry that looks like this......which means we'll eventually be able to pass a JSON
user
object directly into Ziggy'sroute()
function as a parameter, even though that model doesn't useid
as its route key:This implementation requires reflecting into the parameters of all routes in the application and instantiating an Eloquent model for every bound parameter, which could conceivably have an impact on performance in apps with a lot of routes. This would only become an issue if it happened on every request, so to mitigate that, this PR also changes the
@routes
Blade directive to output Ziggy's javascript directly instead of just embedding a call to ourBladeRouteGenerator
. This means that Ziggy's entire output will be cached automatically inside the application's compiled Blade views. Note that this means users will have to runphp artisan view:clear
after changing any of their routes. I'll add a note about it to the Readme before we release v1.Huge thanks to @taylorotwell for pointing me in the right direction to get this working!
Closes #308, see also #143 and #301.