epg-grabber/bin/epg-grabber.js

111 lines
3.3 KiB
JavaScript
Raw Normal View History

2021-10-05 23:36:28 +02:00
#! /usr/bin/env node
const { Command } = require('commander')
const program = new Command()
2021-10-14 23:09:36 +02:00
const fs = require('fs')
2021-10-05 23:36:28 +02:00
const path = require('path')
const grabber = require('../src/index')
const utils = require('../src/utils')
const { name, version, description } = require('../package.json')
2021-10-06 02:43:10 +02:00
const merge = require('lodash.merge')
2021-11-16 15:59:26 +01:00
const { createLogger, format, transports } = require('winston')
const { combine, timestamp, printf } = format
2021-10-05 23:36:28 +02:00
program
.name(name)
.version(version, '-v, --version')
.description(description)
2021-10-06 02:02:06 +02:00
.requiredOption('-c, --config <config>', 'Path to [site].config.js file')
2021-10-06 02:52:34 +02:00
.option('-o, --output <output>', 'Path to output file')
2021-10-05 23:36:28 +02:00
.option('--channels <channels>', 'Path to channels.xml file')
2021-10-06 02:52:34 +02:00
.option('--lang <lang>', 'Set default language for all programs')
2021-11-16 15:59:26 +01:00
.option('--days <days>', 'Number of days for which to grab the program', parseInteger, 1)
2021-10-06 02:52:34 +02:00
.option('--delay <delay>', 'Delay between requests (in mileseconds)', parseInteger)
2021-10-05 23:36:28 +02:00
.option('--debug', 'Enable debug mode', false)
2021-11-16 15:59:26 +01:00
.option('--log <log>', 'Path to log file')
.option('--log-level <level>', 'Set log level', 'info')
2021-10-05 23:36:28 +02:00
.parse(process.argv)
const options = program.opts()
2021-11-16 15:59:26 +01:00
const fileFormat = printf(({ level, message, timestamp }) => {
return `[${timestamp}] ${level.toUpperCase()}: ${message}`
})
const consoleFormat = printf(({ level, message, timestamp }) => {
if (level === 'error') return ` Error: ${message}`
return message
})
const t = [new transports.Console({ format: consoleFormat })]
if (options.log) {
t.push(
new transports.File({
filename: path.resolve(options.log),
format: combine(timestamp(), fileFormat),
options: { flags: 'w' }
})
)
}
const logger = createLogger({
level: options.logLevel,
transports: t
})
2021-10-05 23:36:28 +02:00
async function main() {
2021-11-16 15:59:26 +01:00
logger.info('Starting...')
2021-10-05 23:36:28 +02:00
2021-11-16 15:59:26 +01:00
logger.info(`Loading '${options.config}'...`)
2021-10-06 02:43:10 +02:00
let config = require(path.resolve(options.config))
config = merge(config, options)
2021-10-06 02:02:06 +02:00
2021-10-05 23:36:28 +02:00
if (options.channels) config.channels = options.channels
else if (config.channels)
config.channels = path.join(path.dirname(options.config), config.channels)
else throw new Error("The required 'channels' property is missing")
2021-11-16 15:59:26 +01:00
if (!config.channels) return logger.error('Path to [site].channels.xml is missing')
logger.info(`Loading '${config.channels}'...`)
2021-10-14 23:09:36 +02:00
const channelsXML = fs.readFileSync(path.resolve(config.channels), { encoding: 'utf-8' })
const parsed = utils.parseChannels(channelsXML)
const channels = parsed.channels || []
2021-10-05 23:36:28 +02:00
let programs = []
2021-11-16 15:59:26 +01:00
let i = 1
let days = options.days || 1
const total = channels.length * days
2021-10-05 23:36:28 +02:00
for (let channel of channels) {
2021-10-06 15:38:16 +02:00
await grabber
.grab(channel, config, (data, err) => {
2021-11-16 15:59:26 +01:00
logger.info(
`[${i}/${total}] ${config.site} - ${data.channel.xmltv_id} - ${data.date.format(
'MMM D, YYYY'
)} (${data.programs.length} programs)`
2021-10-06 17:12:11 +02:00
)
2021-11-16 15:59:26 +01:00
if (err) logger.error(err.message)
if (i < total) i++
2021-10-05 23:36:28 +02:00
})
2021-10-06 15:38:16 +02:00
.then(results => {
2021-10-05 23:36:28 +02:00
programs = programs.concat(results)
})
}
const xml = utils.convertToXMLTV({ config, channels, programs })
2021-10-14 18:59:46 +02:00
const outputPath = config.output || 'guide.xml'
utils.writeToFile(outputPath, xml)
2021-10-05 23:36:28 +02:00
2021-11-16 15:59:26 +01:00
logger.info(`File '${outputPath}' successfully saved`)
logger.info('Finish')
2021-10-05 23:36:28 +02:00
}
main()
2021-10-06 02:43:10 +02:00
function parseInteger(val) {
return val ? parseInt(val) : null
}