mirror of
https://github.com/iptv-org/epg.git
synced 2025-05-10 00:50:09 -04:00
Update mojmaxtv.hrvatskitelekom.hr.config.js
This commit is contained in:
parent
cd7182ddb3
commit
fab5f9ad08
1 changed files with 45 additions and 18 deletions
|
@ -6,11 +6,21 @@ const crypto = require('crypto')
|
||||||
|
|
||||||
// API Configuration Constants
|
// API Configuration Constants
|
||||||
const NATCO_CODE = 'hr'
|
const NATCO_CODE = 'hr'
|
||||||
|
const APP_LANGUAGE = 'hr'
|
||||||
const APP_KEY = 'GWaBW4RTloLwpUgYVzOiW5zUxFLmoMj5'
|
const APP_KEY = 'GWaBW4RTloLwpUgYVzOiW5zUxFLmoMj5'
|
||||||
const APP_VERSION = '02.0.1080'
|
const APP_VERSION = '02.0.1080'
|
||||||
const NATCO_KEY = 'l2lyvGVbUm2EKJE96ImQgcc8PKMZWtbE'
|
const NATCO_KEY = 'l2lyvGVbUm2EKJE96ImQgcc8PKMZWtbE'
|
||||||
const SITE_URL = 'mojmaxtv.hrvatskitelekom.hr'
|
const SITE_URL = 'mojmaxtv.hrvatskitelekom.hr'
|
||||||
|
|
||||||
|
// Role Types
|
||||||
|
const ROLE_TYPES = {
|
||||||
|
ACTOR: 'GLUMI', // Croatian for "ACTS"
|
||||||
|
DIRECTOR: 'REŽIJA', // Croatian for "DIRECTOR"
|
||||||
|
PRODUCER: 'PRODUKCIJA', // Croatian for "PRODUCER"
|
||||||
|
WRITER: 'AUTOR',
|
||||||
|
SCENARIO: 'SCENARIJ'
|
||||||
|
}
|
||||||
|
|
||||||
// Dynamic API Endpoint based on NATCO_CODE
|
// Dynamic API Endpoint based on NATCO_CODE
|
||||||
const API_ENDPOINT = `https://tv-${NATCO_CODE}-prod.yo-digital.com/${NATCO_CODE}-bifrost`
|
const API_ENDPOINT = `https://tv-${NATCO_CODE}-prod.yo-digital.com/${NATCO_CODE}-bifrost`
|
||||||
|
|
||||||
|
@ -18,6 +28,9 @@ const API_ENDPOINT = `https://tv-${NATCO_CODE}-prod.yo-digital.com/${NATCO_CODE}
|
||||||
const DEVICE_ID = crypto.randomUUID()
|
const DEVICE_ID = crypto.randomUUID()
|
||||||
const SESSION_ID = crypto.randomUUID()
|
const SESSION_ID = crypto.randomUUID()
|
||||||
|
|
||||||
|
// Set of known role names for quick lookup
|
||||||
|
const KNOWN_ROLES = new Set(Object.values(ROLE_TYPES))
|
||||||
|
|
||||||
const cached = {}
|
const cached = {}
|
||||||
|
|
||||||
const getHeaders = () => ({
|
const getHeaders = () => ({
|
||||||
|
@ -35,12 +48,34 @@ const getHeaders = () => ({
|
||||||
'x-user-agent': `web|web|Chrome-133|${APP_VERSION}|1`
|
'x-user-agent': `web|web|Chrome-133|${APP_VERSION}|1`
|
||||||
})
|
})
|
||||||
|
|
||||||
|
const unknownRoles = new Map()
|
||||||
|
|
||||||
|
function detectUnknownRoles(item) {
|
||||||
|
if (!item.roles) return
|
||||||
|
|
||||||
|
item.roles.forEach(role => {
|
||||||
|
if (!KNOWN_ROLES.has(role.role_name)) {
|
||||||
|
const count = unknownRoles.get(role.role_name) || 0
|
||||||
|
unknownRoles.set(role.role_name, count + 1)
|
||||||
|
|
||||||
|
// Log the first occurrence of each unknown role with an example
|
||||||
|
if (count === 0) {
|
||||||
|
console.log('New role type detected:', {
|
||||||
|
role_name: role.role_name,
|
||||||
|
example_person: role.person_name,
|
||||||
|
program_id: item.program_id
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
site: SITE_URL,
|
site: SITE_URL,
|
||||||
url({ date }) {
|
url({ date }) {
|
||||||
return `${API_ENDPOINT}/epg/channel/schedules?date=${date.format(
|
return `${API_ENDPOINT}/epg/channel/schedules?date=${date.format(
|
||||||
'YYYY-MM-DD'
|
'YYYY-MM-DD'
|
||||||
)}&hour_offset=0&hour_range=3&channelMap_id&filler=true&app_language=${NATCO_CODE}&natco_code=${NATCO_CODE}`
|
)}&hour_offset=0&hour_range=3&channelMap_id&filler=true&app_language=${APP_LANGUAGE}&natco_code=${NATCO_CODE}`
|
||||||
},
|
},
|
||||||
request: {
|
request: {
|
||||||
headers: getHeaders(),
|
headers: getHeaders(),
|
||||||
|
@ -82,15 +117,19 @@ module.exports = {
|
||||||
const programs = []
|
const programs = []
|
||||||
for (let item of items) {
|
for (let item of items) {
|
||||||
const detail = await loadProgramDetails(item)
|
const detail = await loadProgramDetails(item)
|
||||||
|
|
||||||
|
// detectUnknownRoles(detail)
|
||||||
|
|
||||||
programs.push({
|
programs.push({
|
||||||
title: item.description,
|
title: item.description,
|
||||||
|
sub_title: item.episode_name,
|
||||||
description: parseDescription(detail),
|
description: parseDescription(detail),
|
||||||
categories: parseCategories(detail),
|
categories: Array.isArray(item.genres) ? item.genres.map(g => g.name) : [],
|
||||||
date: parseDate(item),
|
date: parseDate(item),
|
||||||
image: detail.poster_image_url,
|
image: detail.poster_image_url,
|
||||||
actors: parseRoles(detail, 'GLUMI'),
|
actors: parseRoles(detail, ROLE_TYPES.ACTOR),
|
||||||
directors: parseRoles(detail, 'REŽIJA'),
|
directors: parseRoles(detail, ROLE_TYPES.DIRECTOR),
|
||||||
producers: parseRoles(detail, 'Producent'),
|
producers: parseRoles(detail, ROLE_TYPES.PRODUCER),
|
||||||
season: parseSeason(item),
|
season: parseSeason(item),
|
||||||
episode: parseEpisode(item),
|
episode: parseEpisode(item),
|
||||||
rating: parseRating(item),
|
rating: parseRating(item),
|
||||||
|
@ -104,7 +143,7 @@ module.exports = {
|
||||||
async channels() {
|
async channels() {
|
||||||
const data = await axios
|
const data = await axios
|
||||||
.get(
|
.get(
|
||||||
`${API_ENDPOINT}/epg/channel?channelMap_id=&includeVirtualChannels=false&natco_key=${NATCO_KEY}&app_language=${NATCO_CODE}&natco_code=${NATCO_CODE}`,
|
`${API_ENDPOINT}/epg/channel?channelMap_id=&includeVirtualChannels=false&natco_key=${NATCO_KEY}&app_language=${APP_LANGUAGE}&natco_code=${NATCO_CODE}`,
|
||||||
{ ...module.exports.request, headers: getHeaders() }
|
{ ...module.exports.request, headers: getHeaders() }
|
||||||
)
|
)
|
||||||
.then(r => r.data)
|
.then(r => r.data)
|
||||||
|
@ -172,18 +211,6 @@ function parseDescription(item) {
|
||||||
return item.details.description
|
return item.details.description
|
||||||
}
|
}
|
||||||
|
|
||||||
function parseCategories(item) {
|
|
||||||
if (!item.details?.metadata) return []
|
|
||||||
|
|
||||||
const genreMetadata = item.details.metadata.find(meta =>
|
|
||||||
meta.type === 'GENRES'
|
|
||||||
)
|
|
||||||
|
|
||||||
if (!genreMetadata?.value) return []
|
|
||||||
|
|
||||||
return genreMetadata.value.split(', ').filter(Boolean)
|
|
||||||
}
|
|
||||||
|
|
||||||
function parseRoles(item, role_name) {
|
function parseRoles(item, role_name) {
|
||||||
if (!item.roles) return null
|
if (!item.roles) return null
|
||||||
return item.roles.filter(role => role.role_name === role_name).map(role => role.person_name)
|
return item.roles.filter(role => role.role_name === role_name).map(role => role.person_name)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue