mirror of
https://github.com/iptv-org/epg.git
synced 2025-05-09 16:40:07 -04:00
Merge pull request #2323 from Sicilykill/issue_2322
Resolves issue #2322
This commit is contained in:
commit
eee14ca3f6
2 changed files with 56 additions and 9 deletions
|
@ -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);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
|
@ -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({
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue