Spaces:
Running
Running
File size: 7,214 Bytes
1e6a278 4bfaa35 1e6a278 4bfaa35 1e6a278 e72ad7d 1e6a278 f9c615f 4bfaa35 1e6a278 e72ad7d fef9259 1e6a278 e72ad7d 1e6a278 f9c615f 1e6a278 8d2eb7f f9c615f 8d2eb7f f9c615f a6e8131 f9c615f a6e8131 1e6a278 f9c615f 1e6a278 f9c615f 1e6a278 f9c615f 1e6a278 4bfaa35 f9c615f 4bfaa35 f9c615f 4bfaa35 e72ad7d 4bfaa35 ea69154 e72ad7d 1e6a278 0b7c833 |
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 |
import requests
import datetime
import http.server
import websockets
import websocket
import asyncio
import sqlite3
import json
import gradio as gr
from bs4 import BeautifulSoup
from gradio_client import Client
import time
client_messages = []
server_responses = []
messages = []
used_ports = []
websocket_server = None
stop = asyncio.Future()
# Global variables to store references to the textboxes
messageTextbox = None
serverMessageTextbox = None
def slow_echo(message, history):
for i in range(len(message)):
time.sleep(0.3)
yield "You typed: " + message[: i+1]
# Define a function to read the HTML file
def read_html_file(file_name):
with open(file_name, 'r') as file:
html_content = file.read()
return html_content
# Set up the HTTP server
class SimpleHTTPRequestHandler(http.server.SimpleHTTPRequestHandler):
def do_GET(self):
if self.path == '/':
self.send_response(200)
self.send_header('Content-type', 'text/html')
self.end_headers()
with open('index.html', 'rb') as file:
self.wfile.write(file.read())
else:
self.send_response(404)
self.end_headers()
# Set up the SQLite database
db = sqlite3.connect('chat-hub.db')
cursor = db.cursor()
cursor.execute('CREATE TABLE IF NOT EXISTS messages (id INTEGER PRIMARY KEY AUTOINCREMENT, sender TEXT, message TEXT, timestamp TEXT)')
db.commit()
# Define the function for sending an error message
def sendErrorMessage(ws, errorMessage):
errorResponse = {'error': errorMessage}
ws.send(json.dumps(errorResponse))
# Define a function to ask a question to the chatbot and display the response
async def askQuestion(question):
try:
response = requests.post(
"https://flowiseai-flowise.hf.space/api/v1/prediction/8fd03bee-7752-484f-844f-bdae1e4cb4fe",
headers={"Content-Type": "application/json"},
json={"question": question},
)
response_content = response.content.decode('utf-8')
client_messages.append(response_content)
return response_content
except Exception as e:
print(e)
# Define a function to ask a question to the chatbot and display the response
async def askQuestion2(question):
try:
message = server_responses[-1]
url = "https://api.chaindesk.ai/datastores/query/clka5g9zc000drg6mxl671ekv"
payload = {"query": message,
"topK":2
}
headers = {
"Authorization": "Bearer 5315cd7b-bb79-49bc-bca2-8bcc7b243504",
"Content-Type": "application/json"
}
response = requests.request("POST", url, json=payload, headers=headers)
print(response.text)
return response.text
except Exception as e:
print(e)
async def handleWebSocket(ws):
print('New connection')
await ws.send('Hello! You are now entering a chat room for AI agents working as instances of NeuralGPT. Keep in mind that you are speaking with another chatbot')
while True:
message = await ws.recv()
message_copy = message
client_messages.append(message_copy)
print(f'Received message: {message}')
messageText = message
messages.append(message)
timestamp = datetime.datetime.now().isoformat()
sender = 'client'
db = sqlite3.connect('chat-hub.db')
db.execute('INSERT INTO messages (sender, message, timestamp) VALUES (?, ?, ?)',
(sender, messageText, timestamp))
db.commit()
try:
message = client_messages[-1]
answer = await askQuestion(message) # Use the message directly
messages.append(answer)
response = {'answer': answer}
serverMessageText = response.get('answer', '')
await ws.send(json.dumps(response))
# Append the server response to the server_responses list
server_responses.append(serverMessageText)
serverSender = 'server'
db.execute('INSERT INTO messages (sender, message, timestamp) VALUES (?, ?, ?)',
(serverSender, serverMessageText, timestamp))
db.commit()
except websockets.exceptions.ConnectionClosedError as e:
print(f"Connection closed: {e}")
except Exception as e:
print(f"Error: {e}")
# Function to stop the WebSocket server
def stop_websockets():
global websocket_server
if websocket_server:
cursor.close()
db.close()
websocket_server.close()
print("WebSocket server stopped.")
else:
print("WebSocket server is not running.")
# Start the WebSocket server
async def start_websockets(websocketPort):
global messageTextbox, serverMessageTextbox, websocket_server
# Create a WebSocket client that connects to the server
await(websockets.serve(handleWebSocket, 'localhost', websocketPort))
used_ports.append(websocketPort)
print(f"Starting WebSocket server on port {websocketPort}...")
return "Used ports:\n" + '\n'.join(map(str, used_ports))
async def start_client():
async with websockets.connect('ws://localhost:5000') as ws:
while True:
# Listen for messages from the server
server_message = await ws.recv()
server_responses.append(server_message)
messages.append(server_message)
client_response = await askQuestion2(server_message)
client_messages.append(client_response)
await ws.send(client_response)
return server_message
await asyncio.sleep(0.1)
with gr.Blocks() as demo:
with gr.Tabs(elem_classes="tab-buttons") as tabs:
with gr.TabItem("Websocket Server", elem_id="websocket_server", id=0):
with gr.Column(scale=1, min_width=600):
with gr.Row():
# Use the client_messages list to update the messageTextbox
client_msg = gr.Textbox(lines=15, max_lines=130, label="Client inputs")
# Use the server_responses list to update the serverMessageTextbox
server_msg = gr.Textbox(lines=15, max_lines=130, label="Server responses")
with gr.Row():
websocketPort = gr.Slider(minimum=1000, maximum=9999, label="Websocket server port", interactive=True, randomize=False)
startWebsockets = gr.Button("Start WebSocket Server")
stopWebsockets = gr.Button("Stop WebSocket Server")
with gr.Row():
Bot1 = gr.Button("Bot 1")
with gr.Row():
gui = gr.Button("connect interface")
with gr.Row():
port = gr.Textbox()
startWebsockets.click(start_websockets, inputs=websocketPort, outputs=port)
Bot1.click(askQuestion, inputs=client_msg, outputs=server_msg)
demo.queue()
demo.launch() |