This commit is contained in:
himanshu8443
2025-06-16 22:26:38 +05:30
parent 3f3e12f5df
commit 2a4aa2a680
185 changed files with 4645 additions and 3952 deletions

View File

@@ -0,0 +1,12 @@
export const catalog = [
{
title: "Popular Movies",
filter: "/top/catalog/movie/top.json",
},
{
title: "Featured Movies",
filter: "/imdbRating/catalog/movie/imdbRating.json",
},
];
export const genres = [];

View File

@@ -1,15 +0,0 @@
import {ProviderType} from '../types';
import {guardahdCatalog, guardahdGenresList} from '../guardahd/guardahdCatalog';
import {allGetPost} from '../autoEmbed/allGetPost';
import {guardahdGetSearchPosts} from '../guardahd/guardahdGetPosts';
import {ridoGetInfo} from './ridoGetMeta';
import {ridoGetStream} from './ridoGetSream';
export const ridoMovies: ProviderType = {
catalog: guardahdCatalog,
genres: guardahdGenresList,
GetMetaData: ridoGetInfo,
GetHomePosts: allGetPost,
GetStream: ridoGetStream,
GetSearchPosts: guardahdGetSearchPosts,
};

View File

@@ -0,0 +1,87 @@
import { EpisodeLink, Info, Link, ProviderContext } from "../types";
export const getMeta = async function ({
link,
providerContext,
}: {
link: string;
providerContext: ProviderContext;
}): Promise<Info> {
try {
const { getBaseUrl, axios } = providerContext;
const res = await axios.get(link);
const data = res.data;
const meta = {
title: "",
synopsis: "",
image: "",
imdbId: data?.meta?.imdb_id || "",
type: data?.meta?.type || "movie",
};
const baseUrl = await getBaseUrl("ridomovies");
let slug = "";
try {
const res2 = await axios.get(
baseUrl + "/core/api/search?q=" + meta.imdbId
);
const data2 = res2.data;
slug = data2?.data?.items[0]?.fullSlug;
if (!slug || meta?.type === "series") {
return {
title: "",
synopsis: "",
image: "",
imdbId: data?.meta?.imdb_id || "",
type: meta?.type || "movie",
linkList: [],
};
}
} catch (err) {
return {
title: "",
synopsis: "",
image: "",
imdbId: meta?.imdbId || "",
type: meta?.type || "movie",
linkList: [],
};
}
const links: Link[] = [];
let directLinks: EpisodeLink[] = [];
let season = new Map();
if (meta.type === "series") {
data?.meta?.videos?.map((video: any) => {
if (video?.season <= 0) return;
if (!season.has(video?.season)) {
season.set(video?.season, []);
}
season.get(video?.season).push({
title: "Episode " + video?.episode,
link: "",
});
});
for (const [seasonNum, episodes] of season.entries()) {
links.push({
title: "Season " + seasonNum,
directLinks: episodes,
});
}
} else {
directLinks.push({ title: "Movie", link: link });
links.push({ title: "Movie", directLinks: directLinks });
}
return {
...meta,
linkList: links,
};
} catch (err) {
return {
title: "",
synopsis: "",
image: "",
imdbId: "",
type: "movie",
linkList: [],
};
}
};

View File

@@ -0,0 +1,85 @@
import { Post, ProviderContext } from "../types";
export const getPosts = async function ({
filter,
signal,
providerContext,
}: {
filter: string;
page: number;
providerValue: string;
signal: AbortSignal;
providerContext: ProviderContext;
}): Promise<Post[]> {
try {
const catalog: Post[] = [];
const url = "https://cinemeta-catalogs.strem.io" + filter;
console.log("allGetPostUrl", url);
const res = await providerContext.axios.get(url, {
headers: providerContext.commonHeaders,
signal,
});
const data = res.data;
data?.metas.map((result: any) => {
const title = result?.name;
const id = result?.imdb_id || result?.id;
const type = result?.type;
const image = result?.poster;
if (id) {
catalog.push({
title: title,
link: `https://v3-cinemeta.strem.io/meta/${type}/${id}.json`,
image: image,
});
}
});
console.log("catalog", catalog.length);
return catalog;
} catch (err) {
console.error("AutoEmbed error ", err);
return [];
}
};
export const getSearchPosts = async function ({
searchQuery,
page,
signal,
providerContext,
}: {
searchQuery: string;
page: number;
providerValue: string;
providerContext: ProviderContext;
signal: AbortSignal;
}): Promise<Post[]> {
try {
const { axios, commonHeaders: headers } = providerContext;
if (page > 1) {
return [];
}
const catalog: Post[] = [];
const url2 = `https://v3-cinemeta.strem.io/catalog/movie/top/search=${encodeURI(
searchQuery
)}.json`;
const res2 = await axios.get(url2, { headers, signal });
const data2 = res2.data;
data2?.metas.map((result: any) => {
const title = result?.name || "";
const id = result?.imdb_id || result?.id;
const image = result?.poster;
const type = result?.type;
if (id) {
catalog.push({
title: title,
link: `https://v3-cinemeta.strem.io/meta/${type}/${id}.json`,
image: image,
});
}
});
return catalog;
} catch (err) {
console.error("AutoEmbed error ", err);
return [];
}
};

