Spaces:
Runtime error
Runtime error
Marked log output ticker with show-api=False, so that it does not get served by MCP as a tool.
5dd5c65
verified
| '''Main script to run gradio interface and MCP server.''' | |
| import logging | |
| from functools import partial | |
| from pathlib import Path | |
| from logging.handlers import RotatingFileHandler | |
| import gradio as gr | |
| import assets.html as html | |
| import functions.tools as tool_funcs | |
| import functions.gradio_functions as gradio_funcs | |
| # Set-up logging | |
| # Make sure log directory exists | |
| Path('logs').mkdir(parents=True, exist_ok=True) | |
| # Clear old logs if present | |
| gradio_funcs.delete_old_logs('logs', 'rss_server') | |
| # Set up the root logger so we catch logs from everything | |
| logging.basicConfig( | |
| handlers=[RotatingFileHandler( | |
| 'logs/rss_server.log', | |
| maxBytes=100000, | |
| backupCount=10, | |
| mode='w' | |
| )], | |
| level=logging.INFO, | |
| format='%(levelname)s - %(name)s - %(message)s' | |
| ) | |
| # Get a logger | |
| logger = logging.getLogger(__name__) | |
| with gr.Blocks() as demo: | |
| # Page text | |
| gr.HTML(html.TITLE) | |
| gr.HTML(html.DESCRIPTION) | |
| # Log output | |
| dialog_output = gr.Textbox(label='Server logs', lines=10, max_lines=100) | |
| timer = gr.Timer(0.5, active=True) | |
| timer.tick( # pylint: disable=no-member | |
| lambda: gradio_funcs.update_log(), # pylint: disable=unnecessary-lambda | |
| outputs=dialog_output, | |
| show_api=False | |
| ) | |
| # Get feed tool | |
| website_url = gr.Textbox('hackernews.com', label='Website') | |
| output = gr.Textbox(label='RSS entries', lines=10) | |
| submit_button = gr.Button('Submit') | |
| submit_button.click( # pylint: disable=no-member | |
| fn=tool_funcs.get_feed, | |
| inputs=website_url, | |
| outputs=output, | |
| api_name='Get RSS feed content' | |
| ) | |
| if __name__ == '__main__': | |
| demo.launch(mcp_server=True) | |