iptv/scripts/commands/generate-playlists.js

321 lines
8.3 KiB
JavaScript
Raw Normal View History

2022-02-06 22:04:56 +01:00
const { create: createPlaylist } = require('../core/playlist')
const { db, logger, generator, file, api } = require('../core')
2021-12-12 05:10:03 +01:00
const _ = require('lodash')
async function main() {
2022-02-06 22:04:56 +01:00
const streams = await loadStreams()
2021-12-12 05:10:03 +01:00
2022-02-06 22:04:56 +01:00
await generator.generate('categories', streams)
2022-02-06 22:19:09 +01:00
await generator.generate('countries', streams)
2022-02-06 23:22:20 +01:00
await generator.generate('languages', streams)
await generator.generate('regions', streams)
2021-12-12 05:10:03 +01:00
2022-02-06 22:04:56 +01:00
// await generateRegions()
// await generateIndex()
// await generateIndexNSFW()
// await generateIndexCategory()
// await generateIndexCountry()
// await generateIndexLanguage()
// await generateIndexRegion()
2021-12-12 05:10:03 +01:00
2022-02-06 22:04:56 +01:00
// await generateChannelsJson()
2021-12-12 05:10:03 +01:00
2022-02-06 22:04:56 +01:00
// await saveLogs()
2021-12-12 05:10:03 +01:00
}
2022-02-06 22:04:56 +01:00
main()
2021-12-12 05:10:03 +01:00
2022-02-06 23:22:20 +01:00
// async function generateRegions() {
// logger.info(`Generating regions/...`)
// for (const region of regions) {
// const { count } = await generator.generate(
// `${PUBLIC_PATH}/regions/${region.code.toLowerCase()}.m3u`,
// {
// regions: { $elemMatch: region }
// }
// )
// await log('regions', {
// name: region.name,
// code: region.code,
// count
// })
// }
// const { count: undefinedCount } = await generator.generate(
// `${PUBLIC_PATH}/regions/undefined.m3u`,
// { regions: { $size: 0 } },
// {
// saveEmpty: true,
// onLoad: function (items) {
// return items.map(item => {
// item.group_title = 'Undefined'
// return item
// })
// }
// }
// )
// await log('regions', {
// name: 'Undefined',
// code: 'UNDEFINED',
// count: undefinedCount
// })
// }
2021-12-12 05:10:03 +01:00
async function generateIndexNSFW() {
logger.info(`Generating index.nsfw.m3u...`)
await generator.generate(
`${PUBLIC_PATH}/index.nsfw.m3u`,
{},
{
includeNSFW: true,
onLoad: function (items) {
return items.map(item => {
if (!item.categories || !item.categories.length) {
item.group_title = 'Other'
}
return item
})
},
sortBy: item => {
if (item.group_title === 'Other') return '_'
return item.group_title || ''
}
}
)
2021-12-12 05:10:03 +01:00
}
async function generateIndex() {
logger.info(`Generating index.m3u...`)
await generator.generate(
`${PUBLIC_PATH}/index.m3u`,
{},
{
onLoad: function (items) {
return items.map(item => {
if (!item.categories || !item.categories.length) {
item.group_title = 'Other'
}
return item
})
},
sortBy: item => {
if (item.group_title === 'Other') return '_'
return item.group_title || ''
}
}
)
2021-12-12 05:10:03 +01:00
}
async function generateIndexCategory() {
logger.info(`Generating index.category.m3u...`)
await generator.generate(
`${PUBLIC_PATH}/index.category.m3u`,
{},
{
onLoad: function (items) {
let results = items
.filter(item => !item.categories || !item.categories.length)
.map(item => {
const newItem = _.cloneDeep(item)
newItem.group_title = 'Other'
return newItem
})
for (const category of _.sortBy(Object.values(categories), ['name'])) {
let filtered = items
.filter(item => {
return (
Array.isArray(item.categories) &&
item.categories.map(c => c.slug).includes(category.slug)
)
})
.map(item => {
const newItem = _.cloneDeep(item)
newItem.group_title = category.name
return newItem
})
results = results.concat(filtered)
}
return results
},
sortBy: item => {
if (item.group_title === 'Other') return '_'
return item.group_title
}
}
2021-12-12 05:10:03 +01:00
)
}
async function generateIndexCountry() {
logger.info(`Generating index.country.m3u...`)
await generator.generate(
`${PUBLIC_PATH}/index.country.m3u`,
{},
{
onLoad: function (items) {
let results = items
.filter(item => !item.countries || !item.countries.length)
2021-12-12 05:10:03 +01:00
.map(item => {
const newItem = _.cloneDeep(item)
newItem.group_title = 'Undefined'
2022-01-01 10:06:58 +01:00
newItem.categories = []
2021-12-12 05:10:03 +01:00
return newItem
})
for (const country of _.sortBy(Object.values(countries), ['name'])) {
let filtered = items
.filter(item => {
return (
Array.isArray(item.countries) &&
item.countries.map(c => c.code).includes(country.code)
)
2021-12-12 05:10:03 +01:00
})
.map(item => {
const newItem = _.cloneDeep(item)
newItem.group_title = country.name
return newItem
})
results = results.concat(filtered)
}
return results
},
sortBy: item => {
if (item.group_title === 'Undefined') return '_'
return item.group_title
}
2021-12-12 05:10:03 +01:00
}
)
}
async function generateIndexLanguage() {
logger.info(`Generating index.language.m3u...`)
await generator.generate(
`${PUBLIC_PATH}/index.language.m3u`,
{},
{
onLoad: function (items) {
let results = items
2021-12-31 09:06:41 +01:00
.filter(item => !item.languages || !item.languages.length)
2021-12-12 05:10:03 +01:00
.map(item => {
const newItem = _.cloneDeep(item)
newItem.group_title = 'Undefined'
2022-01-01 10:06:58 +01:00
newItem.categories = []
2021-12-12 05:10:03 +01:00
return newItem
})
for (const language of languages) {
let filtered = items
.filter(item => {
return (
Array.isArray(item.languages) &&
item.languages.map(c => c.code).includes(language.code)
)
2021-12-12 05:10:03 +01:00
})
.map(item => {
const newItem = _.cloneDeep(item)
newItem.group_title = language.name
return newItem
})
results = results.concat(filtered)
}
return results
},
sortBy: item => {
if (item.group_title === 'Undefined') return '_'
return item.group_title
}
2021-12-12 05:10:03 +01:00
}
)
}
async function generateIndexRegion() {
logger.info(`Generating index.region.m3u...`)
await generator.generate(
`${PUBLIC_PATH}/index.region.m3u`,
{},
{
onLoad: function (items) {
let results = items
.filter(item => !item.regions.length)
.map(item => {
const newItem = _.cloneDeep(item)
newItem.group_title = 'Undefined'
2022-01-01 10:06:58 +01:00
newItem.categories = []
2021-12-12 05:10:03 +01:00
return newItem
})
for (const region of regions) {
let filtered = items
.filter(item => {
return item.regions.map(c => c.code).includes(region.code)
})
.map(item => {
const newItem = _.cloneDeep(item)
newItem.group_title = region.name
return newItem
})
results = results.concat(filtered)
}
return results
},
sortBy: item => {
if (item.group_title === 'Undefined') return '_'
return item.group_title
}
2021-12-12 05:10:03 +01:00
}
)
}
2022-02-06 22:04:56 +01:00
async function loadStreams() {
await api.channels.load()
let channels = await api.channels.all()
channels = _.keyBy(channels, 'id')
2021-12-12 05:10:03 +01:00
2022-02-06 22:04:56 +01:00
await api.countries.load()
let countries = await api.countries.all()
countries = _.keyBy(countries, 'code')
2021-12-12 05:10:03 +01:00
2022-02-06 22:04:56 +01:00
await api.categories.load()
let categories = await api.categories.all()
categories = _.keyBy(categories, 'id')
2021-12-12 05:10:03 +01:00
2022-02-06 22:04:56 +01:00
await api.languages.load()
let languages = await api.languages.all()
languages = _.keyBy(languages, 'code')
2021-12-12 05:10:03 +01:00
2022-02-06 22:04:56 +01:00
await api.guides.load()
let guides = await api.guides.all()
guides = _.groupBy(guides, 'channel')
await db.streams.load()
let streams = await db.streams.find({})
return streams.map(stream => {
const channel = channels[stream.channel_id] || null
stream.channel = channel
stream.broadcast_area = channel
? channel.broadcast_area.map(item => {
const [_, code] = item.split('/')
return code
})
: []
stream.categories = channel ? channel.categories.map(id => categories[id]) : []
stream.languages = channel ? channel.languages.map(code => languages[code]) : []
stream.guides = guides[stream.channel_id] ? guides[stream.channel_id].map(g => g.url) : []
return stream
})
2021-12-12 05:10:03 +01:00
}