mirror of
https://github.com/vega-org/vega-providers.git
synced 2026-04-17 23:51:44 +00:00
init
This commit is contained in:
101
providers/vega/catalog.ts
Normal file
101
providers/vega/catalog.ts
Normal file
@@ -0,0 +1,101 @@
|
||||
export const homeList = [
|
||||
{
|
||||
title: 'New',
|
||||
filter: '',
|
||||
},
|
||||
{
|
||||
title: 'Netflix',
|
||||
filter: 'web-series/netflix',
|
||||
},
|
||||
{
|
||||
title: 'Amazon Prime',
|
||||
filter: 'web-series/amazon-prime-video',
|
||||
},
|
||||
{
|
||||
title: '4K Movies',
|
||||
filter: 'movies-by-quality/2160p',
|
||||
},
|
||||
];
|
||||
|
||||
export const genresList = [
|
||||
{
|
||||
title: 'Action',
|
||||
filter: 'category/movies-by-genres/action',
|
||||
},
|
||||
{
|
||||
title: 'Adventure',
|
||||
filter: 'category/movies-by-genres/adventure',
|
||||
},
|
||||
{
|
||||
title: 'Animation',
|
||||
filter: 'category/movies-by-genres/animation',
|
||||
},
|
||||
{
|
||||
title: 'Biography',
|
||||
filter: 'category/movies-by-genres/biography',
|
||||
},
|
||||
{
|
||||
title: 'Comedy',
|
||||
filter: 'category/movies-by-genres/comedy',
|
||||
},
|
||||
{
|
||||
title: 'Crime',
|
||||
filter: 'category/movies-by-genres/crime',
|
||||
},
|
||||
{
|
||||
title: 'Documentary',
|
||||
filter: 'category/movies-by-genres/documentary',
|
||||
},
|
||||
{
|
||||
title: 'Drama',
|
||||
filter: 'category/movies-by-genres/drama',
|
||||
},
|
||||
{
|
||||
title: 'Family',
|
||||
filter: 'category/movies-by-genres/family',
|
||||
},
|
||||
{
|
||||
title: 'Fantasy',
|
||||
filter: 'category/movies-by-genres/fantasy',
|
||||
},
|
||||
{
|
||||
title: 'History',
|
||||
filter: 'category/movies-by-genres/history',
|
||||
},
|
||||
{
|
||||
title: 'Horror',
|
||||
filter: 'category/movies-by-genres/horror',
|
||||
},
|
||||
{
|
||||
title: 'Music',
|
||||
filter: 'category/movies-by-genres/music',
|
||||
},
|
||||
{
|
||||
title: 'Mystery',
|
||||
filter: 'category/movies-by-genres/mystery',
|
||||
},
|
||||
{
|
||||
title: 'Romance',
|
||||
filter: 'category/movies-by-genres/romance',
|
||||
},
|
||||
{
|
||||
title: 'Sci-Fi',
|
||||
filter: 'category/movies-by-genres/sci-fi',
|
||||
},
|
||||
{
|
||||
title: 'Sport',
|
||||
filter: 'category/movies-by-genres/sport',
|
||||
},
|
||||
{
|
||||
title: 'Thriller',
|
||||
filter: 'category/movies-by-genres/thriller',
|
||||
},
|
||||
{
|
||||
title: 'War',
|
||||
filter: 'category/movies-by-genres/war',
|
||||
},
|
||||
{
|
||||
title: 'Western',
|
||||
filter: 'category/movies-by-genres/western',
|
||||
},
|
||||
];
|
||||
39
providers/vega/getEpisodesLink.ts
Normal file
39
providers/vega/getEpisodesLink.ts
Normal file
@@ -0,0 +1,39 @@
|
||||
import {EpisodeLink, ProviderContext} from '../types';
|
||||
|
||||
export const vegaGetEpisodeLinks = async function ({
|
||||
url,
|
||||
providerContext,
|
||||
}: {
|
||||
url: string;
|
||||
providerContext: ProviderContext;
|
||||
}): Promise<EpisodeLink[]> {
|
||||
const {axios, cheerio, commonHeaders: headers} = providerContext;
|
||||
console.log('getEpisodeLinks', url);
|
||||
try {
|
||||
const res = await axios.get(url, {headers});
|
||||
const $ = cheerio.load(res.data);
|
||||
const container = $('.entry-content,.entry-inner');
|
||||
$('.unili-content,.code-block-1').remove();
|
||||
const episodes: EpisodeLink[] = [];
|
||||
container.find('h4').each((index, element) => {
|
||||
const el = $(element);
|
||||
const title = el.text().replaceAll('-', '').replaceAll(':', '');
|
||||
const link = el
|
||||
.next('p')
|
||||
.find(
|
||||
'.btn-outline[style="background:linear-gradient(135deg,#ed0b0b,#f2d152); color: white;"]',
|
||||
)
|
||||
.parent()
|
||||
.attr('href');
|
||||
if (title && link) {
|
||||
episodes.push({title, link});
|
||||
}
|
||||
});
|
||||
// console.log(episodes);
|
||||
return episodes;
|
||||
} catch (err) {
|
||||
console.log('getEpisodeLinks error: ');
|
||||
// console.error(err);
|
||||
return [];
|
||||
}
|
||||
};
|
||||
157
providers/vega/getInfo.ts
Normal file
157
providers/vega/getInfo.ts
Normal file
@@ -0,0 +1,157 @@
|
||||
import {Info, Link, ProviderContext} from '../types';
|
||||
|
||||
const headers = {
|
||||
Accept:
|
||||
'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
||||
'Cache-Control': 'no-store',
|
||||
'Accept-Language': 'en-US,en;q=0.9',
|
||||
DNT: '1',
|
||||
'sec-ch-ua':
|
||||
'"Not_A Brand";v="8", "Chromium";v="120", "Microsoft Edge";v="120"',
|
||||
'sec-ch-ua-mobile': '?0',
|
||||
'sec-ch-ua-platform': '"Windows"',
|
||||
'Sec-Fetch-Dest': 'document',
|
||||
'Sec-Fetch-Mode': 'navigate',
|
||||
'Sec-Fetch-Site': 'none',
|
||||
'Sec-Fetch-User': '?1',
|
||||
Cookie:
|
||||
'_lscache_vary=62abf8b96599676eb8ec211cffaeb8ff; ext_name=ojplmecpdpgccookcobabopnaifgidhf; cf_clearance=n4Y1XTKZ5TfIMBNQuAXzerwKpx0U35KoOm3imfT0GpU-1732097818-1.2.1.1-ZeAnEu.8D9TSZHYDoj7vwo1A1rpdKl304ZpaBn_QbAQOr211JFAb7.JRQU3EL2eIy1Dfl8HhYvH7_259.22lUz8gbchHcQ8hvfuQXMtFMCbqDBLzjNUZa9stuk.39l28IcPhH9Z2szsf3SGtNI1sAfo66Djt7sOReLK3lHw9UkJp7BdGqt6a2X9qAc8EsAI3lE480Tmt0fkHv14Oc30LSbPB_WwFmiqAki2W.Gv9hV7TN_QBFESleTDlXd.6KGflfd4.KwWF7rpSRo_cgoc9ALLLIafpxHVbe7_g5r7zvpml_Pj8fEL75fw.1GBuy16bciHBuB8s_kahuJYUnhtQFFgfTQl8_Gn6KeovBWx.PJ7nFv5sklHUfAyBVq3t30xKe8ZDydsQ_G.yipfj_In5GmmWcXGb6E4.bioDOwW_sKLtxwdTQt7Nu.RkILX_mKvXNpyLqflIVj8G7X5E8I.unw',
|
||||
'Upgrade-Insecure-Requests': '1',
|
||||
'User-Agent':
|
||||
'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36 Edg/131.0.0.0',
|
||||
};
|
||||
|
||||
export const vegaGetInfo = async ({
|
||||
link,
|
||||
providerContext,
|
||||
}: {
|
||||
link: string;
|
||||
providerContext: ProviderContext;
|
||||
}): Promise<Info> => {
|
||||
try {
|
||||
const {axios, cheerio} = providerContext;
|
||||
const url = link;
|
||||
console.log('url', url);
|
||||
const baseUrl = url.split('/').slice(0, 3).join('/');
|
||||
const response = await axios.get(url, {
|
||||
headers: {
|
||||
...headers,
|
||||
Referer: baseUrl,
|
||||
},
|
||||
});
|
||||
const $ = cheerio.load(response.data);
|
||||
const infoContainer = $('.entry-content,.post-inner');
|
||||
const heading = infoContainer?.find('h3');
|
||||
const imdbId =
|
||||
heading?.next('p')?.find('a')?.[0]?.attribs?.href?.match(/tt\d+/g)?.[0] ||
|
||||
infoContainer.text().match(/tt\d+/g)?.[0] ||
|
||||
'';
|
||||
// console.log(imdbId)
|
||||
|
||||
const type = heading?.next('p')?.text()?.includes('Series Name')
|
||||
? 'series'
|
||||
: 'movie';
|
||||
// console.log(type);
|
||||
// title
|
||||
const titleRegex = /Name: (.+)/;
|
||||
const title = heading?.next('p')?.text()?.match(titleRegex)?.[1] || '';
|
||||
// console.log(title);
|
||||
|
||||
// synopsis
|
||||
const synopsisNode = infoContainer?.find('p')?.next('h3,h4')?.next('p')?.[0]
|
||||
?.children?.[0];
|
||||
const synopsis =
|
||||
synopsisNode && 'data' in synopsisNode ? synopsisNode.data : '';
|
||||
// console.log(synopsis);
|
||||
|
||||
// image
|
||||
let image =
|
||||
infoContainer?.find('img[data-lazy-src]')?.attr('data-lazy-src') || '';
|
||||
if (image.startsWith('//')) {
|
||||
image = 'https:' + image;
|
||||
}
|
||||
// console.log(image);
|
||||
|
||||
// console.log({title, synopsis, image, imdbId, type});
|
||||
/// Links
|
||||
const hr = infoContainer?.first()?.find('hr');
|
||||
const list = hr?.nextUntil('hr');
|
||||
const links: Link[] = [];
|
||||
list.each((index, element: any) => {
|
||||
element = $(element);
|
||||
// title
|
||||
const title = element?.text() || '';
|
||||
|
||||
const quality = element?.text().match(/\d+p\b/)?.[0] || '';
|
||||
// console.log(title);
|
||||
// movieLinks
|
||||
const movieLinks = element
|
||||
?.next()
|
||||
.find('.dwd-button')
|
||||
.text()
|
||||
.toLowerCase()
|
||||
.includes('download')
|
||||
? element?.next().find('.dwd-button')?.parent()?.attr('href')
|
||||
: '';
|
||||
|
||||
// episode links
|
||||
const vcloudLinks = element
|
||||
?.next()
|
||||
.find(
|
||||
".btn-outline[style='background:linear-gradient(135deg,#ed0b0b,#f2d152); color: white;'],.btn-outline[style='background:linear-gradient(135deg,#ed0b0b,#f2d152); color: #fdf8f2;']",
|
||||
)
|
||||
?.parent()
|
||||
?.attr('href');
|
||||
console.log(title);
|
||||
const episodesLink =
|
||||
(vcloudLinks
|
||||
? vcloudLinks
|
||||
: element
|
||||
?.next()
|
||||
.find('.dwd-button')
|
||||
.text()
|
||||
.toLowerCase()
|
||||
.includes('episode')
|
||||
? element?.next().find('.dwd-button')?.parent()?.attr('href')
|
||||
: '') ||
|
||||
element
|
||||
?.next()
|
||||
.find(
|
||||
".btn-outline[style='background:linear-gradient(135deg,#0ebac3,#09d261); color: white;']",
|
||||
)
|
||||
?.parent()
|
||||
?.attr('href');
|
||||
if (movieLinks || episodesLink) {
|
||||
links.push({
|
||||
title,
|
||||
directLinks: movieLinks
|
||||
? [{title: 'Movie', link: movieLinks, type: 'movie'}]
|
||||
: [],
|
||||
episodesLink,
|
||||
quality,
|
||||
});
|
||||
}
|
||||
});
|
||||
// console.log(links);
|
||||
return {
|
||||
title,
|
||||
synopsis,
|
||||
image,
|
||||
imdbId,
|
||||
type,
|
||||
linkList: links,
|
||||
};
|
||||
} catch (error) {
|
||||
console.log('getInfo error');
|
||||
console.error(error);
|
||||
// ToastAndroid.show('No response', ToastAndroid.SHORT);
|
||||
return {
|
||||
title: '',
|
||||
synopsis: '',
|
||||
image: '',
|
||||
imdbId: '',
|
||||
type: '',
|
||||
linkList: [],
|
||||
};
|
||||
}
|
||||
};
|
||||
121
providers/vega/getPosts.ts
Normal file
121
providers/vega/getPosts.ts
Normal file
@@ -0,0 +1,121 @@
|
||||
import {Post, ProviderContext} from '../types';
|
||||
|
||||
const headers = {
|
||||
Accept:
|
||||
'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
||||
'Cache-Control': 'no-store',
|
||||
'Accept-Language': 'en-US,en;q=0.9',
|
||||
DNT: '1',
|
||||
'sec-ch-ua':
|
||||
'"Not_A Brand";v="8", "Chromium";v="120", "Microsoft Edge";v="120"',
|
||||
'sec-ch-ua-mobile': '?0',
|
||||
'sec-ch-ua-platform': '"Windows"',
|
||||
'Sec-Fetch-Dest': 'document',
|
||||
'Sec-Fetch-Mode': 'navigate',
|
||||
'Sec-Fetch-Site': 'none',
|
||||
'Sec-Fetch-User': '?1',
|
||||
Cookie:
|
||||
'_lscache_vary=62abf8b96599676eb8ec211cffaeb8ff; ext_name=ojplmecpdpgccookcobabopnaifgidhf; cf_clearance=n4Y1XTKZ5TfIMBNQuAXzerwKpx0U35KoOm3imfT0GpU-1732097818-1.2.1.1-ZeAnEu.8D9TSZHYDoj7vwo1A1rpdKl304ZpaBn_QbAQOr211JFAb7.JRQU3EL2eIy1Dfl8HhYvH7_259.22lUz8gbchHcQ8hvfuQXMtFMCbqDBLzjNUZa9stuk.39l28IcPhH9Z2szsf3SGtNI1sAfo66Djt7sOReLK3lHw9UkJp7BdGqt6a2X9qAc8EsAI3lE480Tmt0fkHv14Oc30LSbPB_WwFmiqAki2W.Gv9hV7TN_QBFESleTDlXd.6KGflfd4.KwWF7rpSRo_cgoc9ALLLIafpxHVbe7_g5r7zvpml_Pj8fEL75fw.1GBuy16bciHBuB8s_kahuJYUnhtQFFgfTQl8_Gn6KeovBWx.PJ7nFv5sklHUfAyBVq3t30xKe8ZDydsQ_G.yipfj_In5GmmWcXGb6E4.bioDOwW_sKLtxwdTQt7Nu.RkILX_mKvXNpyLqflIVj8G7X5E8I.unw',
|
||||
'Upgrade-Insecure-Requests': '1',
|
||||
'User-Agent':
|
||||
'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36 Edg/131.0.0.0',
|
||||
};
|
||||
|
||||
export const vegaGetPosts = async ({
|
||||
filter,
|
||||
page,
|
||||
providerValue,
|
||||
signal,
|
||||
providerContext,
|
||||
}: {
|
||||
filter: string;
|
||||
page: number;
|
||||
providerValue: string;
|
||||
signal: AbortSignal;
|
||||
providerContext: ProviderContext;
|
||||
}): Promise<Post[]> => {
|
||||
const {getBaseUrl, axios, cheerio} = providerContext;
|
||||
const baseUrl = await getBaseUrl('Vega');
|
||||
|
||||
console.log('vegaGetPosts baseUrl:', providerValue, baseUrl);
|
||||
const url = `${baseUrl}/${filter}/page/${page}/`;
|
||||
console.log('vegaGetPosts url:', url);
|
||||
return posts(baseUrl, url, signal, headers, axios, cheerio);
|
||||
};
|
||||
|
||||
export const vegaGetPostsSearch = async ({
|
||||
searchQuery,
|
||||
page,
|
||||
providerValue,
|
||||
signal,
|
||||
providerContext,
|
||||
}: {
|
||||
searchQuery: string;
|
||||
page: number;
|
||||
providerValue: string;
|
||||
signal: AbortSignal;
|
||||
providerContext: ProviderContext;
|
||||
}): Promise<Post[]> => {
|
||||
const {getBaseUrl, axios, commonHeaders, cheerio} = providerContext;
|
||||
const baseUrl = await getBaseUrl('Vega');
|
||||
|
||||
console.log('vegaGetPosts baseUrl:', providerValue, baseUrl);
|
||||
const url = `${baseUrl}/page/${page}/?s=${searchQuery}`;
|
||||
console.log('vegaGetPosts url:', url);
|
||||
|
||||
return posts(baseUrl, url, signal, commonHeaders, axios, cheerio);
|
||||
};
|
||||
|
||||
async function posts(
|
||||
baseUrl: string,
|
||||
url: string,
|
||||
signal: AbortSignal,
|
||||
headers: Record<string, string> = {},
|
||||
axios: ProviderContext['axios'],
|
||||
cheerio: ProviderContext['cheerio'],
|
||||
): Promise<Post[]> {
|
||||
try {
|
||||
const urlRes = await axios.get(url, {
|
||||
headers: {
|
||||
...headers,
|
||||
Referer: baseUrl,
|
||||
},
|
||||
signal,
|
||||
});
|
||||
const $ = cheerio.load(urlRes.data);
|
||||
const posts: Post[] = [];
|
||||
$('.blog-items,.post-list')
|
||||
?.children('article')
|
||||
?.each((index, element) => {
|
||||
const post = {
|
||||
title: (
|
||||
$(element)
|
||||
?.find('a')
|
||||
?.attr('title')
|
||||
?.replace('Download', '')
|
||||
?.match(/^(.*?)\s*\((\d{4})\)|^(.*?)\s*\((Season \d+)\)/)?.[0] ||
|
||||
$(element)?.find('a')?.attr('title')?.replace('Download', '') ||
|
||||
$(element)?.find('.post-title').text()?.replace('Download', '') ||
|
||||
''
|
||||
).trim(),
|
||||
|
||||
link: $(element)?.find('a')?.attr('href') || '',
|
||||
image:
|
||||
$(element).find('a').find('img').attr('data-lazy-src') ||
|
||||
$(element).find('a').find('img').attr('data-src') ||
|
||||
$(element).find('a').find('img').attr('src') ||
|
||||
'',
|
||||
};
|
||||
if (post.image.startsWith('//')) {
|
||||
post.image = 'https:' + post.image;
|
||||
}
|
||||
posts.push(post);
|
||||
});
|
||||
|
||||
// console.log(posts);
|
||||
return posts;
|
||||
} catch (error) {
|
||||
console.error('vegaGetPosts error:', error);
|
||||
return [];
|
||||
}
|
||||
}
|
||||
117
providers/vega/getStream.ts
Normal file
117
providers/vega/getStream.ts
Normal file
@@ -0,0 +1,117 @@
|
||||
import {ProviderContext, Stream} from '../types';
|
||||
|
||||
const headers = {
|
||||
Accept:
|
||||
'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
||||
'Cache-Control': 'no-store',
|
||||
'Accept-Language': 'en-US,en;q=0.9',
|
||||
DNT: '1',
|
||||
'sec-ch-ua':
|
||||
'"Not_A Brand";v="8", "Chromium";v="120", "Microsoft Edge";v="120"',
|
||||
'sec-ch-ua-mobile': '?0',
|
||||
'sec-ch-ua-platform': '"Windows"',
|
||||
'Sec-Fetch-Dest': 'document',
|
||||
'Sec-Fetch-Mode': 'navigate',
|
||||
'Sec-Fetch-Site': 'none',
|
||||
'Sec-Fetch-User': '?1',
|
||||
Cookie:
|
||||
'_lscache_vary=62abf8b96599676eb8ec211cffaeb8ff; ext_name=ojplmecpdpgccookcobabopnaifgidhf; cf_clearance=n4Y1XTKZ5TfIMBNQuAXzerwKpx0U35KoOm3imfT0GpU-1732097818-1.2.1.1-ZeAnEu.8D9TSZHYDoj7vwo1A1rpdKl304ZpaBn_QbAQOr211JFAb7.JRQU3EL2eIy1Dfl8HhYvH7_259.22lUz8gbchHcQ8hvfuQXMtFMCbqDBLzjNUZa9stuk.39l28IcPhH9Z2szsf3SGtNI1sAfo66Djt7sOReLK3lHw9UkJp7BdGqt6a2X9qAc8EsAI3lE480Tmt0fkHv14Oc30LSbPB_WwFmiqAki2W.Gv9hV7TN_QBFESleTDlXd.6KGflfd4.KwWF7rpSRo_cgoc9ALLLIafpxHVbe7_g5r7zvpml_Pj8fEL75fw.1GBuy16bciHBuB8s_kahuJYUnhtQFFgfTQl8_Gn6KeovBWx.PJ7nFv5sklHUfAyBVq3t30xKe8ZDydsQ_G.yipfj_In5GmmWcXGb6E4.bioDOwW_sKLtxwdTQt7Nu.RkILX_mKvXNpyLqflIVj8G7X5E8I.unw',
|
||||
'Upgrade-Insecure-Requests': '1',
|
||||
'User-Agent':
|
||||
'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36 Edg/131.0.0.0',
|
||||
};
|
||||
|
||||
export async function vegaGetStream({
|
||||
link,
|
||||
type,
|
||||
signal,
|
||||
providerContext,
|
||||
}: {
|
||||
link: string;
|
||||
type: string;
|
||||
signal: AbortSignal;
|
||||
providerContext: ProviderContext;
|
||||
}) {
|
||||
const {axios, cheerio, extractors} = providerContext;
|
||||
const {hubcloudExtracter} = extractors;
|
||||
try {
|
||||
const streamLinks: Stream[] = [];
|
||||
console.log('dotlink', link);
|
||||
if (type === 'movie') {
|
||||
// vlink
|
||||
const dotlinkRes = await axios(`${link}`, {headers});
|
||||
const dotlinkText = dotlinkRes.data;
|
||||
// console.log('dotlinkText', dotlinkText);
|
||||
const vlink = dotlinkText.match(/<a\s+href="([^"]*cloud\.[^"]*)"/i) || [];
|
||||
// console.log('vLink', vlink[1]);
|
||||
link = vlink[1];
|
||||
|
||||
// filepress link
|
||||
try {
|
||||
const $ = cheerio.load(dotlinkText);
|
||||
const filepressLink = $(
|
||||
'.btn.btn-sm.btn-outline[style="background:linear-gradient(135deg,rgb(252,185,0) 0%,rgb(0,0,0)); color: #fdf8f2;"]',
|
||||
)
|
||||
.parent()
|
||||
.attr('href');
|
||||
// console.log('filepressLink', filepressLink);
|
||||
const filepressID = filepressLink?.split('/').pop();
|
||||
const filepressBaseUrl = filepressLink
|
||||
?.split('/')
|
||||
.slice(0, -2)
|
||||
.join('/');
|
||||
// console.log('filepressID', filepressID);
|
||||
// console.log('filepressBaseUrl', filepressBaseUrl);
|
||||
const filepressTokenRes = await axios.post(
|
||||
filepressBaseUrl + '/api/file/downlaod/',
|
||||
{
|
||||
id: filepressID,
|
||||
method: 'indexDownlaod',
|
||||
captchaValue: null,
|
||||
},
|
||||
{
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
Referer: filepressBaseUrl,
|
||||
},
|
||||
},
|
||||
);
|
||||
// console.log('filepressTokenRes', filepressTokenRes.data);
|
||||
if (filepressTokenRes.data?.status) {
|
||||
const filepressToken = filepressTokenRes.data?.data;
|
||||
const filepressStreamLink = await axios.post(
|
||||
filepressBaseUrl + '/api/file/downlaod2/',
|
||||
{
|
||||
id: filepressToken,
|
||||
method: 'indexDownlaod',
|
||||
captchaValue: null,
|
||||
},
|
||||
{
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
Referer: filepressBaseUrl,
|
||||
},
|
||||
},
|
||||
);
|
||||
// console.log('filepressStreamLink', filepressStreamLink.data);
|
||||
streamLinks.push({
|
||||
server: 'filepress',
|
||||
link: filepressStreamLink.data?.data?.[0],
|
||||
type: 'mkv',
|
||||
});
|
||||
}
|
||||
} catch (error) {
|
||||
console.log('filepress error: ');
|
||||
// console.error(error);
|
||||
}
|
||||
}
|
||||
|
||||
return await hubcloudExtracter(link, signal);
|
||||
} catch (error: any) {
|
||||
console.log('getStream error: ', error);
|
||||
if (error.message.includes('Aborted')) {
|
||||
} else {
|
||||
}
|
||||
return [];
|
||||
}
|
||||
}
|
||||
17
providers/vega/index.ts
Normal file
17
providers/vega/index.ts
Normal file
@@ -0,0 +1,17 @@
|
||||
import {vegaGetInfo} from './getInfo';
|
||||
import {vegaGetStream} from './getStream';
|
||||
import {vegaGetEpisodeLinks} from './getEpisodesLink';
|
||||
import {vegaGetPosts, vegaGetPostsSearch} from './getPosts';
|
||||
import {homeList, genresList} from './catalog';
|
||||
import {ProviderType} from '../types';
|
||||
|
||||
export const vegaMovies: ProviderType = {
|
||||
catalog: homeList,
|
||||
genres: genresList,
|
||||
GetMetaData: vegaGetInfo,
|
||||
GetHomePosts: vegaGetPosts,
|
||||
GetStream: vegaGetStream,
|
||||
nonStreamableServer: ['filepress', 'hubcloud', 'HubCdn'],
|
||||
GetEpisodeLinks: vegaGetEpisodeLinks,
|
||||
GetSearchPosts: vegaGetPostsSearch,
|
||||
};
|
||||
Reference in New Issue
Block a user