Merge pull request #2473 from iptv-org/remove-duplicates-from-generated-playlists
Remove duplicates from generated playlists
This commit is contained in:
commit
f75f38b690
|
@ -13,8 +13,8 @@ function main() {
|
|||
generateCountryIndex()
|
||||
generateLanguageIndex()
|
||||
generateCategories()
|
||||
generateLanguages()
|
||||
generateCountries()
|
||||
generateLanguages()
|
||||
generateChannelsJson()
|
||||
finish()
|
||||
}
|
||||
|
@ -37,8 +37,13 @@ function generateIndex() {
|
|||
const sfwFilename = `${ROOT_DIR}/index.sfw.m3u`
|
||||
utils.createFile(sfwFilename, '#EXTM3U\n')
|
||||
|
||||
const buffer = []
|
||||
const channels = db.channels.sortBy(['name', 'url']).all()
|
||||
for (const channel of channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
utils.appendToFile(filename, channel.toString())
|
||||
if (channel.isSFW()) {
|
||||
utils.appendToFile(sfwFilename, channel.toString())
|
||||
|
@ -54,8 +59,13 @@ function generateCategoryIndex() {
|
|||
const sfwFilename = `${ROOT_DIR}/index.category.sfw.m3u`
|
||||
utils.createFile(sfwFilename, '#EXTM3U\n')
|
||||
|
||||
const buffer = []
|
||||
const channels = db.channels.sortBy(['category', 'name', 'url']).all()
|
||||
for (const channel of channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
utils.appendToFile(filename, channel.toString())
|
||||
if (channel.isSFW()) {
|
||||
utils.appendToFile(sfwFilename, channel.toString())
|
||||
|
@ -71,8 +81,13 @@ function generateCountryIndex() {
|
|||
const sfwFilename = `${ROOT_DIR}/index.country.sfw.m3u`
|
||||
utils.createFile(sfwFilename, '#EXTM3U\n')
|
||||
|
||||
const buffer = []
|
||||
const unsorted = db.playlists.only(['unsorted'])[0]
|
||||
for (const channel of unsorted.channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
const category = channel.category
|
||||
const sfw = channel.isSFW()
|
||||
channel.category = ''
|
||||
|
@ -86,6 +101,10 @@ function generateCountryIndex() {
|
|||
const playlists = db.playlists.sortBy(['country']).except(['unsorted'])
|
||||
for (const playlist of playlists) {
|
||||
for (const channel of playlist.channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
const category = channel.category
|
||||
const sfw = channel.isSFW()
|
||||
channel.category = playlist.country
|
||||
|
@ -106,8 +125,13 @@ function generateLanguageIndex() {
|
|||
const sfwFilename = `${ROOT_DIR}/index.language.sfw.m3u`
|
||||
utils.createFile(sfwFilename, '#EXTM3U\n')
|
||||
|
||||
const channels = db.channels.sortBy(['name', 'url']).forLanguage({ code: null }).get()
|
||||
const buffer = []
|
||||
const channels = db.channels.sortBy(['name', 'url']).forLanguage({ code: 'undefined' }).get()
|
||||
for (const channel of channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
const category = channel.category
|
||||
const sfw = channel.isSFW()
|
||||
channel.category = ''
|
||||
|
@ -122,6 +146,10 @@ function generateLanguageIndex() {
|
|||
for (const language of languages) {
|
||||
const channels = db.channels.sortBy(['name', 'url']).forLanguage(language).get()
|
||||
for (const channel of channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
const category = channel.category
|
||||
const sfw = channel.isSFW()
|
||||
channel.category = language.name
|
||||
|
@ -139,12 +167,17 @@ function generateCategories() {
|
|||
const outputDir = `${ROOT_DIR}/categories`
|
||||
utils.createDir(outputDir)
|
||||
|
||||
const buffer = []
|
||||
for (const category of [...db.categories.all(), { id: 'other' }]) {
|
||||
const filename = `${outputDir}/${category.id}.m3u`
|
||||
utils.createFile(filename, '#EXTM3U\n')
|
||||
|
||||
const channels = db.channels.sortBy(['name', 'url']).forCategory(category).get()
|
||||
for (const channel of channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
utils.appendToFile(filename, channel.toString())
|
||||
}
|
||||
}
|
||||
|
@ -155,6 +188,7 @@ function generateCountries() {
|
|||
const outputDir = `${ROOT_DIR}/countries`
|
||||
utils.createDir(outputDir)
|
||||
|
||||
const buffer = []
|
||||
for (const country of [...db.countries.all(), { code: 'undefined' }]) {
|
||||
const filename = `${outputDir}/${country.code}.m3u`
|
||||
utils.createFile(filename, '#EXTM3U\n')
|
||||
|
@ -164,6 +198,10 @@ function generateCountries() {
|
|||
|
||||
const channels = db.channels.sortBy(['name', 'url']).forCountry(country).get()
|
||||
for (const channel of channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
utils.appendToFile(filename, channel.toString())
|
||||
if (channel.isSFW()) {
|
||||
utils.appendToFile(sfwFilename, channel.toString())
|
||||
|
@ -177,6 +215,7 @@ function generateLanguages() {
|
|||
const outputDir = `${ROOT_DIR}/languages`
|
||||
utils.createDir(outputDir)
|
||||
|
||||
const buffer = []
|
||||
for (const language of [...db.languages.all(), { code: 'undefined' }]) {
|
||||
const filename = `${outputDir}/${language.code}.m3u`
|
||||
utils.createFile(filename, '#EXTM3U\n')
|
||||
|
@ -186,6 +225,10 @@ function generateLanguages() {
|
|||
|
||||
const channels = db.channels.sortBy(['name', 'url']).forLanguage(language).get()
|
||||
for (const channel of channels) {
|
||||
const info = channel.getInfo()
|
||||
if (buffer.includes(info)) continue
|
||||
buffer.push(info)
|
||||
|
||||
utils.appendToFile(filename, channel.toString())
|
||||
if (channel.isSFW()) {
|
||||
utils.appendToFile(sfwFilename, channel.toString())
|
||||
|
@ -200,7 +243,7 @@ function generateChannelsJson() {
|
|||
const channels = db.channels
|
||||
.sortBy(['name', 'url'])
|
||||
.all()
|
||||
.map(c => c.toJSON())
|
||||
.map(c => c.toObject())
|
||||
utils.createFile(filename, JSON.stringify(channels))
|
||||
}
|
||||
|
||||
|
|
|
@ -185,9 +185,7 @@ class Channel {
|
|||
return ''
|
||||
}
|
||||
|
||||
toString(raw = false) {
|
||||
if (raw) return this.raw + '\n'
|
||||
|
||||
getInfo() {
|
||||
this.tvg.country = this.tvg.country.toUpperCase()
|
||||
|
||||
let info = `-1 tvg-id="${this.tvgId}" tvg-name="${this.tvgName}" tvg-country="${this.tvg.country}" tvg-language="${this.tvg.language}" tvg-logo="${this.logo}"`
|
||||
|
@ -210,10 +208,16 @@ class Channel {
|
|||
info += `\n#EXTVLCOPT:http-user-agent=${this.http['user-agent']}`
|
||||
}
|
||||
|
||||
return '#EXTINF:' + info + '\n' + this.url + '\n'
|
||||
return info
|
||||
}
|
||||
|
||||
toJSON() {
|
||||
toString(raw = false) {
|
||||
if (raw) return this.raw + '\n'
|
||||
|
||||
return '#EXTINF:' + this.getInfo() + '\n' + this.url + '\n'
|
||||
}
|
||||
|
||||
toObject() {
|
||||
return {
|
||||
name: this.name,
|
||||
logo: this.logo || null,
|
||||
|
|
Loading…
Reference in New Issue