new version

This commit is contained in:
UrloMythus
2026-04-15 19:23:14 +02:00
parent 5120b19d0b
commit 8134936d59
135 changed files with 3013 additions and 1589 deletions
+22 -3
View File
@@ -1,23 +1,42 @@
import re
from typing import Dict, Any
from curl_cffi.requests import AsyncSession
from mediaflow_proxy.extractors.base import BaseExtractor, ExtractorError
class LuluStreamExtractor(BaseExtractor):
"""LuluStream URL extractor.
Uses curl_cffi + Chrome impersonation to bypass Cloudflare protection.
lulustream.com embeds are served via luluvdo.com.
"""
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.mediaflow_endpoint = "hls_manifest_proxy"
async def extract(self, url: str, **kwargs) -> Dict[str, Any]:
response = await self._make_request(url)
proxy = self._get_proxy(url)
async with AsyncSession() as session:
response = await session.get(
url,
impersonate="chrome",
timeout=30,
allow_redirects=True,
**({"proxy": proxy} if proxy else {}),
)
if response.status_code >= 400:
raise ExtractorError(f"HTTP {response.status_code} while fetching {url}")
# See https://github.com/Gujal00/ResolveURL/blob/master/script.module.resolveurl/lib/resolveurl/plugins/lulustream.py
pattern = r"""sources:\s*\[{file:\s*["'](?P<url>[^"']+)"""
match = re.search(pattern, response.text, re.DOTALL)
if not match:
raise ExtractorError("Failed to extract source URL")
final_url = match.group(1)
raise ExtractorError("LuluStream: Failed to extract source URL")
final_url = match.group("url")
self.base_headers["referer"] = url
return {