|
|
@ -9,6 +9,8 @@ const path = require('path');
|
|
|
|
require('dotenv').config({ path: path.resolve(__dirname, '..', '..', '.env') });
|
|
|
|
require('dotenv').config({ path: path.resolve(__dirname, '..', '..', '.env') });
|
|
|
|
|
|
|
|
|
|
|
|
const mongoose = require('mongoose');
|
|
|
|
const mongoose = require('mongoose');
|
|
|
|
|
|
|
|
const moment = require('moment');
|
|
|
|
|
|
|
|
|
|
|
|
const { read: feedReader } = require('feed-reader');
|
|
|
|
const { read: feedReader } = require('feed-reader');
|
|
|
|
|
|
|
|
|
|
|
|
const {
|
|
|
|
const {
|
|
|
@ -23,7 +25,7 @@ module.pkg = require(path.resolve(__dirname, '..', '..', 'package.json'));
|
|
|
|
module.config = {
|
|
|
|
module.config = {
|
|
|
|
environment: process.env.NODE_ENV,
|
|
|
|
environment: process.env.NODE_ENV,
|
|
|
|
root: module.rootPath,
|
|
|
|
root: module.rootPath,
|
|
|
|
component: { logId: 'newsroom', index: 'newsroom', className: 'NewsroomWorker' },
|
|
|
|
component: { logId: 'wrk:newsroom', index: 'newsroom', className: 'NewsroomWorker' },
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
module.config.site = require(path.join(module.rootPath, 'config', 'site'));
|
|
|
|
module.config.site = require(path.join(module.rootPath, 'config', 'site'));
|
|
|
@ -53,14 +55,30 @@ class NewsroomWorker extends SiteWorker {
|
|
|
|
const NOW = new Date();
|
|
|
|
const NOW = new Date();
|
|
|
|
const { feed: feedService } = this.dtp.services;
|
|
|
|
const { feed: feedService } = this.dtp.services;
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
this.log.info('loading latest feed data', { feedId: feed._id, title: feed.title });
|
|
|
|
this.log.info('loading latest feed data', {
|
|
|
|
|
|
|
|
feed: {
|
|
|
|
|
|
|
|
_id: feed._id,
|
|
|
|
|
|
|
|
title: feed.title,
|
|
|
|
|
|
|
|
published: {
|
|
|
|
|
|
|
|
date: feed.published,
|
|
|
|
|
|
|
|
moment: moment(feed.published).fromNow(),
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
});
|
|
|
|
await feedService.updateFavicon(feed);
|
|
|
|
await feedService.updateFavicon(feed);
|
|
|
|
const response = await feedReader(feed.url);
|
|
|
|
const response = await feedReader(feed.url);
|
|
|
|
await SiteAsync.each(response.entries, async (entry) => {
|
|
|
|
await SiteAsync.each(response.entries, async (entry) => {
|
|
|
|
await Feed.updateOne({ _id: feed._id }, { $set: { published: feed.published || NOW }});
|
|
|
|
await Feed.updateOne({ _id: feed._id }, { $set: { published: feed.published || NOW }});
|
|
|
|
await feedService.createEntry(feed, entry);
|
|
|
|
await feedService.createEntry(feed, entry);
|
|
|
|
}, 4);
|
|
|
|
}, 4);
|
|
|
|
this.log.info('feed updated', { entries: response.entries.length });
|
|
|
|
|
|
|
|
|
|
|
|
this.log.info('feed updated', {
|
|
|
|
|
|
|
|
feed: {
|
|
|
|
|
|
|
|
_id: feed._id,
|
|
|
|
|
|
|
|
title: feed.title,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
entryCount: response.entries.length,
|
|
|
|
|
|
|
|
});
|
|
|
|
} catch (error) {
|
|
|
|
} catch (error) {
|
|
|
|
this.log.error('failed to update feed', { feedId: feed._id, title: feed.title, error });
|
|
|
|
this.log.error('failed to update feed', { feedId: feed._id, title: feed.title, error });
|
|
|
|
}
|
|
|
|
}
|
|
|
|