|
|
|
const { file, logger, api, parser, id } = require('../../core')
|
|
|
|
const { program } = require('commander')
|
|
|
|
const chalk = require('chalk')
|
|
|
|
const _ = require('lodash')
|
|
|
|
|
|
|
|
program.argument('[filepath]', 'Path to file to validate').parse(process.argv)
|
|
|
|
|
|
|
|
async function main() {
|
|
|
|
const files = program.args.length ? program.args : await file.list('channels/*.m3u')
|
|
|
|
|
|
|
|
logger.info(`loading blocklist...`)
|
|
|
|
await api.channels.load()
|
|
|
|
await api.blocklist.load()
|
|
|
|
|
|
|
|
let blocklist = await api.blocklist.all()
|
|
|
|
blocklist = blocklist
|
|
|
|
.map(blocked => {
|
|
|
|
const channel = api.channels.find({ id: blocked.channel })
|
|
|
|
if (!channel) return null
|
|
|
|
return { ...blocked, name: channel.name }
|
|
|
|
})
|
|
|
|
.filter(i => i)
|
|
|
|
logger.info(`found ${blocklist.length} records`)
|
|
|
|
|
|
|
|
let errors = []
|
|
|
|
let warnings = []
|
|
|
|
for (const filepath of files) {
|
|
|
|
if (!filepath.endsWith('.m3u')) continue
|
|
|
|
|
|
|
|
const basename = file.basename(filepath)
|
|
|
|
const [__, country] = basename.match(/([a-z]{2})(|_.*)\.m3u/i) || [null, null]
|
|
|
|
|
|
|
|
const fileLog = []
|
|
|
|
const items = await parser.parsePlaylist(filepath)
|
|
|
|
for (const item of items) {
|
|
|
|
if (item.tvg.id && !api.channels.find({ id: item.tvg.id })) {
|
|
|
|
fileLog.push({
|
|
|
|
type: 'warning',
|
|
|
|
line: item.line,
|
|
|
|
message: `"${item.tvg.id}" is not in the database`
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
const channel_id = id.generate(item.name, country)
|
|
|
|
const found = blocklist.find(
|
|
|
|
blocked =>
|
|
|
|
item.tvg.id.toLowerCase() === blocked.channel.toLowerCase() ||
|
|
|
|
channel_id.toLowerCase() === blocked.channel.toLowerCase()
|
|
|
|
)
|
|
|
|
if (found) {
|
|
|
|
fileLog.push({
|
|
|
|
type: 'error',
|
|
|
|
line: item.line,
|
|
|
|
message: `"${found.name}" is on the blocklist due to claims of copyright holders (${found.ref})`
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (fileLog.length) {
|
|
|
|
logger.info(`\n${chalk.underline(filepath)}`)
|
|
|
|
|
|
|
|
fileLog.forEach(err => {
|
|
|
|
const position = err.line.toString().padEnd(6, ' ')
|
|
|
|
const type = err.type.padEnd(9, ' ')
|
|
|
|
const status = err.type === 'error' ? chalk.red(type) : chalk.yellow(type)
|
|
|
|
logger.info(` ${chalk.gray(position)}${status}${err.message}`)
|
|
|
|
})
|
|
|
|
|
|
|
|
errors = errors.concat(fileLog.filter(e => e.type === 'error'))
|
|
|
|
warnings = warnings.concat(fileLog.filter(e => e.type === 'warning'))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.error(
|
|
|
|
chalk.red(
|
|
|
|
`\n${errors.length + warnings.length} problems (${errors.length} errors, ${
|
|
|
|
warnings.length
|
|
|
|
} warnings)`
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
if (errors.length) {
|
|
|
|
process.exit(1)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
main()
|