forked from openhab/openhab-cloud
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlogger.js
102 lines (87 loc) · 2.65 KB
/
logger.js
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
/*
This module maintains logger for openhab-cloud application and it's components
Logging is sent to console (with timestamp) and openhab Loggly (without timestamp)
as plain text.
*/
var winston = require('winston'), logger;
require('winston-daily-rotate-file');
var system = require('./system');
system.setConfiguration(require('./config.json'))
//default NPM levels with the addition of 'audit" for audit logs
var levels = {
error: 0,
warn: 1,
info: 2,
verbose: 3,
debug: 4,
silly: 5,
audit: 6
};
var timeFormat = winston.format.timestamp({
format: 'YYYY-MM-DD HH:mm:ss:sss'
});
var logFormat = winston.format.printf(function (info) {
return `${info.timestamp} ${info.level}: ${info.message}`
})
var fileLog = new (winston.transports.DailyRotateFile)({
filename: system.getLoggerDir() + 'openhab-cloud-%DATE%-process-' + system.getNodeProcessPort() + '.log',
datePattern: 'YYYY-MM-DD',
zippedArchive: false,
maxFiles: system.getLoggerMaxFiles(),
handleExceptions: true,
level: system.getLoggerLevel(),
format: winston.format.combine(
timeFormat,
winston.format.splat(),
logFormat
)
});
var auditFilter = winston.format(function (info, opts) {
if (info.level === 'audit') { return info; }
return false;
});
var auditLog = new (winston.transports.DailyRotateFile)({
filename: system.getLoggerDir() + 'audit-%DATE%-process-' + system.getNodeProcessPort() + '.log',
datePattern: 'YYYY-MM-DD',
zippedArchive: false,
maxFiles: system.getLoggerMaxFiles(),
level: 'audit',
format: winston.format.combine(
auditFilter(),
timeFormat,
winston.format.splat(),
logFormat
)
});
var consoleLog = new (winston.transports.Console)({
handleExceptions: true,
level: system.getLoggerLevel(),
format: winston.format.combine(
timeFormat,
winston.format.splat(),
logFormat
)
})
if(system.getLoggerType() == 'console') {
var defaultLog = consoleLog
} else {
var defaultLog = fileLog
}
logger = winston.createLogger({
transports: [
defaultLog,
auditLog
],
exitOnError: false,
levels: levels
});
logger.auditRequest = function (req) {
var headers = req.headers;
// Strip off path prefix for remote vhosts hack
var requestPath = req.path;
if (requestPath.indexOf('/remote/') === 0) {
requestPath = requestPath.replace('/remote', '');
}
this.audit("%s | %s | %s | %s | %s | %s | %s", req.user.username, req.openhab.status, req.method, requestPath, headers[`x-real-ip`], headers['host'], headers['user-agent'])
}
module.exports = logger;