@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.
@@ -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._;