From 0906ce9285758c01759046f9625df910123319c0 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Thu, 3 Mar 2022 20:31:54 +0300 Subject: [PATCH 1/4] Create artonline.tv.config.js --- sites/artonline.tv/artonline.tv.config.js | 65 +++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 sites/artonline.tv/artonline.tv.config.js diff --git a/sites/artonline.tv/artonline.tv.config.js b/sites/artonline.tv/artonline.tv.config.js new file mode 100644 index 00000000..4aadf797 --- /dev/null +++ b/sites/artonline.tv/artonline.tv.config.js @@ -0,0 +1,65 @@ +const customParseFormat = require('dayjs/plugin/customParseFormat') +const timezone = require('dayjs/plugin/timezone') +const utc = require('dayjs/plugin/utc') +const dayjs = require('dayjs') + +dayjs.extend(customParseFormat) +dayjs.extend(timezone) +dayjs.extend(utc) + +module.exports = { + site: 'artonline.tv', + url: function ({ channel }) { + return `https://www.artonline.tv/Home/Tvlist${channel.site_id}` + }, + request: { + method: 'POST', + headers: { + 'content-type': 'application/x-www-form-urlencoded' + }, + data: function({ date }) { + const diff = date.diff(dayjs.utc().startOf('d'), 'd') + const params = new URLSearchParams() + params.append('objId', diff) + + return params + } + }, + parser: function ({ content }) { + const programs = [] + if(!content) return programs + const items = JSON.parse(content) + items.forEach(item => { + const icon = parseIcon(item) + const start = parseStart(item) + const duration = parseDuration(item) + const stop = start.add(duration, 's') + programs.push({ + title: item.title, + description: item.description, + icon, + start, + stop + }) + }) + + return programs + } +} + +function parseStart(item) { + const [_, M, D, YYYY] = item.adddate.match(/(\d+)\/(\d+)\/(\d+) /) + const [HH, mm] = item.start_Time.split(':') + + return dayjs(`${YYYY}-${M}-${D}T${HH}:${mm}:00`, 'YYYY-M-DTHH:mm:ss', 'Asia/Riyadh') +} + +function parseDuration(item) { + const [__, HH, mm, ss] = item.duration.match(/(\d+):(\d+):(\d+)/) + + return parseInt(HH) * 3600 + parseInt(mm) * 60 + parseInt(ss) +} + +function parseIcon(item) { + return item.thumbnail ? `https://www.artonline.tv${item.thumbnail}` : null +} From 9abae1837f3ef77437a56e8a2846cf219475ec4a Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Thu, 3 Mar 2022 20:32:02 +0300 Subject: [PATCH 2/4] Create artonline.tv.test.js --- sites/artonline.tv/artonline.tv.test.js | 65 +++++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 sites/artonline.tv/artonline.tv.test.js diff --git a/sites/artonline.tv/artonline.tv.test.js b/sites/artonline.tv/artonline.tv.test.js new file mode 100644 index 00000000..cfd93357 --- /dev/null +++ b/sites/artonline.tv/artonline.tv.test.js @@ -0,0 +1,65 @@ +// npx epg-grabber --config=sites/artonline.tv/artonline.tv.config.js --channels=sites/artonline.tv/artonline.tv_sa.channels.xml --output=guide.xml --days=2 + +const { parser, url, request } = require('./artonline.tv.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: 'Aflam2', + xmltv_id: 'ARTAflam2.sa' +} + +it('can generate valid url', () => { + expect(url({ channel })).toBe('https://www.artonline.tv/Home/TvlistAflam2') +}) + +it('can generate valid request method', () => { + expect(request.method).toBe('POST') +}) + +it('can generate valid request headers', () => { + expect(request.headers).toMatchObject({ + 'content-type': 'application/x-www-form-urlencoded' + }) +}) + +it('can generate valid request data for today', () => { + const date = dayjs.utc().startOf('d') + const data = request.data({ date }) + expect(data.get('objId')).toBe('0') +}) + +it('can generate valid request data for tomorrow', () => { + const date = dayjs.utc().startOf('d').add(1, 'd') + const data = request.data({ date }) + expect(data.get('objId')).toBe('1') +}) + +it('can parse response', () => { + const content = `[{"id":158963,"eventid":null,"duration":"01:34:00","lang":"Arabic","title":"الراقصه و السياسي","description":"تقرر الراقصه سونيا انشاء دار حضانه للأطفال اليتامى و عندما تتقدم بمشورعها للمسئول يرفض فتتحداه ، تلجأ للوزير عبد الحميد رأفت تربطه بها علاقة قديمة ، يخشى على مركزه و يرفض مساعدتها فتقرر كتابة مذكراتها بمساعدة أحد الصحفيين ، يتخوف عبد الحميد و المسئولين ثم يفاجأ عبد الحميد بحصول سونيا على الموافقه للمشورع و البدء في تنفيذه و ذلك لعلاقتها بأحد كبار المسئولين .","thumbnail":"/UploadImages/Channel/ARTAFLAM1/03/AlRaqesaWaAlSeyasi.jpg","image":"0","start_Time":"00:30","adddate":"3/4/2022 12:00:00 AM","repeat1":null,"iD_genre":0,"iD_Show_Type":0,"iD_Channel":77,"iD_country":0,"iD_rating":0,"end_time":"02:04","season_Number":0,"epoisode_Number":0,"hasCatchup":0,"cmsid":0,"containerID":0,"imagePath":"../../UploadImages/Channel/ARTAFLAM1/3/","youtube":"0","published_at":"0","directed_by":"0","composition":"0","cast":"0","timeShow":null,"short_description":"تقرر الراقصه سونيا انشاء دار حضانه للأطفال اليتامى و عندما تتقدم بمشورعها للمسئول يرفض فتتحداه ، تلجأ للوزير عبد الحميد رأفت تربطه بها علاقة قديمة ، يخشى على مركزه و يرفض مساعدتها فتقرر كتابة مذكراتها بمساعدة أحد الصحفيين ، يتخوف عبد الحميد و المسئولين ثم يفاجأ عبد الحميد بحصول سونيا على الموافقه للمشورع و البدء في تنفيذه و ذلك لعلاقتها بأحد كبار المسئولين .","seOdescription":null,"tagseo":null,"channel_name":null,"pathimage":null,"pathThumbnail":null}]` + const result = parser({ content }).map(p => { + p.start = p.start.toJSON() + p.stop = p.stop.toJSON() + return p + }) + + expect(result).toMatchObject([ + { + start: '2022-03-03T21:30:00.000Z', + stop: '2022-03-03T23:04:00.000Z', + title: 'الراقصه و السياسي', + description: 'تقرر الراقصه سونيا انشاء دار حضانه للأطفال اليتامى و عندما تتقدم بمشورعها للمسئول يرفض فتتحداه ، تلجأ للوزير عبد الحميد رأفت تربطه بها علاقة قديمة ، يخشى على مركزه و يرفض مساعدتها فتقرر كتابة مذكراتها بمساعدة أحد الصحفيين ، يتخوف عبد الحميد و المسئولين ثم يفاجأ عبد الحميد بحصول سونيا على الموافقه للمشورع و البدء في تنفيذه و ذلك لعلاقتها بأحد كبار المسئولين .', + icon: 'https://www.artonline.tv/UploadImages/Channel/ARTAFLAM1/03/AlRaqesaWaAlSeyasi.jpg' + } + ]) +}) + +it('can handle empty guide', () => { + const result = parser({ + content: '' + }) + expect(result).toMatchObject([]) +}) From bc9f431118337a8369c9f4185c8cdeaa89afb53a Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Thu, 3 Mar 2022 20:32:14 +0300 Subject: [PATCH 3/4] Create artonline.tv_sa.channels.xml --- sites/artonline.tv/artonline.tv_sa.channels.xml | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 sites/artonline.tv/artonline.tv_sa.channels.xml diff --git a/sites/artonline.tv/artonline.tv_sa.channels.xml b/sites/artonline.tv/artonline.tv_sa.channels.xml new file mode 100644 index 00000000..abd0989f --- /dev/null +++ b/sites/artonline.tv/artonline.tv_sa.channels.xml @@ -0,0 +1,10 @@ + + + + ART Aflam 1 + ART Aflam 2 + ART Cinema + ART Hekayat + ART Hekayat 2 + + \ No newline at end of file From ee2dbfe7e35c5d19d871dbe1388e16004e94c430 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Thu, 3 Mar 2022 20:32:19 +0300 Subject: [PATCH 4/4] Create artonline.tv.yml --- .github/workflows/artonline.tv.yml | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 .github/workflows/artonline.tv.yml diff --git a/.github/workflows/artonline.tv.yml b/.github/workflows/artonline.tv.yml new file mode 100644 index 00000000..8a422300 --- /dev/null +++ b/.github/workflows/artonline.tv.yml @@ -0,0 +1,17 @@ +name: artonline.tv +on: + schedule: + - cron: '0 0 * * *' + workflow_dispatch: + workflow_run: + workflows: [_trigger] + types: + - completed +jobs: + load: + uses: ./.github/workflows/_load.yml + with: + site: ${{github.workflow}} + secrets: + APP_ID: ${{ secrets.APP_ID }} + APP_PRIVATE_KEY: ${{ secrets.APP_PRIVATE_KEY }}