diff --git a/.github/workflows/wavve.com.yml b/.github/workflows/wavve.com.yml new file mode 100644 index 00000000..77732027 --- /dev/null +++ b/.github/workflows/wavve.com.yml @@ -0,0 +1,17 @@ +name: wavve.com +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 }} diff --git a/sites/wavve.com/wavve.com.config.js b/sites/wavve.com/wavve.com.config.js new file mode 100644 index 00000000..e27e941c --- /dev/null +++ b/sites/wavve.com/wavve.com.config.js @@ -0,0 +1,69 @@ +const axios = require('axios') +const dayjs = require('dayjs') +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 = { + site: 'wavve.com', + url: function ({ channel, date }) { + return `https://apis.pooq.co.kr/live/epgs/channels/${channel.site_id}?startdatetime=${date + .tz('Asia/Seoul') + .format('YYYY-MM-DD')}%2000%3A00&enddatetime=${date + .tz('Asia/Seoul') + .add(1, 'd') + .format('YYYY-MM-DD')}%2000%3A00&apikey=E5F3E0D30947AA5440556471321BB6D9&limit=500` + }, + parser: function ({ content }) { + let programs = [] + const items = parseItems(content) + items.forEach(item => { + programs.push({ + title: item.title, + start: parseStart(item), + stop: parseStop(item) + }) + }) + + return programs + }, + async channels({ country }) { + const channels = [] + + const data = await axios + .get( + `https://apis.pooq.co.kr/live/epgs?enddatetime=2022-04-17%2019%3A00&genre=all&limit=500&startdatetime=2022-04-17%2016%3A00&apikey=E5F3E0D30947AA5440556471321BB6D9` + ) + .then(r => r.data) + .catch(console.log) + + data.list.forEach(i => { + channels.push({ + name: i.channelname, + site_id: i.channelid, + lang: 'ko' + }) + }) + + return channels + } +} + +function parseStart(item) { + return dayjs.tz(item.starttime, 'YYYY-MM-DD HH:mm', 'Asia/Seoul') +} + +function parseStop(item) { + return dayjs.tz(item.endtime, 'YYYY-MM-DD HH:mm', 'Asia/Seoul') +} + +function parseItems(content) { + const data = JSON.parse(content) + if (!data || !Array.isArray(data.list)) return [] + + return data.list +} diff --git a/sites/wavve.com/wavve.com.test.js b/sites/wavve.com/wavve.com.test.js new file mode 100644 index 00000000..a750804d --- /dev/null +++ b/sites/wavve.com/wavve.com.test.js @@ -0,0 +1,45 @@ +// npm run channels:parse -- --config=sites/wavve.com/wavve.com.config.js --output=sites/wavve.com/wavve.com_kr.channels.xml +// npx epg-grabber --config=sites/wavve.com/wavve.com.config.js --channels=sites/wavve.com/wavve.com_kr.channels.xml --output=guide.xml --days=2 + +const { parser, url } = require('./wavve.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 date = dayjs.utc('2022-04-17', 'YYYY-MM-DD').startOf('d') +const channel = { + site_id: 'K01', + xmltv_id: 'KBS1TV.kr' +} + +it('can generate valid url', () => { + expect(url({ channel, date })).toBe( + 'https://apis.pooq.co.kr/live/epgs/channels/K01?startdatetime=2022-04-17%2000%3A00&enddatetime=2022-04-18%2000%3A00&apikey=E5F3E0D30947AA5440556471321BB6D9&limit=500' + ) +}) + +it('can parse response', () => { + const content = `{"pagecount":"37","count":"37","list":[{"cpid":"C3","channelid":"K01","channelname":"KBS 1TV","channelimage":"img.pooq.co.kr/BMS/Channelimage30/image/KBS-1TV-1.jpg","scheduleid":"K01_20220416223000","programid":"","title":"특파원 보고 세계는 지금","image":"wchimg.wavve.com/live/thumbnail/K01.jpg","starttime":"2022-04-16 22:30","endtime":"2022-04-16 23:15","timemachine":"Y","license":"y","livemarks":[],"targetage":"0","tvimage":"img.pooq.co.kr/BMS/Channelimage30/image/KBS 1TV-2.png","ispreorder":"n","preorderlink":"n","alarm":"n"}]}` + const result = parser({ content }).map(p => { + p.start = p.start.toJSON() + p.stop = p.stop.toJSON() + return p + }) + + expect(result).toMatchObject([ + { + start: '2022-04-16T13:30:00.000Z', + stop: '2022-04-16T14:15:00.000Z', + title: '특파원 보고 세계는 지금' + } + ]) +}) + +it('can handle empty guide', () => { + const result = parser({ + content: `{"pagecount":"0","count":"0","list":[]}` + }) + expect(result).toMatchObject([]) +}) diff --git a/sites/wavve.com/wavve.com_kr.channels.xml b/sites/wavve.com/wavve.com_kr.channels.xml new file mode 100644 index 00000000..f955f372 --- /dev/null +++ b/sites/wavve.com/wavve.com_kr.channels.xml @@ -0,0 +1,82 @@ + + + + ANIBOX + ANIMAX + ANIONE + 애니플러스 + AsiaM + AsiaN + 브라보키즈 + BTN + CCTV4 + CGTN + 채널A + 채널A 플러스 + 채널차이나 + 채널J + 채널W + 가톨릭평화방송 + CTS기독교TV + 대교어린이TV + Discovery + 동아TV + EBS 1 + EBS 2 + EBS 키즈 + 노는채널 E채널 + EDGETV + FUNTV + GS MY SHOP + GS SHOP + HISTORY + 현대홈쇼핑 + 현대홈쇼핑+샵 + 인디필름 + JNG + KBS 1TV + KBS 2TV + KBS DRAMA + KBS JOY + KBS Life + KBS Story + K SHOPPING + LIFETIME + 롯데홈쇼핑 + 롯데홈쇼핑 ONETV + MBC Drama + MBC Every1 + MBC M + MBC ON + MBC + MBN + MBN 플러스 + 매일경제TV + 머니투데이방송 + 국회방송 + SBS Nick + NS홈쇼핑 + NS SHOP+ + 폴라리스TV + SBS Biz + SBS Fil + SBS funE + SBS Golf + SBS MTV + SBS Plus + SBS + 신세계TV쇼핑 + 쇼핑엔티 + SK스토아 + SmileTV Plus + 텔레노벨라 + THE MOVIE + TVasia Plus + TV CHOSUN + TV CHOSUN2 + 블렌딩 뮤직비디오 + 한국경제TV + 연합뉴스TV + YTN + +