2016-03-31 11:05:32 +02:00
|
|
|
/* Magic Mirror
|
|
|
|
* Node Helper: Newsfeed
|
|
|
|
*
|
2020-04-28 23:05:28 +02:00
|
|
|
* By Michael Teeuw https://michaelteeuw.nl
|
2016-03-31 11:05:32 +02:00
|
|
|
* MIT Licensed.
|
|
|
|
*/
|
|
|
|
|
2016-04-05 14:35:11 -04:00
|
|
|
var NodeHelper = require("node_helper");
|
|
|
|
var validUrl = require("valid-url");
|
|
|
|
var Fetcher = require("./fetcher.js");
|
2016-03-30 12:20:46 +02:00
|
|
|
|
2016-03-30 14:49:37 +02:00
|
|
|
module.exports = NodeHelper.create({
|
|
|
|
// Subclass start method.
|
2020-05-11 22:22:32 +02:00
|
|
|
start: function () {
|
2016-04-05 14:35:11 -04:00
|
|
|
console.log("Starting module: " + this.name);
|
2016-03-30 14:49:37 +02:00
|
|
|
this.fetchers = [];
|
|
|
|
},
|
2016-03-30 12:20:46 +02:00
|
|
|
|
2016-03-30 14:49:37 +02:00
|
|
|
// Subclass socketNotificationReceived received.
|
2020-05-11 22:22:32 +02:00
|
|
|
socketNotificationReceived: function (notification, payload) {
|
2016-04-05 14:35:11 -04:00
|
|
|
if (notification === "ADD_FEED") {
|
2016-04-20 14:39:38 +02:00
|
|
|
this.createFetcher(payload.feed, payload.config);
|
|
|
|
return;
|
2016-03-30 14:49:37 +02:00
|
|
|
}
|
|
|
|
},
|
2016-03-30 12:20:46 +02:00
|
|
|
|
2017-03-30 21:15:51 +02:00
|
|
|
/* createFetcher(feed, config)
|
|
|
|
* Creates a fetcher for a new feed if it doesn't exist yet.
|
|
|
|
* Otherwise it reuses the existing one.
|
2016-03-30 12:20:46 +02:00
|
|
|
*
|
2017-03-30 21:15:51 +02:00
|
|
|
* attribute feed object - A feed object.
|
|
|
|
* attribute config object - A configuration object containing reload interval in milliseconds.
|
2016-03-30 12:20:46 +02:00
|
|
|
*/
|
2020-05-11 22:22:32 +02:00
|
|
|
createFetcher: function (feed, config) {
|
2016-03-30 14:49:37 +02:00
|
|
|
var self = this;
|
2016-03-30 12:20:46 +02:00
|
|
|
|
2016-12-01 19:48:53 -03:00
|
|
|
var url = feed.url || "";
|
|
|
|
var encoding = feed.encoding || "UTF-8";
|
2017-11-15 12:21:22 +07:00
|
|
|
var reloadInterval = feed.reloadInterval || config.reloadInterval || 5 * 60 * 1000;
|
2016-04-20 14:39:38 +02:00
|
|
|
|
2016-04-05 14:35:11 -04:00
|
|
|
if (!validUrl.isUri(url)) {
|
|
|
|
self.sendSocketNotification("INCORRECT_URL", url);
|
2016-03-30 12:20:46 +02:00
|
|
|
return;
|
|
|
|
}
|
2016-03-29 15:44:43 +02:00
|
|
|
|
2016-03-30 14:49:37 +02:00
|
|
|
var fetcher;
|
2016-04-05 14:35:11 -04:00
|
|
|
if (typeof self.fetchers[url] === "undefined") {
|
|
|
|
console.log("Create new news fetcher for url: " + url + " - Interval: " + reloadInterval);
|
2018-06-26 20:01:28 -04:00
|
|
|
fetcher = new Fetcher(url, reloadInterval, encoding, config.logFeedWarnings);
|
2016-04-03 19:52:13 +02:00
|
|
|
|
2020-05-11 22:22:32 +02:00
|
|
|
fetcher.onReceive(function (fetcher) {
|
2016-04-20 14:39:38 +02:00
|
|
|
self.broadcastFeeds();
|
2016-03-30 14:49:37 +02:00
|
|
|
});
|
|
|
|
|
2020-05-11 22:22:32 +02:00
|
|
|
fetcher.onError(function (fetcher, error) {
|
2016-04-05 14:35:11 -04:00
|
|
|
self.sendSocketNotification("FETCH_ERROR", {
|
2016-03-30 14:49:37 +02:00
|
|
|
url: fetcher.url(),
|
|
|
|
error: error
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
self.fetchers[url] = fetcher;
|
|
|
|
} else {
|
2016-06-04 20:32:55 -06:00
|
|
|
console.log("Use existing news fetcher for url: " + url);
|
2016-03-30 14:49:37 +02:00
|
|
|
fetcher = self.fetchers[url];
|
|
|
|
fetcher.setReloadInterval(reloadInterval);
|
|
|
|
fetcher.broadcastItems();
|
|
|
|
}
|
2016-03-29 15:44:43 +02:00
|
|
|
|
2016-03-30 14:49:37 +02:00
|
|
|
fetcher.startFetch();
|
2016-04-20 14:39:38 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
/* broadcastFeeds()
|
2016-12-30 17:47:33 -03:00
|
|
|
* Creates an object with all feed items of the different registered feeds,
|
2016-04-20 14:39:38 +02:00
|
|
|
* and broadcasts these using sendSocketNotification.
|
|
|
|
*/
|
2020-05-11 22:22:32 +02:00
|
|
|
broadcastFeeds: function () {
|
2016-04-20 14:39:38 +02:00
|
|
|
var feeds = {};
|
|
|
|
for (var f in this.fetchers) {
|
|
|
|
feeds[f] = this.fetchers[f].items();
|
|
|
|
}
|
|
|
|
this.sendSocketNotification("NEWS_ITEMS", feeds);
|
2016-03-30 14:49:37 +02:00
|
|
|
}
|
|
|
|
});
|