node-red/red/runtime/index.js

155 lines
5.3 KiB
JavaScript
Raw Normal View History

2013-09-05 16:02:48 +02:00
/**
2015-02-03 23:02:26 +01:00
* Copyright 2013, 2015 IBM Corp.
2013-09-05 16:02:48 +02:00
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
**/
var when = require('when');
2013-09-05 16:02:48 +02:00
var redNodes = require("./nodes");
2014-09-22 15:33:26 +02:00
var storage = require("./storage");
2015-02-03 23:02:26 +01:00
var log = require("./log");
2015-04-15 21:59:39 +02:00
var i18n = require("./i18n");
var events = require("./events");
var settings = require("./settings");
var path = require('path');
var fs = require("fs");
2013-09-05 16:02:48 +02:00
2015-02-04 23:28:17 +01:00
var runtimeMetricInterval = null;
function init(userSettings) {
userSettings.version = version();
log.init(userSettings);
settings.init(userSettings);
}
2015-02-04 23:28:17 +01:00
function version() {
var p = require(path.join(__dirname,"..","..","package.json")).version;
/* istanbul ignore else */
if (fs.existsSync(path.join(__dirname,"..","..",".git"))) {
p += "-git";
}
return p;
2014-11-04 12:34:49 +01:00
}
function start() {
2015-04-15 21:59:39 +02:00
return i18n.init()
.then(function() { return storage.init(settings)})
.then(function() { return settings.load(storage)})
.then(function() {
2015-02-04 23:28:17 +01:00
if (log.metric()) {
runtimeMetricInterval = setInterval(function() {
reportMetrics();
2015-03-21 18:42:06 +01:00
}, settings.runtimeMetricInterval||15000);
2015-02-04 23:28:17 +01:00
}
2015-05-08 15:21:01 +02:00
console.log("\n\n"+log._("runtime.welcome")+"\n===================\n");
2014-11-04 12:34:49 +01:00
if (settings.version) {
2015-05-08 15:21:01 +02:00
log.info(log._("runtime.version",{component:"Node-RED",version:"v"+settings.version}));
}
2015-05-08 15:21:01 +02:00
log.info(log._("runtime.version",{component:"Node.js ",version:process.version}));
log.info(log._("server.loading"));
redNodes.init(settings,storage);
return redNodes.load().then(function() {
2014-11-04 12:34:49 +01:00
var i;
var nodeErrors = redNodes.getNodeList(function(n) { return n.err!=null;});
var nodeMissing = redNodes.getNodeList(function(n) { return n.module && n.enabled && !n.loaded && !n.err;});
2014-11-04 12:34:49 +01:00
if (nodeErrors.length > 0) {
2015-02-03 23:02:26 +01:00
log.warn("------------------------------------------");
2014-11-04 12:34:49 +01:00
if (settings.verbose) {
for (i=0;i<nodeErrors.length;i+=1) {
2015-02-03 23:02:26 +01:00
log.warn("["+nodeErrors[i].name+"] "+nodeErrors[i].err);
2014-09-22 15:33:26 +02:00
}
} else {
2015-05-08 15:21:01 +02:00
log.warn(log._("server.errors",{count:nodeErrors.length}));
log.warn(log._("server.errors-help"));
}
2015-02-03 23:02:26 +01:00
log.warn("------------------------------------------");
2014-09-22 15:33:26 +02:00
}
2014-11-04 12:34:49 +01:00
if (nodeMissing.length > 0) {
2015-05-08 15:21:01 +02:00
log.warn(log._("server.missing-modules"));
2014-11-04 12:34:49 +01:00
var missingModules = {};
for (i=0;i<nodeMissing.length;i++) {
var missing = nodeMissing[i];
missingModules[missing.module] = (missingModules[missing.module]||[]).concat(missing.types);
}
var promises = [];
for (i in missingModules) {
if (missingModules.hasOwnProperty(i)) {
2015-02-03 23:02:26 +01:00
log.warn(" - "+i+": "+missingModules[i].join(", "));
if (settings.autoInstallModules && i != "node-red") {
redNodes.installModule(i).otherwise(function(err) {
2014-11-04 12:34:49 +01:00
// Error already reported. Need the otherwise handler
// to stop the error propagating any further
});
2014-09-22 15:33:26 +02:00
}
}
}
2014-11-04 12:34:49 +01:00
if (!settings.autoInstallModules) {
2015-05-08 15:21:01 +02:00
log.info(log._("server.removing-modules"));
redNodes.cleanModuleList();
2014-11-04 12:34:49 +01:00
}
}
2015-05-08 15:21:01 +02:00
log.info(log._("runtime.paths.settings",{path:settings.settingsFile}));
redNodes.loadFlows().then(redNodes.startFlows);
2014-11-04 12:34:49 +01:00
}).otherwise(function(err) {
console.log(err);
});
});
}
2014-11-04 12:34:49 +01:00
2015-02-04 23:28:17 +01:00
function reportMetrics() {
var memUsage = process.memoryUsage();
2015-03-21 18:42:06 +01:00
log.log({
level: log.METRIC,
event: "runtime.memory.rss",
value: memUsage.rss
});
log.log({
level: log.METRIC,
event: "runtime.memory.heapTotal",
value: memUsage.heapTotal
});
log.log({
level: log.METRIC,
event: "runtime.memory.heapUsed",
value: memUsage.heapUsed
});
2015-02-04 23:28:17 +01:00
}
function stop() {
2015-02-04 23:28:17 +01:00
if (runtimeMetricInterval) {
clearInterval(runtimeMetricInterval);
runtimeMetricInterval = null;
}
return redNodes.stopFlows();
}
var runtime = module.exports = {
init: init,
start: start,
2014-11-04 12:34:49 +01:00
stop: stop,
2014-11-21 17:35:29 +01:00
version: version,
log: log,
i18n: i18n,
settings: settings,
storage: storage,
events: events,
api: redNodes,
util: require("./util")
}