Files
epg/sites/distro.tv/distro.tv.config.js
2026-02-20 17:40:04 +05:30

81 lines
2.3 KiB
JavaScript

const axios = require('axios')
const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc')
const customParseFormat = require('dayjs/plugin/customParseFormat')
const HEADERS = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/144.0.0.0 Safari/537.36 Edg/144.0.0.0',
'Referer': 'https://distro.tv/',
'Origin': 'https://distro.tv'
}
dayjs.extend(utc)
dayjs.extend(customParseFormat)
module.exports = {
site: 'distro.tv',
days: 3,
request: {
headers: HEADERS,
timeout: 60000
},
url({ channel, date }) {
const diff = date.diff(dayjs.utc().startOf('d'), 'd')
let range
if (diff <= 0) {
range = 'now,24h'
} else {
const start = diff * 24
const end = (diff + 1) * 24
range = `${start}h,${end}h`
}
return `https://tv.jsrdn.com/epg/query.php?range=${range}&id=${channel.site_id},`
},
parser({ content, channel }) {
if (!content || !channel) return []
let programs = []
try {
const data = JSON.parse(content)
if (!data.epg || !data.epg[channel.site_id] || !Array.isArray(data.epg[channel.site_id].slots)) {
return []
}
programs = data.epg[channel.site_id].slots.map(program => ({
title: program.title,
description: program.description || null,
icon: program.img_thumbh || null,
start: dayjs.utc(program.start, 'YYYY-MM-DD HH:mm:ss'),
stop: dayjs.utc(program.end, 'YYYY-MM-DD HH:mm:ss')
}))
} catch {
return []
}
return programs.filter(p => p.title && p.start.isValid() && p.stop.isValid())
},
async channels() {
const { data } = await axios.get('https://tv.jsrdn.com/tv_v5/getfeed.php?type=live', {
headers: HEADERS
})
const channels = []
if (data && data.shows) {
Object.values(data.shows).forEach(show => {
const episode = show.seasons?.[0]?.episodes?.[0]
if (episode && episode.id) {
channels.push({
lang: 'en',
// lang: show.language || 'en',
site_id: episode.id.toString(),
name: show.title,
// logo: show.img_logo,
// url: episode.content?.url || null
})
}
})
}
return channels
}
}