| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | /* Magic Mirror | 
					
						
							|  |  |  |  * Node Helper Superclass | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-04-28 23:05:28 +02:00
										 |  |  |  * By Michael Teeuw https://michaelteeuw.nl
 | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  |  * MIT Licensed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-05-02 10:39:09 +02:00
										 |  |  | const Class = require("./class.js"); | 
					
						
							| 
									
										
										
										
											2020-05-11 07:25:42 +02:00
										 |  |  | const Log = require("./logger.js"); | 
					
						
							| 
									
										
										
										
											2020-05-02 10:39:09 +02:00
										 |  |  | const express = require("express"); | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-02 10:39:09 +02:00
										 |  |  | var NodeHelper = Class.extend({ | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | 	init: function () { | 
					
						
							| 
									
										
										
										
											2020-05-11 07:25:42 +02:00
										 |  |  | 		Log.log("Initializing new module helper ..."); | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | 	loaded: function (callback) { | 
					
						
							| 
									
										
										
										
											2020-05-11 07:25:42 +02:00
										 |  |  | 		Log.log("Module helper loaded: " + this.name); | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 		callback(); | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | 	start: function () { | 
					
						
							| 
									
										
										
										
											2020-05-11 07:25:42 +02:00
										 |  |  | 		Log.log("Starting module helper: " + this.name); | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* stop() | 
					
						
							|  |  |  | 	 * Called when the MagicMirror server receives a `SIGINT` | 
					
						
							|  |  |  | 	 * Close any open connections, stop any sub-processes and | 
					
						
							|  |  |  | 	 * gracefully exit the module. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | 	stop: function () { | 
					
						
							| 
									
										
										
										
											2020-05-11 07:25:42 +02:00
										 |  |  | 		Log.log("Stopping module helper: " + this.name); | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* socketNotificationReceived(notification, payload) | 
					
						
							|  |  |  | 	 * This method is called when a socket notification arrives. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument notification string - The identifier of the notification. | 
					
						
							|  |  |  | 	 * argument payload mixed - The payload of the notification. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | 	socketNotificationReceived: function (notification, payload) { | 
					
						
							| 
									
										
										
										
											2020-05-11 07:25:42 +02:00
										 |  |  | 		Log.log(this.name + " received a socket notification: " + notification + " - Payload: " + payload); | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* setName(name) | 
					
						
							|  |  |  | 	 * Set the module name. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument name string - Module name. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 	setName: function (name) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 		this.name = name; | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* setPath(path) | 
					
						
							|  |  |  | 	 * Set the module path. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument path string - Module path. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 	setPath: function (path) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 		this.path = path; | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* sendSocketNotification(notification, payload) | 
					
						
							|  |  |  | 	 * Send a socket notification to the node helper. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument notification string - The identifier of the notification. | 
					
						
							|  |  |  | 	 * argument payload mixed - The payload of the notification. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 	sendSocketNotification: function (notification, payload) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 		this.io.of(this.name).emit(notification, payload); | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* setExpressApp(app) | 
					
						
							|  |  |  | 	 * Sets the express app object for this module. | 
					
						
							|  |  |  | 	 * This allows you to host files from the created webserver. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument app Express app - The Express app object. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 	setExpressApp: function (app) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 		this.expressApp = app; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		var publicPath = this.path + "/public"; | 
					
						
							|  |  |  | 		app.use("/" + this.name, express.static(publicPath)); | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* setSocketIO(io) | 
					
						
							|  |  |  | 	 * Sets the socket io object for this module. | 
					
						
							|  |  |  | 	 * Binds message receiver. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * argument io Socket.io - The Socket io object. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 	setSocketIO: function (io) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 		var self = this; | 
					
						
							|  |  |  | 		self.io = io; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-11 07:25:42 +02:00
										 |  |  | 		Log.log("Connecting socket for: " + this.name); | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 		var namespace = this.name; | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 		io.of(namespace).on("connection", function (socket) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 			// add a catch all event.
 | 
					
						
							|  |  |  | 			var onevent = socket.onevent; | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 			socket.onevent = function (packet) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 				var args = packet.data || []; | 
					
						
							| 
									
										
										
										
											2020-03-15 15:49:34 +01:00
										 |  |  | 				onevent.call(this, packet); // original call
 | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 				packet.data = ["*"].concat(args); | 
					
						
							| 
									
										
										
										
											2020-03-15 15:49:34 +01:00
										 |  |  | 				onevent.call(this, packet); // additional call to catch-all
 | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 			}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			// register catch all.
 | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 			socket.on("*", function (notification, payload) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 				if (notification !== "*") { | 
					
						
							| 
									
										
										
										
											2020-05-11 07:25:42 +02:00
										 |  |  | 					//Log.log('received message in namespace: ' + namespace);
 | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 					self.socketNotificationReceived(notification, payload); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | NodeHelper.create = function (moduleDefinition) { | 
					
						
							| 
									
										
										
										
											2019-12-31 19:31:13 +00:00
										 |  |  | 	return NodeHelper.extend(moduleDefinition); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-02 10:39:09 +02:00
										 |  |  | /*************** DO NOT EDIT THE LINE BELOW ***************/ | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | if (typeof module !== "undefined") { | 
					
						
							|  |  |  | 	module.exports = NodeHelper; | 
					
						
							|  |  |  | } |