2017 © Pedro Peláez
 

library route-binder

Laravel route binding, done right.

image

laravelba/route-binder

Laravel route binding, done right.

  • Thursday, June 29, 2017
  • by guiwoda
  • Repository
  • 6 Watchers
  • 68 Stars
  • 26,310 Installations
  • PHP
  • 2 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 11 Versions
  • 6 % Grown

The README.md

Route Binder

Laravel route binding, done right., (*1)

Build Status, (*2)

Laravel 4 or 5?

The master branch holds code compatible with Laravel 5. Releases for Laravel 5 start from the 3.0 tag., (*3)

For the Laravel 4 compatible release, go to the laravel4 branch., (*4)

The problem

Projects start simple: a few routes, maybe some resource controllers, and maybe some parameter binding here and there. But soon, the routes.php file starts to pile up, spawning hundreds of lines, with complex nested groups and filters or even (god forbid) having calls to App::make. Even more cumbersome, having to scroll all those lines searching for that odd route name that you clearly forget because, who remembers those anyway?, (*5)

This package helps you with (at least) three things:, (*6)

  1. It makes your routes part of your Application by letting you use DI through the IoC container
  2. It lets you split up routes in multiple files (classes) without the need for old-fashioned includes or requires
  3. As you'll be creating classes, you have an opportunity to declare some string constants and hold references to those nasty route names

The solution

This package is just two contracts, a config file and a ServiceProvider., (*7)

As usual, include the ServiceProvider in your config/app.php file like so:, (*8)

'providers' => [
    // ...
    LaravelBA\RouteBinder\RouteBinderServiceProvider::class,
    // ...
]

Then, publish the package's configuration:, (*9)

php artisan vendor:publish --provider="LaravelBA\RouteBinder\RouteBinderServiceProvider"

Afterwards, you'll need to create some classes that implement either the LaravelBA\RouteBinder\Routes interface, the LaravelBA\RouteBinder\Bindings interface or both. Don't panic! You'll see it's a piece of cake:, (*10)

namespace App\Http\Routes;

use Illuminate\Contracts\Routing\Registrar;
use Illuminate\Routing\Router;
use LaravelBA\RouteBinder\Bindings;
use LaravelBA\RouteBinder\Routes;

class FooRoutes implements Routes, Bindings
{
    /**
     * This is what I meant with #3 up there.
     * Completely optional, but highly recommended.
     */
    const INDEX = 'foo.index';

    /**
     * This one is required if you implement the Bindings interface
     */
    public function addBindings(Router $router)
    {
        $router->bind('user_id', function(){
            // Fetch your User object here!
        });
    }

    /**
     * This one is required if you implement the Routes interface
     */
    public function addRoutes(Registrar $router)
    {
        $router->get('foo', ['as' => self::INDEX, 'uses' => function(){
            return view('hello');
        }]);
    }
}

And add them to the published config file (you find it now in config/routes.php):, (*11)

return [
    'binders' => [
        App\Http\Routes\FooRoutes::class,
        App\Http\Routes\BarRoutes::class,
        App\Http\Routes\BazRoutes::class,
        App\Http\Routes\AwesomeRoutes::class,
    ]
];

And you're done! Now all your routes are nicely organized, and if things get out of hand, you can always split 'em up more!, (*12)

The IoC Container

I love Laravel's Route model binding functionality. I must confess though, I don't use Eloquent, so I always go for the Route::bind() option., (*13)

But this feature, as powerful as it may be, is pretty nasty on your architecture. Having calls to the DB on the routes.php file is awful, and going App::make(SomeRepository::class) does not look that much better either., (*14)

With this little package, your Bindings objects can depend on any Service or Repository layer of your application. Now, you could even test those bindings by mocking the dependencies and expecting a call to whatever Repository::find() method you use on route resolution!, (*15)

This may look like waaaaaay too complicated a scenario right now, but trust me, you'll love it., (*16)

The Versions

15/09 2015

4.0.1

4.0.1.0

Laravel route binding, done right.

  Sources   Download

MIT

The Requires

 

The Development Requires

14/09 2015

4.0.0

4.0.0.0

Laravel route binding, done right.

  Sources   Download

MIT

The Requires

 

The Development Requires

20/02 2015

dev-laravel4

dev-laravel4

Laravel route binding, done right.

  Sources   Download

MIT

The Requires

 

The Development Requires

12/02 2015

3.0.0

3.0.0.0

Laravel route binding, done right.

  Sources   Download

MIT

The Requires

 

The Development Requires

09/02 2015

2.0.1

2.0.1.0

Laravel route binding, done right.

  Sources   Download

MIT

The Requires

 

The Development Requires

04/02 2015

2.0.0

2.0.0.0

Laravel route binding, done right.

  Sources   Download

MIT

The Requires

 

The Development Requires

29/01 2015

1.0.1

1.0.1.0

Laravel route binding, done right.

  Sources   Download

MIT

The Requires

 

The Development Requires

29/01 2015

1.0.0

1.0.0.0

Laravel route binding, done right.

  Sources   Download

MIT

The Requires

 

The Development Requires