|
1
|
|
|
<?php |
|
2
|
|
|
/** |
|
3
|
|
|
* This file contains only the WebProcessorMonolog class. |
|
4
|
|
|
*/ |
|
5
|
|
|
|
|
6
|
|
|
declare(strict_types = 1); |
|
7
|
|
|
|
|
8
|
|
|
namespace AppBundle\Monolog; |
|
9
|
|
|
|
|
10
|
|
|
use Symfony\Component\HttpFoundation\RequestStack; |
|
11
|
|
|
|
|
12
|
|
|
/** |
|
13
|
|
|
* WebProcessorMonolog extends information included in error reporting. |
|
14
|
|
|
*/ |
|
15
|
|
|
class WebProcessorMonolog |
|
16
|
|
|
{ |
|
17
|
|
|
/** @var RequestStack The request stack. */ |
|
18
|
|
|
private $requestStack; |
|
19
|
|
|
|
|
20
|
|
|
/** @var string The unique identifier for the session. */ |
|
21
|
|
|
private $sessionId; |
|
|
|
|
|
|
22
|
|
|
|
|
23
|
|
|
/** |
|
24
|
|
|
* WebProcessorMonolog constructor. |
|
25
|
|
|
* @param RequestStack $requestStack |
|
26
|
|
|
*/ |
|
27
|
34 |
|
public function __construct(RequestStack $requestStack) |
|
28
|
|
|
{ |
|
29
|
34 |
|
$this->requestStack = $requestStack; |
|
30
|
34 |
|
} |
|
31
|
|
|
|
|
32
|
|
|
/** |
|
33
|
|
|
* Adds extra information to the log entry. |
|
34
|
|
|
* @param array $record |
|
35
|
|
|
* @return array |
|
36
|
|
|
*/ |
|
37
|
16 |
|
public function processRecord(array $record): array |
|
38
|
|
|
{ |
|
39
|
16 |
|
$request = $this->requestStack->getCurrentRequest(); |
|
40
|
|
|
|
|
41
|
16 |
|
if ($request && $request->hasSession()) { |
|
42
|
14 |
|
$record['extra']['host'] = $request->getHost(); |
|
43
|
14 |
|
$record['extra']['uri'] = $request->getUri(); |
|
44
|
14 |
|
$record['extra']['useragent'] = $request->headers->get('User-Agent'); |
|
45
|
14 |
|
$record['extra']['referer'] = $request->headers->get('referer'); |
|
46
|
|
|
|
|
47
|
14 |
|
$session = $request->getSession(); |
|
48
|
|
|
|
|
49
|
|
|
// Necessary to combat abuse. |
|
50
|
14 |
|
if (null !== $session->get('logged_in_user')) { |
|
51
|
|
|
$record['extra']['username'] = $session->get('logged_in_user')->username; |
|
52
|
|
|
} else { |
|
53
|
|
|
// Intentionally not included if we have a username, for privacy reasons. |
|
54
|
14 |
|
$record['extra']['xff'] = $request->headers->get('x-forwarded-for', ''); |
|
55
|
|
|
} |
|
56
|
|
|
} |
|
57
|
|
|
|
|
58
|
16 |
|
return $record; |
|
59
|
|
|
} |
|
60
|
|
|
} |
|
61
|
|
|
|