Home

Awesome

Stack Middleware for Laravel

Tests Packagist License Latest Stable Version Total Downloads Fruitcake

Laravel 4 used HttpKernelInterface Middlewares for its Middleware, but Laravel 5 uses a new way. This package provides a way to wrap StackPHP Middleware so it can be used with Laravel 5

First, require this package in your composer file

composer require barryvdh/laravel-stack-middleware

After updating, add the ServiceProvider to the array of providers in config/app.php

Barryvdh\StackMiddleware\ServiceProvider::class,

Usage

A Stack Middleware usually needs a Kernel. We can't use the real Kernel, so this package provides a one. You can use the bind method to wrap a Stack (HttpKernelInterface) middleware and register it in the App container. You can access the StackMiddleware class under the stack key in the Container, or with the Facade (Barryvdh\StackMiddleware\Facade). It can also be typehinted directly, eg. on the boot() method of a ServiceProvider.

The first argument is the new Middleware name. The second is either:

app('stack')->bind('AddRobotsHeaders', 'League\StackRobots\Robots', ['env' => 'production', 'envVar' => 'APP_ENV']);
use League\StackRobots\Robots;
use Barryvdh\StackMiddleware\StackMiddleware;

public function boot(StackMiddleware $stack) {
    $stack->bind('AddRobotsHeaders', function($kernel) {
        return new Robots($kernel, 'production', 'APP_ENV');
    });
}

Both examples have the same result, you can now add AddRobotsHeaders to the $middleware list in Kernel.php

If you want to use the Facade, you can add that to your config/app.php. You can then use Stack::bind(...) instead.

    'Stack' => 'Barryvdh\StackMiddleware\Facade',

Examples & Implementations

More information

For more information, read the StackPHP website.

License

MIT