2017 © Pedro Peláez
 

library dot-controller

DotKernel controller like middleware component with plugin support

image

dotkernel/dot-controller

DotKernel controller like middleware component with plugin support

  • Monday, April 16, 2018
  • by dotkernel
  • Repository
  • 2 Watchers
  • 1 Stars
  • 777 Installations
  • PHP
  • 10 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 9 Versions
  • 6 % Grown

The README.md

dot-controller

This is DotKernel's controller package that can be use like middleware inside DotKernel or Mezzio application. It provides base classes for action based controllers similar to Laminas controller component. It is more lightweight though, but supports controller plugins and event listeners, (*1)

OSS Lifecycle PHP from Packagist (specify version), (*2)

GitHub issues GitHub forks GitHub stars GitHub license, (*3)

Build Static codecov, (*4)

SymfonyInsight, (*5)

Installation

Install dot-controller by executing the following Composer command:, (*6)

$ composer require dotkernel/dot-controller

Usage

Middleware controllers act as a handler for multiple routes. Some conventions were made:, (*7)

  • register controllers in the routes array just like any mezzio middleware. The requirement is that you should define an action route parameter(possibly optional) anywhere inside the route(e.g /user[/{action}])
  • action parameter value is converted to a method name inside the controller. Underscore, dot and line characters are removed and the action name is converted to camel-case suffixed by the string Action. For example a route and action pair like /user/forgot-password will be converted to method forgotPasswordAction.
  • the default action value, if not present in the URI is index, so you should always define an indexAction within your controllers for displaying a default page or redirecting.

In order to create your action based controllers, you must extend the abstract class DotKernel\DotController\AbstractActionController, (*8)

Example

Creating a UserController with default action and a register action. Will handle routes /user and /user/register, (*9)

use DotKernel\DotController\AbstractActionController;

class UserController extends AbstractActionController
{
    public function indexAction()
    {
        //...
    }

    public function registerAction()
    {
        //...
    }
}

Then register this controller as a routed middleware in file RoutesDelegator.php just like a regular middleware., (*10)

//Example from a DotKernel RoutesDelegator
$app->route(
    '/user[/{action}]',
    UserController::class,
    [RequestMethodInterface::METHOD_GET, RequestMethodInterface::METHOD_POST],
    'user'
);

Multiple controllers for the same route

Use case: You have defined a controller inside some package, with default actions. You want to add actions that fall into the same controller name(or route name more exactly). You want to do this without extending the controller provided by the package. In this case you can do the following, (*11)

  • create your own controller, independent of the package's controller which adds more actions
  • Mezzio lets you define an array of middleware for a route, so you can register this controller before the package's controller

Now when a request for this route comes in, your controller will run first. DotKernel controllers are designed to ignore requests that cannot be matched to one of its methods, so if no action matches, it will call the next middleware, in our case, the second controller. If this is the last controller, and action does not match here, it will go to the default 404 Not found page(handled by NotFoundDelegate), (*12)

The Versions

16/04 2018

dev-master

9999999-dev

DotKernel controller like middleware component with plugin support

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar dotkernel
by n3vrax

16/04 2018

dev-develop

dev-develop

DotKernel controller like middleware component with plugin support

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar dotkernel
by n3vrax