|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
declare(strict_types=1); |
|
4
|
|
|
|
|
5
|
|
|
if (!function_exists('getServerEchoSpacer')) { |
|
6
|
|
|
function getServerEchoSpacer(string $leftSide, string $rightSide, int $columns): string |
|
7
|
|
|
{ |
|
8
|
|
|
$strlen = function (string $str): int { |
|
9
|
|
|
if (function_exists('mb_strlen')) { |
|
10
|
|
|
return mb_strlen($str); |
|
11
|
|
|
} |
|
12
|
|
|
|
|
13
|
|
|
return strlen($str); |
|
14
|
|
|
}; |
|
15
|
|
|
$leftLen = $strlen(preg_replace('#\\x1b[[][^A-Za-z]*[A-Za-z]#', '', $leftSide)); |
|
16
|
|
|
$rightLen = $strlen(preg_replace('#\\x1b[[][^A-Za-z]*[A-Za-z]#', '', $rightSide)); |
|
17
|
|
|
|
|
18
|
|
|
if ($leftLen > $columns) { |
|
19
|
|
|
$leftLen = $leftLen % $columns; |
|
20
|
|
|
} |
|
21
|
|
|
|
|
22
|
|
|
$spacer = str_repeat('.', $columns - (($leftLen + $rightLen + 2) % $columns)); |
|
23
|
|
|
|
|
24
|
|
|
return " \033[1;30m{$spacer}\033[0m "; |
|
25
|
|
|
} |
|
26
|
|
|
} |
|
27
|
|
|
|
|
28
|
|
|
if (!function_exists('serverEcho')) { |
|
29
|
|
|
function serverEcho(int $statusCode, string $msg, float $time, bool $fromHandler = false): void |
|
30
|
|
|
{ |
|
31
|
|
|
$isXhr = (!empty($_SERVER['HTTP_X_REQUESTED_WITH']) |
|
32
|
|
|
&& strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) === 'xmlhttprequest') ? '[XHR]' : ''; |
|
33
|
|
|
$method = isset($_SERVER['REQUEST_METHOD']) ? |
|
34
|
|
|
strtoupper($_SERVER['REQUEST_METHOD']) : ''; |
|
35
|
|
|
$statusColor = match (true) { |
|
36
|
|
|
$statusCode >= 200 && $statusCode < 300 => '32', |
|
37
|
|
|
$statusCode >= 300 && $statusCode < 400 => '34', |
|
38
|
|
|
$statusCode >= 400 && $statusCode < 500 => '33', |
|
39
|
|
|
$statusCode >= 500 => '31', |
|
40
|
|
|
default => '37', |
|
41
|
|
|
}; |
|
42
|
|
|
$duration = sprintf('%.5f', round($time, 5)); |
|
43
|
|
|
$columns = (int)getenv('CONIA_TERMINAL_COLUMNS'); |
|
44
|
|
|
|
|
45
|
|
|
list($usec, $sec) = explode(' ', microtime()); |
|
46
|
|
|
$usec = str_replace('0.', '.', $usec); |
|
47
|
|
|
$timestamp = date('H:i:s', (int)$sec) . substr($usec, 0, 3); |
|
48
|
|
|
$url = urldecode($msg); |
|
49
|
|
|
|
|
50
|
|
|
$leftSide = |
|
51
|
|
|
// timestamp |
|
52
|
|
|
"\033[0;37m{$timestamp}\033[0m " . |
|
53
|
|
|
// status code |
|
54
|
|
|
"\033[0;{$statusColor}m{$statusCode}\033[0m " . |
|
55
|
|
|
// request method |
|
56
|
|
|
"{$method} " . |
|
57
|
|
|
// request uri |
|
58
|
|
|
"\033[0;{$statusColor}m{$url}\033[0m"; |
|
59
|
|
|
$rightSide = |
|
60
|
|
|
// from error handler |
|
61
|
|
|
($fromHandler ? "\033[0;36m[EXC]\033[0m" : '') . |
|
62
|
|
|
// xhr indicator |
|
63
|
|
|
"\033[0;36m{$isXhr}\033[0m" . |
|
64
|
|
|
($fromHandler || $isXhr ? ' ' : '') . |
|
65
|
|
|
// time |
|
66
|
|
|
"\033[0;37m{$duration}s\033[0m"; |
|
67
|
|
|
|
|
68
|
|
|
error_log($leftSide . getServerEchoSpacer($leftSide, $rightSide, $columns) . $rightSide); |
|
69
|
|
|
} |
|
70
|
|
|
} |
|
71
|
|
|
|