Files
epg/sites/cubmu.com/cubmu.com.config.js

145 lines
3.9 KiB
JavaScript
Raw Normal View History

const axios = require('axios')
2025-09-28 13:06:13 +03:00
const dayjs = require('dayjs')
const timezone = require('dayjs/plugin/timezone')
const utc = require('dayjs/plugin/utc')
dayjs.extend(timezone)
dayjs.extend(utc)
const tz = 'Asia/Jakarta'
const dateFormat = 'YYYY-MM-DD HH:mm:ss'
const headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/147.0.0.0 Safari/537.36',
'Origin': 'https://cubmu.com',
'Referer': 'https://cubmu.com/',
}
let runtimeConfig, accessToken
2025-09-28 13:06:13 +03:00
module.exports = {
site: 'cubmu.com',
days: 2,
url({ channel, date }) {
return `https://servicebuss.transvision.co.id/global/v2/epg/programs?channel_id=${
channel.site_id
}&schedule_date=${date.format(
2025-09-28 13:06:13 +03:00
'YYYY-MM-DD'
)}`
},
request: {
async headers() {
await fetchAccessToken()
return {
Authorization: `Bearer ${accessToken}`,
...headers,
}
}
2025-09-28 13:06:13 +03:00
},
parser({ content }) {
2025-09-28 13:06:13 +03:00
const programs = []
if (content && typeof content === 'string') {
content = JSON.parse(content)
}
if (Array.isArray(content?.data)) {
content.data.forEach(item => {
programs.push({
title: item.program_name,
start: dayjs.tz(item.schedule_start_time, dateFormat, tz),
stop: dayjs.tz(item.schedule_end_time, dateFormat, tz),
})
2025-09-28 13:06:13 +03:00
})
}
2025-09-28 13:06:13 +03:00
return programs
},
async channels({ lang = 'id' }) {
const now = dayjs()
await fetchAccessToken()
2025-09-28 13:06:13 +03:00
const result = await axios
.get(`https://servicebuss.transvision.co.id/global/v2/master-channels?platform_id=1&page=1&per_page=100&schedule_date=${now.format('YYYY-MM-DD')}`, {
headers: {
Authorization: `Bearer ${accessToken}`,
...headers,
}
})
.then(r => r.data)
.catch(err => console.error(err.message))
2025-09-28 13:06:13 +03:00
const channels = []
if (Array.isArray(result?.data?.items)) {
result.data.items.forEach(channel => {
channels.push({
lang,
site_id: channel.channel_id,
name: channel.channel_name,
2025-09-28 13:06:13 +03:00
})
})
}
return channels
}
}
async function fetchRuntimeConfig() {
if (!runtimeConfig) {
const cheerio = require('cheerio')
const url = 'https://cubmu.com/'
const result = await axios
.get(url)
.then(r => r.data)
.catch(err => console.error(err.message))
2025-09-28 13:06:13 +03:00
const $ = cheerio.load(result)
2025-09-28 13:06:13 +03:00
runtimeConfig = JSON.parse($('#__NEXT_DATA__').text()).runtimeConfig || {}
}
2025-09-28 13:06:13 +03:00
}
async function fetchAccessToken() {
if (!runtimeConfig) {
await fetchRuntimeConfig()
}
const url = 'https://servicebuss.transvision.co.id/global/v3/auth/redirect-login'
if (!accessToken) {
// extracted from https://cubmu.com/_next/static/chunks/pages/_app-ac49656f9b4eac2d.js
const f = t => {
let e = t,
r = 'xx',
n = Math.round(+new Date / 1e3),
i = ''.concat(e, '{SPLITTER}').concat(n)
return [0, 1].map(() => {
i = ''.concat(r).concat(btoa(i))
}), i
}
const payload = {
app_id: 'cubmu',
device: {
device_brand: 'Web Browser',
device_id: 'web_browser',
device_type: 'Opera',
firebase_id: 'NOT_ALLOWED',
notes: 'Web Browser-V2.1',
},
email_or_phone: runtimeConfig?.emailMaster,
password: f(runtimeConfig?.passwordMaster),
tvs_platform_id: 'standalone',
}
const result = await axios
.post(url, payload, {
headers: {
...headers,
'Content-Type': 'application/json',
}
})
.then(r => r.data)
.catch(err => console.error(err.message))
2025-09-28 13:06:13 +03:00
if (result?.data?.access_token) {
accessToken = result.data.access_token
}
}
if (!accessToken) {
throw new Error(`Unable to fetch access token from ${url}!`)
}
2025-09-28 13:06:13 +03:00
}