Merge pull request #2323 from Sicilykill/issue_2322

Resolves issue #2322
This commit is contained in:
Dum4G 2024-02-05 17:10:37 +03:00 committed by GitHub
commit eee14ca3f6
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 56 additions and 9 deletions

View file

@ -2,13 +2,33 @@ const axios = require('axios')
const dayjs = require('dayjs') const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc') const utc = require('dayjs/plugin/utc')
dayjs.extend(utc) let apiVersion;
let isApiVersionFetched = false;
(async () => {
try {
await fetchApiVersion();
isApiVersionFetched = true;
} catch (error) {
console.error('Error during script initialization:', error);
}
})();
dayjs.extend(utc)
module.exports = { module.exports = {
site: 'pickx.be', site: 'pickx.be',
days: 2, days: 2,
url({ channel, date }) { apiVersion: function () {
return `https://px-epg.azureedge.net/airings/11702375189765v.4.2/${date.format('YYYY-MM-DD')}/channel/${channel.site_id}?timezone=Europe%2FBrussels` return apiVersion;
},
fetchApiVersion: fetchApiVersion, // Export fetchApiVersion
url: async function ({ channel, date }) {
while (!isApiVersionFetched) {
await new Promise(resolve => setTimeout(resolve, 100)); // Wait for 100 milliseconds
}
return `https://px-epg.azureedge.net/airings/${apiVersion}/${date.format('YYYY-MM-DD')}/channel/${channel.site_id}?timezone=Europe%2FBrussels`;
}, },
request: { request: {
headers: { headers: {
@ -108,4 +128,27 @@ module.exports = {
} }
}) || [] }) || []
} }
} }
function fetchApiVersion() {
return new Promise(async (resolve, reject) => {
try {
const response = await axios.get('https://px-epg.azureedge.net/version', {
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);
reject(error);
}
});
}

View file

@ -1,11 +1,13 @@
const { parser, url, request } = require('./pickx.be.config.js') const { parser, url, request, fetchApiVersion, apiVersion } = require('./pickx.be.config.js')
const fs = require('fs') const fs = require('fs')
const path = require('path') const path = require('path')
const dayjs = require('dayjs') const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc') const utc = require('dayjs/plugin/utc')
dayjs.extend(utc) dayjs.extend(utc)
const date = dayjs.utc('2023-12-13').startOf('d') const date = dayjs.utc('2023-12-13').startOf('d')
const channel = { const channel = {
lang: 'fr', lang: 'fr',
@ -13,10 +15,12 @@ const channel = {
xmltv_id: 'Vedia.be' xmltv_id: 'Vedia.be'
} }
it('can generate valid url', () => { it('can generate valid url', async () => {
expect(url({channel, date})) await fetchApiVersion();
.toBe('https://px-epg.azureedge.net/airings/11702375189765v.4.2/2023-12-13/channel/UID0118?timezone=Europe%2FBrussels') const generatedUrl = await url({ channel, date });
}) const resolvedApiVersion = apiVersion();
expect(generatedUrl).toBe(`https://px-epg.azureedge.net/airings/${resolvedApiVersion}/2023-12-13/channel/UID0118?timezone=Europe%2FBrussels`);
});
it('can generate valid request headers', () => { it('can generate valid request headers', () => {
expect(request.headers).toMatchObject({ expect(request.headers).toMatchObject({