UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

126 lines (125 loc) 4.57 kB
var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf, __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: !0 }); }, __copyProps = (to, from, except, desc) => { if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: !0 }) : target, mod )), __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod); var registry_exports = {}; __export(registry_exports, { checkServerAlive: () => checkServerAlive, clearRoute: () => clearRoute, createRegistry: () => createRegistry, findServerById: () => findServerById, findServersByBundleId: () => findServersByBundleId, getAllRoutes: () => getAllRoutes, getAllServers: () => getAllServers, getLastActiveServer: () => getLastActiveServer, getRoute: () => getRoute, pruneDeadServers: () => pruneDeadServers, registerServer: () => registerServer, setRoute: () => setRoute, touchServer: () => touchServer, unregisterServer: () => unregisterServer }); module.exports = __toCommonJS(registry_exports); var net = __toESM(require("node:net"), 1); let idCounter = 0; function createRegistry() { return { servers: /* @__PURE__ */ new Map(), routes: /* @__PURE__ */ new Map() }; } function checkServerAlive(server) { return new Promise((resolve) => { const socket = new net.Socket(), timeout = setTimeout(() => { socket.destroy(), resolve(!1); }, 1e3); socket.on("connect", () => { clearTimeout(timeout), socket.destroy(), resolve(!0); }), socket.on("error", () => { clearTimeout(timeout), socket.destroy(), resolve(!1); }), socket.connect(server.port, "127.0.0.1"); }); } async function pruneDeadServers(state, onPruned) { const servers = getAllServers(state); let prunedCount = 0; for (const server of servers) await checkServerAlive(server) || (unregisterServer(state, server.id), onPruned?.(server), prunedCount++); return prunedCount; } function registerServer(state, opts) { const id = `server-${++idCounter}`, registration = { id, port: opts.port, bundleId: opts.bundleId, root: opts.root, registeredAt: Date.now() }; return state.servers.set(id, registration), registration; } function unregisterServer(state, id) { const deleted = state.servers.delete(id); for (const [key, route] of state.routes) route.serverId === id && state.routes.delete(key); return deleted; } function findServersByBundleId(state, bundleId) { const matches = []; for (const server of state.servers.values()) server.bundleId === bundleId && matches.push(server); return matches; } function findServerById(state, id) { return state.servers.get(id); } function setRoute(state, key, serverId) { const binding = { key, serverId, createdAt: Date.now() }; return state.routes.set(key, binding), binding; } function getRoute(state, key) { return state.routes.get(key); } function clearRoute(state, key) { return state.routes.delete(key); } function getAllServers(state) { return Array.from(state.servers.values()); } function getAllRoutes(state) { return Array.from(state.routes.values()); } function touchServer(state, id) { const server = state.servers.get(id); return server ? (server.lastActiveAt = Date.now(), !0) : !1; } function getLastActiveServer(state) { let lastActive = null, maxTime = 0; for (const server of state.servers.values()) { const activeTime = server.lastActiveAt || server.registeredAt; activeTime > maxTime && (maxTime = activeTime, lastActive = server); } return lastActive; } //# sourceMappingURL=registry.js.map