Merge pull request #134 from movie-web/dev

Version 2.2.7: Fixing showbox once again
This commit is contained in:
William Oldham 2024-03-31 23:28:53 +01:00 committed by GitHub
commit 0e941923d5
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 11 additions and 8 deletions

View File

@ -2,6 +2,9 @@
title: 'Changelog'
---
# Version 2.2.7
- Fix showbox
# Version 2.2.6
- Fix febbox
- Validate if a stream is actually playable. Streams that are not responding are no longer returned.

View File

@ -1,6 +1,6 @@
{
"name": "@movie-web/providers",
"version": "2.2.6",
"version": "2.2.7",
"description": "Package that contains all the providers of movie-web",
"type": "module",
"main": "./lib/index.umd.js",

View File

@ -22,26 +22,26 @@ export async function validatePlayableStream(
stream: Stream,
ops: ProviderRunnerOptions | IndividualEmbedRunnerOptions,
): Promise<Stream | null> {
const fetcher = stream.flags.length === 1 && stream.flags.includes('cors-allowed') ? ops.fetcher : ops.proxiedFetcher;
if (stream.type === 'hls') {
const headResult = await fetcher.full(stream.playlist, {
method: 'HEAD',
const result = await ops.proxiedFetcher.full(stream.playlist, {
method: 'GET',
headers: {
...stream.preferredHeaders,
...stream.headers,
},
});
if (headResult.statusCode !== 200) return null;
if (result.statusCode < 200 || result.statusCode >= 400) return null;
return stream;
}
if (stream.type === 'file') {
const validQualitiesResults = await Promise.all(
Object.values(stream.qualities).map((quality) =>
fetcher.full(quality.url, {
method: 'HEAD',
ops.proxiedFetcher.full(quality.url, {
method: 'GET',
headers: {
...stream.preferredHeaders,
...stream.headers,
Range: 'bytes=0-1',
},
}),
),
@ -49,7 +49,7 @@ export async function validatePlayableStream(
// remove invalid qualities from the stream
const validQualities = stream.qualities;
Object.keys(stream.qualities).forEach((quality, index) => {
if (validQualitiesResults[index].statusCode !== 200) {
if (validQualitiesResults[index].statusCode < 200 || validQualitiesResults[index].statusCode >= 400) {
delete validQualities[quality as keyof typeof stream.qualities];
}
});