iptv/helpers/format.js

139 lines
3.4 KiB
JavaScript
Raw Normal View History

2019-07-20 09:03:31 +02:00
const util = require('./util')
2019-04-30 15:52:38 +02:00
2019-08-07 15:51:34 +02:00
const debug = false
const verbose = false
const parseEpg = process.env.npm_config_epg || false
2019-08-07 14:40:58 +02:00
let stats = {
total: 0,
2019-08-08 01:24:15 +02:00
updated: 0,
duplicates: 0,
unvalid: 0,
removed: 0
2019-08-07 14:40:58 +02:00
}
let buffer = {}
let unsorted = {}
2019-07-20 09:06:29 +02:00
2019-08-07 14:40:58 +02:00
async function main() {
2019-08-07 15:51:34 +02:00
console.log(`Parsing 'index.m3u'...`)
2019-08-07 14:40:58 +02:00
const playlist = util.parsePlaylist('index.m3u')
2019-09-22 15:47:49 +02:00
const countries = playlist.items
2019-07-20 09:06:29 +02:00
if(debug) {
2019-08-07 14:40:58 +02:00
console.log('Debug mode is turn on')
2019-07-20 09:06:29 +02:00
}
2019-04-30 15:52:38 +02:00
const unsortedPlaylist = util.parsePlaylist('channels/unsorted.m3u')
for(const item of unsortedPlaylist.items) {
2019-10-07 01:45:06 +02:00
unsorted[item.url] = util.createChannel(item)
}
2019-04-30 15:52:38 +02:00
for(let country of countries) {
if (util.skipPlaylist(country.url)) {
continue
}
2019-08-08 01:50:53 +02:00
if(verbose) {
2019-08-08 01:50:53 +02:00
console.log(`Clear cache...`)
}
util.clearCache()
2019-08-07 15:51:34 +02:00
console.log(`Parsing '${country.url}'...`)
2019-08-07 14:40:58 +02:00
const playlist = util.parsePlaylist(country.url)
if(verbose) {
2019-08-07 15:51:34 +02:00
console.log(`Creating channels list...`)
}
2019-08-07 14:40:58 +02:00
let channels = []
for(let item of playlist.items) {
2019-10-07 01:45:06 +02:00
let channel = util.createChannel(item)
2019-08-08 01:24:15 +02:00
if(util.checkCache(channel.url)) {
stats.duplicates++
} else if(!util.validateUrl(channel.url)) {
stats.unvalid++
} else {
2019-08-08 01:24:15 +02:00
channels.push(channel)
util.addToCache(channel.url)
}
if(unsorted[channel.url]) {
if(verbose) {
console.log(`Removed '${channel.url}' from 'channels/unsorted.m3u'...`)
}
delete unsorted[channel.url]
stats.removed++
stats.duplicates++
}
2019-08-07 14:40:58 +02:00
}
2019-04-30 15:52:38 +02:00
2019-08-07 14:40:58 +02:00
const epgUrl = playlist.attrs['x-tvg-url']
if(epgUrl && !buffer[epgUrl] && parseEpg) {
2019-08-07 15:51:34 +02:00
console.log(`Loading '${epgUrl}'...`)
2019-08-07 14:40:58 +02:00
const epg = await util.loadEPG(epgUrl)
2019-08-07 15:51:34 +02:00
console.log(`Adding '${epgUrl}' to buffer...`)
2019-08-07 14:40:58 +02:00
buffer[epgUrl] = epg
2019-04-30 15:52:38 +02:00
}
2019-08-07 15:51:34 +02:00
if(buffer[epgUrl]) {
console.log(`Fills in missing channel's data...`)
for(let channel of channels) {
let channelId = channel.id
if(!channelId) continue
let c = buffer[epgUrl].channels[channelId]
if(!c) continue
let updated = false
if(!channel.name && c.names[0]) {
channel.name = c.names[0]
updated = true
if(verbose) {
2019-08-07 15:51:34 +02:00
console.log(`Added name '${c.names[0]}' to '${channel.id}'`)
}
2019-08-07 14:40:58 +02:00
}
2019-08-07 15:51:34 +02:00
if(!channel.logo && c.icon) {
const icon = c.icon.split('|')[0]
channel.logo = icon
2019-08-07 15:51:34 +02:00
updated = true
if(verbose) {
console.log(`Added logo '${icon}' to '${channel.id}'`)
2019-08-07 15:51:34 +02:00
}
2019-08-07 14:40:58 +02:00
}
2019-08-07 15:51:34 +02:00
if(updated) {
stats.updated++
}
2019-08-07 14:40:58 +02:00
}
}
if(verbose) {
2019-08-07 15:51:34 +02:00
console.log(`Sorting channels...`)
}
channels = util.sortByTitleAndUrl(channels)
2019-04-30 15:52:38 +02:00
if(!debug) {
console.log(`Updating '${country.url}'...`)
util.createFile(country.url, playlist.getHeader())
channels.forEach(channel => {
util.appendToFile(country.url, channel.toString())
})
}
2019-04-30 15:52:38 +02:00
stats.total += channels.length
2019-04-30 15:52:38 +02:00
}
if(!debug & stats.removed > 0) {
console.log(`Updating 'channels/unsorted.m3u'...`)
util.createFile('channels/unsorted.m3u', playlist.getHeader())
Object.values(unsorted).forEach(channel => {
util.appendToFile('channels/unsorted.m3u', channel.toString())
})
}
console.log(`Total: ${stats.total}. Duplicates: ${stats.duplicates}. Unvalid: ${stats.unvalid}. Updated: ${stats.updated}.`)
2019-08-07 14:40:58 +02:00
}
2019-04-30 15:52:38 +02:00
2019-08-07 14:40:58 +02:00
main()