2014-05-03 23:26:35 +02:00
|
|
|
/**
|
2016-06-11 23:53:27 +02:00
|
|
|
* Copyright 2014, 2016 IBM Corp.
|
2014-05-03 23:26:35 +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.
|
|
|
|
**/
|
2014-05-07 20:19:08 +02:00
|
|
|
|
2014-05-03 23:26:35 +02:00
|
|
|
var util = require("util");
|
|
|
|
var EventEmitter = require("events").EventEmitter;
|
2014-05-14 22:17:54 +02:00
|
|
|
var when = require("when");
|
2014-05-03 23:26:35 +02:00
|
|
|
|
2014-11-06 12:39:30 +01:00
|
|
|
var redUtil = require("../util");
|
2015-01-27 15:41:20 +01:00
|
|
|
var Log = require("../log");
|
2015-12-29 23:16:51 +01:00
|
|
|
var context = require("./context");
|
2014-05-03 23:26:35 +02:00
|
|
|
var flows = require("./flows");
|
2016-10-29 22:46:19 +02:00
|
|
|
var router = require("./router");
|
2014-05-03 23:26:35 +02:00
|
|
|
|
|
|
|
function Node(n) {
|
|
|
|
this.id = n.id;
|
|
|
|
this.type = n.type;
|
2015-02-20 02:17:24 +01:00
|
|
|
this.z = n.z;
|
2015-03-04 22:42:11 +01:00
|
|
|
this._closeCallbacks = [];
|
2016-11-01 14:10:51 +01:00
|
|
|
this._config = n;
|
2015-03-06 23:58:30 +01:00
|
|
|
|
2014-05-03 23:26:35 +02:00
|
|
|
if (n.name) {
|
|
|
|
this.name = n.name;
|
|
|
|
}
|
2015-11-02 21:41:59 +01:00
|
|
|
if (n._alias) {
|
|
|
|
this._alias = n._alias;
|
|
|
|
}
|
2015-01-08 23:34:26 +01:00
|
|
|
this.updateWires(n.wires);
|
|
|
|
}
|
|
|
|
|
|
|
|
util.inherits(Node, EventEmitter);
|
|
|
|
|
|
|
|
Node.prototype.updateWires = function(wires) {
|
2016-10-29 22:46:19 +02:00
|
|
|
router.add(this,wires);
|
2015-01-08 23:34:26 +01:00
|
|
|
this.wires = wires || [];
|
|
|
|
}
|
2016-10-29 22:46:19 +02:00
|
|
|
|
2015-12-29 23:16:51 +01:00
|
|
|
Node.prototype.context = function() {
|
|
|
|
if (!this._context) {
|
|
|
|
this._context = context.get(this._alias||this.id,this.z);
|
|
|
|
}
|
|
|
|
return this._context;
|
|
|
|
}
|
2014-05-15 21:55:01 +02:00
|
|
|
|
|
|
|
Node.prototype._on = Node.prototype.on;
|
|
|
|
|
2014-10-10 11:50:54 +02:00
|
|
|
Node.prototype.on = function(event, callback) {
|
2014-05-14 22:34:17 +02:00
|
|
|
var node = this;
|
2014-05-14 22:17:54 +02:00
|
|
|
if (event == "close") {
|
2015-03-04 22:42:11 +01:00
|
|
|
this._closeCallbacks.push(callback);
|
|
|
|
} else {
|
|
|
|
this._on(event, callback);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Node.prototype.close = function() {
|
|
|
|
var promises = [];
|
|
|
|
var node = this;
|
|
|
|
for (var i=0;i<this._closeCallbacks.length;i++) {
|
|
|
|
var callback = this._closeCallbacks[i];
|
2014-05-14 22:17:54 +02:00
|
|
|
if (callback.length == 1) {
|
2015-03-04 22:42:11 +01:00
|
|
|
promises.push(
|
|
|
|
when.promise(function(resolve) {
|
2014-10-10 11:50:54 +02:00
|
|
|
callback.call(node, function() {
|
2014-05-14 22:17:54 +02:00
|
|
|
resolve();
|
|
|
|
});
|
2015-03-04 22:42:11 +01:00
|
|
|
})
|
|
|
|
);
|
2014-05-14 22:17:54 +02:00
|
|
|
} else {
|
2015-03-04 22:42:11 +01:00
|
|
|
callback.call(node);
|
2014-05-14 22:17:54 +02:00
|
|
|
}
|
2015-03-04 22:42:11 +01:00
|
|
|
}
|
|
|
|
if (promises.length > 0) {
|
2016-06-11 23:53:27 +02:00
|
|
|
return when.settle(promises).then(function() {
|
2016-10-29 22:46:19 +02:00
|
|
|
router.remove(this);
|
2016-06-11 23:53:27 +02:00
|
|
|
if (this._context) {
|
2016-10-29 22:46:19 +02:00
|
|
|
context.delete(this._alias||this.id,this.z);
|
2016-06-11 23:53:27 +02:00
|
|
|
}
|
|
|
|
});
|
2014-05-15 21:55:01 +02:00
|
|
|
} else {
|
2016-10-29 22:46:19 +02:00
|
|
|
router.remove(this);
|
2016-06-11 23:53:27 +02:00
|
|
|
if (this._context) {
|
2016-10-29 22:46:19 +02:00
|
|
|
context.delete(this._alias||this.id,this.z);
|
2016-06-11 23:53:27 +02:00
|
|
|
}
|
2015-03-04 22:42:11 +01:00
|
|
|
return;
|
2014-05-14 22:17:54 +02:00
|
|
|
}
|
2014-10-10 11:50:54 +02:00
|
|
|
};
|
|
|
|
|
2014-05-03 23:26:35 +02:00
|
|
|
Node.prototype.send = function(msg) {
|
2016-10-29 22:46:19 +02:00
|
|
|
router.send(this,msg);
|
2014-10-10 11:50:54 +02:00
|
|
|
};
|
2014-05-03 23:26:35 +02:00
|
|
|
|
2015-03-06 23:58:30 +01:00
|
|
|
Node.prototype.receive = function(msg) {
|
2015-01-27 15:41:20 +01:00
|
|
|
if (!msg) {
|
|
|
|
msg = {};
|
|
|
|
}
|
2015-02-06 17:36:32 +01:00
|
|
|
if (!msg._msgid) {
|
2015-06-02 16:54:37 +02:00
|
|
|
msg._msgid = redUtil.generateId();
|
2015-01-27 15:41:20 +01:00
|
|
|
}
|
2015-03-06 23:58:30 +01:00
|
|
|
this.metric("receive",msg);
|
2015-08-19 22:14:45 +02:00
|
|
|
try {
|
2015-05-02 23:15:33 +02:00
|
|
|
this.emit("input", msg);
|
|
|
|
} catch(err) {
|
|
|
|
this.error(err,msg);
|
|
|
|
}
|
2014-10-10 11:50:54 +02:00
|
|
|
};
|
2014-05-03 23:26:35 +02:00
|
|
|
|
2014-07-09 08:42:34 +02:00
|
|
|
function log_helper(self, level, msg) {
|
2014-10-10 11:50:54 +02:00
|
|
|
var o = {
|
|
|
|
level: level,
|
|
|
|
id: self.id,
|
|
|
|
type: self.type,
|
|
|
|
msg: msg
|
|
|
|
};
|
2014-07-09 08:42:34 +02:00
|
|
|
if (self.name) {
|
|
|
|
o.name = self.name;
|
2014-07-02 00:46:25 +02:00
|
|
|
}
|
2015-01-27 15:41:20 +01:00
|
|
|
Log.log(o);
|
2014-05-03 23:26:35 +02:00
|
|
|
}
|
2014-07-09 08:42:34 +02:00
|
|
|
|
|
|
|
Node.prototype.log = function(msg) {
|
2015-02-03 23:02:26 +01:00
|
|
|
log_helper(this, Log.INFO, msg);
|
2014-10-10 11:50:54 +02:00
|
|
|
};
|
2014-07-09 08:42:34 +02:00
|
|
|
|
2014-05-03 23:26:35 +02:00
|
|
|
Node.prototype.warn = function(msg) {
|
2015-02-03 23:02:26 +01:00
|
|
|
log_helper(this, Log.WARN, msg);
|
2014-10-10 11:50:54 +02:00
|
|
|
};
|
2014-07-09 08:42:34 +02:00
|
|
|
|
2015-02-20 02:17:24 +01:00
|
|
|
Node.prototype.error = function(logMessage,msg) {
|
|
|
|
logMessage = logMessage || "";
|
|
|
|
log_helper(this, Log.ERROR, logMessage);
|
2015-03-06 23:58:30 +01:00
|
|
|
/* istanbul ignore else */
|
2015-02-20 23:59:48 +01:00
|
|
|
if (msg) {
|
|
|
|
flows.handleError(this,logMessage,msg);
|
|
|
|
}
|
2014-10-10 11:50:54 +02:00
|
|
|
};
|
2014-07-09 08:42:34 +02:00
|
|
|
|
2015-02-04 21:44:07 +01:00
|
|
|
/**
|
|
|
|
* If called with no args, returns whether metric collection is enabled
|
|
|
|
*/
|
2015-02-03 14:51:05 +01:00
|
|
|
Node.prototype.metric = function(eventname, msg, metricValue) {
|
2015-02-04 21:44:07 +01:00
|
|
|
if (typeof eventname === "undefined") {
|
|
|
|
return Log.metric();
|
|
|
|
}
|
2015-02-03 14:51:05 +01:00
|
|
|
var metrics = {};
|
2015-02-03 23:02:26 +01:00
|
|
|
metrics.level = Log.METRIC;
|
2015-01-27 15:41:20 +01:00
|
|
|
metrics.nodeid = this.id;
|
2015-03-06 23:58:30 +01:00
|
|
|
metrics.event = "node."+this.type+"."+eventname;
|
2015-02-06 17:36:32 +01:00
|
|
|
metrics.msgid = msg._msgid;
|
2015-02-04 23:28:17 +01:00
|
|
|
metrics.value = metricValue;
|
2015-01-27 15:41:20 +01:00
|
|
|
Log.log(metrics);
|
|
|
|
}
|
|
|
|
|
2014-05-08 15:15:54 +02:00
|
|
|
/**
|
|
|
|
* status: { fill:"red|green", shape:"dot|ring", text:"blah" }
|
|
|
|
*/
|
2014-05-30 21:30:26 +02:00
|
|
|
Node.prototype.status = function(status) {
|
2015-08-19 22:14:45 +02:00
|
|
|
flows.handleStatus(this,status);
|
2014-10-10 11:50:54 +02:00
|
|
|
};
|
2014-05-03 23:26:35 +02:00
|
|
|
module.exports = Node;
|