From f91ecc91dddacaf8a09335959223ae272f8bce89 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 13 Nov 2021 15:49:07 +0300 Subject: [PATCH 1/8] Create canalplus-reunion.com.test.js --- .../canalplus-reunion.com.test.js | 55 +++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 sites/canalplus-reunion.com/canalplus-reunion.com.test.js diff --git a/sites/canalplus-reunion.com/canalplus-reunion.com.test.js b/sites/canalplus-reunion.com/canalplus-reunion.com.test.js new file mode 100644 index 00000000..3bcd9b03 --- /dev/null +++ b/sites/canalplus-reunion.com/canalplus-reunion.com.test.js @@ -0,0 +1,55 @@ +// npx epg-grabber --config=sites/canalplus-reunion.com/canalplus-reunion.com.config.js --channels=sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml --output=.gh-pages/guides/km/canalplus-reunion.com.epg.xml --days=2 + +const { parser, url, logo } = require('./canalplus-reunion.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 channel = { + site_id: '60020', + xmltv_id: 'CanalPlusReunion.fr', + logo: 'https://service.canal-overseas.com/image-api/v1/image/702e588188caa19c38c438d14bfc8870' +} + +it('can generate valid url for today', () => { + const date = dayjs.utc().startOf('d') + expect(url({ channel, date })).toBe( + 'https://service.canal-overseas.com/ott-frontend/vector/63001/channel/60020/events?filter.day=0' + ) +}) + +it('can generate valid url for tomorrow', () => { + const date = dayjs.utc().startOf('d').add(1, 'd') + expect(url({ channel, date })).toBe( + 'https://service.canal-overseas.com/ott-frontend/vector/63001/channel/60020/events?filter.day=1' + ) +}) + +it('can get logo url', () => { + expect(logo({ channel })).toBe( + 'https://service.canal-overseas.com/image-api/v1/image/702e588188caa19c38c438d14bfc8870' + ) +}) + +it('can parse response', () => { + const content = `{"timeSlices":[{"contents":[{"title":"Fin des programmes","thirdTitle":"MA TV","startTime":1636768800,"endTime":1636855200,"onClick":{"displayTemplate":"miniDetail","displayName":"Fin des programmes","URLPage":"https://service.canal-overseas.com/ott-frontend/vector/63001/event/110427432","URLVitrine":"https://service.canal-overseas.com/ott-frontend/vector/63001/program/0/recommendations"},"programID":0,"diffusionID":"110427432","URLImageDefault":"https://service.canal-overseas.com/image-api/v1/image/generic","URLImage":"https://service.canal-overseas.com/image-api/v1/image/generic"}],"timeSlice":"0"},{"contents":[{"title":"Le cercle","subtitle":"5 Novembre 2021","thirdTitle":"CANAL+ HD","startTime":1636793201,"endTime":1636795901,"onClick":{"displayTemplate":"miniDetail","displayName":"Le cercle","URLPage":"https://service.canal-overseas.com/ott-frontend/vector/63001/event/110427540","URLVitrine":"https://service.canal-overseas.com/ott-frontend/vector/63001/program/193072081/recommendations"},"programID":193072081,"diffusionID":"110427540","URLImageDefault":"https://service.canal-overseas.com/image-api/v1/image/2a311987c642d97485d5f531e698dfb7","URLImage":"https://service.canal-overseas.com/image-api/v1/image/2de336e6a8c962921638c8aeee5f7e52"}],"timeSlice":"1"},{"contents":[],"timeSlice":"2"},{"contents":[],"timeSlice":"3"},{"contents":[],"timeSlice":"4"}]}` + const result = parser({ content }) + + expect(result).toMatchObject([ + { + start: '2021-11-13T08:46:41.000Z', + stop: '2021-11-13T09:31:41.000Z', + title: 'Le cercle', + icon: 'https://service.canal-overseas.com/image-api/v1/image/2a311987c642d97485d5f531e698dfb7' + } + ]) +}) + +it('can handle empty guide', () => { + const result = parser({ + content: `{"currentPage":{"displayTemplate":"error","BOName":"Page introuvable"},"title":"Page introuvable","text":"La page que vous demandez est introuvable. Si le problème persiste, vous pouvez contacter l'assistance de CANAL+/CANALSAT.","code":404}` + }) + expect(result).toMatchObject([]) +}) From 3a9c49461d958ae62da15d5150fd912b40637b64 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 13 Nov 2021 15:49:17 +0300 Subject: [PATCH 2/8] Create canalplus-reunion.com.config.js --- .../canalplus-reunion.com.config.js | 47 +++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 sites/canalplus-reunion.com/canalplus-reunion.com.config.js diff --git a/sites/canalplus-reunion.com/canalplus-reunion.com.config.js b/sites/canalplus-reunion.com/canalplus-reunion.com.config.js new file mode 100644 index 00000000..218a7bff --- /dev/null +++ b/sites/canalplus-reunion.com/canalplus-reunion.com.config.js @@ -0,0 +1,47 @@ +const dayjs = require('dayjs') + +module.exports = { + site: 'canalplus-reunion.com', + url: function ({ channel, date }) { + const diff = date.diff(dayjs().startOf('d'), 'd') + + return `https://service.canal-overseas.com/ott-frontend/vector/63001/channel/${channel.site_id}/events?filter.day=${diff}` + }, + logo({ channel }) { + return channel.logo + }, + parser: function ({ content }) { + let programs = [] + const items = parseItems(content) + items.forEach(item => { + if (item.title === 'Fin des programmes') return + programs.push({ + title: item.title, + icon: item.URLImageDefault, + start: parseStart(item).toJSON(), + stop: parseStop(item).toJSON() + }) + }) + + return programs + } +} + +function parseStart(item) { + return dayjs.unix(item.startTime) +} + +function parseStop(item) { + return dayjs.unix(item.endTime) +} + +function parseItems(content) { + const data = JSON.parse(content) + if (!data || !data.timeSlices) return [] + const items = data.timeSlices.reduce((acc, curr) => { + acc = acc.concat(curr.contents) + return acc + }, []) + + return items +} From 5e406587389fd1ae7de09e2da64b3f20ddb5f8d4 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 13 Nov 2021 15:49:20 +0300 Subject: [PATCH 3/8] Create canalplus-reunion.com_km.channels.xml --- .../canalplus-reunion.com_km.channels.xml | 124 ++++++++++++++++++ 1 file changed, 124 insertions(+) create mode 100644 sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml diff --git a/sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml b/sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml new file mode 100644 index 00000000..30f887c8 --- /dev/null +++ b/sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml @@ -0,0 +1,124 @@ + + + + 6ter + 13ème Rue + Action + Antenne Réunion TV + A+ + ARTE Français + Automoto la chaîne + BBC World News Africa + BeIn Sports 1 France + BeIn Sports 2 France + BeIn Sports 3 France + C8 + Canal + Cinéma Réunion + Canal + Décalé + Canal + Kids + Canal + Réunion + Canal + Séries Réunion + Canal + Sport Réunion + CGTN Français + Cine + Classic + Cine + Club + Cine + Émotion + Cine + Famiz + Cine + Frisson + Cine + Premier + C News + Colmax TV + Colors + Comédie + + C Star + Discovery Channel France + Discovery Science France + Disney Channel France + Disney Junior France + Disney+ France + Dorcel TV Africa + E! France + English Club TV + Equidia + Eurosport 1 France + Eurosport 2 France + France 2 + France 3 + France 4 + France 5 + France 24 Français + Franceinfo: + Game One + Golf + + Gulli + Histoire TV + InfoSport + + Iqraa Africa & Europe + Kanal Austral TV + Kolo TV + KTO + Kwezi TV + LCI + LCP Assemblée Nationale + L'Équipe + Ludikids + M6 + Mayotte 1ère + MBS + Mezzo + MTV France + MTV Hits France + MTV India + National Geographic France + National Geographic Wild France + Nickelodeon France + Nickelodeon Junior France + Nollywood TV + Novegasy + Novelas TV + NRJ 12 + OCS choc + OCS City + OCS geants + OCS max + ORTC TV + Paramount Channel France + Paris Première + Penthouse Black + Piwi + + Planète + + Planète + A&E + Planète + CI + Réunion 1ère + RFM TV + RTA + RTL 9 + Seasons + Série Club + Syfy France + Télé Kréol + TéléToon + + Téva + TF 1 + TF 1 Séries Films + TFX + TMC + Trace Caribbean + Trace Urban Afrique + Trace Vanilla Islands + Trek + TV5Monde Afrique + TV Breizh + TV Malagasy + TV Plus Madagascar + TV Record Madagascar + Ushuaïa TV + Vixen + W9 + Wataaa TV + XXL + Zee Cinema Africa + Zee TV Africa + Zing UK + + \ No newline at end of file From 0e99f9b4517a9523b3a61f8e8d0b032f2d679cbd Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 13 Nov 2021 15:49:24 +0300 Subject: [PATCH 4/8] Create canalplus-reunion.com_re.channels.xml --- .../canalplus-reunion.com_re.channels.xml | 124 ++++++++++++++++++ 1 file changed, 124 insertions(+) create mode 100644 sites/canalplus-reunion.com/canalplus-reunion.com_re.channels.xml diff --git a/sites/canalplus-reunion.com/canalplus-reunion.com_re.channels.xml b/sites/canalplus-reunion.com/canalplus-reunion.com_re.channels.xml new file mode 100644 index 00000000..30f887c8 --- /dev/null +++ b/sites/canalplus-reunion.com/canalplus-reunion.com_re.channels.xml @@ -0,0 +1,124 @@ + + + + 6ter + 13ème Rue + Action + Antenne Réunion TV + A+ + ARTE Français + Automoto la chaîne + BBC World News Africa + BeIn Sports 1 France + BeIn Sports 2 France + BeIn Sports 3 France + C8 + Canal + Cinéma Réunion + Canal + Décalé + Canal + Kids + Canal + Réunion + Canal + Séries Réunion + Canal + Sport Réunion + CGTN Français + Cine + Classic + Cine + Club + Cine + Émotion + Cine + Famiz + Cine + Frisson + Cine + Premier + C News + Colmax TV + Colors + Comédie + + C Star + Discovery Channel France + Discovery Science France + Disney Channel France + Disney Junior France + Disney+ France + Dorcel TV Africa + E! France + English Club TV + Equidia + Eurosport 1 France + Eurosport 2 France + France 2 + France 3 + France 4 + France 5 + France 24 Français + Franceinfo: + Game One + Golf + + Gulli + Histoire TV + InfoSport + + Iqraa Africa & Europe + Kanal Austral TV + Kolo TV + KTO + Kwezi TV + LCI + LCP Assemblée Nationale + L'Équipe + Ludikids + M6 + Mayotte 1ère + MBS + Mezzo + MTV France + MTV Hits France + MTV India + National Geographic France + National Geographic Wild France + Nickelodeon France + Nickelodeon Junior France + Nollywood TV + Novegasy + Novelas TV + NRJ 12 + OCS choc + OCS City + OCS geants + OCS max + ORTC TV + Paramount Channel France + Paris Première + Penthouse Black + Piwi + + Planète + + Planète + A&E + Planète + CI + Réunion 1ère + RFM TV + RTA + RTL 9 + Seasons + Série Club + Syfy France + Télé Kréol + TéléToon + + Téva + TF 1 + TF 1 Séries Films + TFX + TMC + Trace Caribbean + Trace Urban Afrique + Trace Vanilla Islands + Trek + TV5Monde Afrique + TV Breizh + TV Malagasy + TV Plus Madagascar + TV Record Madagascar + Ushuaïa TV + Vixen + W9 + Wataaa TV + XXL + Zee Cinema Africa + Zee TV Africa + Zing UK + + \ No newline at end of file From dc2d0317f6d4195315a13754a9eec6649cadfa93 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 13 Nov 2021 15:49:27 +0300 Subject: [PATCH 5/8] Create canalplus-reunion.com_yt.channels.xml --- .../canalplus-reunion.com_yt.channels.xml | 124 ++++++++++++++++++ 1 file changed, 124 insertions(+) create mode 100644 sites/canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml diff --git a/sites/canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml b/sites/canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml new file mode 100644 index 00000000..30f887c8 --- /dev/null +++ b/sites/canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml @@ -0,0 +1,124 @@ + + + + 6ter + 13ème Rue + Action + Antenne Réunion TV + A+ + ARTE Français + Automoto la chaîne + BBC World News Africa + BeIn Sports 1 France + BeIn Sports 2 France + BeIn Sports 3 France + C8 + Canal + Cinéma Réunion + Canal + Décalé + Canal + Kids + Canal + Réunion + Canal + Séries Réunion + Canal + Sport Réunion + CGTN Français + Cine + Classic + Cine + Club + Cine + Émotion + Cine + Famiz + Cine + Frisson + Cine + Premier + C News + Colmax TV + Colors + Comédie + + C Star + Discovery Channel France + Discovery Science France + Disney Channel France + Disney Junior France + Disney+ France + Dorcel TV Africa + E! France + English Club TV + Equidia + Eurosport 1 France + Eurosport 2 France + France 2 + France 3 + France 4 + France 5 + France 24 Français + Franceinfo: + Game One + Golf + + Gulli + Histoire TV + InfoSport + + Iqraa Africa & Europe + Kanal Austral TV + Kolo TV + KTO + Kwezi TV + LCI + LCP Assemblée Nationale + L'Équipe + Ludikids + M6 + Mayotte 1ère + MBS + Mezzo + MTV France + MTV Hits France + MTV India + National Geographic France + National Geographic Wild France + Nickelodeon France + Nickelodeon Junior France + Nollywood TV + Novegasy + Novelas TV + NRJ 12 + OCS choc + OCS City + OCS geants + OCS max + ORTC TV + Paramount Channel France + Paris Première + Penthouse Black + Piwi + + Planète + + Planète + A&E + Planète + CI + Réunion 1ère + RFM TV + RTA + RTL 9 + Seasons + Série Club + Syfy France + Télé Kréol + TéléToon + + Téva + TF 1 + TF 1 Séries Films + TFX + TMC + Trace Caribbean + Trace Urban Afrique + Trace Vanilla Islands + Trek + TV5Monde Afrique + TV Breizh + TV Malagasy + TV Plus Madagascar + TV Record Madagascar + Ushuaïa TV + Vixen + W9 + Wataaa TV + XXL + Zee Cinema Africa + Zee TV Africa + Zing UK + + \ No newline at end of file From 9abe402598a604ced985f64e9aafa2544c1b1000 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 13 Nov 2021 15:50:48 +0300 Subject: [PATCH 6/8] Update canalplus-reunion.com_km.channels.xml --- .../canalplus-reunion.com/canalplus-reunion.com_km.channels.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml b/sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml index 30f887c8..a97c630e 100644 --- a/sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml +++ b/sites/canalplus-reunion.com/canalplus-reunion.com_km.channels.xml @@ -1,5 +1,5 @@ - + 6ter 13ème Rue From 4b56d890248299b6d7f79257a7bddc2b731da4fc Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 13 Nov 2021 15:50:51 +0300 Subject: [PATCH 7/8] Update canalplus-reunion.com_re.channels.xml --- .../canalplus-reunion.com/canalplus-reunion.com_re.channels.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sites/canalplus-reunion.com/canalplus-reunion.com_re.channels.xml b/sites/canalplus-reunion.com/canalplus-reunion.com_re.channels.xml index 30f887c8..a97c630e 100644 --- a/sites/canalplus-reunion.com/canalplus-reunion.com_re.channels.xml +++ b/sites/canalplus-reunion.com/canalplus-reunion.com_re.channels.xml @@ -1,5 +1,5 @@ - + 6ter 13ème Rue From 38ab9bc0a0ffd8e9367963e339f62c5d304d175f Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 13 Nov 2021 15:50:53 +0300 Subject: [PATCH 8/8] Update canalplus-reunion.com_yt.channels.xml --- .../canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sites/canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml b/sites/canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml index 30f887c8..a97c630e 100644 --- a/sites/canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml +++ b/sites/canalplus-reunion.com/canalplus-reunion.com_yt.channels.xml @@ -1,5 +1,5 @@ - + 6ter 13ème Rue