File size: 6,952 Bytes
71f20f2 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 |
import os
import logging
from fastapi import FastAPI, File, UploadFile, HTTPException, APIRouter, Form, Request
from pydantic import BaseModel
from services.file_upload_service import FileHandler
from services.chat_service import ChatAgentService
from fastapi.staticfiles import StaticFiles
from fastapi.templating import Jinja2Templates
from fastapi.middleware.cors import CORSMiddleware
from dotenv import load_dotenv
import mysql.connector
# Create the FastAPI app
app = FastAPI(title="RedmindGen", description="Chat with your Data", version="1.0.0")
# Load environment variables from .env file
load_dotenv()
# Get the path to the vector database
vector_db_path_documents = os.getenv('VECTOR_DB_PATH_DOCUMENTS')
# Mount static files
app.mount("/static", StaticFiles(directory="static"), name="static")
# Jinja2 templates
templates = Jinja2Templates(directory="templates")
#log handling
LOG_PATH = os.getenv('LOG_PATH')
LOG_FILENAME = "redmindgen.log"
full_log_path = os.path.join(LOG_PATH, LOG_FILENAME)
# Configure logging
logging.basicConfig(filename=full_log_path, level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
logging.info("File upload start")
# Configure CORS
origins = [
"http://localhost:8000", # Adjust this to the origins you want to allow
"http://127.0.0.1:8000", # Example: Frontend running on a different port
"http://167.71.75.10:8003/"
]
app.add_middleware(
CORSMiddleware,
allow_origins=origins, # Allows specified origins (use ["*"] for all origins)
allow_credentials=True,
allow_methods=["*"], # Allows all methods
allow_headers=["*"], # Allows all headers
)
@app.get("/")
async def read_root(request: Request):
"""
Root endpoint that returns the index.html template.
"""
return templates.TemplateResponse("index.html", {"request": request})
def verify_user(username: str, password: str):
"""
Function to verify user credentials by checking the username and password in the database.
Returns "success" if the user is logged in, otherwise returns "failure".
"""
# Connect to MySQL database
cnx = mysql.connector.connect(user='root', password='',
host='localhost',
database='redmind_gpt')
# Create a cursor object
cursor = cnx.cursor()
# Execute the query
query = "SELECT * FROM user_detail WHERE username = %s AND password = %s"
values = (username, password) # Replace with actual values from the front end
cursor.execute(query, values)
# Fetch the result
result = cursor.fetchone()
# Check if the result is not None
if result is not None:
# User is logged in
return "success"
else:
# User is not logged in
return "failure"
# Close the cursor and connection
cursor.close()
cnx.close()
@app.post("/validate-user")
async def validate_user(request: Request, username: str = Form(...), password: str = Form(...)):
"""
Endpoint to validate user credentials.
If the credentials are valid, it returns the dashboard.html template.
Otherwise, it returns the index.html template.
"""
status = verify_user(username, password)
if status == 'success':
return templates.TemplateResponse("dashboard.html", {"request": request, "username": username})
else:
return templates.TemplateResponse("index.html", {"request": request})
@app.get("/knowledgebase")
async def knowledgebase(request: Request):
"""
Endpoint for the knowledgebase page.
Returns the knowledgebase.html template.
"""
return templates.TemplateResponse("knowledgebase.html", {"request": request})
@app.get("/chatbot")
async def chatbot(request: Request):
"""
Endpoint for the knowledgebase page.
Returns the knowledgebase.html template.
"""
return templates.TemplateResponse("chatpage.html", {"request": request})
@app.get("/company_profile")
async def company_profile(request: Request):
"""
Endpoint for the company profile page.
Returns the company_profile.html template.
"""
return templates.TemplateResponse("company_profile.html", {"request": request})
@app.get("/data_connectors")
async def data_connectors(request: Request):
"""
Endpoint for the company profile page.
Returns the company_profile.html template.
"""
return templates.TemplateResponse("data_connectors.html", {"request": request})
@app.get("/API_connectors")
async def API_connectors(request: Request):
"""
Endpoint for the company profile page.
Returns the company_profile.html template.
"""
return templates.TemplateResponse("API_connectors.html", {"request": request})
@app.post("/upload_file/")
async def upload_file(
file: UploadFile = File(..., description="Upload a file"),
document_name: str = Form(..., description="The name of the document."),
document_description: str = Form(..., description="A brief description of the document."),
department: str = Form(..., description="The department associated with the document."),
version: str = Form(..., description="The version of the document."),
last_updated: str = Form(..., description="The date when the document was last updated.")
):
"""
Endpoint to handle file uploads.
It validates the file type and calls the FileHandler to handle the file upload.
Returns the result of the file upload."""
print("upload_file called")
allowed_extensions = {'txt', 'pdf', 'docx', 'csv', 'xlsx'}
if file.filename.split('.')[-1].lower() not in allowed_extensions:
raise HTTPException(status_code=400,
detail="Unsupported file type. Supported types: TXT, PDF, DOCX, CSV, XLSX.")
try:
file_handler = FileHandler(vector_db_path=vector_db_path_documents)
print(vector_db_path_documents)
result = await file_handler.handle_file_upload(file, document_name, document_description, department, version,
last_updated)
print("result")
return result
except Exception as e:
logging.error(f"Error handling file uploads: {str(e)}")
raise HTTPException(status_code=500, detail=str(e))
@app.post("/chat_with_agent")
async def chat_with_agent(request: Request, user_question: str = Form(...)):
"""
Endpoint to chat with the chat agent.
It calls the ChatAgentService to get the answer to the user's question.
Returns the answer.
"""
print(user_question)
chat_service = ChatAgentService()
try:
print("chat_with_agent called")
answer = chat_service.answer_question(user_question)
print("answer returned")
return answer
except Exception as e:
logging.error(f"Error in chat api: {str(e)}")
raise HTTPException(status_code=500, detail=str(e))
|