generated from WebexSamples/Webex-Samples-Template
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathapp.js
72 lines (62 loc) · 1.86 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
const { bootstrap } = require('global-agent');
const { cleanEnv, str, num } = require('envalid');
const Watcher = require('./lib/feedWatcher');
const logger = require('./src/logger')('app');
const { version } = require('./package.json');
// Initialize Proxy Server, if defined.
if (process.env.GLOBAL_AGENT_HTTP_PROXY) {
logger.debug('invoke global agent proxy');
bootstrap();
}
// Process ENV Parameters
const env = cleanEnv(process.env, {
RSS_INTERVAL: num({ default: 5 }),
FEED_ROOM_ID: str(),
RSS_FEED_URL: str(),
TOKEN: str(),
});
const parserService = require('./src/parserService');
// Load RSS Watcher Instances
const interval = env.RSS_INTERVAL;
const newFeedWatcher = new Watcher(process.env.RSS_FEED_URL, interval);
// Process New Feed
newFeedWatcher.on('new entries', (entries) => {
entries.forEach((item) => {
logger.debug('new feed item');
parserService.parseFeed(item);
});
});
// Handle New Feed Errors
newFeedWatcher.on('error', (error) => {
logger.warn(`New Feed Error: ${error}`);
});
// Init Function
async function init() {
logger.info(`RSS bot Loading, v${version}`);
try {
const bot = await parserService.getBot();
logger.info(`Bot Loaded: ${bot.displayName} (${bot.emails[0]})`);
} catch (error) {
logger.error('ERROR: Unable to load Webex Bot, check Token.');
logger.debug(error.message);
process.exit(2);
}
try {
const feedRoom = await parserService.getRoom(env.FEED_ROOM_ID);
logger.info(`Feed Room Name: ${feedRoom.title}`);
} catch (error) {
logger.error('ERROR: Bot is not a member of the RSS Feed Room!');
process.exit(2);
}
newFeedWatcher.start();
logger.info('Startup Complete!');
}
// Initiate
init();
// Handle Graceful Shutdown (CTRL+C)
process.on('SIGINT', () => {
logger.debug('Stopping...');
newFeedWatcher.stop();
logger.debug('Feeds Stopped.');
process.exit(0);
});