Passed
Push — master ( 7ce4a7...fc05cd )
by Sébastien
02:20
created

AccessLoggerMiddleware::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 1
dl 0
loc 3
ccs 0
cts 3
cp 0
crap 2
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace App\Middleware;
6
7
use App\Infra\Log\AccessLogger;
8
use Psr\Http\Message\ResponseInterface;
9
use Psr\Http\Message\ServerRequestInterface;
10
use Psr\Http\Server\MiddlewareInterface;
11
use Psr\Http\Server\RequestHandlerInterface;
12
13
14
class AccessLoggerMiddleware implements MiddlewareInterface
15
{
16
17
    /**
18
     * @var AccessLogger
19
     */
20
    private $accessLogger;
21
22
    public function __construct(AccessLogger $accessLogger)
23
    {
24
        $this->accessLogger = $accessLogger;
25
    }
26
27
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
28
    {
29
        $response =  $handler->handle($request);
30
31
        $ip = $this->getClientIp($request);
32
33
        $this->accessLogger->log(
34
        	AccessLogger::TYPE_LOGIN_SUCCESS,
35
			'[email protected]',
36
			$ip
37
		);
38
39
        return $response;
40
    }
41
42
    private function getClientIp(ServerRequestInterface $request): ?string {
43
		$serverParams = $request->getServerParams();
44
		if (isset($serverParams['REMOTE_ADDR'])) {
45
			return $serverParams['REMOTE_ADDR'];
46
		}
47
		return null;
48
	}
49
50
}
51