f1-stream: drop demo + landing-page extractors, add fetch-proxy injection
Per user feedback: the demo Big Buck Bunny / Apple test streams aren't useful in an F1-streams app. Removed DemoExtractor entirely. Tightened the discord-extractor path filter from "any stream-shaped path" to "direct embed/player path only" — the previous filter still let sportsurge `/event/...` landing pages through, which the verifier mistook for playable because they render player-class divs without a real player. Embed proxy now also rewrites window.fetch + XMLHttpRequest.open inside the upstream HTML so that cross-origin XHRs (e.g. the hmembeds `/sec/<JWT>` token-binding endpoint) go through our /embed-asset relay. This avoids the CORS reject that fired when the player JS tried to call hghndasw.gbgdhdffhf.shop/sec/... from an `f1.viktorbarzin.me` origin. The verifier now requires a `<video>` element to mark embed streams playable (not just a player-class div). Curated streams bypass the verifier — hmembeds aggressively detects headless Chromium (devtool trap, console-clear timing, automation flags) and won't progress past JW Player init in our pod, but the user's real browser should clear those checks. We can't honestly headless-verify hmembeds, so we trust the curator instead of falsely rejecting them. Image: viktorbarzin/f1-stream:v6.1.1
This commit is contained in:
parent
f90d79ed4e
commit
574cdf08d2
5 changed files with 87 additions and 27 deletions
|
|
@ -96,6 +96,63 @@ _FRAME_BUSTER_DEFEAT_TEMPLATE = """
|
|||
loc.assign = function(u){{ if (typeof u === 'string' && u.indexOf('google.com') !== -1) return; if (origAssign) origAssign(u); }};
|
||||
loc.replace = function(u){{ if (typeof u === 'string' && u.indexOf('google.com') !== -1) return; if (origReplace) origReplace(u); }};
|
||||
}} catch (e) {{}}
|
||||
|
||||
// Route all cross-origin fetch/XHR requests through our /embed-asset
|
||||
// proxy. The hmembeds player calls a token-binding endpoint
|
||||
// (hghndasw.gbgdhdffhf.shop/sec/<JWT>) that CORS-rejects requests from
|
||||
// any origin other than hmembeds.one. By rewriting the URL to
|
||||
// /embed-asset?url=..., the browser fetches our same-origin endpoint
|
||||
// (no CORS issue), and our backend fetches the upstream with the
|
||||
// correct Referer/Origin server-side (no CORS issue there either).
|
||||
try {{
|
||||
var b64url = function(s) {{
|
||||
return btoa(unescape(encodeURIComponent(s)))
|
||||
.replace(/\\+/g, '-').replace(/\\//g, '_').replace(/=+$/, '');
|
||||
}};
|
||||
var sameOrigin = function(u) {{
|
||||
try {{ return (new URL(u, document.baseURI || location.href)).origin === location.origin; }}
|
||||
catch (_) {{ return true; }}
|
||||
}};
|
||||
var toAbsolute = function(u) {{
|
||||
try {{ return (new URL(u, document.baseURI || location.href)).toString(); }}
|
||||
catch (_) {{ return u; }}
|
||||
}};
|
||||
var proxify = function(u) {{
|
||||
var abs = toAbsolute(u);
|
||||
if (sameOrigin(abs)) return u;
|
||||
// Don't double-proxy.
|
||||
if (abs.indexOf('/embed-asset?') !== -1 || abs.indexOf('/embed?') !== -1) return u;
|
||||
return location.origin + '/embed-asset?url=' + b64url(abs);
|
||||
}};
|
||||
|
||||
var _fetch = window.fetch && window.fetch.bind(window);
|
||||
if (_fetch) {{
|
||||
window.fetch = function(input, init) {{
|
||||
try {{
|
||||
if (typeof input === 'string') {{
|
||||
return _fetch(proxify(input), init);
|
||||
}} else if (input && input.url) {{
|
||||
var newUrl = proxify(input.url);
|
||||
if (newUrl !== input.url) {{
|
||||
return _fetch(new Request(newUrl, input), init);
|
||||
}}
|
||||
}}
|
||||
}} catch (e) {{}}
|
||||
return _fetch(input, init);
|
||||
}};
|
||||
}}
|
||||
|
||||
var XHR = window.XMLHttpRequest;
|
||||
if (XHR && XHR.prototype && XHR.prototype.open) {{
|
||||
var _open = XHR.prototype.open;
|
||||
XHR.prototype.open = function(method, url) {{
|
||||
try {{ url = proxify(url); }} catch (e) {{}}
|
||||
var args = Array.prototype.slice.call(arguments);
|
||||
args[1] = url;
|
||||
return _open.apply(this, args);
|
||||
}};
|
||||
}}
|
||||
}} catch (e) {{}}
|
||||
}})();</script>
|
||||
"""
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue