File size: 1,277 Bytes
42f970b
c732a18
ab558ef
 
c732a18
ab558ef
fb9d63e
ab558ef
4eaf1b2
ab558ef
 
 
 
d5c9e08
ab558ef
fb9d63e
ab558ef
 
 
 
 
4eaf1b2
ab558ef
d5c9e08
ab558ef
abfc5be
3efcae6
ab558ef
d5c9e08
ab558ef
d5c9e08
 
c732a18
ab558ef
 
 
fb9d63e
d5c9e08
 
f3ceb0f
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
import time
import gradio as gr
import requests
import json

# Función que hace la solicitud a la API y muestra la respuesta progresivamente
def slow_api_response(message, history):
    url = "https://data-monopolio.dev.dd360.mx/ai-assistant/v1"

    # Crea el payload con el mensaje proporcionado
    payload = json.dumps({
        "query": message,
        "sessionId": "12345",
        "numMessages": "3",  # Actualiza el número de mensajes en el historial
        "userId": "user-01",
        "property_id": "c0ced2220b87fc23762facf617157a4f"
    })
    
    headers = {
        'Content-Type': 'application/json'
    }

    try:
        # Realiza la solicitud POST a la API
        response = requests.request("POST", url, headers=headers, data=payload)
        api_response = response.text
        api_response = api_response.encode().decode('unicode_escape')
        
        # Simula una respuesta progresiva
        for i in range(len(api_response)):
            time.sleep(0.05)  # Simula un retraso
            yield api_response[:i + 1]  # Devuelve la respuesta progresiva

    except requests.RequestException as e:
        yield f"Error: {str(e)}"

# Interfaz Gradio usando la función slow_api_response
demo = gr.ChatInterface(fn=slow_api_response).launch()