View File

@@ -1,87 +0,0 @@
import {EpisodeLink, Info, Link, ProviderContext} from '../types';
export const ridoGetInfo = async function ({
link,
providerContext,
}: {
link: string;
providerContext: ProviderContext;
}): Promise<Info> {
try {
const {getBaseUrl, axios} = providerContext;
const res = await axios.get(link);
const data = res.data;
const meta = {
title: '',
synopsis: '',
image: '',
imdbId: data?.meta?.imdb_id || '',
type: data?.meta?.type || 'movie',
};
const baseUrl = await getBaseUrl('ridomovies');
let slug = '';
try {
const res2 = await axios.get(
baseUrl + '/core/api/search?q=' + meta.imdbId,
);
const data2 = res2.data;
slug = data2?.data?.items[0]?.fullSlug;
if (!slug || meta?.type === 'series') {
return {
title: '',
synopsis: '',
image: '',
imdbId: data?.meta?.imdb_id || '',
type: meta?.type || 'movie',
linkList: [],
};
}
} catch (err) {
return {
title: '',
synopsis: '',
image: '',
imdbId: meta?.imdbId || '',
type: meta?.type || 'movie',
linkList: [],
};
}
const links: Link[] = [];
let directLinks: EpisodeLink[] = [];
let season = new Map();
if (meta.type === 'series') {
data?.meta?.videos?.map((video: any) => {
if (video?.season <= 0) return;
if (!season.has(video?.season)) {
season.set(video?.season, []);
}
season.get(video?.season).push({
title: 'Episode ' + video?.episode,
link: '',
});
});
for (const [seasonNum, episodes] of season.entries()) {
links.push({
title: 'Season ' + seasonNum,
directLinks: episodes,
});
}
} else {
directLinks.push({title: 'Movie', link: link});
links.push({title: 'Movie', directLinks: directLinks});
}
return {
...meta,
linkList: links,
};
} catch (err) {
return {
title: '',
synopsis: '',
image: '',
imdbId: '',
type: 'movie',
linkList: [],
};
}
};

View File

@@ -1,6 +1,6 @@
import {ProviderContext, Stream} from '../types';
import { ProviderContext, Stream } from "../types";
export const ridoGetStream = async ({
export const getStream = async ({
link: data,
providerContext,
}: {
@@ -8,7 +8,7 @@ export const ridoGetStream = async ({
providerContext: ProviderContext;
}): Promise<Stream[]> => {
try {
const {cheerio, commonHeaders: headers, axios} = providerContext;
const { cheerio, commonHeaders: headers, axios } = providerContext;
const streamData = JSON.parse(data);
const streamLinks: Stream[] = [];
@@ -22,15 +22,15 @@ export const ridoGetStream = async ({
// const postId = res.data.split('\\"postid\\":\\"')[1].split('\\"')[0];
// console.log('rido post id', postId);
const url = streamData?.baseUrl + '/api/' + streamData?.slug;
console.log('rido url', url);
const url = streamData?.baseUrl + "/api/" + streamData?.slug;
console.log("rido url", url);
const res = await axios.get(url, {headers});
const res = await axios.get(url, { headers });
const iframe = res.data.data?.[0]?.url;
console.log('rido data', iframe);
console.log("rido data", iframe);
const iframeUrl = iframe.split('src="')[1].split('"')[0];
console.log('rido iframeUrl', iframeUrl);
console.log("rido iframeUrl", iframeUrl);
const iframeRes = await axios.get(iframeUrl, {
headers: {
...headers,
@@ -40,16 +40,16 @@ export const ridoGetStream = async ({
const $ = cheerio.load(iframeRes.data);
const script = $('script:contains("eval")').html();
if (!script) {
throw new Error('Unable to find script');
throw new Error("Unable to find script");
}
// console.log('rido script', script);
const srcUrl = unpackJavaScript(script.trim());
console.log('rido srcUrl', srcUrl);
console.log("rido srcUrl", srcUrl);
streamLinks.push({
link: srcUrl,
server: 'rido',
type: 'm3u8',
server: "rido",
type: "m3u8",
headers: {
Referer: iframeUrl,
},
@@ -57,19 +57,19 @@ export const ridoGetStream = async ({
return streamLinks;
} catch (e) {
console.log('rido get stream err', e);
console.log("rido get stream err", e);
return [];
}
};
function unpackJavaScript(packedCode: string): string {
const encodedString = packedCode.split('|aHR')[1].split('|')[0];
const base64Url = 'aHR' + encodedString;
const encodedString = packedCode.split("|aHR")[1].split("|")[0];
const base64Url = "aHR" + encodedString;
function addPadding(base64: string) {
return base64 + '='.repeat((4 - (base64.length % 4)) % 4);
return base64 + "=".repeat((4 - (base64.length % 4)) % 4);
}
console.log('rido base64Url', base64Url);
console.log("rido base64Url", base64Url);
const unpackedCode = atob(addPadding(base64Url));
return unpackedCode;
}