forked from lin-toto/zoombot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
70 lines (60 loc) · 2.1 KB
/
index.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
import cron from 'node-cron'
import { Table } from 'console-table-printer'
import config from './config.js'
import Zoom from './zoom.js'
import logger from './logger.js'
async function launchMeeting (meeting) {
const loggerName = `[Main/${meeting.name}] `
try {
const zoom = new Zoom(meeting.name, meeting.zoomConfig)
logger.debug(loggerName + 'Created zoom instance for meeting')
await zoom.join()
logger.info(loggerName + 'Successfully joined meeting')
for (const pluginConfig of meeting.plugins) {
// eslint-disable-next-line new-cap
const plugin = new pluginConfig.plugin(pluginConfig.name, zoom, pluginConfig.config)
logger.debug(loggerName + `Created plugin ${pluginConfig.name}`)
const pluginPromise = plugin.run()
logger.info(loggerName + `Started plugin ${pluginConfig.name}`)
pluginPromise.then(() => {
if (plugin.running) {
logger.warn(loggerName + `Plugin ${pluginConfig.name} terminated unexpectedly`)
} else {
logger.info(loggerName + `Plugin ${pluginConfig.name} terminated successfully`)
}
}).catch(e => {
logger.error(loggerName + `Plugin ${pluginConfig.name} terminated with exception`)
logger.error(e)
})
}
} catch (e) {
logger.error(loggerName + 'Unexpected error occurred:')
logger.error(e)
}
}
async function printTasks (config) {
logger.info('[Main] Registered tasks:')
const table = new Table()
table.addRows(config.map(meeting => {
return {
name: meeting.name,
participantName: meeting.zoomConfig.participantName,
schedule: meeting.cron ? meeting.cron : 'Immediate',
meetingId: meeting.zoomConfig.meetingId
}
}))
table.printTable()
}
async function main () {
printTasks(config)
for (const meeting of config) {
if (meeting.cron) {
logger.debug('[Main] Registered meeting cron job ' + meeting.name)
cron.schedule(meeting.cron, async () => await launchMeeting(meeting), {})
} else {
logger.debug('[Main] Launching immediate job ' + meeting.name)
await launchMeeting(meeting)
}
}
}
main()