ShootMiddleware::process()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 2
c 1
b 0
f 0
dl 0
loc 4
ccs 2
cts 2
cp 1
rs 10
cc 1
nc 1
nop 2
crap 1
1
<?php
2
declare(strict_types=1);
3
4
namespace Shoot\Shoot\Http;
5
6
use Psr\Http\Message\ResponseInterface;
7
use Psr\Http\Message\ServerRequestInterface;
8
use Psr\Http\Server\MiddlewareInterface;
9
use Psr\Http\Server\RequestHandlerInterface;
10
use Shoot\Shoot\Pipeline;
11
12
/**
13
 * This HTTP middleware makes sure the request object is always set before you render your templates. Make sure to place
14
 * it after any other middleware that might enrich the request object, but before your first call to Twig.
15
 */
16
final class ShootMiddleware implements MiddlewareInterface
17
{
18
    /** @var Pipeline */
19
    private $pipeline;
20
21
    /**
22
     * Constructs a new instance of ShootMiddleware. The same instance of the Pipeline as passed into the Twig extension
23
     * must be used here.
24
     *
25
     * @param Pipeline $pipeline
26
     */
27 1
    public function __construct(Pipeline $pipeline)
28
    {
29 1
        $this->pipeline = $pipeline;
30 1
    }
31
32
    /**
33
     * Process an incoming server request and return a response, optionally delegating
34
     * response creation to a handler.
35
     *
36
     * @param ServerRequestInterface  $request
37
     * @param RequestHandlerInterface $handler
38
     *
39
     * @return ResponseInterface
40
     */
41 1
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
42
    {
43
        return $this->pipeline->withRequest($request, function () use ($request, $handler): ResponseInterface {
44 1
            return $handler->handle($request);
45 1
        });
46
    }
47
}
48