mirror of
https://github.com/movie-web/movie-web.git
synced 2025-01-28 05:25:31 +01:00
Merge branch 'dev' into dev
This commit is contained in:
commit
682017977b
@ -9,6 +9,8 @@ import "./providers/m4ufree";
|
|||||||
import "./providers/hdwatched";
|
import "./providers/hdwatched";
|
||||||
import "./providers/2embed";
|
import "./providers/2embed";
|
||||||
import "./providers/sflix";
|
import "./providers/sflix";
|
||||||
|
import "./providers/streamflix";
|
||||||
|
import "./providers/remotestream";
|
||||||
|
|
||||||
// embeds
|
// embeds
|
||||||
import "./embeds/streamm4u";
|
import "./embeds/streamm4u";
|
||||||
|
49
src/backend/providers/remotestream.ts
Normal file
49
src/backend/providers/remotestream.ts
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
import { mwFetch } from "@/backend/helpers/fetch";
|
||||||
|
import { registerProvider } from "@/backend/helpers/register";
|
||||||
|
import { MWStreamQuality, MWStreamType } from "@/backend/helpers/streams";
|
||||||
|
import { MWMediaType } from "@/backend/metadata/types";
|
||||||
|
|
||||||
|
const remotestreamBase = `https://fsa.remotestre.am`;
|
||||||
|
|
||||||
|
registerProvider({
|
||||||
|
id: "remotestream",
|
||||||
|
displayName: "Remote Stream",
|
||||||
|
disabled: false,
|
||||||
|
rank: 55,
|
||||||
|
type: [MWMediaType.MOVIE, MWMediaType.SERIES],
|
||||||
|
|
||||||
|
async scrape({ media, episode, progress }) {
|
||||||
|
if (!this.type.includes(media.meta.type)) {
|
||||||
|
throw new Error("Unsupported type");
|
||||||
|
}
|
||||||
|
|
||||||
|
progress(30);
|
||||||
|
const type = media.meta.type === MWMediaType.MOVIE ? "Movies" : "Shows";
|
||||||
|
let playlistLink = `${remotestreamBase}/${type}/${media.tmdbId}`;
|
||||||
|
|
||||||
|
if (media.meta.type === MWMediaType.SERIES) {
|
||||||
|
const seasonNumber = media.meta.seasonData.number;
|
||||||
|
const episodeNumber = media.meta.seasonData.episodes.find(
|
||||||
|
(e) => e.id === episode
|
||||||
|
)?.number;
|
||||||
|
|
||||||
|
playlistLink += `/${seasonNumber}/${episodeNumber}/${episodeNumber}.m3u8`;
|
||||||
|
} else {
|
||||||
|
playlistLink += `/${media.tmdbId}.m3u8`;
|
||||||
|
}
|
||||||
|
|
||||||
|
const streamRes = await mwFetch<Blob>(playlistLink);
|
||||||
|
if (streamRes.type !== "application/x-mpegurl")
|
||||||
|
throw new Error("No watchable item found");
|
||||||
|
progress(90);
|
||||||
|
return {
|
||||||
|
embeds: [],
|
||||||
|
stream: {
|
||||||
|
streamUrl: playlistLink,
|
||||||
|
quality: MWStreamQuality.QUNKNOWN,
|
||||||
|
type: MWStreamType.HLS,
|
||||||
|
captions: [],
|
||||||
|
},
|
||||||
|
};
|
||||||
|
},
|
||||||
|
});
|
70
src/backend/providers/streamflix.ts
Normal file
70
src/backend/providers/streamflix.ts
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
import { proxiedFetch } from "@/backend/helpers/fetch";
|
||||||
|
import { registerProvider } from "@/backend/helpers/register";
|
||||||
|
import {
|
||||||
|
MWCaptionType,
|
||||||
|
MWStreamQuality,
|
||||||
|
MWStreamType,
|
||||||
|
} from "@/backend/helpers/streams";
|
||||||
|
import { MWMediaType } from "@/backend/metadata/types";
|
||||||
|
|
||||||
|
const streamflixBase = "https://us-west2-compute-proxied.streamflix.one";
|
||||||
|
|
||||||
|
const qualityMap: Record<number, MWStreamQuality> = {
|
||||||
|
360: MWStreamQuality.Q360P,
|
||||||
|
540: MWStreamQuality.Q540P,
|
||||||
|
480: MWStreamQuality.Q480P,
|
||||||
|
720: MWStreamQuality.Q720P,
|
||||||
|
1080: MWStreamQuality.Q1080P,
|
||||||
|
};
|
||||||
|
|
||||||
|
registerProvider({
|
||||||
|
id: "streamflix",
|
||||||
|
displayName: "StreamFlix",
|
||||||
|
disabled: false,
|
||||||
|
rank: 69,
|
||||||
|
type: [MWMediaType.MOVIE, MWMediaType.SERIES],
|
||||||
|
|
||||||
|
async scrape({ media, episode, progress }) {
|
||||||
|
if (!this.type.includes(media.meta.type)) {
|
||||||
|
throw new Error("Unsupported type");
|
||||||
|
}
|
||||||
|
|
||||||
|
progress(30);
|
||||||
|
const type = media.meta.type === MWMediaType.MOVIE ? "movies" : "tv";
|
||||||
|
let seasonNumber: number | undefined;
|
||||||
|
let episodeNumber: number | undefined;
|
||||||
|
|
||||||
|
if (media.meta.type === MWMediaType.SERIES) {
|
||||||
|
// can't do type === "tv" here :(
|
||||||
|
seasonNumber = media.meta.seasonData.number;
|
||||||
|
episodeNumber = media.meta.seasonData.episodes.find(
|
||||||
|
(e: any) => e.id === episode
|
||||||
|
)?.number;
|
||||||
|
}
|
||||||
|
|
||||||
|
const streamRes = await proxiedFetch<any>(`/api/player/${type}`, {
|
||||||
|
baseURL: streamflixBase,
|
||||||
|
params: {
|
||||||
|
id: media.tmdbId,
|
||||||
|
s: seasonNumber,
|
||||||
|
e: episodeNumber,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
if (!streamRes.headers.Referer) throw new Error("No watchable item found");
|
||||||
|
progress(90);
|
||||||
|
return {
|
||||||
|
embeds: [],
|
||||||
|
stream: {
|
||||||
|
streamUrl: streamRes.sources[0].url,
|
||||||
|
quality: qualityMap[streamRes.sources[0].quality],
|
||||||
|
type: MWStreamType.HLS,
|
||||||
|
captions: streamRes.subtitles.map((s: Record<string, any>) => ({
|
||||||
|
needsProxy: true,
|
||||||
|
url: s.url,
|
||||||
|
type: MWCaptionType.VTT,
|
||||||
|
langIso: s.lang,
|
||||||
|
})),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
},
|
||||||
|
});
|
Loading…
x
Reference in New Issue
Block a user