Spaces:
Sleeping
Sleeping
import logging | |
import gradio as gr | |
from sql_generator import SQLGenerator | |
from intent_classifier import IntentClassifier | |
from rag_system import RAGSystem | |
# Initialize logging | |
logging.basicConfig( | |
level=logging.INFO, # Set the logging level (DEBUG, INFO, WARNING, ERROR, CRITICAL) | |
format='%(asctime)s - %(levelname)s - %(message)s' # Format for the log messages | |
) | |
class UnifiedSystem: | |
def __init__(self): | |
self.sql_generator = SQLGenerator() | |
self.intent_classifier = IntentClassifier() | |
self.rag_system = RAGSystem() | |
def process_query(self, query): | |
logging.info(f"Processing query: {query}") # Log the incoming query | |
intent, confidence = self.intent_classifier.classify(query) | |
logging.info(f"Classified intent: {intent} with confidence: {confidence:.2f}") | |
if intent == "database_query": | |
sql_query = self.sql_generator.generate_query(query) # Assuming this method is correct | |
products = self.sql_generator.fetch_shopify_data("products") | |
if products and 'products' in products: | |
results = "\n".join([ | |
f"Title: {p['title']}, Vendor: {p['vendor']}" | |
for p in products['products'] | |
]) | |
return f"Intent: Database Query (Confidence: {confidence:.2f})\n\n" \ | |
f"SQL Query: {sql_query}\n\nResults:\n{results}" | |
else: | |
logging.warning("No results found or error fetching data from Shopify.") | |
return "No results found or error fetching data from Shopify." | |
elif intent == "product_description": | |
rag_response = self.rag_system.process_query(query) | |
return f"Intent: Product Description (Confidence: {confidence:.2f})\n\n" \ | |
f"Response: {rag_response}" | |
logging.error("Intent not recognized.") | |
return "Intent not recognized." | |
def create_interface(): | |
system = UnifiedSystem() | |
iface = gr.Interface( | |
fn=system.process_query, | |
inputs=gr.Textbox( | |
label="Enter your query", | |
placeholder="e.g., 'Show me all T-shirts' or 'Describe the product features'" | |
), | |
outputs=gr.Textbox(label="Response"), | |
title="Unified Query Processing System", | |
description="Enter a natural language query to search products or get descriptions." | |
) | |
return iface | |
if __name__ == "__main__": | |
iface = create_interface() | |
iface.launch() | |