diff --git a/scripts/channels.js b/scripts/channels.js index aa0c2574..25cb6268 100644 --- a/scripts/channels.js +++ b/scripts/channels.js @@ -6,7 +6,7 @@ const { json2xml } = require('./utils') const program = new Command() program .requiredOption('-c, --config ', 'Config file') - .option('-s, --set [args...]', 'Set custom arguments') + .option('-s, --set [args...]', 'Set custom arguments', []) .option('-o, --output ', 'Output file') .parse(process.argv) diff --git a/sites/tvarenasport.com/tvarenasport.com.config.js b/sites/tvarenasport.com/tvarenasport.com.config.js index e2b957da..7ba80254 100644 --- a/sites/tvarenasport.com/tvarenasport.com.config.js +++ b/sites/tvarenasport.com/tvarenasport.com.config.js @@ -22,9 +22,9 @@ module.exports = { const items = parseItems(content, channel) items.forEach(item => { programs.push({ - title: item.title, + title: item.title.trim(), category: item.league, - description: item.sport, + description: item.sport.trim(), start: dayjs(item.start), stop: dayjs(item.end) }) diff --git a/sites/tvarenasport.hr/tvarenasport.hr.config.js b/sites/tvarenasport.hr/tvarenasport.hr.config.js new file mode 100644 index 00000000..f70bf471 --- /dev/null +++ b/sites/tvarenasport.hr/tvarenasport.hr.config.js @@ -0,0 +1,49 @@ +const axios = require('axios') +const dayjs = require('dayjs') + +module.exports = { + site: 'tvarenasport.hr', + url: function ({ channel, date }) { + return `https://www.tvarenasport.hr/api/schedule?date=${date.format('DD-MM-YYYY')}` + }, + parser: function ({ content, channel }) { + let programs = [] + const items = parseItems(content, channel) + items.forEach(item => { + programs.push({ + title: item.title.trim(), + category: item.sport, + description: item.league.trim(), + start: dayjs(item.start), + stop: dayjs(item.end) + }) + }) + + return programs + }, + async channels({ country, lang }) { + const data = await axios + .get(`https://www.tvarenasport.hr/api/schedule`) + .then(r => r.data) + .catch(console.log) + + const channels = [] + for (let id in data.channels) { + const item = data.channels[id] + channels.push({ + lang: 'hr', + site_id: id, + name: item.name + }) + } + + return channels + } +} + +function parseItems(content, channel) { + const data = JSON.parse(content) + if (!data || !Array.isArray(data.items)) return [] + + return data.items.filter(i => i.group === channel.site_id) +} diff --git a/sites/tvarenasport.hr/tvarenasport.hr.test.js b/sites/tvarenasport.hr/tvarenasport.hr.test.js new file mode 100644 index 00000000..b1a50d63 --- /dev/null +++ b/sites/tvarenasport.hr/tvarenasport.hr.test.js @@ -0,0 +1,47 @@ +// node ./scripts/channels.js --config=./sites/tvarenasport.hr/tvarenasport.hr.config.js --output=./sites/tvarenasport.hr/tvarenasport.hr_hr.channels.xml +// npx epg-grabber --config=sites/tvarenasport.hr/tvarenasport.hr.config.js --channels=sites/tvarenasport.hr/tvarenasport.hr_hr.channels.xml --output=.gh-pages/guides/hr/tvarenasport.hr.epg.xml --days=2 + +const { parser, url } = require('./tvarenasport.hr.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-17', 'YYYY-MM-DD').startOf('d') +const channel = { + site_id: '380', + xmltv_id: 'ArenaSport1Hrvatska.rs' +} + +it('can generate valid url', () => { + expect(url({ channel, date })).toBe('https://www.tvarenasport.hr/api/schedule?date=17-11-2021') +}) + +it('can parse response', () => { + const content = `{"items":[{"id":6104,"title":"NAJAVA PROGRAMA","start":"2021-11-16T23:00:00Z","end":"2021-11-17T23:00:00Z","sport":"Najava programa","league":"NAJAVA PROGRAMA","group":"1294","isLive":false,"doNotMiss":false,"domain":"cro"},{"id":6000,"title":" DIJON - UNICAJA","start":"2021-11-16T23:30:00Z","end":"2021-11-17T01:00:00Z","sport":"Košarka","league":" LIGA PRVAKA","group":"380","isLive":false,"doNotMiss":false,"domain":"cro"}]}` + const result = parser({ channel, content }).map(p => { + p.start = p.start.toJSON() + p.stop = p.stop.toJSON() + return p + }) + + expect(result).toMatchObject([ + { + start: '2021-11-16T23:30:00.000Z', + stop: '2021-11-17T01:00:00.000Z', + title: 'DIJON - UNICAJA', + category: 'Košarka', + description: 'LIGA PRVAKA' + } + ]) +}) + +it('can handle empty guide', () => { + const result = parser({ + date, + channel, + content: `{"channels":[]}` + }) + expect(result).toMatchObject([]) +}) diff --git a/sites/tvarenasport.hr/tvarenasport.hr_hr.channels.xml b/sites/tvarenasport.hr/tvarenasport.hr_hr.channels.xml new file mode 100644 index 00000000..28d7a55a --- /dev/null +++ b/sites/tvarenasport.hr/tvarenasport.hr_hr.channels.xml @@ -0,0 +1,15 @@ + + + + Arena Sport 1 Hrvatska + Arena Sport 2 Hrvatska + Arena Sport 3 Hrvatska + Arena Sport 4 Hrvatska + Arena Sport 5 Hrvatska + Arena Sport 6 Hrvatska + Arena Sport 7 Hrvatska + Arena Sport 8 Hrvatska + Arena Sport 9 Hrvatska + Arena Sport 10 Hrvatska + +