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()
|
generateCountryIndex()
|
||||||
generateLanguageIndex()
|
generateLanguageIndex()
|
||||||
generateCategories()
|
generateCategories()
|
||||||
generateLanguages()
|
|
||||||
generateCountries()
|
generateCountries()
|
||||||
|
generateLanguages()
|
||||||
generateChannelsJson()
|
generateChannelsJson()
|
||||||
finish()
|
finish()
|
||||||
}
|
}
|
||||||
@ -37,8 +37,13 @@ function generateIndex() {
|
|||||||
const sfwFilename = `${ROOT_DIR}/index.sfw.m3u`
|
const sfwFilename = `${ROOT_DIR}/index.sfw.m3u`
|
||||||
utils.createFile(sfwFilename, '#EXTM3U\n')
|
utils.createFile(sfwFilename, '#EXTM3U\n')
|
||||||
|
|
||||||
|
const buffer = []
|
||||||
const channels = db.channels.sortBy(['name', 'url']).all()
|
const channels = db.channels.sortBy(['name', 'url']).all()
|
||||||
for (const channel of channels) {
|
for (const channel of channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
utils.appendToFile(filename, channel.toString())
|
utils.appendToFile(filename, channel.toString())
|
||||||
if (channel.isSFW()) {
|
if (channel.isSFW()) {
|
||||||
utils.appendToFile(sfwFilename, channel.toString())
|
utils.appendToFile(sfwFilename, channel.toString())
|
||||||
@ -54,8 +59,13 @@ function generateCategoryIndex() {
|
|||||||
const sfwFilename = `${ROOT_DIR}/index.category.sfw.m3u`
|
const sfwFilename = `${ROOT_DIR}/index.category.sfw.m3u`
|
||||||
utils.createFile(sfwFilename, '#EXTM3U\n')
|
utils.createFile(sfwFilename, '#EXTM3U\n')
|
||||||
|
|
||||||
|
const buffer = []
|
||||||
const channels = db.channels.sortBy(['category', 'name', 'url']).all()
|
const channels = db.channels.sortBy(['category', 'name', 'url']).all()
|
||||||
for (const channel of channels) {
|
for (const channel of channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
utils.appendToFile(filename, channel.toString())
|
utils.appendToFile(filename, channel.toString())
|
||||||
if (channel.isSFW()) {
|
if (channel.isSFW()) {
|
||||||
utils.appendToFile(sfwFilename, channel.toString())
|
utils.appendToFile(sfwFilename, channel.toString())
|
||||||
@ -71,8 +81,13 @@ function generateCountryIndex() {
|
|||||||
const sfwFilename = `${ROOT_DIR}/index.country.sfw.m3u`
|
const sfwFilename = `${ROOT_DIR}/index.country.sfw.m3u`
|
||||||
utils.createFile(sfwFilename, '#EXTM3U\n')
|
utils.createFile(sfwFilename, '#EXTM3U\n')
|
||||||
|
|
||||||
|
const buffer = []
|
||||||
const unsorted = db.playlists.only(['unsorted'])[0]
|
const unsorted = db.playlists.only(['unsorted'])[0]
|
||||||
for (const channel of unsorted.channels) {
|
for (const channel of unsorted.channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
const category = channel.category
|
const category = channel.category
|
||||||
const sfw = channel.isSFW()
|
const sfw = channel.isSFW()
|
||||||
channel.category = ''
|
channel.category = ''
|
||||||
@ -86,6 +101,10 @@ function generateCountryIndex() {
|
|||||||
const playlists = db.playlists.sortBy(['country']).except(['unsorted'])
|
const playlists = db.playlists.sortBy(['country']).except(['unsorted'])
|
||||||
for (const playlist of playlists) {
|
for (const playlist of playlists) {
|
||||||
for (const channel of playlist.channels) {
|
for (const channel of playlist.channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
const category = channel.category
|
const category = channel.category
|
||||||
const sfw = channel.isSFW()
|
const sfw = channel.isSFW()
|
||||||
channel.category = playlist.country
|
channel.category = playlist.country
|
||||||
@ -106,8 +125,13 @@ function generateLanguageIndex() {
|
|||||||
const sfwFilename = `${ROOT_DIR}/index.language.sfw.m3u`
|
const sfwFilename = `${ROOT_DIR}/index.language.sfw.m3u`
|
||||||
utils.createFile(sfwFilename, '#EXTM3U\n')
|
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) {
|
for (const channel of channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
const category = channel.category
|
const category = channel.category
|
||||||
const sfw = channel.isSFW()
|
const sfw = channel.isSFW()
|
||||||
channel.category = ''
|
channel.category = ''
|
||||||
@ -122,6 +146,10 @@ function generateLanguageIndex() {
|
|||||||
for (const language of languages) {
|
for (const language of languages) {
|
||||||
const channels = db.channels.sortBy(['name', 'url']).forLanguage(language).get()
|
const channels = db.channels.sortBy(['name', 'url']).forLanguage(language).get()
|
||||||
for (const channel of channels) {
|
for (const channel of channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
const category = channel.category
|
const category = channel.category
|
||||||
const sfw = channel.isSFW()
|
const sfw = channel.isSFW()
|
||||||
channel.category = language.name
|
channel.category = language.name
|
||||||
@ -139,12 +167,17 @@ function generateCategories() {
|
|||||||
const outputDir = `${ROOT_DIR}/categories`
|
const outputDir = `${ROOT_DIR}/categories`
|
||||||
utils.createDir(outputDir)
|
utils.createDir(outputDir)
|
||||||
|
|
||||||
|
const buffer = []
|
||||||
for (const category of [...db.categories.all(), { id: 'other' }]) {
|
for (const category of [...db.categories.all(), { id: 'other' }]) {
|
||||||
const filename = `${outputDir}/${category.id}.m3u`
|
const filename = `${outputDir}/${category.id}.m3u`
|
||||||
utils.createFile(filename, '#EXTM3U\n')
|
utils.createFile(filename, '#EXTM3U\n')
|
||||||
|
|
||||||
const channels = db.channels.sortBy(['name', 'url']).forCategory(category).get()
|
const channels = db.channels.sortBy(['name', 'url']).forCategory(category).get()
|
||||||
for (const channel of channels) {
|
for (const channel of channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
utils.appendToFile(filename, channel.toString())
|
utils.appendToFile(filename, channel.toString())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -155,6 +188,7 @@ function generateCountries() {
|
|||||||
const outputDir = `${ROOT_DIR}/countries`
|
const outputDir = `${ROOT_DIR}/countries`
|
||||||
utils.createDir(outputDir)
|
utils.createDir(outputDir)
|
||||||
|
|
||||||
|
const buffer = []
|
||||||
for (const country of [...db.countries.all(), { code: 'undefined' }]) {
|
for (const country of [...db.countries.all(), { code: 'undefined' }]) {
|
||||||
const filename = `${outputDir}/${country.code}.m3u`
|
const filename = `${outputDir}/${country.code}.m3u`
|
||||||
utils.createFile(filename, '#EXTM3U\n')
|
utils.createFile(filename, '#EXTM3U\n')
|
||||||
@ -164,6 +198,10 @@ function generateCountries() {
|
|||||||
|
|
||||||
const channels = db.channels.sortBy(['name', 'url']).forCountry(country).get()
|
const channels = db.channels.sortBy(['name', 'url']).forCountry(country).get()
|
||||||
for (const channel of channels) {
|
for (const channel of channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
utils.appendToFile(filename, channel.toString())
|
utils.appendToFile(filename, channel.toString())
|
||||||
if (channel.isSFW()) {
|
if (channel.isSFW()) {
|
||||||
utils.appendToFile(sfwFilename, channel.toString())
|
utils.appendToFile(sfwFilename, channel.toString())
|
||||||
@ -177,6 +215,7 @@ function generateLanguages() {
|
|||||||
const outputDir = `${ROOT_DIR}/languages`
|
const outputDir = `${ROOT_DIR}/languages`
|
||||||
utils.createDir(outputDir)
|
utils.createDir(outputDir)
|
||||||
|
|
||||||
|
const buffer = []
|
||||||
for (const language of [...db.languages.all(), { code: 'undefined' }]) {
|
for (const language of [...db.languages.all(), { code: 'undefined' }]) {
|
||||||
const filename = `${outputDir}/${language.code}.m3u`
|
const filename = `${outputDir}/${language.code}.m3u`
|
||||||
utils.createFile(filename, '#EXTM3U\n')
|
utils.createFile(filename, '#EXTM3U\n')
|
||||||
@ -186,6 +225,10 @@ function generateLanguages() {
|
|||||||
|
|
||||||
const channels = db.channels.sortBy(['name', 'url']).forLanguage(language).get()
|
const channels = db.channels.sortBy(['name', 'url']).forLanguage(language).get()
|
||||||
for (const channel of channels) {
|
for (const channel of channels) {
|
||||||
|
const info = channel.getInfo()
|
||||||
|
if (buffer.includes(info)) continue
|
||||||
|
buffer.push(info)
|
||||||
|
|
||||||
utils.appendToFile(filename, channel.toString())
|
utils.appendToFile(filename, channel.toString())
|
||||||
if (channel.isSFW()) {
|
if (channel.isSFW()) {
|
||||||
utils.appendToFile(sfwFilename, channel.toString())
|
utils.appendToFile(sfwFilename, channel.toString())
|
||||||
@ -200,7 +243,7 @@ function generateChannelsJson() {
|
|||||||
const channels = db.channels
|
const channels = db.channels
|
||||||
.sortBy(['name', 'url'])
|
.sortBy(['name', 'url'])
|
||||||
.all()
|
.all()
|
||||||
.map(c => c.toJSON())
|
.map(c => c.toObject())
|
||||||
utils.createFile(filename, JSON.stringify(channels))
|
utils.createFile(filename, JSON.stringify(channels))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -185,9 +185,7 @@ class Channel {
|
|||||||
return ''
|
return ''
|
||||||
}
|
}
|
||||||
|
|
||||||
toString(raw = false) {
|
getInfo() {
|
||||||
if (raw) return this.raw + '\n'
|
|
||||||
|
|
||||||
this.tvg.country = this.tvg.country.toUpperCase()
|
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}"`
|
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']}`
|
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 {
|
return {
|
||||||
name: this.name,
|
name: this.name,
|
||||||
logo: this.logo || null,
|
logo: this.logo || null,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user