Merge pull request #2091 from iptv-org/fix-gatotv.com

Fix gatotv.com
This commit is contained in:
Ismaël Moret 2023-06-18 22:53:15 +02:00 committed by GitHub
commit 46277613ae
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 2385 additions and 494 deletions

File diff suppressed because it is too large Load diff

View file

@ -2,14 +2,7 @@ const axios = require('axios')
const cheerio = require('cheerio') const cheerio = require('cheerio')
const url = require('url') const url = require('url')
const path = require('path') const path = require('path')
const dayjs = require('dayjs') const { DateTime } = require('luxon')
const utc = require('dayjs/plugin/utc')
const timezone = require('dayjs/plugin/timezone')
const customParseFormat = require('dayjs/plugin/customParseFormat')
dayjs.extend(utc)
dayjs.extend(timezone)
dayjs.extend(customParseFormat)
module.exports = { module.exports = {
site: 'gatotv.com', site: 'gatotv.com',
@ -21,20 +14,17 @@ module.exports = {
let programs = [] let programs = []
const items = parseItems(content) const items = parseItems(content)
date = date.subtract(1, 'd') date = date.subtract(1, 'd')
items.forEach((item, index) => { items.forEach((item, i) => {
const prev = programs[programs.length - 1] const prev = programs[programs.length - 1]
const $item = cheerio.load(item) const $item = cheerio.load(item)
let start = parseStart($item, date) let start = parseStart($item, date)
if (prev) { if (i === 0 && start.hour >= 5) {
if (start.isBefore(prev.start)) { start = start.plus({ days: 1 })
start = start.add(1, 'd')
date = date.add(1, 'd') date = date.add(1, 'd')
} }
prev.stop = start let stop = parseStop($item, date)
} if (stop < start) {
let stop = parseStop($item, start) stop = stop.plus({ days: 1 })
if (stop.isBefore(start)) {
stop = stop.add(1, 'd')
date = date.add(1, 'd') date = date.add(1, 'd')
} }
@ -87,13 +77,17 @@ function parseIcon($item) {
function parseStart($item, date) { function parseStart($item, date) {
const time = $item('td:nth-child(1) > div > time').attr('datetime') const time = $item('td:nth-child(1) > div > time').attr('datetime')
return dayjs.tz(`${date.format('YYYY-MM-DD')} ${time}`, 'YYYY-MM-DD HH:mm', 'EST') return DateTime.fromFormat(`${date.format('YYYY-MM-DD')} ${time}`, 'yyyy-MM-dd HH:mm', {
zone: 'EST'
}).toUTC()
} }
function parseStop($item, date) { function parseStop($item, date) {
const time = $item('td:nth-child(2) > div > time').attr('datetime') const time = $item('td:nth-child(2) > div > time').attr('datetime')
return dayjs.tz(`${date.format('YYYY-MM-DD')} ${time}`, 'YYYY-MM-DD HH:mm', 'EST') return DateTime.fromFormat(`${date.format('YYYY-MM-DD')} ${time}`, 'yyyy-MM-dd HH:mm', {
zone: 'EST'
}).toUTC()
} }
function parseItems(content) { function parseItems(content) {

View file

@ -1,5 +1,5 @@
// npm run channels:parse -- --config=./sites/gatotv.com/gatotv.com.config.js --output=./sites/gatotv.com/gatotv.com.channels.xml // npm run channels:parse -- --config=./sites/gatotv.com/gatotv.com.config.js --output=./sites/gatotv.com/gatotv.com.channels.xml
// npx epg-grabber --config=sites/gatotv.com/gatotv.com.config.js --channels=sites/gatotv.com/gatotv.com.channels.xml --output=guide.xml --days=2 // npx epg-grabber --config=sites/gatotv.com/gatotv.com.config.js --channels=sites/gatotv.com/gatotv.com.channels.xml --output=guide.xml
const { parser, url, request } = require('./gatotv.com.config.js') const { parser, url, request } = require('./gatotv.com.config.js')
const fs = require('fs') const fs = require('fs')
@ -10,18 +10,18 @@ const customParseFormat = require('dayjs/plugin/customParseFormat')
dayjs.extend(customParseFormat) dayjs.extend(customParseFormat)
dayjs.extend(utc) dayjs.extend(utc)
const date = dayjs.utc('2023-01-31', 'YYYY-MM-DD').startOf('d') let date = dayjs.utc('2023-06-13', 'YYYY-MM-DD').startOf('d')
const channel = { const channel = {
site_id: 'punto_2_puerto_rico', site_id: 'm_0',
xmltv_id: 'WKAQDT2.us' xmltv_id: '0porMovistarPlus.es'
} }
it('can generate valid url', () => { it('can generate valid url', () => {
expect(url({ channel, date })).toBe('https://www.gatotv.com/canal/punto_2_puerto_rico/2023-01-31') expect(url({ channel, date })).toBe('https://www.gatotv.com/canal/m_0/2023-06-13')
}) })
it('can parse response', () => { it('can parse response', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.html'), 'utf8') const content = fs.readFileSync(path.resolve(__dirname, '__data__/content_0.html'), 'utf8')
const results = parser({ date, channel, content }).map(p => { const results = parser({ date, channel, content }).map(p => {
p.start = p.start.toJSON() p.start = p.start.toJSON()
p.stop = p.stop.toJSON() p.stop = p.stop.toJSON()
@ -30,24 +30,44 @@ it('can parse response', () => {
}) })
expect(results[0]).toMatchObject({ expect(results[0]).toMatchObject({
start: '2023-01-31T04:30:00.000Z', start: '2023-06-13T04:30:00.000Z',
stop: '2023-01-31T05:30:00.000Z', stop: '2023-06-13T05:32:00.000Z',
title: 'Decisiones de mujeres' title: 'Supergarcía'
}) })
expect(results[2]).toMatchObject({ expect(results[1]).toMatchObject({
start: '2023-01-31T06:30:00.000Z', start: '2023-06-13T05:32:00.000Z',
stop: '2023-01-31T07:30:00.000Z', stop: '2023-06-13T06:59:00.000Z',
title: 'El Señor de los Cielos', title: 'La resistencia'
icon: 'https://imagenes.gatotv.com/categorias/telenovelas/miniatura/el_senor_de_los_cielos.jpg',
description:
'La vida de Amado Carrillo Fuentes, conocido como “El Señor de los Cielos”, uno de los cabecillas del Cuartel de Juárez.'
}) })
expect(results[33]).toMatchObject({ expect(results[25]).toMatchObject({
start: '2023-02-01T04:30:00.000Z', start: '2023-06-14T04:46:00.000Z',
stop: '2023-02-01T05:30:00.000Z', stop: '2023-06-14T05:00:00.000Z',
title: 'Decisiones de mujeres' title: 'Una familia absolutamente normal'
})
})
it('can parse response when the guide starts from midnight', () => {
date = date.add(1, 'd')
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content_1.html'), 'utf8')
const results = parser({ date, channel, content }).map(p => {
p.start = p.start.toJSON()
p.stop = p.stop.toJSON()
return p
})
expect(results[0]).toMatchObject({
start: '2023-06-14T05:00:00.000Z',
stop: '2023-06-14T05:32:00.000Z',
title: 'Ilustres Ignorantes'
})
expect(results[26]).toMatchObject({
start: '2023-06-15T04:30:00.000Z',
stop: '2023-06-15T05:30:00.000Z',
title: 'Showriano'
}) })
}) })