-
-
Notifications
You must be signed in to change notification settings - Fork 2k
/
formatter.zep
93 lines (75 loc) · 2.41 KB
/
formatter.zep
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
/*
+------------------------------------------------------------------------+
| Phalcon Framework |
+------------------------------------------------------------------------+
| Copyright (c) 2011-2017 Phalcon Team (https://phalconphp.com) |
+------------------------------------------------------------------------+
| This source file is subject to the New BSD License that is bundled |
| with this package in the file LICENSE.txt. |
| |
| If you did not receive a copy of the license and are unable to |
| obtain it through the world-wide-web, please send an email |
| to [email protected] so we can send you a copy immediately. |
+------------------------------------------------------------------------+
| Authors: Andres Gutierrez <[email protected]> |
| Eduar Carvajal <[email protected]> |
+------------------------------------------------------------------------+
*/
namespace Phalcon\Logger;
use Phalcon\Logger;
/**
* Phalcon\Logger\Formatter
*
* This is a base class for logger formatters
*/
abstract class Formatter implements FormatterInterface
{
/**
* Returns the string meaning of a logger constant
*/
public function getTypeString(int type) -> string
{
switch type {
case Logger::DEBUG:
return "DEBUG";
case Logger::ERROR:
return "ERROR";
case Logger::WARNING:
return "WARNING";
case Logger::CRITICAL:
return "CRITICAL";
case Logger::CUSTOM:
return "CUSTOM";
case Logger::ALERT:
return "ALERT";
case Logger::NOTICE:
return "NOTICE";
case Logger::INFO:
return "INFO";
case Logger::EMERGENCY:
return "EMERGENCY";
case Logger::SPECIAL:
return "SPECIAL";
}
return "CUSTOM";
}
/**
* Interpolates context values into the message placeholders
*
* @see http://www.php-fig.org/psr/psr-3/ Section 1.2 Message
* @param string $message
* @param array $context
*/
public function interpolate(string message, var context = null)
{
var replace, key, value;
if typeof context == "array" && count(context) > 0 {
let replace = [];
for key, value in context {
let replace["{" . key . "}"] = value;
}
return strtr(message, replace);
}
return message;
}
}