blob: 3a16702f2ab26e2ac534de80ccada198b184eb06 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
<?php
namespace JsonApi\Middlewares;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface as Request;
use Psr\Http\Server\RequestHandlerInterface as RequestHandler;
use Slim\Psr7\Response;
/**
* Diese Klasse definiert eine Middleware, die Requests umleitet,
* die mit einem Schrägstrich enden (und zwar jeweils auf das Pendant
* ohne Schrägstrich).
*/
class RemoveTrailingSlashes
{
/**
* Diese Middleware überprüft den Pfad der URI des Requests. Endet
* diese auf einem Schrägstrich, wird nicht weiter an `$next`
* delegiert, sondern eine Response mit `Location`-Header also
* einem Redirect zurückgegeben.
*
* @param Request $request das Request-Objekt
* @param RequestHandler $handler der PSR-15 Request Handler
*
* @return ResponseInterface das neue Response-Objekt
*/
public function __invoke(Request $request, RequestHandler $handler)
{
$uri = $request->getUri();
$path = $uri->getPath();
if ('/' != $path && '/' == substr($path, -1)) {
// recursively remove slashes when its more than 1 slash
$path = rtrim($path, '/');
// permanently redirect paths with a trailing slash
// to their non-trailing counterpart
$uri = $uri->withPath($path);
if ('GET' == $request->getMethod()) {
$response = new Response();
return $response
->withHeader('Location', (string) $uri)
->withStatus(301);
} else {
$request = $request->withUri($uri);
}
}
return $handler->handle($request);
}
}
|