File size: 1,493 Bytes
422431d
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import gradio as gr
from api import app
import uvicorn
import threading
import time

# Create a simple Gradio interface
def create_interface():
    with gr.Blocks(title="ChatDocxAI Backend") as interface:
        gr.Markdown("# ChatDocxAI Backend")
        gr.Markdown("""
        This is the backend server for ChatDocxAI. It provides the following endpoints:
        
        - `/upload` - Upload documents
        - `/ask` - Ask questions about uploaded documents
        
        The frontend should be configured to communicate with this backend.
        """)

        with gr.Row():
            with gr.Column():
                gr.Markdown("## Server Status")
                status = gr.Textbox(value="Server is running", label="Status")
                
        with gr.Row():
            with gr.Column():
                gr.Markdown("## API Documentation")
                doc_link = gr.HTML(f"<a href='/docs' target='_blank'>View FastAPI Docs</a>")
    
    return interface

# Function to start FastAPI in a separate thread
def start_fastapi():
    uvicorn.run(app, host="0.0.0.0", port=7860)

# Start FastAPI in a separate thread
fastapi_thread = threading.Thread(target=start_fastapi)
fastapi_thread.daemon = True
fastapi_thread.start()

# Allow some time for FastAPI to start
time.sleep(2)

# Create and launch the Gradio interface
interface = create_interface()

# Launch the interface with Gradio defaults (no specific port)
if __name__ == "__main__":
    interface.launch()