mirror of
https://github.com/vega-org/vega-providers.git
synced 2026-04-17 15:41:45 +00:00
renaming
This commit is contained in:
12
providers/ridoMovies/catalog.ts
Normal file
12
providers/ridoMovies/catalog.ts
Normal 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 = [];
|
||||
@@ -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,
|
||||
};
|
||||
87
providers/ridoMovies/meta.ts
Normal file
87
providers/ridoMovies/meta.ts
Normal 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: [],
|
||||
};
|
||||
}
|
||||
};
|
||||
85
providers/ridoMovies/posts.ts
Normal file
85
providers/ridoMovies/posts.ts
Normal 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 [];
|
||||
}
|
||||
};
|
||||
@@ -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: [],
|
||||
};
|
||||
}
|
||||
};
|
||||
@@ -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;
|
||||
}
|
||||
Reference in New Issue
Block a user