From 6acb07ed4e768b9dd9e5dac68b54dcf4d2e11350 Mon Sep 17 00:00:00 2001 From: David Claeys Date: Tue, 26 Nov 2024 13:41:02 +0100 Subject: [PATCH] update readme and fix --- README.md | 12 ++--- fixes/pickx.be/pickx.be.config.js | 74 +++++++++++++++++++------------ 2 files changed, 51 insertions(+), 35 deletions(-) diff --git a/README.md b/README.md index 16b89a5..06fbcb4 100644 --- a/README.md +++ b/README.md @@ -38,12 +38,12 @@ If you have suggestions or a problem with them please submit an issue. This the list of the provided custom fixes : -| Provider | Author | Status | -|------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| -| movistarplus.es | [davidclaeysquinones](https://github.com/davidclaeysquinones) | [PR](https://github.com/iptv-org/epg/pull/2440) pending approval | -| pickx.be | [davidclaeysquinones](https://github.com/davidclaeysquinones) | [PR](https://github.com/iptv-org/epg/pull/2430) merged since commit [d159110](https://github.com/iptv-org/epg/commit/d15911006e163262c0c7f267deae28160c0d7a8f) | -| telenet.tv | [davidclaeysquinones](https://github.com/davidclaeysquinones) | [PR](https://github.com/iptv-org/epg/pull/2429) merged since commit [fd382db](https://github.com/iptv-org/epg/commit/fd382db08da7a96150928b8dcfef115e29e661d3) | -| web.magentatv.de | [klausellus-wallace](https://github.com/klausellus-wallace) | [PR](https://github.com/iptv-org/epg/pull/2458) pending approval | +| Provider | Author(s) | Status | +|------------------|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| +| movistarplus.es | [davidclaeysquinones](https://github.com/davidclaeysquinones) | [PR](https://github.com/iptv-org/epg/pull/2440) pending approval | +| pickx.be | [davidclaeysquinones](https://github.com/davidclaeysquinones) and [BellezaEmporium](https://github.com/BellezaEmporium) | [PR](https://github.com/iptv-org/epg/pull/2480) pending approval | +| telenet.tv | [davidclaeysquinones](https://github.com/davidclaeysquinones) | [PR](https://github.com/iptv-org/epg/pull/2429) merged since commit [fd382db](https://github.com/iptv-org/epg/commit/fd382db08da7a96150928b8dcfef115e29e661d3) | +| web.magentatv.de | [klausellus-wallace](https://github.com/klausellus-wallace) | [PR](https://github.com/iptv-org/epg/pull/2458) pending approval | If for some reason you want to include your own provider fixes this is possible by creation a mapping in the `/fixes` folder.
The expected structure is */fixes/`provider_name`/`provider_name`.config.js*.
diff --git a/fixes/pickx.be/pickx.be.config.js b/fixes/pickx.be/pickx.be.config.js index 5b8ff15..ee02dd1 100644 --- a/fixes/pickx.be/pickx.be.config.js +++ b/fixes/pickx.be/pickx.be.config.js @@ -1,4 +1,4 @@ -// credit for this fix goes to davidclaeysquinones for his PR on https://github.com/iptv-org/epg/pull/2430 +// credit for this fix goes to davidclaeysquinones for his PR on https://github.com/iptv-org/epg/pull/2430 and to BellezaEmporium for his PR on https://github.com/iptv-org/epg/pull/2480 const axios = require('axios') const dayjs = require('dayjs') @@ -141,40 +141,56 @@ module.exports = { function fetchApiVersion() { return new Promise(async (resolve, reject) => { try { - // https://px-epg.azureedge.net/version is deprecated - // probably the version url will be changed around over time + // load pickx bundle and get react version hash (regex). + // it's not the best way to get the version but it's the only way to get it. - //history of used version urls - //const versionUrl = 'https://www.pickx.be/api/s-3b36540f3cef64510112f3f95c2c0cdca321997ed2b1042ad778523235e155eb' - //const versionUrl = 'https://www.pickx.be/api/s-671f172425e1bc74cd0440fd67aaa6cbe68b582f3f401186c2f46ae97e80516b' - //const versionUrl = 'https://www.pickx.be/api/s-a6b4b4fefaa20e438523a6167e63b8504d96b9df8303473349763c4418cffe30' - //const versionUrl = 'https://www.pickx.be/api/s-8546c5fd136241d42aab714d2fe3ccc5671fd899035efae07cd0b8f4eb23994e' - //const versionUrl = 'https://www.pickx.be/api/s-64464ad9a3bc117af5dca620027216ecade6a51c230135a0f134c0ee042ff407'; - //const versionUrl = 'https://www.pickx.be/api/s-626d8fdabfb1d44e5a614cd69f4b45d6843fdb63566fc80ea4f97f40e4ea3152'; - //const versionUrl = 'https://www.pickx.be/api/s-cefaf96e249e53648c4895c279e7a621233c50b4357d62b0bdf6bff45f31b5c0'; - //const versionUrl = 'https://www.pickx.be/api/s-7fa35253080e9665f9c7d9d85e707d6fb1d1bf07ede11965e859fcb57c723949'; - //const versionUrl = 'https://www.pickx.be/api/s-0e58be3938175b6b900dfb5233bd5cfc0bcf915b633fe57b935f7ce8dbe5f6eb'; - //the new strategy to break the provider is to leave old version url's available and to return invalid results on those endpoints - - const versionUrl = 'https://www.pickx.be//api/s-600b22979b1e1e1dc91773795eed4a630dea2f9452aa1aab9a2947f4c89b901d'; - - - const response = await axios.get(versionUrl, { - headers: { - Origin: 'https://www.pickx.be', - Referer: 'https://www.pickx.be/' - } + // find bundle version + const minBundleVer = "https://www.pickx.be/minimal-bundle-version" + const bundleVerData = await axios.get(minBundleVer, { + headers: { + Origin: 'https://www.pickx.be', + Referer: 'https://www.pickx.be/' + } }) - if (response.status === 200) { - apiVersion = response.data.version - resolve() + if (bundleVerData.status !== 200) { + console.error(`Failed to fetch bundle version. Status: ${bundleVerData.status}`) + reject(`Failed to fetch bundle version. Status: ${bundleVerData.status}`) } else { - console.error(`Failed to fetch API version. Status: ${response.status}`) - reject(`Failed to fetch API version. Status: ${response.status}`) + const bundleVer = bundleVerData.data.version + // get the minified JS app bundle + const bundleUrl = `https://components.pickx.be/pxReactPlayer/${bundleVer}/bundle.min.js` + + // now, find the react hash inside the bundle URL + const bundle = await axios.get(bundleUrl).then(r => { + const re = /REACT_APP_VERSION_HASH:"([^"]+)"/ + const match = r.data.match(re) + if (match && match[1]) { + return match[1] + } else { + throw new Error('React app version hash not found') + } + }).catch(console.error) + + const versionUrl = `https://www.pickx.be/api/s-${bundle.replace('/REACT_APP_VERSION_HASH:"', '')}` + + const response = await axios.get(versionUrl, { + headers: { + Origin: 'https://www.pickx.be', + Referer: 'https://www.pickx.be/' + } + }) + + if (response.status === 200) { + apiVersion = response.data.version + resolve() + } else { + console.error(`Failed to fetch API version. Status: ${response.status}`) + reject(`Failed to fetch API version. Status: ${response.status}`) + } } } catch (error) { - console.error('Error fetching API version:', error.message) + console.error('Error during fetchApiVersion:', error) reject(error) } })