This commit is contained in:
himanshu8443
2025-06-15 21:29:40 +05:30
commit 3f3e12f5df
299 changed files with 18729 additions and 0 deletions

View File

@@ -0,0 +1,27 @@
export const world4uCatalogList = [
{
title: 'Latest',
filter: '',
},
{
title: 'Hollywood',
filter: '/category/hollywood',
},
{
title: 'Bollywood',
filter: '/category/bollywood',
},
{
title: 'Web Series',
filter: '/category/web-series',
},
];
export const world4uGenresList = [
{title: 'South', filter: '/category/hindi-dubbed-movies/south-indian'},
{title: 'Punjabi', filter: '/category/punjabi'},
{title: 'Marathi', filter: '/category/bollywood/marathi'},
{title: 'Gujarati', filter: '/category/gujarati'},
{title: 'Bollywood', filter: '/category/bollywood'},
{title: 'Hollywood', filter: '/category/hollywood'},
];

View File

@@ -0,0 +1,16 @@
import {world4uCatalogList, world4uGenresList} from './catalog';
import {world4uGetEpisodeLinks} from './world4uGetEpisodeLinks';
import {world4uGetInfo} from './world4uGetInfo';
import {world4uGetPosts, world4uGetPostsSearch} from './world4uGetPosts';
import {world4uGetStream} from './world4uGetStream';
import {ProviderType} from '../types';
export const world4u: ProviderType = {
catalog: world4uCatalogList,
genres: world4uGenresList,
GetMetaData: world4uGetInfo,
GetHomePosts: world4uGetPosts,
GetStream: world4uGetStream,
GetEpisodeLinks: world4uGetEpisodeLinks,
GetSearchPosts: world4uGetPostsSearch,
};

View File

@@ -0,0 +1,42 @@
import {EpisodeLink, ProviderContext} from '../types';
export const world4uGetEpisodeLinks = async function ({
url,
providerContext,
}: {
url: string;
providerContext: ProviderContext;
}): Promise<EpisodeLink[]> {
const {axios, cheerio} = providerContext;
try {
const res = await axios.get(url);
const html = res.data;
let $ = cheerio.load(html);
const episodeLinks: EpisodeLink[] = [];
$(
'strong:contains("Episode"),strong:contains("1080"),strong:contains("720"),strong:contains("480")',
).map((i, element) => {
const title = $(element).text();
const link = $(element)
.parent()
.parent()
.next('h4')
.find('a')
.attr('href');
if (link && !title.includes('zip')) {
episodeLinks.push({
title: title,
link,
});
}
});
return episodeLinks;
} catch (err) {
return [
{
title: 'Server 1',
link: url,
},
];
}
};

View File

@@ -0,0 +1,81 @@
import {Info, Link, ProviderContext} from '../types';
export const world4uGetInfo = async function ({
link,
providerContext,
}: {
link: string;
providerContext: ProviderContext;
}): Promise<Info> {
try {
const {axios, cheerio} = providerContext;
const url = link;
const res = await axios.get(url);
const data = res.data;
const $ = cheerio.load(data);
const type = $('.entry-content')
.text()
.toLocaleLowerCase()
.includes('movie name')
? 'movie'
: 'series';
const imdbId = $('.imdb_left').find('a').attr('href')?.split('/')[4] || '';
const title = $('.entry-content')
.find('strong:contains("Name")')
.children()
.remove()
.end()
.text()
.replace(':', '');
const synopsis = $('.entry-content')
.find('p:contains("Synopsis"),p:contains("Plot"),p:contains("Story")')
.children()
.remove()
.end()
.text();
const image =
$('.wp-caption').find('img').attr('data-src') ||
$('.entry-content').find('img').attr('data-src') ||
'';
const links: Link[] = [];
$('.my-button').map((i, element) => {
const title = $(element).parent().parent().prev().text();
const episodesLink = $(element).attr('href');
const quality = title.match(/\b(480p|720p|1080p|2160p)\b/i)?.[0] || '';
if (episodesLink && title) {
links.push({
title,
episodesLink: type === 'series' ? episodesLink : '',
directLinks:
type === 'movie'
? [
{
link: episodesLink,
title,
type: 'movie',
},
]
: [],
quality,
});
}
});
return {
title,
synopsis,
image,
imdbId,
type,
linkList: links,
};
} catch (err) {
return {
title: '',
synopsis: '',
image: '',
imdbId: '',
type: 'movie',
linkList: [],
};
}
};

