iptv/scripts/update-readme.js

166 lines
4.2 KiB
JavaScript
Raw Normal View History

2019-11-02 12:45:09 +03:00
const helper = require('./helper')
2019-11-01 19:34:05 +03:00
2019-11-01 22:15:22 +03:00
let output = {
2019-11-01 22:11:09 +03:00
countries: [],
languages: [],
2020-05-06 18:02:07 +03:00
categories: []
2019-11-01 22:11:09 +03:00
}
2019-11-01 21:13:15 +03:00
function main() {
2019-11-01 22:11:09 +03:00
console.log(`Parsing index...`)
parseIndex()
2019-11-01 21:13:15 +03:00
console.log(`Generating countries table...`)
generateCountriesTable()
console.log(`Generating languages table...`)
generateLanguagesTable()
console.log(`Generating categories table...`)
generateCategoriesTable()
console.log(`Generating README.md...`)
generateReadme()
console.log(`Done.`)
2019-11-01 19:34:05 +03:00
}
2019-11-01 22:11:09 +03:00
function parseIndex() {
2019-11-02 12:45:09 +03:00
const root = helper.parsePlaylist('index.m3u')
2019-11-01 19:34:05 +03:00
2019-11-02 13:50:40 +03:00
let countries = {}
2019-11-01 22:11:09 +03:00
let languages = {}
let categories = {}
2020-04-11 04:34:50 +03:00
for (let rootItem of root.items) {
2019-11-02 12:45:09 +03:00
const playlist = helper.parsePlaylist(rootItem.url)
2019-11-02 13:50:40 +03:00
const countryName = rootItem.name
const countryCode = helper.getBasename(rootItem.url).toLowerCase()
2020-04-11 04:34:50 +03:00
const countryEpg = playlist.header.attrs['x-tvg-url']
? `<code>${playlist.header.attrs['x-tvg-url']}</code>`
: ''
2019-11-01 22:11:09 +03:00
2020-04-11 04:34:50 +03:00
for (let item of playlist.items) {
// countries
2020-04-11 04:34:50 +03:00
if (countries[countryCode]) {
2019-11-02 13:50:40 +03:00
countries[countryCode].channels++
} else {
2020-05-06 18:02:07 +03:00
let flag = helper.code2flag(countryCode)
2020-04-11 04:34:50 +03:00
countries[countryCode] = {
2020-05-06 18:02:07 +03:00
country: flag + '&nbsp;' + countryName,
2020-04-11 04:34:50 +03:00
channels: 1,
playlist: `<code>https://iptv-org.github.io/iptv/countries/${countryCode}.m3u</code>`,
2020-05-06 18:02:07 +03:00
epg: countryEpg
2019-11-02 13:50:40 +03:00
}
}
// languages
2020-04-22 17:27:42 +03:00
const languageNames = item.tvg.language || 'Undefined'
2020-04-22 17:49:04 +03:00
for (let languageName of languageNames.split(';')) {
let languageCode = 'undefined'
if (languageName !== 'Undefined') {
languageCode = helper.getISO6391Code(languageName)
if (!languageCode) continue
}
2020-04-22 17:27:42 +03:00
if (languages[languageCode]) {
languages[languageCode].channels++
} else {
languages[languageCode] = {
language: languageName,
channels: 1,
2020-05-06 18:02:07 +03:00
playlist: `<code>https://iptv-org.github.io/iptv/languages/${languageCode}.m3u</code>`
2020-04-22 17:27:42 +03:00
}
2019-11-01 22:11:09 +03:00
}
}
// categories
2020-09-17 23:28:11 +03:00
const categoryName = helper.filterGroup(item.group.title) || 'Other'
2019-11-01 22:11:09 +03:00
const categoryCode = categoryName.toLowerCase()
2020-04-11 04:34:50 +03:00
if (categories[categoryCode]) {
2019-11-01 22:11:09 +03:00
categories[categoryCode].channels++
} else {
2020-04-11 04:34:50 +03:00
categories[categoryCode] = {
category: categoryName,
channels: 1,
2020-05-06 18:02:07 +03:00
playlist: `<code>https://iptv-org.github.io/iptv/categories/${categoryCode}.m3u</code>`
2019-11-01 22:11:09 +03:00
}
}
}
2019-11-01 21:13:15 +03:00
}
2019-11-01 19:34:05 +03:00
2019-11-02 13:50:40 +03:00
output.countries = Object.values(countries)
2019-11-01 22:15:22 +03:00
output.languages = Object.values(languages)
output.categories = Object.values(categories)
2019-11-01 22:11:09 +03:00
}
function generateCountriesTable() {
2019-11-02 12:45:09 +03:00
const table = helper.generateTable(output.countries, {
2019-11-01 21:13:15 +03:00
columns: [
{ name: 'Country', align: 'left' },
{ name: 'Channels', align: 'right' },
{ name: 'Playlist', align: 'left', nowrap: true },
2020-05-06 18:02:07 +03:00
{ name: 'EPG', align: 'left' }
]
2019-11-01 21:13:15 +03:00
})
2019-11-01 19:34:05 +03:00
2019-11-02 12:45:09 +03:00
helper.createFile('./.readme/_countries.md', table)
2019-11-01 21:13:15 +03:00
}
2019-11-01 19:34:05 +03:00
2019-11-01 21:13:15 +03:00
function generateLanguagesTable() {
2019-11-01 22:15:22 +03:00
output.languages.sort((a, b) => {
2020-04-11 04:34:50 +03:00
if (a.language === 'Undefined') {
return 1
}
if (b.language === 'Undefined') {
return -1
}
if (a.language < b.language) {
return -1
}
if (a.language > b.language) {
return 1
}
2019-11-01 19:34:05 +03:00
return 0
})
2019-11-02 12:45:09 +03:00
const table = helper.generateTable(output.languages, {
2019-11-01 19:34:05 +03:00
columns: [
{ name: 'Language', align: 'left' },
{ name: 'Channels', align: 'right' },
2020-05-06 18:02:07 +03:00
{ name: 'Playlist', align: 'left' }
]
2019-11-01 19:34:05 +03:00
})
2019-11-02 12:45:09 +03:00
helper.createFile('./.readme/_languages.md', table)
2019-11-01 21:13:15 +03:00
}
function generateCategoriesTable() {
2019-11-01 22:15:22 +03:00
output.categories.sort((a, b) => {
2020-04-11 04:34:50 +03:00
if (a.category === 'Other') {
return 1
}
if (b.category === 'Other') {
return -1
}
if (a.category < b.category) {
return -1
}
if (a.category > b.category) {
return 1
}
2019-11-01 21:13:15 +03:00
return 0
})
2019-11-02 12:45:09 +03:00
const table = helper.generateTable(output.categories, {
2019-11-01 19:34:05 +03:00
columns: [
{ name: 'Category', align: 'left' },
{ name: 'Channels', align: 'right' },
2020-05-06 18:02:07 +03:00
{ name: 'Playlist', align: 'left' }
]
2019-11-01 19:34:05 +03:00
})
2019-11-02 12:45:09 +03:00
helper.createFile('./.readme/_categories.md', table)
2019-11-01 21:13:15 +03:00
}
2019-11-01 19:58:56 +03:00
2019-11-01 21:13:15 +03:00
function generateReadme() {
2019-11-02 12:45:09 +03:00
helper.compileMarkdown('../.readme/config.json')
2019-11-01 19:34:05 +03:00
}
main()