mirror of
https://github.com/movie-web/providers.git
synced 2025-09-13 17:33:26 +00:00
Fix febbox qualities
This commit is contained in:
@@ -4,24 +4,36 @@ import { ScrapeContext } from '@/utils/context';
|
||||
|
||||
const allowedQualities = ['360', '480', '720', '1080', '4k'];
|
||||
|
||||
export async function getStreamQualities(ctx: ScrapeContext, apiQuery: object) {
|
||||
const mediaRes: { list: { path: string; quality: string; fid?: number }[] } = (await sendRequest(ctx, apiQuery)).data;
|
||||
interface FebboxQuality {
|
||||
path: string;
|
||||
real_quality: string;
|
||||
fid?: number;
|
||||
}
|
||||
|
||||
const qualityMap = mediaRes.list
|
||||
.filter((file) => allowedQualities.includes(file.quality.replace('p', '')))
|
||||
.map((file) => ({
|
||||
url: file.path,
|
||||
quality: file.quality.replace('p', ''),
|
||||
}));
|
||||
function mapToQuality(quality: FebboxQuality): FebboxQuality | null {
|
||||
console.log(quality);
|
||||
const q = quality.real_quality.replace('p', '').toLowerCase();
|
||||
if (!allowedQualities.includes(q)) return null;
|
||||
return {
|
||||
real_quality: q,
|
||||
path: quality.path,
|
||||
fid: quality.fid,
|
||||
};
|
||||
}
|
||||
|
||||
export async function getStreamQualities(ctx: ScrapeContext, apiQuery: object) {
|
||||
const mediaRes: { list: FebboxQuality[] } = (await sendRequest(ctx, apiQuery)).data;
|
||||
|
||||
const qualityMap = mediaRes.list.map((v) => mapToQuality(v)).filter((v): v is FebboxQuality => !!v);
|
||||
|
||||
const qualities: Record<string, StreamFile> = {};
|
||||
|
||||
allowedQualities.forEach((quality) => {
|
||||
const foundQuality = qualityMap.find((q) => q.quality === quality);
|
||||
if (foundQuality && foundQuality.url) {
|
||||
const foundQuality = qualityMap.find((q) => q.real_quality === quality);
|
||||
if (foundQuality && foundQuality.path) {
|
||||
qualities[quality] = {
|
||||
type: 'mp4',
|
||||
url: foundQuality.url,
|
||||
url: foundQuality.path,
|
||||
};
|
||||
}
|
||||
});
|
||||
|
Reference in New Issue
Block a user