mirror of
https://github.com/vega-org/vega-providers.git
synced 2026-04-17 15:41:45 +00:00
Add MoviezWap provider and update manifest (#1)
Co-authored-by: shaker <your_github_username@users.noreply.github.com> Co-authored-by: himanshu8443 <sangwanhimanshu8443@gmail.com>
This commit is contained in:
@@ -143,6 +143,14 @@
|
||||
"type": "english",
|
||||
"disabled": true
|
||||
},
|
||||
{
|
||||
"display_name": "MoviezWap",
|
||||
"value": "Moviezwap",
|
||||
"version": "1.0",
|
||||
"icon": "",
|
||||
"type": "india",
|
||||
"disabled": false
|
||||
},
|
||||
{
|
||||
"display_name": "ShowBox",
|
||||
"value": "showbox",
|
||||
|
||||
21
providers/moviezwap/catalog.ts
Normal file
21
providers/moviezwap/catalog.ts
Normal file
@@ -0,0 +1,21 @@
|
||||
export const catalog = [
|
||||
{
|
||||
title: "Telugu Movies",
|
||||
filter: "/category/Telugu-(2025)-Movies.html",
|
||||
},
|
||||
{
|
||||
title: "Tamil Movies",
|
||||
filter: "/category/Tamil-(2025)-Movies.html",
|
||||
},
|
||||
{
|
||||
title: "Hollywood Telugu Dubbed",
|
||||
filter: "/category/Telugu-Dubbed-Hollywood-Movies-Complete-Set.html",
|
||||
},
|
||||
{
|
||||
title: "Web Series",
|
||||
filter: "/category/Telugu-Web-Series.html",
|
||||
},
|
||||
];
|
||||
|
||||
export const genres = [];
|
||||
|
||||
43
providers/moviezwap/episodes.ts
Normal file
43
providers/moviezwap/episodes.ts
Normal file
@@ -0,0 +1,43 @@
|
||||
import { EpisodeLink, ProviderContext } from "../types";
|
||||
|
||||
export const getEpisodes = async function ({
|
||||
url,
|
||||
providerContext,
|
||||
}: {
|
||||
url: string;
|
||||
providerContext: ProviderContext;
|
||||
}): Promise<EpisodeLink[]> {
|
||||
const { axios, cheerio, getBaseUrl } = providerContext;
|
||||
try {
|
||||
const res = await axios.get(url);
|
||||
const baseUrl = await getBaseUrl("moviezwap");
|
||||
const html = res.data;
|
||||
const $ = cheerio.load(html);
|
||||
|
||||
const episodeLinks: EpisodeLink[] = [];
|
||||
|
||||
$('a[href*="download.php?file="], a[href*="dwload.php?file="]').each(
|
||||
(i, el) => {
|
||||
const downloadPage =
|
||||
$(el).attr("href")?.replace("dwload.php", "download.php") || "";
|
||||
let text = $(el).text().trim();
|
||||
if (text.includes("Download page")) {
|
||||
// Remove "Download" from the text
|
||||
text = "Play";
|
||||
}
|
||||
if (downloadPage && text) {
|
||||
// Only add links with quality in text
|
||||
episodeLinks.push({
|
||||
title: text,
|
||||
link: baseUrl + downloadPage,
|
||||
});
|
||||
}
|
||||
}
|
||||
);
|
||||
|
||||
return episodeLinks;
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
return [];
|
||||
}
|
||||
};
|
||||
105
providers/moviezwap/meta.ts
Normal file
105
providers/moviezwap/meta.ts
Normal file
@@ -0,0 +1,105 @@
|
||||
import { Info, Link, ProviderContext } from "../types";
|
||||
|
||||
export const getMeta = async function ({
|
||||
link,
|
||||
providerContext,
|
||||
}: {
|
||||
link: string;
|
||||
providerContext: ProviderContext;
|
||||
}): Promise<Info> {
|
||||
try {
|
||||
const { axios, cheerio, getBaseUrl } = providerContext;
|
||||
const baseUrl = await getBaseUrl("moviezwap");
|
||||
const url = link.startsWith("http") ? link : `${baseUrl}${link}`;
|
||||
const res = await axios.get(url);
|
||||
const data = res.data;
|
||||
const $ = cheerio.load(data);
|
||||
|
||||
// 1. Poster image find image with width 260
|
||||
let image = $('img[width="260"]').attr("src") || "";
|
||||
if (image && !image.startsWith("http")) {
|
||||
image = baseUrl + image;
|
||||
}
|
||||
|
||||
const tags = $("font[color='steelblue']")
|
||||
.map((i, el) => $(el).text().trim())
|
||||
.get()
|
||||
.slice(0, 2);
|
||||
|
||||
// 2. Title
|
||||
const title = $("title").text().replace(" - MoviezWap", "").trim() || "";
|
||||
|
||||
// 3. Info table
|
||||
let synopsis = "";
|
||||
let imdbId = "";
|
||||
let type = "movie";
|
||||
let infoRows: string[] = [];
|
||||
$("td:contains('Movie Information')")
|
||||
.parent()
|
||||
.nextAll("tr")
|
||||
.each((i, el) => {
|
||||
const tds = $(el).find("td");
|
||||
if (tds.length === 2) {
|
||||
const key = tds.eq(0).text().trim();
|
||||
const value = tds.eq(1).text().trim();
|
||||
infoRows.push(`${key}: ${value}`);
|
||||
if (key.toLowerCase().includes("plot")) synopsis = value;
|
||||
if (key.toLowerCase().includes("imdb")) imdbId = value;
|
||||
}
|
||||
});
|
||||
if (!synopsis) {
|
||||
// fallback: try to find a <p> with plot
|
||||
synopsis = $("p:contains('plot')").text().trim();
|
||||
}
|
||||
|
||||
// 4. Download links (multiple qualities)
|
||||
const links: Link[] = [];
|
||||
$('a[href*="download.php?file="], a[href*="dwload.php?file="]').each(
|
||||
(i, el) => {
|
||||
const downloadPage =
|
||||
$(el).attr("href")?.replace("dwload.php", "download.php") || "";
|
||||
const text = $(el).text().trim();
|
||||
if (downloadPage && /\d+p/i.test(text)) {
|
||||
// Only add links with quality in text
|
||||
links.push({
|
||||
title: text,
|
||||
directLinks: [{ title: "Movie", link: baseUrl + downloadPage }],
|
||||
});
|
||||
}
|
||||
}
|
||||
);
|
||||
|
||||
$("img[src*='/images/play.png']").each((i, el) => {
|
||||
const downloadPage = $(el).siblings("a").attr("href");
|
||||
const text = $(el).siblings("a").text().trim();
|
||||
console.log("Found link:🔥🔥", text, downloadPage);
|
||||
if (downloadPage && text) {
|
||||
links.push({
|
||||
title: text,
|
||||
episodesLink: baseUrl + downloadPage,
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
return {
|
||||
title,
|
||||
synopsis,
|
||||
image,
|
||||
imdbId,
|
||||
tags,
|
||||
type,
|
||||
linkList: links,
|
||||
//info: infoRows.join("\n"),
|
||||
};
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
return {
|
||||
title: "",
|
||||
synopsis: "",
|
||||
image: "",
|
||||
imdbId: "",
|
||||
type: "movie",
|
||||
linkList: [],
|
||||
};
|
||||
}
|
||||
};
|
||||
70
providers/moviezwap/posts.ts
Normal file
70
providers/moviezwap/posts.ts
Normal file
@@ -0,0 +1,70 @@
|
||||
import { Post, ProviderContext } from "../types";
|
||||
|
||||
export const getPosts = async function ({
|
||||
filter,
|
||||
page,
|
||||
signal,
|
||||
providerContext,
|
||||
}: {
|
||||
filter: string;
|
||||
page: number;
|
||||
providerValue: string;
|
||||
signal: AbortSignal;
|
||||
providerContext: ProviderContext;
|
||||
}): Promise<Post[]> {
|
||||
const { getBaseUrl, cheerio } = providerContext;
|
||||
const baseUrl = await getBaseUrl("moviezwap");
|
||||
const url = `${baseUrl}${filter}`;
|
||||
return posts({ url, signal, cheerio });
|
||||
};
|
||||
|
||||
export const getSearchPosts = async function ({
|
||||
searchQuery,
|
||||
page,
|
||||
signal,
|
||||
providerContext,
|
||||
}: {
|
||||
searchQuery: string;
|
||||
page: number;
|
||||
providerValue: string;
|
||||
signal: AbortSignal;
|
||||
providerContext: ProviderContext;
|
||||
}): Promise<Post[]> {
|
||||
const { getBaseUrl, cheerio } = providerContext;
|
||||
const baseUrl = await getBaseUrl("moviezwap");
|
||||
const url = `${baseUrl}/search.php?q=${encodeURIComponent(searchQuery)}`;
|
||||
return posts({ url, signal, cheerio });
|
||||
};
|
||||
|
||||
async function posts({
|
||||
url,
|
||||
signal,
|
||||
cheerio,
|
||||
}: {
|
||||
url: string;
|
||||
signal: AbortSignal;
|
||||
cheerio: ProviderContext["cheerio"];
|
||||
}): Promise<Post[]> {
|
||||
try {
|
||||
const res = await fetch(url, { signal });
|
||||
const data = await res.text();
|
||||
const $ = cheerio.load(data);
|
||||
const catalog: Post[] = [];
|
||||
$('a[href^="/movie/"]').each((i, el) => {
|
||||
const title = $(el).text().trim();
|
||||
const link = $(el).attr("href");
|
||||
const image = "";
|
||||
if (title && link) {
|
||||
catalog.push({
|
||||
title: title,
|
||||
link: link,
|
||||
image: image,
|
||||
});
|
||||
}
|
||||
});
|
||||
return catalog;
|
||||
} catch (err) {
|
||||
console.error("moviezwapGetPosts error ", err);
|
||||
return [];
|
||||
}
|
||||
}
|
||||
34
providers/moviezwap/stream.ts
Normal file
34
providers/moviezwap/stream.ts
Normal file
@@ -0,0 +1,34 @@
|
||||
import { ProviderContext, Stream } from "../types";
|
||||
|
||||
export async function getStream({
|
||||
link,
|
||||
signal,
|
||||
providerContext,
|
||||
}: {
|
||||
link: string;
|
||||
type: string;
|
||||
signal: AbortSignal;
|
||||
providerContext: ProviderContext;
|
||||
}) {
|
||||
const { axios, cheerio, commonHeaders: headers } = providerContext;
|
||||
const res = await axios.get(link, { headers, signal });
|
||||
const html = res.data;
|
||||
const $ = cheerio.load(html);
|
||||
const Streams: Stream[] = [];
|
||||
|
||||
// Find the actual .mp4 download link
|
||||
let downloadLink = null;
|
||||
$('a:contains("Fast Download Server")').each((i, el) => {
|
||||
const href = $(el).attr("href");
|
||||
if (href && href.toLocaleLowerCase().includes(".mp4")) {
|
||||
Streams.push({
|
||||
link: href,
|
||||
type: "mp4",
|
||||
server: "Fast Download",
|
||||
headers: headers,
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
return Streams;
|
||||
}
|
||||
Reference in New Issue
Block a user