/
ShutdownHandler.php
107 lines (91 loc) · 2.72 KB
/
ShutdownHandler.php
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
<?php
/*
* This file is part of the Helthe Monitor package.
*
* (c) Carl Alexander <carlalexander@helthe.co>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Helthe\Monitor;
use Helthe\Monitor\Client\ClientInterface;
use Helthe\Monitor\Report\ReportFactory;
use Guzzle\Http\Exception\BadResponseException;
/**
* Shutdown handler that sends out all the collected errors when the PHP process ends.
*
* @author Carl Alexander <carlalexander@helthe.co>
*/
class ShutdownHandler
{
/**
* HTTP client.
*
* @var ClientInterface
*/
private $client;
/**
* Error handler.
*
* @var ErrorHandler
*/
private $errorHandler;
/**
* Report factory.
*
* @var ReportFactory
*/
private $reportFactory;
/**
* Registers the shutdown handler.
*
* @param ClientInterface $client
* @param ErrorHandler $errorHandler
* @param ReportFactory $reportFactory
*/
public static function register(ClientInterface $client, ErrorHandler $errorHandler, ReportFactory $reportFactory)
{
$handler = new self($client, $errorHandler, $reportFactory);
register_shutdown_function(array($handler, 'sendErrors'));
return $handler;
}
/**
* Constructor.
*
* @param ClientInterface $client
* @param ErrorHandler $errorHandler
* @param ReportFactory $reportFactory
*/
public function __construct(ClientInterface $client, ErrorHandler $errorHandler, ReportFactory $reportFactory)
{
$this->client = $client;
$this->errorHandler = $errorHandler;
$this->reportFactory = $reportFactory;
}
/**
* Sends all the errors collected by the error handler.
*/
public function sendErrors()
{
$errors = $this->errorHandler->getErrors();
if (empty($errors)) {
return;
}
$report = $this->reportFactory->createFromErrors($errors);
try {
$this->client->sendReport($report);
} catch (BadResponseException $exception) {
$label = 'Error';
$request = $exception->getRequest();
$response = $exception->getResponse();
if ($response->isClientError()) {
$label = 'Client error';
} elseif ($response->isServerError()) {
$label = 'Server error';
}
error_log(sprintf('%s "%s" with status code %i at %s', $label, $response->getReasonPhrase(), $response->getStatusCode(), $request->getUrl()));
} catch (\Exception $exception) {
error_log($exception->getMessage());
}
}
}