Spaces:
Running
Running
Update app.py
Browse files
app.py
CHANGED
@@ -1,7 +1,38 @@
|
|
1 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2 |
import requests
|
3 |
import os
|
4 |
from datetime import timedelta
|
|
|
5 |
|
6 |
app = Flask(__name__)
|
7 |
app.secret_key = os.urandom(24) # Session encryption key
|
@@ -599,6 +630,9 @@ if __name__ == '__main__':
|
|
599 |
urls.forEach(item => {
|
600 |
const { url, title } = item;
|
601 |
|
|
|
|
|
|
|
602 |
// Create grid item
|
603 |
const gridItem = document.createElement('div');
|
604 |
gridItem.className = 'grid-item';
|
@@ -625,9 +659,9 @@ if __name__ == '__main__':
|
|
625 |
const content = document.createElement('div');
|
626 |
content.className = 'grid-content';
|
627 |
|
628 |
-
// Create iframe to display the actual content
|
629 |
const iframe = document.createElement('iframe');
|
630 |
-
iframe.src =
|
631 |
iframe.title = title;
|
632 |
iframe.sandbox = 'allow-same-origin allow-scripts allow-popups allow-forms';
|
633 |
iframe.allow = 'accelerometer; camera; encrypted-media; geolocation; gyroscope; microphone; midi';
|
|
|
1 |
+
# Proxy route to bypass X-Frame-Options
|
2 |
+
@app.route('/proxy/<path:url>')
|
3 |
+
def proxy(url):
|
4 |
+
# Authorization header if user is logged in
|
5 |
+
headers = {}
|
6 |
+
if 'token' in session:
|
7 |
+
headers["Authorization"] = f"Bearer {session['token']}"
|
8 |
+
|
9 |
+
try:
|
10 |
+
# Parse URL to ensure it's safe
|
11 |
+
parsed_url = urlparse(url)
|
12 |
+
if not parsed_url.netloc.endswith('huggingface.co'):
|
13 |
+
return "Only Huggingface URLs are allowed", 403
|
14 |
+
|
15 |
+
# Make request to the target URL
|
16 |
+
response = requests.get(url, headers=headers, stream=True)
|
17 |
+
|
18 |
+
# Create response
|
19 |
+
resp = Response(
|
20 |
+
response.iter_content(chunk_size=10*1024),
|
21 |
+
content_type=response.headers.get('Content-Type')
|
22 |
+
)
|
23 |
+
|
24 |
+
# Remove headers that prevent iframe embedding
|
25 |
+
resp.headers.remove('X-Frame-Options')
|
26 |
+
resp.headers.remove('Content-Security-Policy')
|
27 |
+
|
28 |
+
return resp
|
29 |
+
except Exception as e:
|
30 |
+
print(f"Proxy error: {e}")
|
31 |
+
return f"Error: {str(e)}", 500from flask import Flask, render_template, request, redirect, url_for, jsonify, session, Response
|
32 |
import requests
|
33 |
import os
|
34 |
from datetime import timedelta
|
35 |
+
from urllib.parse import urlparse
|
36 |
|
37 |
app = Flask(__name__)
|
38 |
app.secret_key = os.urandom(24) # Session encryption key
|
|
|
630 |
urls.forEach(item => {
|
631 |
const { url, title } = item;
|
632 |
|
633 |
+
// Create proxy URL
|
634 |
+
const proxyUrl = `/proxy/${encodeURIComponent(url)}`;
|
635 |
+
|
636 |
// Create grid item
|
637 |
const gridItem = document.createElement('div');
|
638 |
gridItem.className = 'grid-item';
|
|
|
659 |
const content = document.createElement('div');
|
660 |
content.className = 'grid-content';
|
661 |
|
662 |
+
// Create iframe to display the actual content via proxy
|
663 |
const iframe = document.createElement('iframe');
|
664 |
+
iframe.src = proxyUrl;
|
665 |
iframe.title = title;
|
666 |
iframe.sandbox = 'allow-same-origin allow-scripts allow-popups allow-forms';
|
667 |
iframe.allow = 'accelerometer; camera; encrypted-media; geolocation; gyroscope; microphone; midi';
|