PePe / main.py
nileshhanotia's picture
Create main.py
e266142 verified
raw
history blame
2.57 kB
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()