Merge pull request #45 from joelmathewthomas/feature/websocket-proxy
Feature/websocket proxy
This commit is contained in:
@@ -35,29 +35,54 @@ function UploadPage() {
|
||||
const startLogs = async () => {
|
||||
setLogs([formatLogMessage("Initializing freqsplit")]);
|
||||
|
||||
setTimeout(() => {
|
||||
setLogs((prevLogs) => [...prevLogs, formatLogMessage("Connecting to server")]);
|
||||
setLogs((prevLogs) => [
|
||||
...prevLogs,
|
||||
formatLogMessage("Connecting to server"),
|
||||
]);
|
||||
|
||||
// Send GET request to /api/ping
|
||||
axios.get("/api/ping")
|
||||
.then((ping_resp) => {
|
||||
if (ping_resp.status === 200) {
|
||||
setTimeout(() => {
|
||||
setLogs((prevLogs) => [...prevLogs, formatLogMessage("Connection established successfully")]);
|
||||
axios
|
||||
.get("/api/ping")
|
||||
.then((ping_resp) => {
|
||||
if (ping_resp.status === 200) {
|
||||
setLogs((prevLogs) => [
|
||||
...prevLogs,
|
||||
formatLogMessage("Connection established successfully"),
|
||||
]);
|
||||
setLogs((prevLogs) => [
|
||||
...prevLogs,
|
||||
formatLogMessage("Waiting for WebSocket connection"),
|
||||
]);
|
||||
|
||||
const checkWebSocketConnection = () => {
|
||||
if (isConnected) {
|
||||
setLogs((prevLogs) => [
|
||||
...prevLogs,
|
||||
formatLogMessage("WebSocket connected"),
|
||||
]);
|
||||
setInputEnabled(true);
|
||||
}, 80);
|
||||
} else {
|
||||
setLogs((prevLogs) => [...prevLogs, formatLogMessage("Failed to connect to server")]);
|
||||
}
|
||||
})
|
||||
.catch(() => {
|
||||
setLogs((prevLogs) => [...prevLogs, formatLogMessage("Failed to connect to server")]);
|
||||
});
|
||||
}, 90);
|
||||
} else {
|
||||
setTimeout(checkWebSocketConnection, 100);
|
||||
}
|
||||
};
|
||||
|
||||
checkWebSocketConnection();
|
||||
} else {
|
||||
setLogs((prevLogs) => [
|
||||
...prevLogs,
|
||||
formatLogMessage("Failed to connect to server"),
|
||||
]);
|
||||
}
|
||||
})
|
||||
.catch(() => {
|
||||
setLogs((prevLogs) => [
|
||||
...prevLogs,
|
||||
formatLogMessage("Failed to connect to server"),
|
||||
]);
|
||||
});
|
||||
};
|
||||
|
||||
startLogs();
|
||||
}, []);
|
||||
}, [isConnected]);
|
||||
|
||||
const handleDragOver = (e: React.DragEvent<HTMLDivElement>) => {
|
||||
e.preventDefault();
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
import React, { createContext, useContext, useEffect, useState } from "react";
|
||||
|
||||
const WEBSOCKET_URL = "ws://localhost:8000/ws/freqsplit/";
|
||||
const WEBSOCKET_URL = "/ws/freqsplit/";
|
||||
|
||||
interface WebSocketContextType {
|
||||
socket: WebSocket | null;
|
||||
|
||||
@@ -10,6 +10,11 @@ export default defineConfig({
|
||||
target: 'http://localhost:8000',
|
||||
changeOrigin: true,
|
||||
},
|
||||
'/ws': {
|
||||
target: "ws://localhost:8000",
|
||||
ws: true,
|
||||
changeOrigin: true,
|
||||
}
|
||||
},
|
||||
},
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user