This repository was archived by the owner on Dec 13, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlog.js
More file actions
69 lines (50 loc) · 1.61 KB
/
log.js
File metadata and controls
69 lines (50 loc) · 1.61 KB
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
function timestamp(){
return new Date().toISOString()
}
class Logger{
constructor(currentLevel){
this.levels = ['TRACE', 'DEBUG', 'INFO', 'WARN', 'ERROR', 'OFF']
this.changeLevel(currentLevel)
}
changeLevel(newLevel){
if (typeof newLevel === 'undefined'){
// default to INFO level
newLevel = "INFO"
}
if (typeof newLevel === 'string'){
newLevel = this.levels.indexOf(newLevel.toUpperCase())
}
// make sure our log level is valid
if (newLevel < 0) {
// level not found -- use most verbose
newLevel = 0
} else if (newLevel > this.levels.length - 1) {
// level beyond ERROR specified -- use least verbose
newLevel = this.levels.length - 1
}
this.currentLevel = newLevel
}
_log(level, logLinesIterable){
// the pad is to make the log entries line up for all log levels
let logstr = `${timestamp()} [${level.padStart(5)}] - ${logLinesIterable.join(' ')}`
if (this.levels.indexOf(level) >= this.currentLevel){
console.log(logstr)
}
}
trace(...logLinesIterable){
this._log('TRACE', logLinesIterable)
}
debug(...logLinesIterable){
this._log('DEBUG', logLinesIterable)
}
info(...logLinesIterable){
this._log('INFO', logLinesIterable)
}
warn(...logLinesIterable){
this._log('WARN', logLinesIterable)
}
error(...logLinesIterable){
this._log('ERROR', logLinesIterable)
}
}
module.exports = Logger