6 changed files with 89 additions and 21 deletions
@ -0,0 +1,56 @@ |
|||||
|
// newsroom/job/update-feed.js
|
||||
|
// Copyright (C) 2022 DTP Technologies, LLC
|
||||
|
// License: Apache-2.0
|
||||
|
|
||||
|
'use strict'; |
||||
|
|
||||
|
const path = require('path'); |
||||
|
|
||||
|
const mongoose = require('mongoose'); |
||||
|
|
||||
|
const Feed = mongoose.model('Feed'); |
||||
|
|
||||
|
const { SiteWorkerProcess } = require(path.join(__dirname, '..', '..', '..', '..', 'lib', 'site-lib')); |
||||
|
|
||||
|
class UpdateFeedJob extends SiteWorkerProcess { |
||||
|
|
||||
|
static get COMPONENT ( ) { |
||||
|
return { |
||||
|
name: 'newsroomUpdateFeedJob', |
||||
|
slug: 'newsroom-update-feed-job', |
||||
|
}; |
||||
|
} |
||||
|
|
||||
|
constructor (worker) { |
||||
|
super(worker, UpdateFeedJob.COMPONENT); |
||||
|
} |
||||
|
|
||||
|
async start ( ) { |
||||
|
await super.start(); |
||||
|
|
||||
|
this.queue = await this.getJobQueue('newsroom', this.dtp.config.jobQueues.newsroom); |
||||
|
|
||||
|
this.log.info('registering job processor', { queue: this.queue.name, name: 'update-feed' }); |
||||
|
this.queue.process('update-feed', this.processUpdateFeed.bind(this)); |
||||
|
} |
||||
|
|
||||
|
async stop ( ) { |
||||
|
await super.stop(); |
||||
|
} |
||||
|
|
||||
|
async processUpdateFeed (job) { |
||||
|
const { feed: feedService } = this.dtp.services; |
||||
|
const { feedId } = job.data; |
||||
|
this.log.info('newsroom feed update job received', { id: job.id, feedId }); |
||||
|
|
||||
|
try { |
||||
|
const feed = await feedService.getById(feedId); |
||||
|
await this.worker.updateFeed(feed); |
||||
|
} catch (error) { |
||||
|
this.log.error('failed to update newsroom feed', { feedId, error }); |
||||
|
throw error; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
module.exports = UpdateFeedJob; |
Loading…
Reference in new issue