2017 © Pedro Peláez
 

library embryo-middleware

A PSR-15 middleware dispatcher.

image

davidecesarano/embryo-middleware

A PSR-15 middleware dispatcher.

  • Tuesday, July 3, 2018
  • by davidecesarano
  • Repository
  • 1 Watchers
  • 0 Stars
  • 1 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

Embryo Middleware

Simple dispatcher (PSR-15 server request handler) for a queue of PSR-15 middleware entries. Request handlers and middleware components are a fundamental part of any web application. Server side code receives a request message, processes it, and produces a response message. HTTP middleware is a way to move common request and response processing away from the application layer., (*1)

Requirements

Installation

Using Composer:, (*2)

$ composer require davidecesarano/embryo-middleware

Usage

The RequestHandler is a container for a queue of PSR-15 middleware. It takes three methods: * the method add add a middleware to the end of the queue. * the method prepend add a middleware to the beginning of the queue. * the method dispatch requires two arguments, a ServerRequest object and a Response object (used by terminator to return an empty response)., (*3)

Set ServerRequest and Response

Create ServerRequest and Response objects., (*4)

use Embryo\Http\Server\RequestHandler;
use Embryo\Http\Factory\{ServerRequestFactory, ResponseFactory};
use Middlewares\{Uuid, ResponseTime};
use Psr\Http\Message\ServerRequestInterface;

// PSR-7 implementation
$request = (new ServerRequestFactory)->createServerRequestFromServer();
$response = (new ResponseFactory)->createResponse(200);

Add middleware

Create a queue of PSR-15 middleware with the add method or constructor. The add (and prepend) method must be a string or a instance of MiddlewareInterface. In constructor you may create a queue with array of string or instance of MiddlewareInterface., (*5)

In this example we use two PSR-15 compatible middleware: Uuid Middleware and ResponseTime Middleware., (*6)

// PSR-15 MiddlewareInterface implementation
$middleware = new RequestHandler([
    Uuid::class,
    ResponseTime::class
]);
$response = $middleware->dispatch($request, $response);

Result

The dispatch produces a response messages., (*7)

echo 'X-Response-Time: ' . $response->getHeaderLine('X-Response-Time').'<br/>';
echo 'X-Uuid: ' . $response->getHeaderLine('X-Uuid').'<br/>';

echo '

';
    print_r($response->getHeaders());
echo '
';

Example

You may quickly test this using the built-in PHP server going to http://localhost:8000., (*8)

$ cd example
$ php -S localhost:8000

The Versions