omnitool_on_hf / myNodeServer.js
manu-sapiens's picture
gave the manager server a console
0b10343
raw
history blame
8.48 kB
const http = require('http');
const { spawn } = require('child_process');
const PROXY_PORT = 4444; // Change this to a port different from 1688
const TARGET_HOST = '127.0.0.1';
const TARGET_PORT = 1688;
let OMNITOOL_READY = false;
let ALREADY_STARTING = false;
const VERSION = '0.0.4a';
console.log(`************ Omnitool Proxy Server v${VERSION} ************`);
let omnitoolLogs = [];
async function startOmnitoolServer()
{
if (ALREADY_STARTING) return;
ALREADY_STARTING = true;
console.log('Starting Omnitool Server...');
return new Promise((resolve, reject) =>
{
const omnitoolStartProcess = spawn('./omnitool_start.sh');
omnitoolStartProcess.stdout.on('data', (data) =>
{
omnitoolLogs.push(data.toString());
console.log(`omnitool stdout: ${data}`);
if (data.toString().includes(`Server has started and is ready to accept connections`))
{
console.log('Omnitool server started successfully');
setTimeout(() => {
OMNITOOL_READY = true;
resolve(); }, 1000); // Delay by 1 second
}
});
omnitoolStartProcess.stderr.on('data', (data) =>
{
console.error(`omnitool stderr: ${data}`);
});
omnitoolStartProcess.on('close', (code) =>
{
console.log(`Omnitool server process exited with code ${code}`);
if (!OMNITOOL_READY)
{
ALREADY_STARTING = false;
reject(`Omnitool server did not start within the timeout period.`);
}
});
});
}
async function startRequestForwardingServer() {
const server = http.createServer((req, res) => handleRoutes(req, res));
server.listen(PROXY_PORT, '0.0.0.0');
console.log(`Request forwarding server listening on port ${PROXY_PORT}`);
}
async function handleRoutes(req, res)
{
if ( !OMNITOOL_READY && (req.method === 'GET'))
{
switch (req.url)
{
case '/start-omnitool-server':
{
console.log(`Omnitool Server:ALREADY_STARTING = ${ALREADY_STARTING}`)
if (ALREADY_STARTING)
{
res.writeHead(200, { 'Content-Type': 'text/html'});
res.end("Omnitool server already starting");
return;
}
try
{
await startOmnitoolServer();
res.writeHead(200, { 'Content-Type': 'text/html'});
res.end("Omnitool server started successfully");
}
catch (error)
{
console.error(error);
ALREADY_STARTING = false;
res.writeHead(500, { 'Content-Type': 'text/html'});
res.end(`Error starting Omnitool server: ${error}`);
}
return;
}
case '/omnitool-logs':
{
res.writeHead(200, { 'Content-Type': 'application/json'});
const reply = { logs: omnitoolLogs, ready: OMNITOOL_READY };
res.end(JSON.stringify(reply));
return;
}
case '/':
{
const localUrl = req.headers['host'];
let htmlContent = `
<html>
<head>
<title>Proxy Server</title>
<style>
#logContainer {
height: 400px; /* Fixed height */
overflow-y: scroll; /* Enable vertical scrolling */
background-color: black;
color: lime;
font-family: 'Courier New', Courier, monospace;
padding: 10px;
white-space: pre-wrap; /* Keep whitespaces */
border: 1px solid #ddd;
}
</style>
</head>
<body>
<button id="startServerButton" onclick="startServer()">Start Omnitool Server</button>
<button id="exitIframeButton" onclick="window.open('http://${localUrl}', '_blank')">GOTO ${localUrl}</button>
<div id="logContainer"></div>
<script>
function startServer() {
document.getElementById('startServerButton').disabled = true;
fetch('/start-omnitool-server')
.then(response => response.json())
.then(data => {
startLogPolling();
});
}
function startLogPolling() {
const interval = setInterval(() => {
fetch('/omnitool-logs')
.then(response => response.json())
.then(data => {
const logContainer = document.getElementById('logContainer');
logContainer.innerText = data.logs.join("\\n");
if (data.ready) {
logContainer.innerText = "Omnitool is ready! Please open the following link in a new tab: https://${localUrl}";
clearInterval(interval);
//window.location.reload(); // Optionally refresh the page when Omnitool is ready
}
scrollToBottom(logContainer);
});
}, 1000); // Adjusted to 1000ms for efficiency
}
function scrollToBottom(element) {
element.scrollTop = element.scrollHeight;
}
startLogPolling();
</script>
</body>
</html>`;
res.writeHead(200, { 'Content-Type': 'text/html' });
res.end(htmlContent);
return;
}
default:
console.log(`Doing nothing with this request: ${req.url}`);
res.writeHead(200, { 'Content-Type': 'text/html' });
res.end(`Doing nothing with this request: ${req.url}`);
return;
}
}
const options = { hostname: TARGET_HOST, port: TARGET_PORT, path: req.url, method: req.method, headers: req.headers, };
const proxy = http.request(options, (proxyRes) =>
{
res.writeHead(proxyRes.statusCode, proxyRes.headers);
proxyRes.pipe(res, { end: true });
});
req.pipe(proxy, { end: true });
return;
}
// Main function to start everything
async function startManagementServer()
{
try
{
await startRequestForwardingServer();
} catch (error)
{
console.error('Failed to start servers:', error);
}
}
// Start the servers
startManagementServer();