Files
epg/sites/tvguide.com/tvguide.com.config.js

117 lines
3.7 KiB
JavaScript
Raw Permalink Normal View History

2025-09-28 17:55:05 +03:00
const axios = require('axios')
const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc')
const timezone = require('dayjs/plugin/timezone')
dayjs.extend(utc)
dayjs.extend(timezone)
const providerId = '9100001138'
const maxDuration = 240
const segments = 1440 / maxDuration
const headers = {
2026-04-19 05:02:14 +03:00
referer: 'https://www.tvguide.com/',
'User-Agent':
'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36'
2025-09-28 17:55:05 +03:00
}
module.exports = {
site: 'tvguide.com',
days: 2,
request: {
headers: function () {
return headers
},
responseType: 'application/json',
decompress: true,
cache: {
ttl: 24 * 60 * 60 * 1000 // 1 day
}
},
async url({ date, segment = 1 }) {
const params = []
if (date) {
if (segment > 1) {
date = date.add((segment - 1) * maxDuration, 'm')
}
params.push(`start=${date.unix()}`, `duration=${maxDuration}`)
}
2026-04-19 05:02:14 +03:00
return date
? `https://backend.tvguide.com/tvschedules/tvguide/${providerId}/web?${params.join('&')}`
: `https://backend.tvguide.com/tvschedules/tvguide/serviceprovider/${providerId}/sources/web?${params.join('&')}`
2025-09-28 17:55:05 +03:00
},
async parser({ content, date, channel, fetchSegments = true }) {
const programs = []
const f = data => {
const result = []
if (typeof data === 'string') {
data = JSON.parse(data)
}
if (data && Array.isArray(data?.data?.items)) {
data.data.items
.filter(i => i.channel.sourceId.toString() === channel.site_id)
.forEach(i => {
2026-04-19 05:02:14 +03:00
result.push(
...i.programSchedules.map(p => {
return { i: p, url: p.programDetails }
})
)
2025-09-28 17:55:05 +03:00
})
}
return result
}
const queues = f(content)
if (queues.length && fetchSegments) {
for (let segment = 2; segment <= segments; segment++) {
const segmentUrl = await module.exports.url({ date, segment })
console.debug(`fetch segment ${segment}: ${segmentUrl}`)
2025-09-28 17:55:05 +03:00
try {
const res = await axios.get(segmentUrl, { headers })
queues.push(...f(res.data))
} catch (err) {
console.debug(`Failed to fetch segment ${segment}: ${err.message}`)
2025-09-28 17:55:05 +03:00
}
}
}
for (const queue of queues) {
try {
const res = await axios.get(queue.url, { headers })
const item = res.data?.data?.item || queue.i
programs.push({
title: item.title || queue.i.title,
sub_title: item.episodeNumber ? item.episodeTitle : null,
description: item.description,
season: item.seasonNumber,
episode: item.episodeNumber,
rating: item.rating ? { system: 'MPA', value: item.rating } : null,
categories: Array.isArray(item.genres) ? item.genres.map(g => g.name) : null,
start: dayjs.unix(item.startTime || queue.i.startTime),
2026-04-19 05:02:14 +03:00
stop: dayjs.unix(item.endTime || queue.i.endTime)
2025-09-28 17:55:05 +03:00
})
} catch (err) {
console.debug(`Failed to fetch program details ${queue.url}: ${err.message}`)
2025-09-28 17:55:05 +03:00
}
}
return programs
},
async channels() {
const channels = []
try {
2026-04-19 05:04:13 +03:00
const data = await axios.get(await this.url({}), { headers }).then(r => r.data)
2025-09-28 17:55:05 +03:00
data.data.items.forEach(item => {
2026-04-19 05:02:14 +03:00
const name = item.fullName.replace(/Channel|Schedule/g, '').trim()
2025-09-28 17:55:05 +03:00
channels.push({
lang: 'en',
site_id: item.sourceId,
2026-04-19 05:02:14 +03:00
name
2025-09-28 17:55:05 +03:00
})
})
} catch (err) {
console.error('Failed to fetch channels:', err.message)
}
return channels
}
2026-04-19 05:02:14 +03:00
}