Files
2026-04-13 09:30:59 +08:00

49 lines
1.8 KiB
JavaScript

// src/server.ts
import { createServer } from "http";
import cluster from "node:cluster";
import { availableParallelism } from "node:os";
import * as process from "process";
var readableToString = (readable) => new Promise((resolve, reject) => {
let data = "";
readable.on("data", (chunk) => data += chunk);
readable.on("end", () => resolve(data));
readable.on("error", (err) => reject(err));
});
var server_default = (render, options) => {
const _port = typeof options === "number" ? options : options?.port ?? 13714;
const _useCluster = typeof options === "object" && options?.cluster !== void 0 ? options.cluster : false;
const log = (message) => {
console.log(
_useCluster && !cluster.isPrimary ? `[${cluster.worker?.id ?? "N/A"} / ${cluster.worker?.process?.pid ?? "N/A"}] ${message}` : message
);
};
if (_useCluster && cluster.isPrimary) {
log("Primary Inertia SSR server process started...");
for (let i = 0; i < availableParallelism(); i++) {
cluster.fork();
}
return;
}
const routes = {
"/health": async () => ({ status: "OK", timestamp: Date.now() }),
"/shutdown": () => process.exit(),
"/render": async (request) => render(JSON.parse(await readableToString(request))),
"/404": async () => ({ status: "NOT_FOUND", timestamp: Date.now() })
};
createServer(async (request, response) => {
const dispatchRoute = routes[request.url] || routes["/404"];
try {
response.writeHead(200, { "Content-Type": "application/json", Server: "Inertia.js SSR" });
response.write(JSON.stringify(await dispatchRoute(request)));
} catch (e) {
console.error(e);
}
response.end();
}).listen(_port, () => log("Inertia SSR server started."));
log(`Starting SSR server on port ${_port}...`);
};
export {
server_default as default
};
//# sourceMappingURL=server.esm.js.map