@steedos/service-package-registry 2.1.10 → 2.1.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/main/default/manager/registry.js +1 -1
- package/main/default/objects/steedos_packages/buttons/install_purchased_packages.button.js +42 -32
- package/main/default/objects/steedos_packages/buttons/uninstall.button.js +1 -1
- package/main/default/objects/steedos_packages/fields/metadata.$.type.field.yml +3 -1
- package/main/default/util/events.js +73 -0
- package/main/default/util/exec.js +91 -0
- package/main/default/util/hooks.js +243 -0
- package/main/default/util/i18n.js +234 -0
- package/main/default/util/index.js +81 -0
- package/main/default/util/log.js +233 -0
- package/main/default/util/util.js +987 -0
- package/package.json +8 -4
- package/package.service.js +50 -16
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright JS Foundation and other contributors, http://js.foundation
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
* @ignore
|
|
16
|
+
**/
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Internationalization utilities
|
|
20
|
+
* @mixin @node-red/util_i18n
|
|
21
|
+
*/
|
|
22
|
+
|
|
23
|
+
var i18n = require("i18next");
|
|
24
|
+
|
|
25
|
+
var path = require("path");
|
|
26
|
+
var fs = require("fs-extra");
|
|
27
|
+
|
|
28
|
+
var defaultLang = "en-US";
|
|
29
|
+
|
|
30
|
+
var resourceMap = {};
|
|
31
|
+
var resourceCache = {};
|
|
32
|
+
var initPromise;
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Register multiple message catalogs with i18n.
|
|
36
|
+
* @memberof @node-red/util_i18n
|
|
37
|
+
*/
|
|
38
|
+
function registerMessageCatalogs(catalogs) {
|
|
39
|
+
var promises = catalogs.map(function(catalog) {
|
|
40
|
+
return registerMessageCatalog(catalog.namespace,catalog.dir,catalog.file).catch(err => {});
|
|
41
|
+
});
|
|
42
|
+
return Promise.all(promises);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Register a message catalog with i18n.
|
|
47
|
+
* @memberof @node-red/util_i18n
|
|
48
|
+
*/
|
|
49
|
+
async function registerMessageCatalog(namespace,dir,file) {
|
|
50
|
+
return initPromise.then(function() {
|
|
51
|
+
return new Promise((resolve,reject) => {
|
|
52
|
+
resourceMap[namespace] = { basedir:dir, file:file, lngs: []};
|
|
53
|
+
fs.readdir(dir,function(err, files) {
|
|
54
|
+
if (err) {
|
|
55
|
+
resolve();
|
|
56
|
+
} else {
|
|
57
|
+
files.forEach(function(f) {
|
|
58
|
+
if (fs.existsSync(path.join(dir,f,file))) {
|
|
59
|
+
resourceMap[namespace].lngs.push(f);
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
i18n.loadNamespaces(namespace,function() {
|
|
63
|
+
resolve();
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
})
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
function mergeCatalog(fallback,catalog) {
|
|
72
|
+
for (var k in fallback) {
|
|
73
|
+
if (fallback.hasOwnProperty(k)) {
|
|
74
|
+
if (!catalog[k]) {
|
|
75
|
+
catalog[k] = fallback[k];
|
|
76
|
+
} else if (typeof fallback[k] === 'object') {
|
|
77
|
+
mergeCatalog(fallback[k],catalog[k]);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
|
|
84
|
+
async function readFile(lng, ns) {
|
|
85
|
+
if (/[^a-z\-]/i.test(lng)) {
|
|
86
|
+
throw new Error("Invalid language: "+lng)
|
|
87
|
+
}
|
|
88
|
+
if (resourceCache[ns] && resourceCache[ns][lng]) {
|
|
89
|
+
return resourceCache[ns][lng];
|
|
90
|
+
} else if (resourceMap[ns]) {
|
|
91
|
+
const file = path.join(resourceMap[ns].basedir, lng, resourceMap[ns].file);
|
|
92
|
+
const content = await fs.readFile(file, "utf8");
|
|
93
|
+
resourceCache[ns] = resourceCache[ns] || {};
|
|
94
|
+
resourceCache[ns][lng] = JSON.parse(content.replace(/^\uFEFF/, ''));
|
|
95
|
+
var baseLng = lng.split('-')[0];
|
|
96
|
+
if (baseLng !== lng && resourceCache[ns][baseLng]) {
|
|
97
|
+
mergeCatalog(resourceCache[ns][baseLng], resourceCache[ns][lng]);
|
|
98
|
+
}
|
|
99
|
+
if (lng !== defaultLang) {
|
|
100
|
+
mergeCatalog(resourceCache[ns][defaultLang], resourceCache[ns][lng]);
|
|
101
|
+
}
|
|
102
|
+
return resourceCache[ns][lng];
|
|
103
|
+
} else {
|
|
104
|
+
throw new Error("Unrecognised namespace");
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
var MessageFileLoader = {
|
|
109
|
+
type: "backend",
|
|
110
|
+
init: function (services, backendOptions, i18nextOptions) { },
|
|
111
|
+
read: function (lng, ns, callback) {
|
|
112
|
+
readFile(lng, ns)
|
|
113
|
+
.then(data => callback(null, data))
|
|
114
|
+
.catch(err => {
|
|
115
|
+
if (/-/.test(lng)) {
|
|
116
|
+
// if reading language file fails -> try reading base language (e. g. 'fr' instead of 'fr-FR' or 'de' for 'de-DE')
|
|
117
|
+
var baseLng = lng.split('-')[0];
|
|
118
|
+
readFile(baseLng, ns).then(baseData => callback(null, baseData)).catch(err => callback(err));
|
|
119
|
+
} else {
|
|
120
|
+
callback(err);
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
function getCurrentLocale() {
|
|
127
|
+
var env = process.env;
|
|
128
|
+
for (var name of ['LC_ALL', 'LC_MESSAGES', 'LANG']) {
|
|
129
|
+
if (name in env) {
|
|
130
|
+
var val = env[name];
|
|
131
|
+
return val.substring(0, 2);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
return undefined;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
function init(settings) {
|
|
138
|
+
if (!initPromise) {
|
|
139
|
+
// Keep this as a 'when' promise as top-level red.js uses 'otherwise'
|
|
140
|
+
// and embedded users of NR may have copied that.
|
|
141
|
+
initPromise = new Promise((resolve,reject) => {
|
|
142
|
+
i18n.use(MessageFileLoader);
|
|
143
|
+
var opt = {
|
|
144
|
+
// debug: true,
|
|
145
|
+
defaultNS: "runtime",
|
|
146
|
+
ns: [],
|
|
147
|
+
fallbackLng: defaultLang,
|
|
148
|
+
interpolation: {
|
|
149
|
+
unescapeSuffix: 'HTML',
|
|
150
|
+
escapeValue: false,
|
|
151
|
+
prefix: '__',
|
|
152
|
+
suffix: '__'
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
var lang = settings.lang || getCurrentLocale();
|
|
156
|
+
if (lang) {
|
|
157
|
+
opt.lng = lang;
|
|
158
|
+
}
|
|
159
|
+
i18n.init(opt ,function() {
|
|
160
|
+
resolve();
|
|
161
|
+
});
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
|
|
167
|
+
/**
|
|
168
|
+
* Gets a message catalog.
|
|
169
|
+
* @name catalog
|
|
170
|
+
* @function
|
|
171
|
+
* @memberof @node-red/util_i18n
|
|
172
|
+
*/
|
|
173
|
+
function getCatalog(namespace,lang) {
|
|
174
|
+
var result = null;
|
|
175
|
+
lang = lang || defaultLang;
|
|
176
|
+
if (/[^a-z\-]/i.test(lang)) {
|
|
177
|
+
throw new Error("Invalid language: "+lng)
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
if (resourceCache.hasOwnProperty(namespace)) {
|
|
181
|
+
result = resourceCache[namespace][lang];
|
|
182
|
+
if (!result) {
|
|
183
|
+
var langParts = lang.split("-");
|
|
184
|
+
if (langParts.length == 2) {
|
|
185
|
+
result = resourceCache[namespace][langParts[0]];
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
return result;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* Gets a list of languages a given catalog is available in.
|
|
194
|
+
* @name availableLanguages
|
|
195
|
+
* @function
|
|
196
|
+
* @memberof @node-red/util_i18n
|
|
197
|
+
*/
|
|
198
|
+
function availableLanguages(namespace) {
|
|
199
|
+
if (resourceMap.hasOwnProperty(namespace)) {
|
|
200
|
+
return resourceMap[namespace].lngs
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
var obj = module.exports = {
|
|
205
|
+
init: init,
|
|
206
|
+
registerMessageCatalog: registerMessageCatalog,
|
|
207
|
+
registerMessageCatalogs: registerMessageCatalogs,
|
|
208
|
+
catalog: getCatalog,
|
|
209
|
+
availableLanguages: availableLanguages,
|
|
210
|
+
/**
|
|
211
|
+
* The underlying i18n library for when direct access is really needed
|
|
212
|
+
*/
|
|
213
|
+
i: i18n,
|
|
214
|
+
/**
|
|
215
|
+
* The default language of the runtime
|
|
216
|
+
*/
|
|
217
|
+
defaultLang: defaultLang
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
/**
|
|
221
|
+
* Perform a message catalog lookup.
|
|
222
|
+
* @name _
|
|
223
|
+
* @function
|
|
224
|
+
* @memberof @node-red/util_i18n
|
|
225
|
+
*/
|
|
226
|
+
obj['_'] = function() {
|
|
227
|
+
//var opts = {};
|
|
228
|
+
//if (def) {
|
|
229
|
+
// opts.defaultValue = def;
|
|
230
|
+
//}
|
|
231
|
+
//console.log(arguments);
|
|
232
|
+
var res = i18n.t.apply(i18n,arguments);
|
|
233
|
+
return res;
|
|
234
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Copyright JS Foundation and other contributors, http://js.foundation
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
**/
|
|
16
|
+
|
|
17
|
+
const log = require("./log");
|
|
18
|
+
const i18n = require("./i18n");
|
|
19
|
+
const util = require("./util");
|
|
20
|
+
const events = require("./events");
|
|
21
|
+
const exec = require("./exec");
|
|
22
|
+
const hooks = require("./hooks");
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* This module provides common utilities for the Node-RED runtime and editor
|
|
26
|
+
*
|
|
27
|
+
* @namespace @node-red/util
|
|
28
|
+
*/
|
|
29
|
+
module.exports = {
|
|
30
|
+
/**
|
|
31
|
+
* Initialise the module with the runtime settings
|
|
32
|
+
* @param {Object} settings
|
|
33
|
+
* @memberof @node-red/util
|
|
34
|
+
*/
|
|
35
|
+
init: function(settings) {
|
|
36
|
+
log.init(settings);
|
|
37
|
+
i18n.init(settings);
|
|
38
|
+
},
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Logging utilities
|
|
42
|
+
* @mixes @node-red/util_log
|
|
43
|
+
* @memberof @node-red/util
|
|
44
|
+
*/
|
|
45
|
+
log: log,
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* Internationalization utilities
|
|
49
|
+
* @mixes @node-red/util_i18n
|
|
50
|
+
* @memberof @node-red/util
|
|
51
|
+
*/
|
|
52
|
+
i18n: i18n,
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* General utilities
|
|
56
|
+
* @mixes @node-red/util_util
|
|
57
|
+
* @memberof @node-red/util
|
|
58
|
+
*/
|
|
59
|
+
util: util,
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Runtime events
|
|
63
|
+
* @mixes @node-red/util_event
|
|
64
|
+
* @memberof @node-red/util
|
|
65
|
+
*/
|
|
66
|
+
events: events,
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Run system commands with event-log integration
|
|
70
|
+
* @mixes @node-red/util_exec
|
|
71
|
+
* @memberof @node-red/util
|
|
72
|
+
*/
|
|
73
|
+
exec: exec,
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Runtime hooks
|
|
77
|
+
* @mixes @node-red/util_hooks
|
|
78
|
+
* @memberof @node-red/util
|
|
79
|
+
*/
|
|
80
|
+
hooks: hooks
|
|
81
|
+
}
|
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Copyright JS Foundation and other contributors, http://js.foundation
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
**/
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Logging utilities
|
|
19
|
+
* @mixin @node-red/util_log
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
var util = require("util");
|
|
23
|
+
var EventEmitter = require("events").EventEmitter;
|
|
24
|
+
|
|
25
|
+
var i18n = require("./i18n");
|
|
26
|
+
|
|
27
|
+
var levels = {
|
|
28
|
+
off: 1,
|
|
29
|
+
fatal: 10,
|
|
30
|
+
error: 20,
|
|
31
|
+
warn: 30,
|
|
32
|
+
info: 40,
|
|
33
|
+
debug: 50,
|
|
34
|
+
trace: 60,
|
|
35
|
+
audit: 98,
|
|
36
|
+
metric: 99
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
var levelNames = {
|
|
40
|
+
10: "fatal",
|
|
41
|
+
20: "error",
|
|
42
|
+
30: "warn",
|
|
43
|
+
40: "info",
|
|
44
|
+
50: "debug",
|
|
45
|
+
60: "trace",
|
|
46
|
+
98: "audit",
|
|
47
|
+
99: "metric"
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
var logHandlers = [];
|
|
51
|
+
|
|
52
|
+
var verbose;
|
|
53
|
+
|
|
54
|
+
var metricsEnabled = false;
|
|
55
|
+
|
|
56
|
+
var LogHandler = function(settings) {
|
|
57
|
+
this.logLevel = settings ? levels[settings.level]||levels.info : levels.info;
|
|
58
|
+
this.metricsOn = settings ? settings.metrics||false : false;
|
|
59
|
+
this.auditOn = settings ? settings.audit||false : false;
|
|
60
|
+
|
|
61
|
+
metricsEnabled = metricsEnabled || this.metricsOn;
|
|
62
|
+
|
|
63
|
+
this.handler = (settings && settings.handler) ? settings.handler(settings) : consoleLogger;
|
|
64
|
+
this.on("log",function(msg) {
|
|
65
|
+
if (this.shouldReportMessage(msg.level)) {
|
|
66
|
+
this.handler(msg);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
util.inherits(LogHandler, EventEmitter);
|
|
71
|
+
|
|
72
|
+
LogHandler.prototype.shouldReportMessage = function(msglevel) {
|
|
73
|
+
return (msglevel == log.METRIC && this.metricsOn) ||
|
|
74
|
+
(msglevel == log.AUDIT && this.auditOn) ||
|
|
75
|
+
msglevel <= this.logLevel;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
var consoleLogger = function(msg) {
|
|
79
|
+
if (msg.level == log.METRIC || msg.level == log.AUDIT) {
|
|
80
|
+
util.log("["+levelNames[msg.level]+"] "+JSON.stringify(msg));
|
|
81
|
+
} else {
|
|
82
|
+
if (verbose && msg.msg && msg.msg.stack) {
|
|
83
|
+
util.log("["+levelNames[msg.level]+"] "+(msg.type?"["+msg.type+":"+(msg.name||msg.id)+"] ":"")+msg.msg.stack);
|
|
84
|
+
} else {
|
|
85
|
+
var message = msg.msg;
|
|
86
|
+
try {
|
|
87
|
+
if (typeof message === 'object' && message !== null && message.toString() === '[object Object]' && message.message) {
|
|
88
|
+
message = message.message;
|
|
89
|
+
}
|
|
90
|
+
} catch(e){
|
|
91
|
+
message = 'Exception trying to log: '+util.inspect(message);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
util.log("["+levelNames[msg.level]+"] "+(msg.type?"["+msg.type+":"+(msg.name||msg.id)+"] ":"")+message);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
var log = module.exports = {
|
|
101
|
+
|
|
102
|
+
FATAL: 10,
|
|
103
|
+
ERROR: 20,
|
|
104
|
+
WARN: 30,
|
|
105
|
+
INFO: 40,
|
|
106
|
+
DEBUG: 50,
|
|
107
|
+
TRACE: 60,
|
|
108
|
+
AUDIT: 98,
|
|
109
|
+
METRIC: 99,
|
|
110
|
+
|
|
111
|
+
init: function(settings) {
|
|
112
|
+
metricsEnabled = false;
|
|
113
|
+
logHandlers = [];
|
|
114
|
+
var loggerSettings = {};
|
|
115
|
+
verbose = settings.verbose;
|
|
116
|
+
if (settings.logging) {
|
|
117
|
+
var keys = Object.keys(settings.logging);
|
|
118
|
+
if (keys.length === 0) {
|
|
119
|
+
log.addHandler(new LogHandler());
|
|
120
|
+
} else {
|
|
121
|
+
for (var i=0, l=keys.length; i<l; i++) {
|
|
122
|
+
var config = settings.logging[keys[i]];
|
|
123
|
+
loggerSettings = config || {};
|
|
124
|
+
if ((keys[i] === "console") || config.handler) {
|
|
125
|
+
log.addHandler(new LogHandler(loggerSettings));
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
} else {
|
|
130
|
+
log.addHandler(new LogHandler());
|
|
131
|
+
}
|
|
132
|
+
},
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Add a log handler function
|
|
136
|
+
* @memberof @node-red/util_log
|
|
137
|
+
*/
|
|
138
|
+
addHandler: function(func) {
|
|
139
|
+
logHandlers.push(func);
|
|
140
|
+
},
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* Remove a log handler function
|
|
144
|
+
* @memberof @node-red/util_log
|
|
145
|
+
*/
|
|
146
|
+
removeHandler: function(func) {
|
|
147
|
+
var index = logHandlers.indexOf(func);
|
|
148
|
+
if (index > -1) {
|
|
149
|
+
logHandlers.splice(index,1);
|
|
150
|
+
}
|
|
151
|
+
},
|
|
152
|
+
|
|
153
|
+
/**
|
|
154
|
+
* Log a message object
|
|
155
|
+
* @memberof @node-red/util_log
|
|
156
|
+
*/
|
|
157
|
+
log: function(msg) {
|
|
158
|
+
msg.timestamp = Date.now();
|
|
159
|
+
logHandlers.forEach(function(handler) {
|
|
160
|
+
handler.emit("log",msg);
|
|
161
|
+
});
|
|
162
|
+
},
|
|
163
|
+
|
|
164
|
+
/**
|
|
165
|
+
* Log a message at INFO level
|
|
166
|
+
* @memberof @node-red/util_log
|
|
167
|
+
*/
|
|
168
|
+
info: function(msg) {
|
|
169
|
+
log.log({level:log.INFO,msg:msg});
|
|
170
|
+
},
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Log a message at WARN level
|
|
174
|
+
* @memberof @node-red/util_log
|
|
175
|
+
*/
|
|
176
|
+
warn: function(msg) {
|
|
177
|
+
log.log({level:log.WARN,msg:msg});
|
|
178
|
+
},
|
|
179
|
+
|
|
180
|
+
/**
|
|
181
|
+
* Log a message at ERROR level
|
|
182
|
+
* @memberof @node-red/util_log
|
|
183
|
+
*/
|
|
184
|
+
error: function(msg) {
|
|
185
|
+
log.log({level:log.ERROR,msg:msg});
|
|
186
|
+
},
|
|
187
|
+
|
|
188
|
+
/**
|
|
189
|
+
* Log a message at TRACE level
|
|
190
|
+
* @memberof @node-red/util_log
|
|
191
|
+
*/
|
|
192
|
+
trace: function(msg) {
|
|
193
|
+
log.log({level:log.TRACE,msg:msg});
|
|
194
|
+
},
|
|
195
|
+
|
|
196
|
+
/**
|
|
197
|
+
* Log a message at DEBUG level
|
|
198
|
+
* @memberof @node-red/util_log
|
|
199
|
+
*/
|
|
200
|
+
debug: function(msg) {
|
|
201
|
+
log.log({level:log.DEBUG,msg:msg});
|
|
202
|
+
},
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* Check if metrics are enabled
|
|
206
|
+
* @memberof @node-red/util_log
|
|
207
|
+
*/
|
|
208
|
+
metric: function() {
|
|
209
|
+
return metricsEnabled;
|
|
210
|
+
},
|
|
211
|
+
|
|
212
|
+
/**
|
|
213
|
+
* Log an audit event.
|
|
214
|
+
* @memberof @node-red/util_log
|
|
215
|
+
*/
|
|
216
|
+
audit: function(msg,req) {
|
|
217
|
+
msg.level = log.AUDIT;
|
|
218
|
+
if (req) {
|
|
219
|
+
msg.user = req.user;
|
|
220
|
+
msg.path = req.path;
|
|
221
|
+
msg.ip = req.ip || (req.headers && req.headers['x-forwarded-for']) || (req.connection && req.connection.remoteAddress) || undefined;
|
|
222
|
+
}
|
|
223
|
+
log.log(msg);
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
/**
|
|
228
|
+
* Perform a message catalog lookup.
|
|
229
|
+
* @name _
|
|
230
|
+
* @function
|
|
231
|
+
* @memberof @node-red/util_log
|
|
232
|
+
*/
|
|
233
|
+
log["_"] = i18n._;
|