const util = require('./util') const debug = false let stats = { countries: 0, channels: 0, updated: 0, duplicates: 0 } let buffer = {} async function main() { console.log(`Parsing 'index.m3u'...`) const playlist = util.parsePlaylist('index.m3u') let countries = playlist.items if(debug) { console.log('Debug mode is turn on') countries = countries.slice(0, 1) // countries = [{ url: 'channels/ru.m3u' }] } for(let country of countries) { console.log(`Parsing '${country.url}'...`) const playlist = util.parsePlaylist(country.url) if(debug) { console.log(`Creating channels list...`) } let channels = [] for(let item of playlist.items) { let channel = util.createChannel({ id: item.inf['tvg-id'], name: item.inf['tvg-name'], logo: item.inf['tvg-logo'], group: item.inf['group-title'], url: item.url, title: item.inf.title }) if(!util.checkCache(channel.url)) { channels.push(channel) util.addToCache(channel.url) } else { stats.duplicates++ } } const epgUrl = playlist.attrs['x-tvg-url'] if(epgUrl && !buffer[epgUrl]) { console.log(`Loading '${epgUrl}'...`) const epg = await util.loadEPG(epgUrl) console.log(`Adding '${epgUrl}' to buffer...`) buffer[epgUrl] = epg } 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(debug) { console.log(`Added name '${c.names[0]}' to '${channel.id}'`) } } if(!channel.logo && c.icon) { channel.logo = c.icon updated = true if(debug) { console.log(`Added logo '${c.icon}' to '${channel.id}'`) } } if(updated) { stats.updated++ } } } if(debug) { console.log(`Sorting channels...`) } channels = util.sortByTitle(channels) console.log(`Updating '${country.url}'...`) util.createFile(country.url, playlist.getHeader()) channels.forEach(channel => { util.appendToFile(country.url, channel.toString()) }) stats.countries++ stats.channels += channels.length } console.log(`Countries: ${stats.countries}. Channels: ${stats.channels}. Updated: ${stats.updated}. Duplicates: ${stats.duplicates}.`) } main()