Spaces:
Runtime error
Runtime error
acecalisto3
commited on
Update app2.py
Browse files
app2.py
CHANGED
@@ -16,13 +16,15 @@ from urllib.parse import urljoin
|
|
16 |
import logging
|
17 |
from sqlalchemy.orm import Session
|
18 |
from sqlalchemy.future import select
|
|
|
|
|
19 |
|
20 |
Base = declarative_base()
|
21 |
|
22 |
class Article(Base):
|
23 |
__tablename__ = 'articles'
|
24 |
id = Column(Integer, primary_key=True)
|
25 |
-
url = Column('url', String(2048), nullable=False, unique=True)
|
26 |
title = Column('title', String(255))
|
27 |
content = Column('content', Text())
|
28 |
hash_value = Column('hash', String(32))
|
@@ -43,6 +45,7 @@ monitoring_tasks = {}
|
|
43 |
url_monitoring_intervals = {}
|
44 |
change_counts = {}
|
45 |
history = []
|
|
|
46 |
|
47 |
async def create_db_engine(db_url):
|
48 |
try:
|
@@ -212,15 +215,15 @@ async def chatbot_response(message: str, history: List[Tuple[str, str]]):
|
|
212 |
return history, history
|
213 |
|
214 |
|
215 |
-
async def update_db_status(
|
216 |
while True:
|
217 |
try:
|
218 |
await db_session.execute("SELECT 1")
|
219 |
db_status = "Connected"
|
220 |
except SQLAlchemyError:
|
221 |
db_status = "Disconnected"
|
|
|
222 |
await asyncio.sleep(60) # Check every minute
|
223 |
-
return db_status
|
224 |
|
225 |
|
226 |
async def update_feed_content(): # Remove db_session parameter
|
@@ -243,11 +246,11 @@ async def update_feed_content(): # Remove db_session parameter
|
|
243 |
logger.error(f"Database error: {e}")
|
244 |
return None
|
245 |
|
246 |
-
async def periodic_update_with_error_handling(
|
247 |
while True:
|
248 |
try:
|
249 |
await asyncio.sleep(300) # Wait for 5 minutes
|
250 |
-
await update_feed_content(
|
251 |
except Exception as e:
|
252 |
logger.error(f"Error in periodic update: {e}")
|
253 |
|
@@ -260,86 +263,79 @@ async def main():
|
|
260 |
|
261 |
demo = gr.Blocks()
|
262 |
|
263 |
-
|
264 |
-
|
265 |
-
|
266 |
-
|
267 |
-
|
268 |
-
|
269 |
-
|
270 |
-
|
271 |
-
|
272 |
-
|
273 |
-
|
274 |
-
|
275 |
-
|
276 |
-
|
277 |
-
|
278 |
-
|
279 |
-
|
280 |
-
|
281 |
-
|
282 |
-
|
283 |
-
|
284 |
-
|
285 |
-
|
286 |
-
|
287 |
-
|
288 |
-
|
289 |
-
|
290 |
-
|
291 |
-
|
292 |
-
|
293 |
-
|
294 |
-
|
295 |
-
|
296 |
-
|
297 |
-
|
298 |
-
|
299 |
-
|
300 |
-
|
301 |
-
|
302 |
-
|
303 |
-
|
304 |
-
|
305 |
-
|
306 |
-
|
307 |
-
|
308 |
-
|
309 |
-
|
310 |
-
|
311 |
-
|
312 |
-
|
313 |
-
|
314 |
-
|
315 |
-
|
316 |
-
|
317 |
-
|
318 |
-
|
319 |
-
|
320 |
-
|
321 |
-
|
322 |
-
|
323 |
-
|
324 |
-
|
325 |
-
|
326 |
-
|
327 |
-
|
328 |
-
|
329 |
-
|
330 |
-
|
331 |
-
asyncio.create_task(periodic_update_with_error_handling(
|
332 |
-
asyncio.create_task(update_db_status(db_status))
|
333 |
-
]
|
334 |
|
335 |
# Launch the demo
|
336 |
await demo.launch()
|
337 |
|
338 |
-
# Wait for background tasks to complete
|
339 |
-
for task in update_tasks:
|
340 |
-
task.cancel()
|
341 |
-
await asyncio.gather(*update_tasks, return_exceptions=True)
|
342 |
-
|
343 |
except Exception as e:
|
344 |
logger.error(f"Error in main: {e}")
|
345 |
finally:
|
|
|
16 |
import logging
|
17 |
from sqlalchemy.orm import Session
|
18 |
from sqlalchemy.future import select
|
19 |
+
from bs4 import BeautifulSoup
|
20 |
+
import validators
|
21 |
|
22 |
Base = declarative_base()
|
23 |
|
24 |
class Article(Base):
|
25 |
__tablename__ = 'articles'
|
26 |
id = Column(Integer, primary_key=True)
|
27 |
+
url = Column('url', String(2048), nullable=False, unique=True)
|
28 |
title = Column('title', String(255))
|
29 |
content = Column('content', Text())
|
30 |
hash_value = Column('hash', String(32))
|
|
|
45 |
url_monitoring_intervals = {}
|
46 |
change_counts = {}
|
47 |
history = []
|
48 |
+
db_session = None # Initialize db_session globally
|
49 |
|
50 |
async def create_db_engine(db_url):
|
51 |
try:
|
|
|
215 |
return history, history
|
216 |
|
217 |
|
218 |
+
async def update_db_status(db_status_textbox):
|
219 |
while True:
|
220 |
try:
|
221 |
await db_session.execute("SELECT 1")
|
222 |
db_status = "Connected"
|
223 |
except SQLAlchemyError:
|
224 |
db_status = "Disconnected"
|
225 |
+
yield db_status # Use a generator to update the textbox
|
226 |
await asyncio.sleep(60) # Check every minute
|
|
|
227 |
|
228 |
|
229 |
async def update_feed_content(): # Remove db_session parameter
|
|
|
246 |
logger.error(f"Database error: {e}")
|
247 |
return None
|
248 |
|
249 |
+
async def periodic_update_with_error_handling():
|
250 |
while True:
|
251 |
try:
|
252 |
await asyncio.sleep(300) # Wait for 5 minutes
|
253 |
+
await update_feed_content()
|
254 |
except Exception as e:
|
255 |
logger.error(f"Error in periodic update: {e}")
|
256 |
|
|
|
263 |
|
264 |
demo = gr.Blocks()
|
265 |
|
266 |
+
with demo:
|
267 |
+
gr.Markdown("# Website Monitor and Chatbot")
|
268 |
+
|
269 |
+
with gr.Row():
|
270 |
+
with gr.Column():
|
271 |
+
db_url = gr.Textbox(
|
272 |
+
label="Database URL", value="sqlite:///monitoring.db")
|
273 |
+
db_status_textbox = gr.Textbox(label="Database Status",
|
274 |
+
interactive=False,
|
275 |
+
value="Connected")
|
276 |
+
|
277 |
+
with gr.Column():
|
278 |
+
with gr.Tab("Configuration"):
|
279 |
+
target_urls = gr.Textbox(
|
280 |
+
label="Target URLs (comma-separated)",
|
281 |
+
placeholder=
|
282 |
+
"https://example.com, https://another-site.com")
|
283 |
+
storage_location = gr.Textbox(
|
284 |
+
label="Storage Location (CSV file path)",
|
285 |
+
placeholder="/path/to/your/file.csv")
|
286 |
+
feed_rss_checkbox = gr.Checkbox(label="Enable RSS Feed")
|
287 |
+
start_button = gr.Button("Start Monitoring")
|
288 |
+
stop_button = gr.Button("Stop Monitoring")
|
289 |
+
status_text = gr.Textbox(label="Status",
|
290 |
+
interactive=False)
|
291 |
+
history_text = gr.Textbox(label="History",
|
292 |
+
lines=10,
|
293 |
+
interactive=False)
|
294 |
+
|
295 |
+
with gr.Tab("User-End View"):
|
296 |
+
feed_content = gr.JSON(label="RSS Feed Content")
|
297 |
+
|
298 |
+
with gr.Tab("Chatbot"):
|
299 |
+
chatbot_interface = gr.Chatbot(type='messages')
|
300 |
+
message_input = gr.Textbox(
|
301 |
+
placeholder="Type your message here...")
|
302 |
+
send_button = gr.Button("Send")
|
303 |
+
|
304 |
+
async def on_start_click(target_urls_str: str, storage_loc: str,
|
305 |
+
feed_enabled: bool):
|
306 |
+
urls = [url.strip() for url in target_urls_str.split(",")]
|
307 |
+
await start_monitoring(urls,
|
308 |
+
storage_loc if storage_loc else None,
|
309 |
+
feed_enabled)
|
310 |
+
return "Monitoring started for valid URLs."
|
311 |
+
|
312 |
+
async def on_stop_click():
|
313 |
+
for url in list(monitoring_tasks.keys()):
|
314 |
+
stop_monitoring(url)
|
315 |
+
return "Monitoring stopped for all URLs."
|
316 |
+
|
317 |
+
start_button.click(
|
318 |
+
on_start_click,
|
319 |
+
inputs=[target_urls, storage_location, feed_rss_checkbox],
|
320 |
+
outputs=[status_text])
|
321 |
+
stop_button.click(on_stop_click, outputs=[status_text])
|
322 |
+
send_button.click(
|
323 |
+
chatbot_response,
|
324 |
+
inputs=[message_input, chatbot_interface],
|
325 |
+
outputs=[chatbot_interface, message_input])
|
326 |
+
|
327 |
+
# Set up the timer
|
328 |
+
feed_updater = gr.Timer(interval=300)
|
329 |
+
feed_updater.tick(fn=update_feed_content,
|
330 |
+
outputs=feed_content)
|
331 |
+
|
332 |
+
# Create background tasks
|
333 |
+
demo.load(update_db_status, outputs=db_status_textbox)
|
334 |
+
asyncio.create_task(periodic_update_with_error_handling())
|
|
|
|
|
335 |
|
336 |
# Launch the demo
|
337 |
await demo.launch()
|
338 |
|
|
|
|
|
|
|
|
|
|
|
339 |
except Exception as e:
|
340 |
logger.error(f"Error in main: {e}")
|
341 |
finally:
|