mirror of
https://github.com/iptv-org/epg
synced 2026-05-08 02:16:59 -04:00
stricter ESLint configuration, linebreak on stylistic per deprecation by ESLint, fixed changes. add attibutes to prevent blockade.
This commit is contained in:
@@ -1,41 +1,41 @@
|
||||
const { parser, url } = require('./tvim.tv.config.js')
|
||||
const fs = require('fs')
|
||||
const path = require('path')
|
||||
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-10-24', 'YYYY-MM-DD').startOf('d')
|
||||
const channel = { site_id: 'T7', xmltv_id: 'T7.rs' }
|
||||
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.json'))
|
||||
|
||||
it('can generate valid url', () => {
|
||||
const result = url({ date, channel })
|
||||
expect(result).toBe(
|
||||
'https://www.tvim.tv/script/program_epg?date=24.10.2021&prog=T7&server_time=true'
|
||||
)
|
||||
})
|
||||
|
||||
it('can parse response', () => {
|
||||
const result = parser({ date, channel, content })
|
||||
expect(result).toMatchObject([
|
||||
{
|
||||
start: 'Sat, 23 Oct 2021 22:00:00 GMT',
|
||||
stop: 'Sun, 24 Oct 2021 02:00:00 GMT',
|
||||
title: 'Programi i T7',
|
||||
description: 'Programi i T7',
|
||||
category: 'test'
|
||||
}
|
||||
])
|
||||
})
|
||||
|
||||
it('can handle empty guide', () => {
|
||||
const result = parser({
|
||||
date,
|
||||
channel,
|
||||
content: fs.readFileSync(path.resolve(__dirname, '__data__/no_content.json'))
|
||||
})
|
||||
expect(result).toMatchObject([])
|
||||
})
|
||||
const { parser, url } = require('./tvim.tv.config.js')
|
||||
const fs = require('fs')
|
||||
const path = require('path')
|
||||
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-10-24', 'YYYY-MM-DD').startOf('d')
|
||||
const channel = { site_id: 'T7', xmltv_id: 'T7.rs' }
|
||||
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.json'))
|
||||
|
||||
it('can generate valid url', () => {
|
||||
const result = url({ date, channel })
|
||||
expect(result).toBe(
|
||||
'https://www.tvim.tv/script/program_epg?date=24.10.2021&prog=T7&server_time=true'
|
||||
)
|
||||
})
|
||||
|
||||
it('can parse response', () => {
|
||||
const result = parser({ date, channel, content })
|
||||
expect(result).toMatchObject([
|
||||
{
|
||||
start: 'Sat, 23 Oct 2021 22:00:00 GMT',
|
||||
stop: 'Sun, 24 Oct 2021 02:00:00 GMT',
|
||||
title: 'Programi i T7',
|
||||
description: 'Programi i T7',
|
||||
category: 'test'
|
||||
}
|
||||
])
|
||||
})
|
||||
|
||||
it('can handle empty guide', () => {
|
||||
const result = parser({
|
||||
date,
|
||||
channel,
|
||||
content: fs.readFileSync(path.resolve(__dirname, '__data__/no_content.json'))
|
||||
})
|
||||
expect(result).toMatchObject([])
|
||||
})
|
||||
|
||||
@@ -1,127 +1,127 @@
|
||||
const cheerio = require('cheerio')
|
||||
const axios = require('axios')
|
||||
const { DateTime } = require('luxon')
|
||||
|
||||
module.exports = {
|
||||
site: 'tvinsider.com',
|
||||
days: 2,
|
||||
url({ channel }) {
|
||||
return `https://www.tvinsider.com/network/${channel.site_id}/schedule/`
|
||||
},
|
||||
parser({ content, date }) {
|
||||
const programs = []
|
||||
const items = parseItems(content, date)
|
||||
items.forEach(item => {
|
||||
const prev = programs[programs.length - 1]
|
||||
const $item = cheerio.load(item)
|
||||
const episodeInfo = parseEP($item)
|
||||
let start = parseStart($item, date)
|
||||
if (!start) return
|
||||
if (prev) {
|
||||
prev.stop = start
|
||||
}
|
||||
const stop = start.plus({ minute: 30 })
|
||||
|
||||
programs.push({
|
||||
title: parseTitle($item),
|
||||
description: parseDescription($item),
|
||||
category: parseCategory($item),
|
||||
date: parseDate($item),
|
||||
...episodeInfo,
|
||||
subTitles: parseSubtitle($item),
|
||||
previouslyShown: parsePreviously($item),
|
||||
start,
|
||||
stop
|
||||
})
|
||||
})
|
||||
|
||||
return programs
|
||||
},
|
||||
async channels() {
|
||||
const html = await axios
|
||||
.get('https://www.tvinsider.com/network/5-star-max/')
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
const $ = cheerio.load(html)
|
||||
const items = $('body > main > section > select > option').toArray()
|
||||
|
||||
const channels = []
|
||||
items.forEach(item => {
|
||||
const name = $(item).text().trim()
|
||||
const path = $(item).attr('value')
|
||||
if (!path) return
|
||||
const [, , site_id] = path.split('/') || [null, null, null]
|
||||
if (!site_id) return
|
||||
|
||||
channels.push({
|
||||
lang: 'en',
|
||||
site_id,
|
||||
name
|
||||
})
|
||||
})
|
||||
|
||||
return channels
|
||||
}
|
||||
}
|
||||
|
||||
function parseTitle($item) {
|
||||
return $item('h3').text().trim()
|
||||
}
|
||||
function parseEP($item){
|
||||
const text = $item('h6').text().trim()
|
||||
const match = text.match(/Season\s+(\d+)\s*•\s*Episode\s+(\d+)/i)
|
||||
|
||||
if (!match) return {} // Return an empty object if no match, so properties are undefined later
|
||||
|
||||
const season = parseInt(match[1], 10)
|
||||
const episode = parseInt(match[2], 10)
|
||||
|
||||
return { season, episode } // Return an object with season and episode
|
||||
}
|
||||
|
||||
function parseSubtitle($item) {
|
||||
return $item('h5').text().trim()
|
||||
}
|
||||
|
||||
function parsePreviously($item){
|
||||
const h3Text = $item('h3').text().trim()
|
||||
const isNewShow = /New$/.test(h3Text)
|
||||
|
||||
if (isNewShow) {
|
||||
return null
|
||||
} else {
|
||||
return {}
|
||||
}
|
||||
}
|
||||
|
||||
function parseDescription($item) {
|
||||
return $item('p').text().trim()
|
||||
}
|
||||
|
||||
function parseCategory($item) {
|
||||
const [category] = $item('h4').text().trim().split(' • ')
|
||||
|
||||
return category
|
||||
}
|
||||
|
||||
function parseDate($item) {
|
||||
const [, date] = $item('h4').text().trim().split(' • ')
|
||||
|
||||
return date
|
||||
}
|
||||
|
||||
function parseStart($item, date) {
|
||||
let time = $item('time').text().trim()
|
||||
time = `${date.format('YYYY-MM-DD')} ${time}`
|
||||
|
||||
return DateTime.fromFormat(time, 'yyyy-MM-dd t', { zone: 'America/New_York' }).toUTC()
|
||||
}
|
||||
|
||||
function parseItems(content, date) {
|
||||
const $ = cheerio.load(content)
|
||||
|
||||
return $(`#${date.format('MM-DD-YYYY')}`)
|
||||
.next()
|
||||
.find('a')
|
||||
.toArray()
|
||||
}
|
||||
const cheerio = require('cheerio')
|
||||
const axios = require('axios')
|
||||
const { DateTime } = require('luxon')
|
||||
|
||||
module.exports = {
|
||||
site: 'tvinsider.com',
|
||||
days: 2,
|
||||
url({ channel }) {
|
||||
return `https://www.tvinsider.com/network/${channel.site_id}/schedule/`
|
||||
},
|
||||
parser({ content, date }) {
|
||||
const programs = []
|
||||
const items = parseItems(content, date)
|
||||
items.forEach(item => {
|
||||
const prev = programs[programs.length - 1]
|
||||
const $item = cheerio.load(item)
|
||||
const episodeInfo = parseEP($item)
|
||||
let start = parseStart($item, date)
|
||||
if (!start) return
|
||||
if (prev) {
|
||||
prev.stop = start
|
||||
}
|
||||
const stop = start.plus({ minute: 30 })
|
||||
|
||||
programs.push({
|
||||
title: parseTitle($item),
|
||||
description: parseDescription($item),
|
||||
category: parseCategory($item),
|
||||
date: parseDate($item),
|
||||
...episodeInfo,
|
||||
subTitles: parseSubtitle($item),
|
||||
previouslyShown: parsePreviously($item),
|
||||
start,
|
||||
stop
|
||||
})
|
||||
})
|
||||
|
||||
return programs
|
||||
},
|
||||
async channels() {
|
||||
const html = await axios
|
||||
.get('https://www.tvinsider.com/network/5-star-max/')
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
const $ = cheerio.load(html)
|
||||
const items = $('body > main > section > select > option').toArray()
|
||||
|
||||
const channels = []
|
||||
items.forEach(item => {
|
||||
const name = $(item).text().trim()
|
||||
const path = $(item).attr('value')
|
||||
if (!path) return
|
||||
const [, , site_id] = path.split('/') || [null, null, null]
|
||||
if (!site_id) return
|
||||
|
||||
channels.push({
|
||||
lang: 'en',
|
||||
site_id,
|
||||
name
|
||||
})
|
||||
})
|
||||
|
||||
return channels
|
||||
}
|
||||
}
|
||||
|
||||
function parseTitle($item) {
|
||||
return $item('h3').text().trim()
|
||||
}
|
||||
function parseEP($item){
|
||||
const text = $item('h6').text().trim()
|
||||
const match = text.match(/Season\s+(\d+)\s*•\s*Episode\s+(\d+)/i)
|
||||
|
||||
if (!match) return {} // Return an empty object if no match, so properties are undefined later
|
||||
|
||||
const season = parseInt(match[1], 10)
|
||||
const episode = parseInt(match[2], 10)
|
||||
|
||||
return { season, episode } // Return an object with season and episode
|
||||
}
|
||||
|
||||
function parseSubtitle($item) {
|
||||
return $item('h5').text().trim()
|
||||
}
|
||||
|
||||
function parsePreviously($item){
|
||||
const h3Text = $item('h3').text().trim()
|
||||
const isNewShow = /New$/.test(h3Text)
|
||||
|
||||
if (isNewShow) {
|
||||
return null
|
||||
} else {
|
||||
return {}
|
||||
}
|
||||
}
|
||||
|
||||
function parseDescription($item) {
|
||||
return $item('p').text().trim()
|
||||
}
|
||||
|
||||
function parseCategory($item) {
|
||||
const [category] = $item('h4').text().trim().split(' • ')
|
||||
|
||||
return category
|
||||
}
|
||||
|
||||
function parseDate($item) {
|
||||
const [, date] = $item('h4').text().trim().split(' • ')
|
||||
|
||||
return date
|
||||
}
|
||||
|
||||
function parseStart($item, date) {
|
||||
let time = $item('time').text().trim()
|
||||
time = `${date.format('YYYY-MM-DD')} ${time}`
|
||||
|
||||
return DateTime.fromFormat(time, 'yyyy-MM-dd t', { zone: 'America/New_York' }).toUTC()
|
||||
}
|
||||
|
||||
function parseItems(content, date) {
|
||||
const $ = cheerio.load(content)
|
||||
|
||||
return $(`#${date.format('MM-DD-YYYY')}`)
|
||||
.next()
|
||||
.find('a')
|
||||
.toArray()
|
||||
}
|
||||
|
||||
@@ -1,99 +1,99 @@
|
||||
const cheerio = require('cheerio')
|
||||
const dayjs = require('dayjs')
|
||||
const utc = require('dayjs/plugin/utc')
|
||||
const timezone = require('dayjs/plugin/timezone')
|
||||
const customParseFormat = require('dayjs/plugin/customParseFormat')
|
||||
const { uniqBy } = require('../../scripts/functions')
|
||||
|
||||
dayjs.extend(utc)
|
||||
dayjs.extend(timezone)
|
||||
dayjs.extend(customParseFormat)
|
||||
|
||||
module.exports = {
|
||||
site: 'tvireland.ie',
|
||||
days: 2,
|
||||
url: function ({ date, channel }) {
|
||||
return `https://www.tvireland.ie/tv/listings/channel/${channel.site_id}?dt=${date.format(
|
||||
'YYYY-MM-DD'
|
||||
)}`
|
||||
},
|
||||
parser: function ({ content, date, channel }) {
|
||||
const programs = []
|
||||
const items = parseItems(content)
|
||||
items.forEach(item => {
|
||||
const prev = programs[programs.length - 1]
|
||||
const $item = cheerio.load(item)
|
||||
let start = parseStart($item, date, channel)
|
||||
if (prev) {
|
||||
if (start.isBefore(prev.start)) {
|
||||
start = start.add(1, 'd')
|
||||
date = date.add(1, 'd')
|
||||
}
|
||||
prev.stop = start
|
||||
}
|
||||
const stop = start.add(30, 'm')
|
||||
programs.push({
|
||||
title: parseTitle($item),
|
||||
start,
|
||||
stop
|
||||
})
|
||||
})
|
||||
|
||||
return programs
|
||||
},
|
||||
async channels() {
|
||||
const axios = require('axios')
|
||||
|
||||
const providers = ['-9000019', '-8000019', '-1000019', '-2000019', '-7000019']
|
||||
|
||||
const channels = []
|
||||
for (let provider of providers) {
|
||||
const data = await axios
|
||||
.post('https://www.tvireland.ie/tv/schedule', null, {
|
||||
params: {
|
||||
provider,
|
||||
region: 'Ireland',
|
||||
TVperiod: 'Night',
|
||||
date: dayjs().format('YYYY-MM-DD'),
|
||||
st: 0,
|
||||
u_time: 2027,
|
||||
is_mobile: 1
|
||||
}
|
||||
})
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
|
||||
const $ = cheerio.load(data)
|
||||
$('.channelname').each((i, el) => {
|
||||
const name = $(el).find('center > a:eq(1)').text()
|
||||
const url = $(el).find('center > a:eq(1)').attr('href')
|
||||
const [, number, slug] = url.match(/\/(\d+)\/(.*)\.html$/)
|
||||
|
||||
channels.push({
|
||||
lang: 'en',
|
||||
name,
|
||||
site_id: `${number}/${slug}`
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
return uniqBy(channels, x => x.site_id)
|
||||
}
|
||||
}
|
||||
|
||||
function parseStart($item, date) {
|
||||
const timeString = $item('td:eq(0)').text().trim()
|
||||
const dateString = `${date.format('YYYY-MM-DD')} ${timeString}`
|
||||
|
||||
return dayjs.tz(dateString, 'YYYY-MM-DD H:mm a', 'Europe/Dublin')
|
||||
}
|
||||
|
||||
function parseTitle($item) {
|
||||
return $item('td:eq(1)').text().trim()
|
||||
}
|
||||
|
||||
function parseItems(content) {
|
||||
const $ = cheerio.load(content)
|
||||
|
||||
return $('table.table > tbody > tr').toArray()
|
||||
}
|
||||
const cheerio = require('cheerio')
|
||||
const dayjs = require('dayjs')
|
||||
const utc = require('dayjs/plugin/utc')
|
||||
const timezone = require('dayjs/plugin/timezone')
|
||||
const customParseFormat = require('dayjs/plugin/customParseFormat')
|
||||
const { uniqBy } = require('../../scripts/functions')
|
||||
|
||||
dayjs.extend(utc)
|
||||
dayjs.extend(timezone)
|
||||
dayjs.extend(customParseFormat)
|
||||
|
||||
module.exports = {
|
||||
site: 'tvireland.ie',
|
||||
days: 2,
|
||||
url: function ({ date, channel }) {
|
||||
return `https://www.tvireland.ie/tv/listings/channel/${channel.site_id}?dt=${date.format(
|
||||
'YYYY-MM-DD'
|
||||
)}`
|
||||
},
|
||||
parser: function ({ content, date, channel }) {
|
||||
const programs = []
|
||||
const items = parseItems(content)
|
||||
items.forEach(item => {
|
||||
const prev = programs[programs.length - 1]
|
||||
const $item = cheerio.load(item)
|
||||
let start = parseStart($item, date, channel)
|
||||
if (prev) {
|
||||
if (start.isBefore(prev.start)) {
|
||||
start = start.add(1, 'd')
|
||||
date = date.add(1, 'd')
|
||||
}
|
||||
prev.stop = start
|
||||
}
|
||||
const stop = start.add(30, 'm')
|
||||
programs.push({
|
||||
title: parseTitle($item),
|
||||
start,
|
||||
stop
|
||||
})
|
||||
})
|
||||
|
||||
return programs
|
||||
},
|
||||
async channels() {
|
||||
const axios = require('axios')
|
||||
|
||||
const providers = ['-9000019', '-8000019', '-1000019', '-2000019', '-7000019']
|
||||
|
||||
const channels = []
|
||||
for (let provider of providers) {
|
||||
const data = await axios
|
||||
.post('https://www.tvireland.ie/tv/schedule', null, {
|
||||
params: {
|
||||
provider,
|
||||
region: 'Ireland',
|
||||
TVperiod: 'Night',
|
||||
date: dayjs().format('YYYY-MM-DD'),
|
||||
st: 0,
|
||||
u_time: 2027,
|
||||
is_mobile: 1
|
||||
}
|
||||
})
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
|
||||
const $ = cheerio.load(data)
|
||||
$('.channelname').each((i, el) => {
|
||||
const name = $(el).find('center > a:eq(1)').text()
|
||||
const url = $(el).find('center > a:eq(1)').attr('href')
|
||||
const [, number, slug] = url.match(/\/(\d+)\/(.*)\.html$/)
|
||||
|
||||
channels.push({
|
||||
lang: 'en',
|
||||
name,
|
||||
site_id: `${number}/${slug}`
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
return uniqBy(channels, x => x.site_id)
|
||||
}
|
||||
}
|
||||
|
||||
function parseStart($item, date) {
|
||||
const timeString = $item('td:eq(0)').text().trim()
|
||||
const dateString = `${date.format('YYYY-MM-DD')} ${timeString}`
|
||||
|
||||
return dayjs.tz(dateString, 'YYYY-MM-DD H:mm a', 'Europe/Dublin')
|
||||
}
|
||||
|
||||
function parseTitle($item) {
|
||||
return $item('td:eq(1)').text().trim()
|
||||
}
|
||||
|
||||
function parseItems(content) {
|
||||
const $ = cheerio.load(content)
|
||||
|
||||
return $('table.table > tbody > tr').toArray()
|
||||
}
|
||||
|
||||
@@ -1,81 +1,81 @@
|
||||
const axios = require('axios')
|
||||
const dayjs = require('dayjs')
|
||||
const { uniqBy } = require('../../scripts/functions')
|
||||
|
||||
module.exports = {
|
||||
site: 'tvmusor.hu',
|
||||
days: 2,
|
||||
url: 'https://tvmusor.borsonline.hu/a/get-events/',
|
||||
request: {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
|
||||
},
|
||||
data({ channel, date }) {
|
||||
const params = new URLSearchParams()
|
||||
params.append(
|
||||
'data',
|
||||
JSON.stringify({
|
||||
blocks: [`${channel.site_id}|${date.format('YYYY-MM-DD')}`]
|
||||
})
|
||||
)
|
||||
|
||||
return params
|
||||
}
|
||||
},
|
||||
parser({ content, channel, date }) {
|
||||
let programs = []
|
||||
const items = parseItems(content, channel, date)
|
||||
items.forEach(item => {
|
||||
const prev = programs[programs.length - 1]
|
||||
let start = dayjs(item.e)
|
||||
let stop = dayjs(item.f)
|
||||
if (prev) {
|
||||
start = prev.stop
|
||||
}
|
||||
|
||||
programs.push({
|
||||
title: item.j,
|
||||
category: item.h,
|
||||
description: item.c,
|
||||
image: parseImage(item),
|
||||
start,
|
||||
stop
|
||||
})
|
||||
})
|
||||
|
||||
return programs
|
||||
},
|
||||
async channels() {
|
||||
const data = await axios
|
||||
.get('https://tvmusor.borsonline.hu/most/')
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
|
||||
const [, channelData] = data.match(/const CHANNEL_DATA = (.*);/)
|
||||
const json = channelData.replace('},}', '}}').replace(/(\d+):/g, '"$1":')
|
||||
const channels = JSON.parse(json)
|
||||
|
||||
return Object.values(channels).map(item => {
|
||||
return {
|
||||
lang: 'hu',
|
||||
site_id: item.id,
|
||||
name: item.name
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
function parseImage(item) {
|
||||
return item.z ? `https://tvmusor.borsonline.hu/images/events/408/${item.z}` : null
|
||||
}
|
||||
|
||||
function parseItems(content, channel, date) {
|
||||
const data = JSON.parse(content)
|
||||
if (!data || !data.data || !data.data.loadedBlocks) return []
|
||||
const blocks = data.data.loadedBlocks
|
||||
const blockId = `${channel.site_id}_${date.format('YYYY-MM-DD')}`
|
||||
if (!Array.isArray(blocks[blockId])) return []
|
||||
|
||||
return uniqBy(uniqBy(blocks[blockId], a => a.e), b => b.b)
|
||||
}
|
||||
const axios = require('axios')
|
||||
const dayjs = require('dayjs')
|
||||
const { uniqBy } = require('../../scripts/functions')
|
||||
|
||||
module.exports = {
|
||||
site: 'tvmusor.hu',
|
||||
days: 2,
|
||||
url: 'https://tvmusor.borsonline.hu/a/get-events/',
|
||||
request: {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
|
||||
},
|
||||
data({ channel, date }) {
|
||||
const params = new URLSearchParams()
|
||||
params.append(
|
||||
'data',
|
||||
JSON.stringify({
|
||||
blocks: [`${channel.site_id}|${date.format('YYYY-MM-DD')}`]
|
||||
})
|
||||
)
|
||||
|
||||
return params
|
||||
}
|
||||
},
|
||||
parser({ content, channel, date }) {
|
||||
let programs = []
|
||||
const items = parseItems(content, channel, date)
|
||||
items.forEach(item => {
|
||||
const prev = programs[programs.length - 1]
|
||||
let start = dayjs(item.e)
|
||||
let stop = dayjs(item.f)
|
||||
if (prev) {
|
||||
start = prev.stop
|
||||
}
|
||||
|
||||
programs.push({
|
||||
title: item.j,
|
||||
category: item.h,
|
||||
description: item.c,
|
||||
image: parseImage(item),
|
||||
start,
|
||||
stop
|
||||
})
|
||||
})
|
||||
|
||||
return programs
|
||||
},
|
||||
async channels() {
|
||||
const data = await axios
|
||||
.get('https://tvmusor.borsonline.hu/most/')
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
|
||||
const [, channelData] = data.match(/const CHANNEL_DATA = (.*);/)
|
||||
const json = channelData.replace('},}', '}}').replace(/(\d+):/g, '"$1":')
|
||||
const channels = JSON.parse(json)
|
||||
|
||||
return Object.values(channels).map(item => {
|
||||
return {
|
||||
lang: 'hu',
|
||||
site_id: item.id,
|
||||
name: item.name
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
function parseImage(item) {
|
||||
return item.z ? `https://tvmusor.borsonline.hu/images/events/408/${item.z}` : null
|
||||
}
|
||||
|
||||
function parseItems(content, channel, date) {
|
||||
const data = JSON.parse(content)
|
||||
if (!data || !data.data || !data.data.loadedBlocks) return []
|
||||
const blocks = data.data.loadedBlocks
|
||||
const blockId = `${channel.site_id}_${date.format('YYYY-MM-DD')}`
|
||||
if (!Array.isArray(blocks[blockId])) return []
|
||||
|
||||
return uniqBy(uniqBy(blocks[blockId], a => a.e), b => b.b)
|
||||
}
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -1,213 +1,213 @@
|
||||
const axios = require('axios')
|
||||
const dayjs = require('dayjs')
|
||||
const utc = require('dayjs/plugin/utc')
|
||||
const customParseFormat = require('dayjs/plugin/customParseFormat')
|
||||
|
||||
let X_CSRFTOKEN
|
||||
let Cookie
|
||||
const cookiesToExtract = ['JSESSIONID', 'CSESSIONID', 'CSRFSESSION']
|
||||
|
||||
dayjs.extend(utc)
|
||||
dayjs.extend(customParseFormat)
|
||||
|
||||
module.exports = {
|
||||
site: 'web.magentatv.de',
|
||||
days: 2,
|
||||
url: 'https://api.prod.sngtv.magentatv.de/EPG/JSON/PlayBillList',
|
||||
request: {
|
||||
method: 'POST',
|
||||
async headers() {
|
||||
return await setHeaders()
|
||||
},
|
||||
data({ channel, date }) {
|
||||
return {
|
||||
count: -1,
|
||||
isFillProgram: 1,
|
||||
offset: 0,
|
||||
properties: [
|
||||
{
|
||||
include:
|
||||
'endtime,genres,id,name,starttime,channelid,pictures,introduce,subName,seasonNum,subNum,cast,country,producedate,externalIds',
|
||||
name: 'playbill'
|
||||
}
|
||||
],
|
||||
type: 2,
|
||||
begintime: date.format('YYYYMMDD000000'),
|
||||
channelid: channel.site_id,
|
||||
endtime: date.add(1, 'd').format('YYYYMMDD000000')
|
||||
}
|
||||
}
|
||||
},
|
||||
parser({ content }) {
|
||||
const programs = []
|
||||
const items = parseItems(content)
|
||||
items.forEach(item => {
|
||||
programs.push({
|
||||
title: item.name,
|
||||
description: item.introduce,
|
||||
image: parseImage(item),
|
||||
category: parseCategory(item),
|
||||
start: parseStart(item),
|
||||
stop: parseStop(item),
|
||||
sub_title: item.subName,
|
||||
season: item.seasonNum,
|
||||
episode: item.subNum,
|
||||
directors: parseDirectors(item),
|
||||
producers: parseProducers(item),
|
||||
adapters: parseAdapters(item),
|
||||
country: item.country?.toUpperCase(),
|
||||
date: item.producedate,
|
||||
urls: parseUrls(item)
|
||||
})
|
||||
})
|
||||
return programs
|
||||
},
|
||||
async channels() {
|
||||
const url = 'https://api.prod.sngtv.magentatv.de/EPG/JSON/AllChannel'
|
||||
const body = {
|
||||
channelNamespace: 2,
|
||||
filterlist: [
|
||||
{
|
||||
key: 'IsHide',
|
||||
value: '-1'
|
||||
}
|
||||
],
|
||||
metaDataVer: 'Channel/1.1',
|
||||
properties: [
|
||||
{
|
||||
include: '/channellist/logicalChannel/contentId,/channellist/logicalChannel/name',
|
||||
name: 'logicalChannel'
|
||||
}
|
||||
],
|
||||
returnSatChannel: 0
|
||||
}
|
||||
const params = {
|
||||
headers: await setHeaders()
|
||||
}
|
||||
|
||||
const data = await axios
|
||||
.post(url, body, params)
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
|
||||
return data.channellist.map(item => {
|
||||
return {
|
||||
lang: 'de',
|
||||
site_id: item.contentId,
|
||||
name: item.name
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
function parseCategory(item) {
|
||||
return item.genres
|
||||
? item.genres
|
||||
.replace('und', ',')
|
||||
.split(',')
|
||||
.map(i => i.trim())
|
||||
: []
|
||||
}
|
||||
|
||||
function parseDirectors(item) {
|
||||
if (!item.cast || !item.cast.director) return []
|
||||
return item.cast.director
|
||||
.replace('und', ',')
|
||||
.split(',')
|
||||
.map(i => i.trim())
|
||||
}
|
||||
|
||||
function parseProducers(item) {
|
||||
if (!item.cast || !item.cast.producer) return []
|
||||
return item.cast.producer
|
||||
.replace('und', ',')
|
||||
.split(',')
|
||||
.map(i => i.trim())
|
||||
}
|
||||
|
||||
function parseAdapters(item) {
|
||||
if (!item.cast || !item.cast.adaptor) return []
|
||||
return item.cast.adaptor
|
||||
.replace('und', ',')
|
||||
.split(',')
|
||||
.map(i => i.trim())
|
||||
}
|
||||
|
||||
function parseUrls(item) {
|
||||
// currently only a imdb id is returned by the api, thus we can construct the url here
|
||||
if (!item.externalIds) return []
|
||||
return JSON.parse(item.externalIds)
|
||||
.filter(externalId => externalId.type === 'imdb' && externalId.id)
|
||||
.map(externalId => ({ system: 'imdb', value: `https://www.imdb.com/title/${externalId.id}` }))
|
||||
}
|
||||
|
||||
function parseImage(item) {
|
||||
if (!Array.isArray(item.pictures) || !item.pictures.length) return null
|
||||
|
||||
return item.pictures[0].href
|
||||
}
|
||||
|
||||
function parseStart(item) {
|
||||
return dayjs.utc(item.starttime, 'YYYY-MM-DD HH:mm:ss')
|
||||
}
|
||||
|
||||
function parseStop(item) {
|
||||
return dayjs.utc(item.endtime, 'YYYY-MM-DD HH:mm:ss')
|
||||
}
|
||||
|
||||
function parseItems(content) {
|
||||
const data = JSON.parse(content)
|
||||
if (!data || !Array.isArray(data.playbilllist)) return []
|
||||
|
||||
return data.playbilllist
|
||||
}
|
||||
|
||||
async function fetchCookieAndToken() {
|
||||
// Only fetch the cookies and csrfToken if they are not already set
|
||||
if (X_CSRFTOKEN && Cookie) {
|
||||
return
|
||||
}
|
||||
|
||||
try {
|
||||
const response = await axios.request({
|
||||
url: 'https://api.prod.sngtv.magentatv.de/EPG/JSON/Authenticate',
|
||||
params: {
|
||||
SID: 'firstup',
|
||||
T: 'Windows_chrome_118'
|
||||
},
|
||||
method: 'POST',
|
||||
data: '{"terminalid":"00:00:00:00:00:00","mac":"00:00:00:00:00:00","terminaltype":"WEBTV","utcEnable":1,"timezone":"Etc/GMT0","userType":3,"terminalvendor":"Unknown"}',
|
||||
})
|
||||
|
||||
// Extract the cookies specified in cookiesToExtract
|
||||
const setCookieHeader = response.headers['set-cookie'] || []
|
||||
const extractedCookies = []
|
||||
cookiesToExtract.forEach(cookieName => {
|
||||
const regex = new RegExp(`${cookieName}=(.+?)(;|$)`)
|
||||
const match = setCookieHeader.find(header => regex.test(header))
|
||||
|
||||
if (match) {
|
||||
const cookieString = regex.exec(match)[0]
|
||||
extractedCookies.push(cookieString)
|
||||
}
|
||||
})
|
||||
|
||||
// check if we recieved a csrfToken only then store the values
|
||||
if (!response.data.csrfToken) {
|
||||
console.log('csrfToken not found in the response.')
|
||||
return
|
||||
}
|
||||
|
||||
X_CSRFTOKEN = response.data.csrfToken
|
||||
Cookie = extractedCookies.join(' ')
|
||||
|
||||
} catch(error) {
|
||||
console.error(error)
|
||||
}
|
||||
}
|
||||
|
||||
async function setHeaders() {
|
||||
await fetchCookieAndToken()
|
||||
|
||||
return { X_CSRFTOKEN, Cookie }
|
||||
}
|
||||
const axios = require('axios')
|
||||
const dayjs = require('dayjs')
|
||||
const utc = require('dayjs/plugin/utc')
|
||||
const customParseFormat = require('dayjs/plugin/customParseFormat')
|
||||
|
||||
let X_CSRFTOKEN
|
||||
let Cookie
|
||||
const cookiesToExtract = ['JSESSIONID', 'CSESSIONID', 'CSRFSESSION']
|
||||
|
||||
dayjs.extend(utc)
|
||||
dayjs.extend(customParseFormat)
|
||||
|
||||
module.exports = {
|
||||
site: 'web.magentatv.de',
|
||||
days: 2,
|
||||
url: 'https://api.prod.sngtv.magentatv.de/EPG/JSON/PlayBillList',
|
||||
request: {
|
||||
method: 'POST',
|
||||
async headers() {
|
||||
return await setHeaders()
|
||||
},
|
||||
data({ channel, date }) {
|
||||
return {
|
||||
count: -1,
|
||||
isFillProgram: 1,
|
||||
offset: 0,
|
||||
properties: [
|
||||
{
|
||||
include:
|
||||
'endtime,genres,id,name,starttime,channelid,pictures,introduce,subName,seasonNum,subNum,cast,country,producedate,externalIds',
|
||||
name: 'playbill'
|
||||
}
|
||||
],
|
||||
type: 2,
|
||||
begintime: date.format('YYYYMMDD000000'),
|
||||
channelid: channel.site_id,
|
||||
endtime: date.add(1, 'd').format('YYYYMMDD000000')
|
||||
}
|
||||
}
|
||||
},
|
||||
parser({ content }) {
|
||||
const programs = []
|
||||
const items = parseItems(content)
|
||||
items.forEach(item => {
|
||||
programs.push({
|
||||
title: item.name,
|
||||
description: item.introduce,
|
||||
image: parseImage(item),
|
||||
category: parseCategory(item),
|
||||
start: parseStart(item),
|
||||
stop: parseStop(item),
|
||||
sub_title: item.subName,
|
||||
season: item.seasonNum,
|
||||
episode: item.subNum,
|
||||
directors: parseDirectors(item),
|
||||
producers: parseProducers(item),
|
||||
adapters: parseAdapters(item),
|
||||
country: item.country?.toUpperCase(),
|
||||
date: item.producedate,
|
||||
urls: parseUrls(item)
|
||||
})
|
||||
})
|
||||
return programs
|
||||
},
|
||||
async channels() {
|
||||
const url = 'https://api.prod.sngtv.magentatv.de/EPG/JSON/AllChannel'
|
||||
const body = {
|
||||
channelNamespace: 2,
|
||||
filterlist: [
|
||||
{
|
||||
key: 'IsHide',
|
||||
value: '-1'
|
||||
}
|
||||
],
|
||||
metaDataVer: 'Channel/1.1',
|
||||
properties: [
|
||||
{
|
||||
include: '/channellist/logicalChannel/contentId,/channellist/logicalChannel/name',
|
||||
name: 'logicalChannel'
|
||||
}
|
||||
],
|
||||
returnSatChannel: 0
|
||||
}
|
||||
const params = {
|
||||
headers: await setHeaders()
|
||||
}
|
||||
|
||||
const data = await axios
|
||||
.post(url, body, params)
|
||||
.then(r => r.data)
|
||||
.catch(console.log)
|
||||
|
||||
return data.channellist.map(item => {
|
||||
return {
|
||||
lang: 'de',
|
||||
site_id: item.contentId,
|
||||
name: item.name
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
function parseCategory(item) {
|
||||
return item.genres
|
||||
? item.genres
|
||||
.replace('und', ',')
|
||||
.split(',')
|
||||
.map(i => i.trim())
|
||||
: []
|
||||
}
|
||||
|
||||
function parseDirectors(item) {
|
||||
if (!item.cast || !item.cast.director) return []
|
||||
return item.cast.director
|
||||
.replace('und', ',')
|
||||
.split(',')
|
||||
.map(i => i.trim())
|
||||
}
|
||||
|
||||
function parseProducers(item) {
|
||||
if (!item.cast || !item.cast.producer) return []
|
||||
return item.cast.producer
|
||||
.replace('und', ',')
|
||||
.split(',')
|
||||
.map(i => i.trim())
|
||||
}
|
||||
|
||||
function parseAdapters(item) {
|
||||
if (!item.cast || !item.cast.adaptor) return []
|
||||
return item.cast.adaptor
|
||||
.replace('und', ',')
|
||||
.split(',')
|
||||
.map(i => i.trim())
|
||||
}
|
||||
|
||||
function parseUrls(item) {
|
||||
// currently only a imdb id is returned by the api, thus we can construct the url here
|
||||
if (!item.externalIds) return []
|
||||
return JSON.parse(item.externalIds)
|
||||
.filter(externalId => externalId.type === 'imdb' && externalId.id)
|
||||
.map(externalId => ({ system: 'imdb', value: `https://www.imdb.com/title/${externalId.id}` }))
|
||||
}
|
||||
|
||||
function parseImage(item) {
|
||||
if (!Array.isArray(item.pictures) || !item.pictures.length) return null
|
||||
|
||||
return item.pictures[0].href
|
||||
}
|
||||
|
||||
function parseStart(item) {
|
||||
return dayjs.utc(item.starttime, 'YYYY-MM-DD HH:mm:ss')
|
||||
}
|
||||
|
||||
function parseStop(item) {
|
||||
return dayjs.utc(item.endtime, 'YYYY-MM-DD HH:mm:ss')
|
||||
}
|
||||
|
||||
function parseItems(content) {
|
||||
const data = JSON.parse(content)
|
||||
if (!data || !Array.isArray(data.playbilllist)) return []
|
||||
|
||||
return data.playbilllist
|
||||
}
|
||||
|
||||
async function fetchCookieAndToken() {
|
||||
// Only fetch the cookies and csrfToken if they are not already set
|
||||
if (X_CSRFTOKEN && Cookie) {
|
||||
return
|
||||
}
|
||||
|
||||
try {
|
||||
const response = await axios.request({
|
||||
url: 'https://api.prod.sngtv.magentatv.de/EPG/JSON/Authenticate',
|
||||
params: {
|
||||
SID: 'firstup',
|
||||
T: 'Windows_chrome_118'
|
||||
},
|
||||
method: 'POST',
|
||||
data: '{"terminalid":"00:00:00:00:00:00","mac":"00:00:00:00:00:00","terminaltype":"WEBTV","utcEnable":1,"timezone":"Etc/GMT0","userType":3,"terminalvendor":"Unknown"}',
|
||||
})
|
||||
|
||||
// Extract the cookies specified in cookiesToExtract
|
||||
const setCookieHeader = response.headers['set-cookie'] || []
|
||||
const extractedCookies = []
|
||||
cookiesToExtract.forEach(cookieName => {
|
||||
const regex = new RegExp(`${cookieName}=(.+?)(;|$)`)
|
||||
const match = setCookieHeader.find(header => regex.test(header))
|
||||
|
||||
if (match) {
|
||||
const cookieString = regex.exec(match)[0]
|
||||
extractedCookies.push(cookieString)
|
||||
}
|
||||
})
|
||||
|
||||
// check if we recieved a csrfToken only then store the values
|
||||
if (!response.data.csrfToken) {
|
||||
console.log('csrfToken not found in the response.')
|
||||
return
|
||||
}
|
||||
|
||||
X_CSRFTOKEN = response.data.csrfToken
|
||||
Cookie = extractedCookies.join(' ')
|
||||
|
||||
} catch(error) {
|
||||
console.error(error)
|
||||
}
|
||||
}
|
||||
|
||||
async function setHeaders() {
|
||||
await fetchCookieAndToken()
|
||||
|
||||
return { X_CSRFTOKEN, Cookie }
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user