View File

@@ -0,0 +1,77 @@
import {Post, ProviderContext} from '../types';
export const world4uGetPosts = async function ({
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('w4u');
const url = `${baseUrl + filter}/page/${page}/`;
return posts({url, signal, axios, cheerio});
};
export const world4uGetPostsSearch = async function ({
searchQuery,
page,
// providerValue,
signal,
providerContext,
}: {
searchQuery: string;
page: number;
providerValue: string;
signal: AbortSignal;
providerContext: ProviderContext;
}): Promise<Post[]> {
const {getBaseUrl, axios, cheerio} = providerContext;
const baseUrl = await getBaseUrl('w4u');
const url = `${baseUrl}/page/${page}/?s=${searchQuery}`;
return posts({url, signal, axios, cheerio});
};
async function posts({
url,
signal,
axios,
cheerio,
}: {
url: string;
signal: AbortSignal;
axios: ProviderContext['axios'];
cheerio: ProviderContext['cheerio'];
}): Promise<Post[]> {
try {
const res = await axios.get(url, {signal});
const data = res.data;
const $ = cheerio.load(data);
const catalog: Post[] = [];
$('.recent-posts')
.children()
.map((i, element) => {
const title = $(element).find('.post-thumb').find('a').attr('title');
const link = $(element).find('.post-thumb').find('a').attr('href');
const image =
$(element).find('.post-thumb').find('img').attr('data-src') ||
$(element).find('.post-thumb').find('img').attr('src');
if (title && link && image) {
catalog.push({
title: title.replace('Download', '').trim(),
link: link,
image: image,
});
}
});
return catalog;
} catch (err) {
return [];
}
}

View File

@@ -0,0 +1,211 @@
import {Stream, ProviderContext} from '../types';
export const world4uGetStream = async function ({
link: url,
type,
providerContext,
}: {
link: string;
type: string;
providerContext: ProviderContext;
}): Promise<Stream[]> {
const {axios, cheerio} = providerContext;
const headers = {
'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-Site': 'none',
'Sec-Fetch-User': '?1',
'Upgrade-Insecure-Requests': '1',
'User-Agent':
'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36 Edg/120.0.0.0',
};
try {
if (type === 'movie') {
const linkRes = await axios.get(url, {headers});
const linkData = linkRes.data;
const $ = cheerio.load(linkData);
url = $('strong:contains("INSTANT")').parent().attr('href') || url;
}
// fastilinks
if (url.includes('fastilinks')) {
const fastilinksRes = await axios.get(url, {headers});
const fastilinksData = fastilinksRes.data;
const $$ = cheerio.load(fastilinksData);
const fastilinksKey = $$(
'input[name="_csrf_token_645a83a41868941e4692aa31e7235f2"]',
).attr('value');
console.log('fastilinksKey', fastilinksKey);
const fastilinksFormData = new FormData();
fastilinksFormData.append(
'_csrf_token_645a83a41868941e4692aa31e7235f2',
fastilinksKey,
);
const fastilinksRes2 = await fetch(url, {
method: 'POST',
headers: headers,
body: fastilinksFormData,
});
const fastilinksHtml = await fastilinksRes2.text();
// console.log('fastilinksHtml', fastilinksHtml);
const $$$ = cheerio.load(fastilinksHtml);
const fastilinksLink =
$$$('a:contains("mediafire")').attr('href') ||
$$$('a:contains("photolinx")').attr('href');
console.log('fastilinksLink', fastilinksLink);
url = fastilinksLink || url;
}
console.log('world4uGetStream', type, url);
if (url.includes('photolinx')) {
console.log('photolinx', url);
// const photolinxBaseUrl = url.split('/').slice(0, 3).join('/');
const photolinxRes = await axios.get(url, {headers});
const photolinxData = photolinxRes.data;
const $$$ = cheerio.load(photolinxData);
const access_token = $$$('#generate_url').attr('data-token');
const uid = $$$('#generate_url').attr('data-uid');
const body = {
type: 'DOWNLOAD_GENERATE',
payload: {
access_token,
uid,
},
};
console.log('photolinxData', JSON.stringify(body));
const photolinxRes2 = await fetch('https://photolinx.shop/action', {
headers: {
'sec-fetch-site': 'same-origin',
'x-requested-with': 'xmlhttprequest',
cookie: 'PHPSESSID=9a8d855c700cf0711831c04960c2e2b4',
Referer: 'https://photolinx.shop/download/5mPkrBD0D2x',
'Referrer-Policy': 'strict-origin-when-cross-origin',
},
body: JSON.stringify(body),
method: 'POST',
});
const photolinxData2 = await photolinxRes2.json();
console.log('photolinxData2', photolinxData2);
const dwUrl = photolinxData2?.download_url;
if (dwUrl) {
const streamLinks = [
{
server: 'Photolinx',
link: dwUrl,
type: 'mkv',
},
];
return streamLinks;
}
}
const res = await axios.get(url, {headers});
const html = res.data;
const streamLinks: Stream[] = [];
let data = {download: ''};
try {
const key =
html.match(/formData\.append\('key',\s*'(\d+)'\);/)?.[1] || '';
console.log('key', key);
const formData = new FormData();
formData.append('key', key);
const streamRes = await fetch(url, {
method: 'POST',
headers: headers,
body: formData,
});
data = await streamRes.json();
} catch (err) {
console.log('error in world4uGetStream', err);
}
// console.log('streamRes', streamRes);
let $ = cheerio.load(html);
// console.log('data', html);
const mediafireUrl =
$('h1:contains("Download")').find('a').attr('href') ||
$('.input.popsok').attr('href');
console.log('mediafireUrl', mediafireUrl);
if (mediafireUrl) {
const directUrl = await axios.head(mediafireUrl);
const urlContentType = directUrl.headers['content-type'];
console.log('mfcontentType', urlContentType);
if (urlContentType && urlContentType.includes('video')) {
streamLinks.push({
server: 'Mediafire',
link: mediafireUrl,
type: 'mkv',
});
return streamLinks;
} else {
const repairRes = await axios.get(mediafireUrl, {
headers: {
Referer: url,
},
});
const repairHtml = repairRes.data;
// Regex to match the window.location.href assignment in the script content
const hrefRegex = /window\.location\.href\s*=\s*['"]([^'"]+)['"]/;
const match = repairHtml.match(hrefRegex);
// If a match is found, return the URL; otherwise return null
let downloadLInk = match ? match[1] : null;
console.log('downloadLInk', downloadLInk);
if (downloadLInk) {
streamLinks.push({
server: 'Mediafire',
link: downloadLInk,
type: 'mkv',
});
}
return streamLinks;
}
}
const requireRepairRes = await axios.head(data.download);
const contentType = requireRepairRes.headers['content-type'];
console.log('contentType', contentType);
if (contentType && contentType.includes('video')) {
streamLinks.push({
server: 'Mediafire',
link: data.download,
type: 'mkv',
});
return streamLinks;
} else {
const repairRes = await axios.get(data.download, {
headers: {
Referer: url,
},
});
const repairHtml = repairRes.data;
const $ = cheerio.load(repairHtml);
const repairLink = $('#continue-btn').attr('href');
console.log('repairLink', 'https://www.mediafire.com' + repairLink);
const repairRequireRepairRes = await axios.get(
'https://www.mediafire.com' + repairLink,
);
const $$ = cheerio.load(repairRequireRepairRes.data);
const repairDownloadLink = $$('.input.popsok').attr('href');
console.log('repairDownloadLink', repairDownloadLink);
if (repairDownloadLink) {
streamLinks.push({
server: 'Mediafire',
link: repairDownloadLink,
type: 'mkv',
});
}
}
return streamLinks;
} catch (err) {
console.log(err);
return [];
}
};