mirror of
https://github.com/iptv-org/epg
synced 2026-05-20 08:15:00 -04:00
Fixes linter errors
This commit is contained in:
@@ -1,94 +1,94 @@
|
||||
const axios = require('axios')
|
||||
const cheerio = require('cheerio')
|
||||
const dayjs = require('dayjs')
|
||||
const utc = require('dayjs/plugin/utc')
|
||||
const customParseFormat = require('dayjs/plugin/customParseFormat')
|
||||
|
||||
dayjs.extend(utc)
|
||||
dayjs.extend(customParseFormat)
|
||||
|
||||
// ERR: certificate has expired
|
||||
module.exports = {
|
||||
site: 'guide.dstv.com',
|
||||
days: 2,
|
||||
request: {
|
||||
cache: {
|
||||
ttl: 60 * 60 * 1000,
|
||||
interpretHeader: false
|
||||
}
|
||||
},
|
||||
url({ channel, date }) {
|
||||
const [bouquetId] = channel.site_id.split('#')
|
||||
|
||||
return `https://guide.dstv.com/api/gridview/page?bouquetId=${bouquetId}&genre=all&date=${date.format(
|
||||
'YYYY-MM-DD'
|
||||
)}`
|
||||
},
|
||||
parser({ content, date, channel }) {
|
||||
const programs = []
|
||||
const items = parseItems(content, channel)
|
||||
items.forEach(item => {
|
||||
const prev = programs[programs.length - 1]
|
||||
let start = parseStart(item, date)
|
||||
if (prev) {
|
||||
if (start.isBefore(prev.start)) {
|
||||
start = start.add(1, 'd')
|
||||
date = date.add(1, 'd')
|
||||
}
|
||||
prev.stop = start
|
||||
} else if (start.hour() > 12) {
|
||||
start = start.subtract(1, 'd')
|
||||
date = date.subtract(1, 'd')
|
||||
}
|
||||
const stop = start.add(1, 'h')
|
||||
programs.push({
|
||||
title: item.title,
|
||||
start,
|
||||
stop
|
||||
})
|
||||
})
|
||||
|
||||
return programs
|
||||
},
|
||||
async channels({ bouquet }) {
|
||||
const data = await axios
|
||||
.get(
|
||||
`https://guide.dstv.com/api/channel/fetchChannelsByGenresInBouquet?bouquetId=${bouquet}&genre=all`
|
||||
)
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
|
||||
const items = data.items
|
||||
return items.map(item => {
|
||||
return {
|
||||
lang: 'en',
|
||||
site_id: `${bouquet}#${item.channelTag}`,
|
||||
name: item.channelName
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
function parseStart(item, date) {
|
||||
const time = `${date.format('MM/DD/YYYY')} ${item.time}`
|
||||
|
||||
return dayjs.utc(time, 'MM/DD/YYYY HH:mm')
|
||||
}
|
||||
|
||||
function parseItems(content, channel) {
|
||||
const [, channelTag] = channel.site_id.split('#')
|
||||
const data = JSON.parse(content)
|
||||
const html = data[channelTag]
|
||||
if (!html) return []
|
||||
const $ = cheerio.load(html)
|
||||
|
||||
return $('li')
|
||||
.map((i, el) => {
|
||||
return {
|
||||
time: $(el).find('.event-time').text().trim(),
|
||||
title: $(el).find('.event-title').text().trim()
|
||||
}
|
||||
})
|
||||
.toArray()
|
||||
.filter(i => i.time && i.title)
|
||||
}
|
||||
const axios = require('axios')
|
||||
const cheerio = require('cheerio')
|
||||
const dayjs = require('dayjs')
|
||||
const utc = require('dayjs/plugin/utc')
|
||||
const customParseFormat = require('dayjs/plugin/customParseFormat')
|
||||
|
||||
dayjs.extend(utc)
|
||||
dayjs.extend(customParseFormat)
|
||||
|
||||
// ERR: certificate has expired
|
||||
module.exports = {
|
||||
site: 'guide.dstv.com',
|
||||
days: 2,
|
||||
request: {
|
||||
cache: {
|
||||
ttl: 60 * 60 * 1000,
|
||||
interpretHeader: false
|
||||
}
|
||||
},
|
||||
url({ channel, date }) {
|
||||
const [bouquetId] = channel.site_id.split('#')
|
||||
|
||||
return `https://guide.dstv.com/api/gridview/page?bouquetId=${bouquetId}&genre=all&date=${date.format(
|
||||
'YYYY-MM-DD'
|
||||
)}`
|
||||
},
|
||||
parser({ content, date, channel }) {
|
||||
const programs = []
|
||||
const items = parseItems(content, channel)
|
||||
items.forEach(item => {
|
||||
const prev = programs[programs.length - 1]
|
||||
let start = parseStart(item, date)
|
||||
if (prev) {
|
||||
if (start.isBefore(prev.start)) {
|
||||
start = start.add(1, 'd')
|
||||
date = date.add(1, 'd')
|
||||
}
|
||||
prev.stop = start
|
||||
} else if (start.hour() > 12) {
|
||||
start = start.subtract(1, 'd')
|
||||
date = date.subtract(1, 'd')
|
||||
}
|
||||
const stop = start.add(1, 'h')
|
||||
programs.push({
|
||||
title: item.title,
|
||||
start,
|
||||
stop
|
||||
})
|
||||
})
|
||||
|
||||
return programs
|
||||
},
|
||||
async channels({ bouquet }) {
|
||||
const data = await axios
|
||||
.get(
|
||||
`https://guide.dstv.com/api/channel/fetchChannelsByGenresInBouquet?bouquetId=${bouquet}&genre=all`
|
||||
)
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
|
||||
const items = data.items
|
||||
return items.map(item => {
|
||||
return {
|
||||
lang: 'en',
|
||||
site_id: `${bouquet}#${item.channelTag}`,
|
||||
name: item.channelName
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
function parseStart(item, date) {
|
||||
const time = `${date.format('MM/DD/YYYY')} ${item.time}`
|
||||
|
||||
return dayjs.utc(time, 'MM/DD/YYYY HH:mm')
|
||||
}
|
||||
|
||||
function parseItems(content, channel) {
|
||||
const [, channelTag] = channel.site_id.split('#')
|
||||
const data = JSON.parse(content)
|
||||
const html = data[channelTag]
|
||||
if (!html) return []
|
||||
const $ = cheerio.load(html)
|
||||
|
||||
return $('li')
|
||||
.map((i, el) => {
|
||||
return {
|
||||
time: $(el).find('.event-time').text().trim(),
|
||||
title: $(el).find('.event-title').text().trim()
|
||||
}
|
||||
})
|
||||
.toArray()
|
||||
.filter(i => i.time && i.title)
|
||||
}
|
||||
|
||||
@@ -1,59 +1,59 @@
|
||||
// npm run grab -- --site=guide.dstv.com
|
||||
// npm run channels:parse -- --config=./sites/guide.dstv.com/guide.dstv.com.config.js --output=./sites/guide.dstv.com/guide.dstv.com.channels.xml --set=bouquet:c35aaecd-5dd1-480b-ae24-357e600a0e4d
|
||||
|
||||
const { parser, url } = require('./guide.dstv.com.config.js')
|
||||
const dayjs = require('dayjs')
|
||||
const utc = require('dayjs/plugin/utc')
|
||||
const customParseFormat = require('dayjs/plugin/customParseFormat')
|
||||
dayjs.extend(customParseFormat)
|
||||
dayjs.extend(utc)
|
||||
|
||||
const date = dayjs.utc('2021-11-24', 'YYYY-MM-DD').startOf('d')
|
||||
const channel = {
|
||||
site_id: 'b0dc42b8-c651-4c3c-8713-a7fcd04744ee#M4H',
|
||||
xmltv_id: 'MNetMovies4.za'
|
||||
}
|
||||
|
||||
it('can generate valid url', () => {
|
||||
const result = url({ date, channel })
|
||||
expect(result).toBe(
|
||||
'https://guide.dstv.com/api/gridview/page?bouquetId=b0dc42b8-c651-4c3c-8713-a7fcd04744ee&genre=all&date=2021-11-24'
|
||||
)
|
||||
})
|
||||
|
||||
it('can parse response', () => {
|
||||
const content =
|
||||
"{\"M4H\": \" <li schedule-id=7be16b76-51fa-4c73-9e85-3b94993cd6ff style='width:540px; left:-35460px'> <a class='event' analytics-id=\\\"eventOpenEvent\\\" analytics-text=\\\"Deadly Flight\\\"> <p class='event-time'> 21:30 </p> <p class='event-title'>Deadly Flight</p> </a> </li> <li schedule-id=7e156af9-005a-4308-b91f-5d45b6fd04e6 style='width:720px; left:-31530px'> <a class='event' analytics-id=\\\"eventOpenEvent\\\" analytics-text=\\\"I Still Believe\\\"> <p class='event-time'> 08:25 </p> <p class='event-title'>I Still Believe</p> </a> </li> <li schedule-id=0464d009-ed1e-4b1d-8282-c2464123ac5a style='width:570px; left:-28860px'> <a class='event' analytics-id=\\\"eventOpenEvent\\\" analytics-text=\\\"Despicable Me\\\"> <p class='event-time'> 15:50 </p> <p class='event-title'>Despicable Me</p> </a> </li> <li schedule-id=7d346d4d-40e1-4177-83a1-56c173c008e2 style='width:690px; left:-27150px'> <a class='event' analytics-id=\\\"eventOpenEvent\\\" analytics-text=\\\"The Foreigner\\\"> <p class='event-time'> 20:35 </p> <p class='event-title'>The Foreigner</p> </a> </li> \"}"
|
||||
const result = parser({ date, channel, content }).map(p => {
|
||||
p.start = p.start.toJSON()
|
||||
p.stop = p.stop.toJSON()
|
||||
return p
|
||||
})
|
||||
expect(result).toMatchObject([
|
||||
{
|
||||
start: '2021-11-23T21:30:00.000Z',
|
||||
stop: '2021-11-24T08:25:00.000Z',
|
||||
title: 'Deadly Flight'
|
||||
},
|
||||
{
|
||||
start: '2021-11-24T08:25:00.000Z',
|
||||
stop: '2021-11-24T15:50:00.000Z',
|
||||
title: 'I Still Believe'
|
||||
},
|
||||
{
|
||||
start: '2021-11-24T15:50:00.000Z',
|
||||
stop: '2021-11-24T20:35:00.000Z',
|
||||
title: 'Despicable Me'
|
||||
},
|
||||
{
|
||||
start: '2021-11-24T20:35:00.000Z',
|
||||
stop: '2021-11-24T21:35:00.000Z',
|
||||
title: 'The Foreigner'
|
||||
}
|
||||
])
|
||||
})
|
||||
|
||||
it('can handle empty guide', () => {
|
||||
const result = parser({ date, channel, content: '{}' })
|
||||
expect(result).toMatchObject([])
|
||||
})
|
||||
// npm run grab -- --site=guide.dstv.com
|
||||
// npm run channels:parse -- --config=./sites/guide.dstv.com/guide.dstv.com.config.js --output=./sites/guide.dstv.com/guide.dstv.com.channels.xml --set=bouquet:c35aaecd-5dd1-480b-ae24-357e600a0e4d
|
||||
|
||||
const { parser, url } = require('./guide.dstv.com.config.js')
|
||||
const dayjs = require('dayjs')
|
||||
const utc = require('dayjs/plugin/utc')
|
||||
const customParseFormat = require('dayjs/plugin/customParseFormat')
|
||||
dayjs.extend(customParseFormat)
|
||||
dayjs.extend(utc)
|
||||
|
||||
const date = dayjs.utc('2021-11-24', 'YYYY-MM-DD').startOf('d')
|
||||
const channel = {
|
||||
site_id: 'b0dc42b8-c651-4c3c-8713-a7fcd04744ee#M4H',
|
||||
xmltv_id: 'MNetMovies4.za'
|
||||
}
|
||||
|
||||
it('can generate valid url', () => {
|
||||
const result = url({ date, channel })
|
||||
expect(result).toBe(
|
||||
'https://guide.dstv.com/api/gridview/page?bouquetId=b0dc42b8-c651-4c3c-8713-a7fcd04744ee&genre=all&date=2021-11-24'
|
||||
)
|
||||
})
|
||||
|
||||
it('can parse response', () => {
|
||||
const content =
|
||||
"{\"M4H\": \" <li schedule-id=7be16b76-51fa-4c73-9e85-3b94993cd6ff style='width:540px; left:-35460px'> <a class='event' analytics-id=\\\"eventOpenEvent\\\" analytics-text=\\\"Deadly Flight\\\"> <p class='event-time'> 21:30 </p> <p class='event-title'>Deadly Flight</p> </a> </li> <li schedule-id=7e156af9-005a-4308-b91f-5d45b6fd04e6 style='width:720px; left:-31530px'> <a class='event' analytics-id=\\\"eventOpenEvent\\\" analytics-text=\\\"I Still Believe\\\"> <p class='event-time'> 08:25 </p> <p class='event-title'>I Still Believe</p> </a> </li> <li schedule-id=0464d009-ed1e-4b1d-8282-c2464123ac5a style='width:570px; left:-28860px'> <a class='event' analytics-id=\\\"eventOpenEvent\\\" analytics-text=\\\"Despicable Me\\\"> <p class='event-time'> 15:50 </p> <p class='event-title'>Despicable Me</p> </a> </li> <li schedule-id=7d346d4d-40e1-4177-83a1-56c173c008e2 style='width:690px; left:-27150px'> <a class='event' analytics-id=\\\"eventOpenEvent\\\" analytics-text=\\\"The Foreigner\\\"> <p class='event-time'> 20:35 </p> <p class='event-title'>The Foreigner</p> </a> </li> \"}"
|
||||
const result = parser({ date, channel, content }).map(p => {
|
||||
p.start = p.start.toJSON()
|
||||
p.stop = p.stop.toJSON()
|
||||
return p
|
||||
})
|
||||
expect(result).toMatchObject([
|
||||
{
|
||||
start: '2021-11-23T21:30:00.000Z',
|
||||
stop: '2021-11-24T08:25:00.000Z',
|
||||
title: 'Deadly Flight'
|
||||
},
|
||||
{
|
||||
start: '2021-11-24T08:25:00.000Z',
|
||||
stop: '2021-11-24T15:50:00.000Z',
|
||||
title: 'I Still Believe'
|
||||
},
|
||||
{
|
||||
start: '2021-11-24T15:50:00.000Z',
|
||||
stop: '2021-11-24T20:35:00.000Z',
|
||||
title: 'Despicable Me'
|
||||
},
|
||||
{
|
||||
start: '2021-11-24T20:35:00.000Z',
|
||||
stop: '2021-11-24T21:35:00.000Z',
|
||||
title: 'The Foreigner'
|
||||
}
|
||||
])
|
||||
})
|
||||
|
||||
it('can handle empty guide', () => {
|
||||
const result = parser({ date, channel, content: '{}' })
|
||||
expect(result).toMatchObject([])
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user