70 lines
2.3 KiB
PHP
70 lines
2.3 KiB
PHP
|
<?php
|
||
|
namespace ContingentParser\Logger;
|
||
|
|
||
|
final class HttpLogger extends Logger
|
||
|
{
|
||
|
private const ARR_HTTP_STATUS_CODE = array(
|
||
|
100 => 'Continue',
|
||
|
101 => 'Switching Protocols',
|
||
|
200 => 'OK',
|
||
|
201 => 'Created',
|
||
|
202 => 'Accepted',
|
||
|
203 => 'Non-Authoritative Information',
|
||
|
204 => 'No Content',
|
||
|
205 => 'Reset Content',
|
||
|
206 => 'Partial Content',
|
||
|
300 => 'Multiple Choices',
|
||
|
301 => 'Moved Permanently',
|
||
|
302 => 'Found',
|
||
|
303 => 'See Other',
|
||
|
304 => 'Not Modified',
|
||
|
305 => 'Use Proxy',
|
||
|
306 => 'Switch Proxy',
|
||
|
307 => 'Temporary Redirect',
|
||
|
400 => 'Bad Request',
|
||
|
401 => 'Unauthorized',
|
||
|
402 => 'Payment Required',
|
||
|
403 => 'Forbidden',
|
||
|
404 => 'Not Found',
|
||
|
405 => 'Method Not Allowed',
|
||
|
406 => 'Not Acceptable',
|
||
|
407 => 'Proxy Authentication Required',
|
||
|
408 => 'Request Timeout',
|
||
|
409 => 'Conflict',
|
||
|
410 => 'Gone',
|
||
|
411 => 'Length Required',
|
||
|
412 => 'Precondition Failed',
|
||
|
413 => 'Payload Too Large',
|
||
|
414 => 'URI Too Long',
|
||
|
415 => 'Unsupported Media Type',
|
||
|
416 => 'Range Not Satisfiable',
|
||
|
417 => 'Expectation Failed',
|
||
|
418 => 'I\'m a teapot',
|
||
|
429 => 'Too Many Requests',
|
||
|
451 => 'Unavailable For Legal Reasons',
|
||
|
500 => 'Internal Server Error',
|
||
|
501 => 'Not Implemented',
|
||
|
502 => 'Bad Gateway',
|
||
|
503 => 'Service Unavailable',
|
||
|
504 => 'Gateway Timeout',
|
||
|
505 => 'HTTP Version Not Supported',
|
||
|
506 => 'Variant Also Negotiates',
|
||
|
507 => 'Insufficient Storage',
|
||
|
508 => 'Loop Detected',
|
||
|
509 => 'Bandwidth Limit Exceeded',
|
||
|
510 => 'Not Extended',
|
||
|
511 => 'Network Authentication Required'
|
||
|
);
|
||
|
public function log(string $message, int $httpCode = null) : void
|
||
|
{
|
||
|
$date = date('Y-m-d H:i:s');
|
||
|
if (empty($httpCode)) {
|
||
|
$logMessage = "[$date] $message\n";
|
||
|
file_put_contents($this->_path, $logMessage, FILE_APPEND);
|
||
|
} else {
|
||
|
$logMessage = "[$date] $message "
|
||
|
.self::ARR_HTTP_STATUS_CODE[$httpCode]."\n";
|
||
|
file_put_contents($this->_path, $logMessage, FILE_APPEND);
|
||
|
}
|
||
|
}
|
||
|
}
|