|
from fastapi import FastAPI, WebSocket |
|
from fastapi.responses import HTMLResponse |
|
import os |
|
|
|
|
|
app = FastAPI() |
|
|
|
html = """ |
|
<!DOCTYPE html> |
|
<html> |
|
<head> |
|
<title>Chat</title> |
|
</head> |
|
<body> |
|
<h1>WebSocket Chat</h1> |
|
<form action="" onsubmit="sendMessage(event)"> |
|
<input type="text" id="messageText" autocomplete="off"/> |
|
<button>Send</button> |
|
</form> |
|
<ul id='messages'> |
|
</ul> |
|
<script> |
|
// var ws = new WebSocket("ws://localhost:8000/ws"); |
|
var ws = new WebSocket("wss://cahya-websocket.hf.space/ws"); |
|
ws.onmessage = function(event) { |
|
var messages = document.getElementById('messages') |
|
var message = document.createElement('li') |
|
var content = document.createTextNode(event.data) |
|
message.appendChild(content) |
|
messages.appendChild(message) |
|
}; |
|
function sendMessage(event) { |
|
var input = document.getElementById("messageText") |
|
ws.send(input.value) |
|
input.value = '' |
|
event.preventDefault() |
|
} |
|
</script> |
|
</body> |
|
</html> |
|
""" |
|
|
|
|
|
@app.get("/") |
|
async def get(): |
|
return HTMLResponse(html) |
|
|
|
@app.get("/env") |
|
async def env(): |
|
environment_variables = "<h3>Environment Variables</h3>" |
|
for name, value in os.environ.items(): |
|
environment_variables += f"{name}: {value}<br>" |
|
return HTMLResponse(environment_variables) |
|
|
|
@app.websocket("/ws") |
|
async def websocket_endpoint(websocket: WebSocket): |
|
await websocket.accept() |
|
while True: |
|
data = await websocket.receive_text() |
|
await websocket.send_text(f"Message text was: {data}") |
|
|
|
|