@feynmanzhang/open-party 0.1.8 → 0.1.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/infra/tailscale.ts","../../node_modules/hono/dist/compose.js","../../node_modules/hono/dist/http-exception.js","../../node_modules/hono/dist/request/constants.js","../../node_modules/hono/dist/utils/body.js","../../node_modules/hono/dist/utils/url.js","../../node_modules/hono/dist/request.js","../../node_modules/hono/dist/utils/html.js","../../node_modules/hono/dist/context.js","../../node_modules/hono/dist/router.js","../../node_modules/hono/dist/utils/constants.js","../../node_modules/hono/dist/hono-base.js","../../node_modules/hono/dist/router/reg-exp-router/matcher.js","../../node_modules/hono/dist/router/reg-exp-router/node.js","../../node_modules/hono/dist/router/reg-exp-router/trie.js","../../node_modules/hono/dist/router/reg-exp-router/router.js","../../node_modules/hono/dist/router/reg-exp-router/prepared-router.js","../../node_modules/hono/dist/router/reg-exp-router/index.js","../../node_modules/hono/dist/router/smart-router/router.js","../../node_modules/hono/dist/router/smart-router/index.js","../../node_modules/hono/dist/router/trie-router/node.js","../../node_modules/hono/dist/router/trie-router/router.js","../../node_modules/hono/dist/router/trie-router/index.js","../../node_modules/hono/dist/hono.js","../../node_modules/hono/dist/index.js","../../node_modules/hono/dist/middleware/cors/index.js","../../node_modules/@hono/node-server/dist/index.mjs","../../src/server/config.ts","../../src/server/logger.ts","../../src/server/persistence.ts","../../src/server/ring-buffer.ts","../../src/server/message-queue.ts","../../src/server/peer-discovery.ts","../../src/server/registry.ts","../../src/server/state.ts","../../src/server/models.ts","../../src/server/callback.ts","../../src/server/routes/agent.ts","../../src/server/routes/proxy.ts","../../src/server/index.ts","../../src/cli/setup.ts","../../src/cli/tty-utils.ts","../../src/cli/server-utils.ts","../../src/cli/login.ts","../../src/cli/tailscale-login.ts","../../src/cli/logout.ts","../../src/cli/start-server.ts","../../src/cli/stop-server.ts","../../src/cli/status.ts","../../src/cli/version.ts","../../src/client/shared/client.ts","../../src/cli/list-agents.ts","../../src/cli/peers.ts","../../src/cli/identity.ts","../../src/client/shared/session-store.ts","../../src/cli/send-message.ts","../../src/cli/check-messages.ts","../../src/cli/online.ts","../../src/cli/offline.ts","../../src/cli/registry.ts","../../src/cli/index.ts"],"sourcesContent":["/**\r\n * Tailscale integration for the Party Server.\r\n *\r\n * - Binary discovery and caching\r\n * - Tailnet hostname / IP resolution\r\n * - Status JSON reading (network topology)\r\n * - IP → identity whois with TTL cache\r\n * - Funnel / Serve lifecycle management\r\n */\r\n\r\nimport { execFileSync, execSync } from 'node:child_process';\r\nimport { existsSync } from 'node:fs';\r\nimport { join } from 'node:path';\r\n\r\n// ---------------------------------------------------------------------------\r\n// Helpers\r\n// ---------------------------------------------------------------------------\r\n\r\n/** Extract the first valid JSON object from possibly noisy CLI output. */\r\nfunction parsePossiblyNoisyJson(raw: string): Record<string, unknown> {\r\n const trimmed = raw.trim();\r\n const start = trimmed.indexOf('{');\r\n const end = trimmed.lastIndexOf('}');\r\n if (start >= 0 && end > start) {\r\n return JSON.parse(trimmed.slice(start, end + 1));\r\n }\r\n return JSON.parse(trimmed);\r\n}\r\n\r\n/** Run a command synchronously and return stdout. Throws on non-zero exit. */\r\nfunction runExec(cmd: string[], timeout = 5000): string {\r\n return execFileSync(cmd[0], cmd.slice(1), {\r\n timeout,\r\n encoding: 'utf-8',\r\n stdio: ['pipe', 'pipe', 'pipe'],\r\n windowsHide: true,\r\n });\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Binary discovery\r\n// ---------------------------------------------------------------------------\r\n\r\nlet cachedBinary: string | null = null;\r\n\r\n/** Return true if path exists and can respond to --version. */\r\nfunction checkBinary(path: string, timeout = 3000): boolean {\r\n if (!path || !existsSync(path)) return false;\r\n try {\r\n execFileSync(path, ['--version'], { timeout, encoding: 'utf-8', stdio: 'pipe', windowsHide: true });\r\n return true;\r\n } catch {\r\n // [ANTI-PATTERN IGNORED]: Binary probe — failure means binary invalid, false is correct signal\r\n return false;\r\n }\r\n}\r\n\r\n/** Locate the tailscale binary using multiple strategies. */\r\nfunction findTailscaleBinary(): string | null {\r\n // Strategy 1 – PATH lookup\r\n try {\r\n const which = process.platform === 'win32' ? 'where' : 'which';\r\n const result = execFileSync(which, ['tailscale'], { timeout: 3000, encoding: 'utf-8', stdio: 'pipe', windowsHide: true });\r\n const fromPath = result.trim().split(/\\r?\\n/)[0];\r\n if (fromPath && checkBinary(fromPath)) return fromPath;\r\n } catch {\r\n // [ANTI-PATTERN IGNORED]: PATH probe — not found means not installed via PATH\r\n }\r\n\r\n // Strategy 2 – Known platform paths\r\n const knownPaths = process.platform === 'win32'\r\n ? [\r\n join(process.env.ProgramFiles || 'C:\\\\Program Files', 'Tailscale', 'tailscale.exe'),\r\n join(process.env['ProgramFiles(x86)'] || 'C:\\\\Program Files (x86)', 'Tailscale', 'tailscale.exe'),\r\n join(process.env.LOCALAPPDATA || '', 'Tailscale', 'tailscale.exe'),\r\n ]\r\n : [\r\n '/Applications/Tailscale.app/Contents/MacOS/Tailscale',\r\n '/usr/bin/tailscale',\r\n '/usr/local/bin/tailscale',\r\n ];\r\n\r\n for (const candidate of knownPaths) {\r\n if (checkBinary(candidate)) return candidate;\r\n }\r\n\r\n // Strategy 3 – find in /Applications (macOS only)\r\n if (process.platform !== 'win32') {\r\n try {\r\n const result = execSync(\r\n 'find /Applications -maxdepth 3 -name Tailscale -path \"*/Tailscale.app/Contents/MacOS/Tailscale\"',\r\n { timeout: 5000, encoding: 'utf-8' },\r\n );\r\n const first = result.trim().split('\\n')[0];\r\n if (first && checkBinary(first)) return first;\r\n } catch {\r\n // [ANTI-PATTERN IGNORED]: macOS app search — not found is expected on non-macOS\r\n }\r\n }\r\n\r\n return null;\r\n}\r\n\r\n/** Return a cached tailscale binary path, discovering it on the first call. */\r\nexport function getTailscaleBinary(): string {\r\n const forced = (process.env.OPENCLAW_TEST_TAILSCALE_BINARY ?? '').trim();\r\n if (forced) {\r\n cachedBinary = forced;\r\n return forced;\r\n }\r\n if (cachedBinary !== null) return cachedBinary;\r\n cachedBinary = findTailscaleBinary() ?? (process.platform === 'win32' ? 'tailscale.exe' : 'tailscale');\r\n return cachedBinary;\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Status & hostname\r\n// ---------------------------------------------------------------------------\r\n\r\n/** Run `tailscale status --json` and return the parsed result. */\r\nexport function readTailscaleStatus(timeout = 5000): Record<string, unknown> {\r\n const binary = getTailscaleBinary();\r\n const stdout = runExec([binary, 'status', '--json'], timeout);\r\n return stdout.trim() ? parsePossiblyNoisyJson(stdout) : {};\r\n}\r\n\r\n/** Derive the current device's tailnet hostname or fall back to its first Tailscale IP. */\r\nexport function getTailnetHostname(binary?: string): string {\r\n const candidates = binary\r\n ? [binary]\r\n : [\r\n getTailscaleBinary(),\r\n '/Applications/Tailscale.app/Contents/MacOS/Tailscale',\r\n ];\r\n\r\n let lastErr: Error | null = null;\r\n for (const candidate of candidates) {\r\n if (candidate.startsWith('/') && !existsSync(candidate)) continue;\r\n try {\r\n const stdout = runExec([candidate, 'status', '--json'], 5000);\r\n const parsed = stdout.trim() ? parsePossiblyNoisyJson(stdout) : {};\r\n const selfInfo = (parsed.Self ?? {}) as Record<string, unknown>;\r\n\r\n const dns = selfInfo.DNSName as string | undefined;\r\n if (typeof dns === 'string' && dns) return dns.replace(/\\.$/, '');\r\n\r\n const ips = selfInfo.TailscaleIPs as string[] | undefined;\r\n if (ips && ips.length > 0) return ips[0];\r\n\r\n throw new Error('Could not determine Tailscale DNS or IP');\r\n } catch (exc) {\r\n // [ANTI-PATTERN IGNORED]: Trying multiple binary candidates — lastErr tracks best error for final throw\r\n lastErr = exc as Error;\r\n }\r\n }\r\n throw lastErr ?? new Error('Could not determine Tailscale DNS or IP');\r\n}\r\n\r\n/** Return the list of Tailscale IPs for the current device. */\r\nexport function getTailscaleIps(): string[] {\r\n const status = readTailscaleStatus();\r\n const selfInfo = status.Self as Record<string, unknown> | undefined;\r\n if (selfInfo && Array.isArray(selfInfo.TailscaleIPs)) {\r\n return selfInfo.TailscaleIPs as string[];\r\n }\r\n return [];\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Whois with TTL cache\r\n// ---------------------------------------------------------------------------\r\n\r\nexport class WhoisIdentity {\r\n constructor(\r\n public readonly login: string,\r\n public readonly name?: string,\r\n ) {}\r\n}\r\n\r\ninterface CacheEntry {\r\n value: WhoisIdentity | null;\r\n expiresAt: number;\r\n}\r\n\r\nconst whoisCache = new Map<string, CacheEntry>();\r\n\r\n/** Best-effort extraction of login/name from tailscale whois JSON. */\r\nfunction parseWhoisIdentity(payload: Record<string, unknown>): WhoisIdentity | null {\r\n const userProfile =\r\n (payload.UserProfile as Record<string, unknown>) ??\r\n (payload.userProfile as Record<string, unknown>) ??\r\n (payload.User as Record<string, unknown>) ??\r\n {};\r\n\r\n const login =\r\n (userProfile.LoginName as string) ||\r\n (userProfile.Login as string) ||\r\n (userProfile.login as string) ||\r\n (payload.LoginName as string) ||\r\n (payload.login as string);\r\n\r\n if (typeof login !== 'string' || !login.trim()) return null;\r\n\r\n const rawName =\r\n (userProfile.DisplayName as string) ||\r\n (userProfile.Name as string) ||\r\n (userProfile.displayName as string) ||\r\n (payload.DisplayName as string) ||\r\n (payload.name as string);\r\n\r\n const name = typeof rawName === 'string' ? rawName.trim() : undefined;\r\n return new WhoisIdentity(login.trim(), name);\r\n}\r\n\r\n/** Resolve an IP to a WhoisIdentity via `tailscale whois --json`. */\r\nexport function readWhoisIdentity(\r\n ip: string,\r\n timeout = 5000,\r\n cacheTtl = 60,\r\n errorTtl = 5,\r\n): WhoisIdentity | null {\r\n const normalized = ip.trim();\r\n if (!normalized) return null;\r\n\r\n const now = performance.now() / 1000;\r\n const cached = whoisCache.get(normalized);\r\n if (cached) {\r\n if (cached.expiresAt > now) return cached.value;\r\n whoisCache.delete(normalized);\r\n }\r\n\r\n const binary = getTailscaleBinary();\r\n let identity: WhoisIdentity | null = null;\r\n try {\r\n const stdout = runExec([binary, 'whois', '--json', normalized], timeout);\r\n const parsed = stdout.trim() ? parsePossiblyNoisyJson(stdout) : {};\r\n identity = parseWhoisIdentity(parsed);\r\n } catch (error) {\r\n // [ANTI-PATTERN IGNORED]: Whois lookup failure — cached as null with short TTL, correct degradation\r\n console.error('[Tailscale] Whois lookup failed for', normalized, error instanceof Error ? error.message : error);\r\n }\r\n\r\n const ttl = identity ? cacheTtl : errorTtl;\r\n whoisCache.set(normalized, { value: identity, expiresAt: now + ttl });\r\n return identity;\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Funnel / Serve lifecycle\r\n// ---------------------------------------------------------------------------\r\n\r\nconst PERMISSION_KEYWORDS = [\r\n 'permission denied',\r\n 'access denied',\r\n 'operation not permitted',\r\n 'not permitted',\r\n 'requires root',\r\n 'must be run as root',\r\n 'must be run with sudo',\r\n 'requires sudo',\r\n 'need sudo',\r\n];\r\n\r\n/** Run cmd; on permission errors retry with sudo -n. */\r\nfunction execWithSudoFallback(cmd: string[], timeout = 15000): string {\r\n try {\r\n return runExec(cmd, timeout);\r\n } catch (exc: unknown) {\r\n const err = exc as { stderr?: string };\r\n const stderrLower = (err.stderr ?? '').toLowerCase();\r\n if (PERMISSION_KEYWORDS.some((kw) => stderrLower.includes(kw))) {\r\n try {\r\n return runExec(['sudo', '-n', ...cmd], timeout);\r\n } catch {\r\n // [ANTI-PATTERN IGNORED]: Sudo fallback also failed — throw original error\r\n }\r\n }\r\n throw exc;\r\n }\r\n}\r\n\r\n/** Enable `tailscale serve` on port (background mode). */\r\nexport function enableServe(port: number, timeout = 15000): void {\r\n const binary = getTailscaleBinary();\r\n execWithSudoFallback([binary, 'serve', '--bg', '--yes', String(port)], timeout);\r\n}\r\n\r\n/** Reset `tailscale serve`. */\r\nexport function disableServe(timeout = 15000): void {\r\n const binary = getTailscaleBinary();\r\n execWithSudoFallback([binary, 'serve', 'reset'], timeout);\r\n}\r\n\r\n/** Enable `tailscale funnel` on port (background mode). */\r\nexport function enableFunnel(port: number, timeout = 15000): void {\r\n const binary = getTailscaleBinary();\r\n execWithSudoFallback([binary, 'funnel', '--bg', '--yes', String(port)], timeout);\r\n}\r\n\r\n/** Reset `tailscale funnel`. */\r\nexport function disableFunnel(timeout = 15000): void {\r\n const binary = getTailscaleBinary();\r\n execWithSudoFallback([binary, 'funnel', 'reset'], timeout);\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Network join & connection status\r\n// ---------------------------------------------------------------------------\r\n\r\n/** Join a Tailscale network using an auth key. */\r\nexport function joinTailnet(\r\n authKey: string,\r\n timeout = 30000,\r\n): { success: boolean; output: string } {\r\n const binary = getTailscaleBinary();\r\n try {\r\n const output = execWithSudoFallback(\r\n [binary, 'up', '--authkey', authKey],\r\n timeout,\r\n );\r\n return { success: true, output: output.trim() };\r\n } catch (e) {\r\n // [ANTI-PATTERN IGNORED]: Tailscale command failure — stderr/message extracted for user-facing error return\r\n const err = e as { stderr?: string; message?: string };\r\n return { success: false, output: (err.stderr ?? err.message ?? '').trim() };\r\n }\r\n}\r\n\r\n/** Get the current Tailscale connection status. */\r\nexport function getTailscaleConnectionStatus(): {\r\n connected: boolean;\r\n tailscale_ip: string | null;\r\n hostname: string | null;\r\n error?: string;\r\n} {\r\n try {\r\n const status = readTailscaleStatus();\r\n const self = (status.Self ?? {}) as Record<string, unknown>;\r\n const online = self.Online === true;\r\n const ips = self.TailscaleIPs as string[] | undefined;\r\n const dns = (self.DNSName as string | undefined)?.replace(/\\.$/, '');\r\n return {\r\n connected: online,\r\n tailscale_ip: ips?.[0] ?? null,\r\n hostname: dns ?? null,\r\n };\r\n } catch (error) {\r\n console.error('[Tailscale] Failed to get connection status:', error);\r\n return {\r\n connected: false,\r\n tailscale_ip: null,\r\n hostname: null,\r\n error: error instanceof Error ? error.message : String(error),\r\n };\r\n }\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Tri-state installation status & install instructions\r\n// ---------------------------------------------------------------------------\r\n\r\nexport type TailscaleState =\r\n | { state: 'not_installed'; platform: string }\r\n | { state: 'not_connected'; binary: string; error?: string }\r\n | { state: 'connected'; binary: string; tailscale_ip: string; hostname: string };\r\n\r\n/** Detect Tailscale installation status as one of three states. */\r\nexport function getTailscaleInstallationStatus(): TailscaleState {\r\n // Bypass cache so we always get the real on-disk state\r\n const binary = findTailscaleBinary();\r\n if (!binary) {\r\n return { state: 'not_installed', platform: process.platform };\r\n }\r\n\r\n try {\r\n const status = readTailscaleStatus();\r\n const self = (status.Self ?? {}) as Record<string, unknown>;\r\n const online = self.Online === true;\r\n\r\n if (online) {\r\n const ips = self.TailscaleIPs as string[] | undefined;\r\n const dns = (self.DNSName as string | undefined)?.replace(/\\.$/, '');\r\n return {\r\n state: 'connected',\r\n binary,\r\n tailscale_ip: ips?.[0] ?? '127.0.0.1',\r\n hostname: dns ?? null!,\r\n };\r\n }\r\n\r\n return { state: 'not_connected', binary };\r\n } catch (error) {\r\n console.error('[Tailscale] Failed to get installation status:', error);\r\n return {\r\n state: 'not_connected' as const,\r\n binary,\r\n error: error instanceof Error ? error.message : String(error),\r\n };\r\n }\r\n}\r\n\r\n/** Clear the cached binary path so the next detection re-scans the filesystem. */\r\nexport function resetTailscaleBinaryCache(): void {\r\n cachedBinary = null;\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Logout (full de-authentication)\r\n// ---------------------------------------------------------------------------\r\n\r\n/** Run `tailscale logout` — disconnects and invalidates the node key. */\r\nexport function logoutTailscale(timeout = 15000): { success: boolean; output: string } {\r\n const binary = getTailscaleBinary();\r\n try {\r\n const output = runExec([binary, 'logout'], timeout);\r\n resetTailscaleBinaryCache();\r\n return { success: true, output: output.trim() };\r\n } catch (e) {\r\n // [ANTI-PATTERN IGNORED]: Tailscale command failure — stderr/message extracted for user-facing error return\r\n const err = e as { stderr?: string; message?: string };\r\n return { success: false, output: (err.stderr ?? err.message ?? '').trim() };\r\n }\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Interactive login (browser-based authentication)\r\n// ---------------------------------------------------------------------------\r\n\r\nimport { type ChildProcess, spawn as nodeSpawn } from 'node:child_process';\r\n\r\nexport interface InteractiveLoginResult {\r\n success: boolean;\r\n url?: string;\r\n output: string;\r\n}\r\n\r\n/**\r\n * Start `tailscale login` as a background child process.\r\n *\r\n * `tailscale login` prints an auth URL to stdout, then blocks until the\r\n * user completes authentication in the browser. This function parses that\r\n * URL and returns it immediately — the caller is responsible for polling\r\n * connection status separately (e.g. via `getTailscaleInstallationStatus()`).\r\n *\r\n * The returned `process` reference lets the caller kill it if needed.\r\n */\r\nexport function startInteractiveLogin(): {\r\n promise: Promise<InteractiveLoginResult>;\r\n process: ChildProcess;\r\n} {\r\n const binary = getTailscaleBinary();\r\n const child = nodeSpawn(binary, ['login'], {\r\n stdio: ['pipe', 'pipe', 'pipe'],\r\n windowsHide: true,\r\n });\r\n\r\n const urlRegex = /https:\\/\\/login\\.tailscale\\.com\\/a\\/[^\\s]+/;\r\n\r\n const promise = new Promise<InteractiveLoginResult>((resolve) => {\r\n let stdout = '';\r\n let resolved = false;\r\n\r\n const done = (result: InteractiveLoginResult) => {\r\n if (resolved) return;\r\n resolved = true;\r\n resolve(result);\r\n };\r\n\r\n child.stdout?.on('data', (data: Buffer) => {\r\n stdout += data.toString();\r\n const match = stdout.match(urlRegex);\r\n if (match) {\r\n done({ success: true, url: match[0], output: stdout.trim() });\r\n }\r\n });\r\n\r\n child.stderr?.on('data', (data: Buffer) => {\r\n stdout += data.toString();\r\n });\r\n\r\n child.on('close', (code) => {\r\n if (code === 0) {\r\n done({ success: true, output: stdout.trim() });\r\n } else {\r\n done({ success: false, output: stdout.trim() || `Exited with code ${code}` });\r\n }\r\n });\r\n\r\n child.on('error', (err) => {\r\n done({ success: false, output: err.message });\r\n });\r\n\r\n // Timeout: give up if no URL appears within 30s\r\n setTimeout(() => {\r\n done({ success: false, output: 'Timeout waiting for login URL' });\r\n try { child.kill(); } catch {\r\n // [ANTI-PATTERN IGNORED]: Kill may fail if process already exited\r\n }\r\n }, 30000);\r\n });\r\n\r\n return { promise, process: child };\r\n}\r\n\r\n/** Return platform-specific install instructions for Tailscale. */\r\nexport function getInstallInstructions(platform: string): {\r\n os: string;\r\n download_url: string;\r\n commands: string[];\r\n needs_sudo: boolean;\r\n} {\r\n switch (platform) {\r\n case 'linux':\r\n return {\r\n os: 'linux',\r\n download_url: 'https://tailscale.com/download/linux',\r\n commands: ['curl -fsSL https://tailscale.com/install.sh | sh'],\r\n needs_sudo: true,\r\n };\r\n case 'darwin':\r\n return {\r\n os: 'macOS',\r\n download_url: 'https://tailscale.com/download/mac',\r\n commands: ['brew install tailscale'],\r\n needs_sudo: false,\r\n };\r\n case 'win32':\r\n return {\r\n os: 'windows',\r\n download_url: 'https://tailscale.com/download/windows',\r\n commands: ['winget install Tailscale.Tailscale'],\r\n needs_sudo: false,\r\n };\r\n default:\r\n return {\r\n os: platform,\r\n download_url: 'https://tailscale.com/download/',\r\n commands: [],\r\n needs_sudo: false,\r\n };\r\n }\r\n}\r\n","// src/compose.ts\nvar compose = (middleware, onError, onNotFound) => {\n return (context, next) => {\n let index = -1;\n return dispatch(0);\n async function dispatch(i) {\n if (i <= index) {\n throw new Error(\"next() called multiple times\");\n }\n index = i;\n let res;\n let isError = false;\n let handler;\n if (middleware[i]) {\n handler = middleware[i][0][0];\n context.req.routeIndex = i;\n } else {\n handler = i === middleware.length && next || void 0;\n }\n if (handler) {\n try {\n res = await handler(context, () => dispatch(i + 1));\n } catch (err) {\n if (err instanceof Error && onError) {\n context.error = err;\n res = await onError(err, context);\n isError = true;\n } else {\n throw err;\n }\n }\n } else {\n if (context.finalized === false && onNotFound) {\n res = await onNotFound(context);\n }\n }\n if (res && (context.finalized === false || isError)) {\n context.res = res;\n }\n return context;\n }\n };\n};\nexport {\n compose\n};\n","// src/http-exception.ts\nvar HTTPException = class extends Error {\n res;\n status;\n /**\n * Creates an instance of `HTTPException`.\n * @param status - HTTP status code for the exception. Defaults to 500.\n * @param options - Additional options for the exception.\n */\n constructor(status = 500, options) {\n super(options?.message, { cause: options?.cause });\n this.res = options?.res;\n this.status = status;\n }\n /**\n * Returns the response object associated with the exception.\n * If a response object is not provided, a new response is created with the error message and status code.\n * @returns The response object.\n */\n getResponse() {\n if (this.res) {\n const newResponse = new Response(this.res.body, {\n status: this.status,\n headers: this.res.headers\n });\n return newResponse;\n }\n return new Response(this.message, {\n status: this.status\n });\n }\n};\nexport {\n HTTPException\n};\n","// src/request/constants.ts\nvar GET_MATCH_RESULT = /* @__PURE__ */ Symbol();\nexport {\n GET_MATCH_RESULT\n};\n","// src/utils/body.ts\nimport { HonoRequest } from \"../request.js\";\nvar parseBody = async (request, options = /* @__PURE__ */ Object.create(null)) => {\n const { all = false, dot = false } = options;\n const headers = request instanceof HonoRequest ? request.raw.headers : request.headers;\n const contentType = headers.get(\"Content-Type\");\n if (contentType?.startsWith(\"multipart/form-data\") || contentType?.startsWith(\"application/x-www-form-urlencoded\")) {\n return parseFormData(request, { all, dot });\n }\n return {};\n};\nasync function parseFormData(request, options) {\n const formData = await request.formData();\n if (formData) {\n return convertFormDataToBodyData(formData, options);\n }\n return {};\n}\nfunction convertFormDataToBodyData(formData, options) {\n const form = /* @__PURE__ */ Object.create(null);\n formData.forEach((value, key) => {\n const shouldParseAllValues = options.all || key.endsWith(\"[]\");\n if (!shouldParseAllValues) {\n form[key] = value;\n } else {\n handleParsingAllValues(form, key, value);\n }\n });\n if (options.dot) {\n Object.entries(form).forEach(([key, value]) => {\n const shouldParseDotValues = key.includes(\".\");\n if (shouldParseDotValues) {\n handleParsingNestedValues(form, key, value);\n delete form[key];\n }\n });\n }\n return form;\n}\nvar handleParsingAllValues = (form, key, value) => {\n if (form[key] !== void 0) {\n if (Array.isArray(form[key])) {\n ;\n form[key].push(value);\n } else {\n form[key] = [form[key], value];\n }\n } else {\n if (!key.endsWith(\"[]\")) {\n form[key] = value;\n } else {\n form[key] = [value];\n }\n }\n};\nvar handleParsingNestedValues = (form, key, value) => {\n if (/(?:^|\\.)__proto__\\./.test(key)) {\n return;\n }\n let nestedForm = form;\n const keys = key.split(\".\");\n keys.forEach((key2, index) => {\n if (index === keys.length - 1) {\n nestedForm[key2] = value;\n } else {\n if (!nestedForm[key2] || typeof nestedForm[key2] !== \"object\" || Array.isArray(nestedForm[key2]) || nestedForm[key2] instanceof File) {\n nestedForm[key2] = /* @__PURE__ */ Object.create(null);\n }\n nestedForm = nestedForm[key2];\n }\n });\n};\nexport {\n parseBody\n};\n","// src/utils/url.ts\nvar splitPath = (path) => {\n const paths = path.split(\"/\");\n if (paths[0] === \"\") {\n paths.shift();\n }\n return paths;\n};\nvar splitRoutingPath = (routePath) => {\n const { groups, path } = extractGroupsFromPath(routePath);\n const paths = splitPath(path);\n return replaceGroupMarks(paths, groups);\n};\nvar extractGroupsFromPath = (path) => {\n const groups = [];\n path = path.replace(/\\{[^}]+\\}/g, (match, index) => {\n const mark = `@${index}`;\n groups.push([mark, match]);\n return mark;\n });\n return { groups, path };\n};\nvar replaceGroupMarks = (paths, groups) => {\n for (let i = groups.length - 1; i >= 0; i--) {\n const [mark] = groups[i];\n for (let j = paths.length - 1; j >= 0; j--) {\n if (paths[j].includes(mark)) {\n paths[j] = paths[j].replace(mark, groups[i][1]);\n break;\n }\n }\n }\n return paths;\n};\nvar patternCache = {};\nvar getPattern = (label, next) => {\n if (label === \"*\") {\n return \"*\";\n }\n const match = label.match(/^\\:([^\\{\\}]+)(?:\\{(.+)\\})?$/);\n if (match) {\n const cacheKey = `${label}#${next}`;\n if (!patternCache[cacheKey]) {\n if (match[2]) {\n patternCache[cacheKey] = next && next[0] !== \":\" && next[0] !== \"*\" ? [cacheKey, match[1], new RegExp(`^${match[2]}(?=/${next})`)] : [label, match[1], new RegExp(`^${match[2]}$`)];\n } else {\n patternCache[cacheKey] = [label, match[1], true];\n }\n }\n return patternCache[cacheKey];\n }\n return null;\n};\nvar tryDecode = (str, decoder) => {\n try {\n return decoder(str);\n } catch {\n return str.replace(/(?:%[0-9A-Fa-f]{2})+/g, (match) => {\n try {\n return decoder(match);\n } catch {\n return match;\n }\n });\n }\n};\nvar tryDecodeURI = (str) => tryDecode(str, decodeURI);\nvar getPath = (request) => {\n const url = request.url;\n const start = url.indexOf(\"/\", url.indexOf(\":\") + 4);\n let i = start;\n for (; i < url.length; i++) {\n const charCode = url.charCodeAt(i);\n if (charCode === 37) {\n const queryIndex = url.indexOf(\"?\", i);\n const hashIndex = url.indexOf(\"#\", i);\n const end = queryIndex === -1 ? hashIndex === -1 ? void 0 : hashIndex : hashIndex === -1 ? queryIndex : Math.min(queryIndex, hashIndex);\n const path = url.slice(start, end);\n return tryDecodeURI(path.includes(\"%25\") ? path.replace(/%25/g, \"%2525\") : path);\n } else if (charCode === 63 || charCode === 35) {\n break;\n }\n }\n return url.slice(start, i);\n};\nvar getQueryStrings = (url) => {\n const queryIndex = url.indexOf(\"?\", 8);\n return queryIndex === -1 ? \"\" : \"?\" + url.slice(queryIndex + 1);\n};\nvar getPathNoStrict = (request) => {\n const result = getPath(request);\n return result.length > 1 && result.at(-1) === \"/\" ? result.slice(0, -1) : result;\n};\nvar mergePath = (base, sub, ...rest) => {\n if (rest.length) {\n sub = mergePath(sub, ...rest);\n }\n return `${base?.[0] === \"/\" ? \"\" : \"/\"}${base}${sub === \"/\" ? \"\" : `${base?.at(-1) === \"/\" ? \"\" : \"/\"}${sub?.[0] === \"/\" ? sub.slice(1) : sub}`}`;\n};\nvar checkOptionalParameter = (path) => {\n if (path.charCodeAt(path.length - 1) !== 63 || !path.includes(\":\")) {\n return null;\n }\n const segments = path.split(\"/\");\n const results = [];\n let basePath = \"\";\n segments.forEach((segment) => {\n if (segment !== \"\" && !/\\:/.test(segment)) {\n basePath += \"/\" + segment;\n } else if (/\\:/.test(segment)) {\n if (/\\?/.test(segment)) {\n if (results.length === 0 && basePath === \"\") {\n results.push(\"/\");\n } else {\n results.push(basePath);\n }\n const optionalSegment = segment.replace(\"?\", \"\");\n basePath += \"/\" + optionalSegment;\n results.push(basePath);\n } else {\n basePath += \"/\" + segment;\n }\n }\n });\n return results.filter((v, i, a) => a.indexOf(v) === i);\n};\nvar _decodeURI = (value) => {\n if (!/[%+]/.test(value)) {\n return value;\n }\n if (value.indexOf(\"+\") !== -1) {\n value = value.replace(/\\+/g, \" \");\n }\n return value.indexOf(\"%\") !== -1 ? tryDecode(value, decodeURIComponent_) : value;\n};\nvar _getQueryParam = (url, key, multiple) => {\n let encoded;\n if (!multiple && key && !/[%+]/.test(key)) {\n let keyIndex2 = url.indexOf(\"?\", 8);\n if (keyIndex2 === -1) {\n return void 0;\n }\n if (!url.startsWith(key, keyIndex2 + 1)) {\n keyIndex2 = url.indexOf(`&${key}`, keyIndex2 + 1);\n }\n while (keyIndex2 !== -1) {\n const trailingKeyCode = url.charCodeAt(keyIndex2 + key.length + 1);\n if (trailingKeyCode === 61) {\n const valueIndex = keyIndex2 + key.length + 2;\n const endIndex = url.indexOf(\"&\", valueIndex);\n return _decodeURI(url.slice(valueIndex, endIndex === -1 ? void 0 : endIndex));\n } else if (trailingKeyCode == 38 || isNaN(trailingKeyCode)) {\n return \"\";\n }\n keyIndex2 = url.indexOf(`&${key}`, keyIndex2 + 1);\n }\n encoded = /[%+]/.test(url);\n if (!encoded) {\n return void 0;\n }\n }\n const results = {};\n encoded ??= /[%+]/.test(url);\n let keyIndex = url.indexOf(\"?\", 8);\n while (keyIndex !== -1) {\n const nextKeyIndex = url.indexOf(\"&\", keyIndex + 1);\n let valueIndex = url.indexOf(\"=\", keyIndex);\n if (valueIndex > nextKeyIndex && nextKeyIndex !== -1) {\n valueIndex = -1;\n }\n let name = url.slice(\n keyIndex + 1,\n valueIndex === -1 ? nextKeyIndex === -1 ? void 0 : nextKeyIndex : valueIndex\n );\n if (encoded) {\n name = _decodeURI(name);\n }\n keyIndex = nextKeyIndex;\n if (name === \"\") {\n continue;\n }\n let value;\n if (valueIndex === -1) {\n value = \"\";\n } else {\n value = url.slice(valueIndex + 1, nextKeyIndex === -1 ? void 0 : nextKeyIndex);\n if (encoded) {\n value = _decodeURI(value);\n }\n }\n if (multiple) {\n if (!(results[name] && Array.isArray(results[name]))) {\n results[name] = [];\n }\n ;\n results[name].push(value);\n } else {\n results[name] ??= value;\n }\n }\n return key ? results[key] : results;\n};\nvar getQueryParam = _getQueryParam;\nvar getQueryParams = (url, key) => {\n return _getQueryParam(url, key, true);\n};\nvar decodeURIComponent_ = decodeURIComponent;\nexport {\n checkOptionalParameter,\n decodeURIComponent_,\n getPath,\n getPathNoStrict,\n getPattern,\n getQueryParam,\n getQueryParams,\n getQueryStrings,\n mergePath,\n splitPath,\n splitRoutingPath,\n tryDecode,\n tryDecodeURI\n};\n","// src/request.ts\nimport { HTTPException } from \"./http-exception.js\";\nimport { GET_MATCH_RESULT } from \"./request/constants.js\";\nimport { parseBody } from \"./utils/body.js\";\nimport { decodeURIComponent_, getQueryParam, getQueryParams, tryDecode } from \"./utils/url.js\";\nvar tryDecodeURIComponent = (str) => tryDecode(str, decodeURIComponent_);\nvar HonoRequest = class {\n /**\n * `.raw` can get the raw Request object.\n *\n * @see {@link https://hono.dev/docs/api/request#raw}\n *\n * @example\n * ```ts\n * // For Cloudflare Workers\n * app.post('/', async (c) => {\n * const metadata = c.req.raw.cf?.hostMetadata?\n * ...\n * })\n * ```\n */\n raw;\n #validatedData;\n // Short name of validatedData\n #matchResult;\n routeIndex = 0;\n /**\n * `.path` can get the pathname of the request.\n *\n * @see {@link https://hono.dev/docs/api/request#path}\n *\n * @example\n * ```ts\n * app.get('/about/me', (c) => {\n * const pathname = c.req.path // `/about/me`\n * })\n * ```\n */\n path;\n bodyCache = {};\n constructor(request, path = \"/\", matchResult = [[]]) {\n this.raw = request;\n this.path = path;\n this.#matchResult = matchResult;\n this.#validatedData = {};\n }\n param(key) {\n return key ? this.#getDecodedParam(key) : this.#getAllDecodedParams();\n }\n #getDecodedParam(key) {\n const paramKey = this.#matchResult[0][this.routeIndex][1][key];\n const param = this.#getParamValue(paramKey);\n return param && /\\%/.test(param) ? tryDecodeURIComponent(param) : param;\n }\n #getAllDecodedParams() {\n const decoded = {};\n const keys = Object.keys(this.#matchResult[0][this.routeIndex][1]);\n for (const key of keys) {\n const value = this.#getParamValue(this.#matchResult[0][this.routeIndex][1][key]);\n if (value !== void 0) {\n decoded[key] = /\\%/.test(value) ? tryDecodeURIComponent(value) : value;\n }\n }\n return decoded;\n }\n #getParamValue(paramKey) {\n return this.#matchResult[1] ? this.#matchResult[1][paramKey] : paramKey;\n }\n query(key) {\n return getQueryParam(this.url, key);\n }\n queries(key) {\n return getQueryParams(this.url, key);\n }\n header(name) {\n if (name) {\n return this.raw.headers.get(name) ?? void 0;\n }\n const headerData = {};\n this.raw.headers.forEach((value, key) => {\n headerData[key] = value;\n });\n return headerData;\n }\n async parseBody(options) {\n return parseBody(this, options);\n }\n #cachedBody = (key) => {\n const { bodyCache, raw } = this;\n const cachedBody = bodyCache[key];\n if (cachedBody) {\n return cachedBody;\n }\n const anyCachedKey = Object.keys(bodyCache)[0];\n if (anyCachedKey) {\n return bodyCache[anyCachedKey].then((body) => {\n if (anyCachedKey === \"json\") {\n body = JSON.stringify(body);\n }\n return new Response(body)[key]();\n });\n }\n return bodyCache[key] = raw[key]();\n };\n /**\n * `.json()` can parse Request body of type `application/json`\n *\n * @see {@link https://hono.dev/docs/api/request#json}\n *\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.json()\n * })\n * ```\n */\n json() {\n return this.#cachedBody(\"text\").then((text) => JSON.parse(text));\n }\n /**\n * `.text()` can parse Request body of type `text/plain`\n *\n * @see {@link https://hono.dev/docs/api/request#text}\n *\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.text()\n * })\n * ```\n */\n text() {\n return this.#cachedBody(\"text\");\n }\n /**\n * `.arrayBuffer()` parse Request body as an `ArrayBuffer`\n *\n * @see {@link https://hono.dev/docs/api/request#arraybuffer}\n *\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.arrayBuffer()\n * })\n * ```\n */\n arrayBuffer() {\n return this.#cachedBody(\"arrayBuffer\");\n }\n /**\n * `.bytes()` parses the request body as a `Uint8Array`.\n *\n * @see {@link https://hono.dev/docs/api/request#bytes}\n *\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.bytes()\n * })\n * ```\n */\n bytes() {\n return this.#cachedBody(\"arrayBuffer\").then((buffer) => new Uint8Array(buffer));\n }\n /**\n * Parses the request body as a `Blob`.\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.blob();\n * });\n * ```\n * @see https://hono.dev/docs/api/request#blob\n */\n blob() {\n return this.#cachedBody(\"blob\");\n }\n /**\n * Parses the request body as `FormData`.\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.formData();\n * });\n * ```\n * @see https://hono.dev/docs/api/request#formdata\n */\n formData() {\n return this.#cachedBody(\"formData\");\n }\n /**\n * Adds validated data to the request.\n *\n * @param target - The target of the validation.\n * @param data - The validated data to add.\n */\n addValidatedData(target, data) {\n this.#validatedData[target] = data;\n }\n valid(target) {\n return this.#validatedData[target];\n }\n /**\n * `.url()` can get the request url strings.\n *\n * @see {@link https://hono.dev/docs/api/request#url}\n *\n * @example\n * ```ts\n * app.get('/about/me', (c) => {\n * const url = c.req.url // `http://localhost:8787/about/me`\n * ...\n * })\n * ```\n */\n get url() {\n return this.raw.url;\n }\n /**\n * `.method()` can get the method name of the request.\n *\n * @see {@link https://hono.dev/docs/api/request#method}\n *\n * @example\n * ```ts\n * app.get('/about/me', (c) => {\n * const method = c.req.method // `GET`\n * })\n * ```\n */\n get method() {\n return this.raw.method;\n }\n get [GET_MATCH_RESULT]() {\n return this.#matchResult;\n }\n /**\n * `.matchedRoutes()` can return a matched route in the handler\n *\n * @deprecated\n *\n * Use matchedRoutes helper defined in \"hono/route\" instead.\n *\n * @see {@link https://hono.dev/docs/api/request#matchedroutes}\n *\n * @example\n * ```ts\n * app.use('*', async function logger(c, next) {\n * await next()\n * c.req.matchedRoutes.forEach(({ handler, method, path }, i) => {\n * const name = handler.name || (handler.length < 2 ? '[handler]' : '[middleware]')\n * console.log(\n * method,\n * ' ',\n * path,\n * ' '.repeat(Math.max(10 - path.length, 0)),\n * name,\n * i === c.req.routeIndex ? '<- respond from here' : ''\n * )\n * })\n * })\n * ```\n */\n get matchedRoutes() {\n return this.#matchResult[0].map(([[, route]]) => route);\n }\n /**\n * `routePath()` can retrieve the path registered within the handler\n *\n * @deprecated\n *\n * Use routePath helper defined in \"hono/route\" instead.\n *\n * @see {@link https://hono.dev/docs/api/request#routepath}\n *\n * @example\n * ```ts\n * app.get('/posts/:id', (c) => {\n * return c.json({ path: c.req.routePath })\n * })\n * ```\n */\n get routePath() {\n return this.#matchResult[0].map(([[, route]]) => route)[this.routeIndex].path;\n }\n};\nvar cloneRawRequest = async (req) => {\n if (!req.raw.bodyUsed) {\n return req.raw.clone();\n }\n const cacheKey = Object.keys(req.bodyCache)[0];\n if (!cacheKey) {\n throw new HTTPException(500, {\n message: \"Cannot clone request: body was already consumed and not cached. Please use HonoRequest methods (e.g., req.json(), req.text()) instead of consuming req.raw directly.\"\n });\n }\n const requestInit = {\n body: await req[cacheKey](),\n cache: req.raw.cache,\n credentials: req.raw.credentials,\n headers: req.header(),\n integrity: req.raw.integrity,\n keepalive: req.raw.keepalive,\n method: req.method,\n mode: req.raw.mode,\n redirect: req.raw.redirect,\n referrer: req.raw.referrer,\n referrerPolicy: req.raw.referrerPolicy,\n signal: req.raw.signal\n };\n return new Request(req.url, requestInit);\n};\nexport {\n HonoRequest,\n cloneRawRequest\n};\n","// src/utils/html.ts\nvar HtmlEscapedCallbackPhase = {\n Stringify: 1,\n BeforeStream: 2,\n Stream: 3\n};\nvar raw = (value, callbacks) => {\n const escapedString = new String(value);\n escapedString.isEscaped = true;\n escapedString.callbacks = callbacks;\n return escapedString;\n};\nvar escapeRe = /[&<>'\"]/;\nvar stringBufferToString = async (buffer, callbacks) => {\n let str = \"\";\n callbacks ||= [];\n const resolvedBuffer = await Promise.all(buffer);\n for (let i = resolvedBuffer.length - 1; ; i--) {\n str += resolvedBuffer[i];\n i--;\n if (i < 0) {\n break;\n }\n let r = resolvedBuffer[i];\n if (typeof r === \"object\") {\n callbacks.push(...r.callbacks || []);\n }\n const isEscaped = r.isEscaped;\n r = await (typeof r === \"object\" ? r.toString() : r);\n if (typeof r === \"object\") {\n callbacks.push(...r.callbacks || []);\n }\n if (r.isEscaped ?? isEscaped) {\n str += r;\n } else {\n const buf = [str];\n escapeToBuffer(r, buf);\n str = buf[0];\n }\n }\n return raw(str, callbacks);\n};\nvar escapeToBuffer = (str, buffer) => {\n const match = str.search(escapeRe);\n if (match === -1) {\n buffer[0] += str;\n return;\n }\n let escape;\n let index;\n let lastIndex = 0;\n for (index = match; index < str.length; index++) {\n switch (str.charCodeAt(index)) {\n case 34:\n escape = \"&quot;\";\n break;\n case 39:\n escape = \"&#39;\";\n break;\n case 38:\n escape = \"&amp;\";\n break;\n case 60:\n escape = \"&lt;\";\n break;\n case 62:\n escape = \"&gt;\";\n break;\n default:\n continue;\n }\n buffer[0] += str.substring(lastIndex, index) + escape;\n lastIndex = index + 1;\n }\n buffer[0] += str.substring(lastIndex, index);\n};\nvar resolveCallbackSync = (str) => {\n const callbacks = str.callbacks;\n if (!callbacks?.length) {\n return str;\n }\n const buffer = [str];\n const context = {};\n callbacks.forEach((c) => c({ phase: HtmlEscapedCallbackPhase.Stringify, buffer, context }));\n return buffer[0];\n};\nvar resolveCallback = async (str, phase, preserveCallbacks, context, buffer) => {\n if (typeof str === \"object\" && !(str instanceof String)) {\n if (!(str instanceof Promise)) {\n str = str.toString();\n }\n if (str instanceof Promise) {\n str = await str;\n }\n }\n const callbacks = str.callbacks;\n if (!callbacks?.length) {\n return Promise.resolve(str);\n }\n if (buffer) {\n buffer[0] += str;\n } else {\n buffer = [str];\n }\n const resStr = Promise.all(callbacks.map((c) => c({ phase, buffer, context }))).then(\n (res) => Promise.all(\n res.filter(Boolean).map((str2) => resolveCallback(str2, phase, false, context, buffer))\n ).then(() => buffer[0])\n );\n if (preserveCallbacks) {\n return raw(await resStr, callbacks);\n } else {\n return resStr;\n }\n};\nexport {\n HtmlEscapedCallbackPhase,\n escapeToBuffer,\n raw,\n resolveCallback,\n resolveCallbackSync,\n stringBufferToString\n};\n","// src/context.ts\nimport { HonoRequest } from \"./request.js\";\nimport { HtmlEscapedCallbackPhase, resolveCallback } from \"./utils/html.js\";\nvar TEXT_PLAIN = \"text/plain; charset=UTF-8\";\nvar setDefaultContentType = (contentType, headers) => {\n return {\n \"Content-Type\": contentType,\n ...headers\n };\n};\nvar createResponseInstance = (body, init) => new Response(body, init);\nvar Context = class {\n #rawRequest;\n #req;\n /**\n * `.env` can get bindings (environment variables, secrets, KV namespaces, D1 database, R2 bucket etc.) in Cloudflare Workers.\n *\n * @see {@link https://hono.dev/docs/api/context#env}\n *\n * @example\n * ```ts\n * // Environment object for Cloudflare Workers\n * app.get('*', async c => {\n * const counter = c.env.COUNTER\n * })\n * ```\n */\n env = {};\n #var;\n finalized = false;\n /**\n * `.error` can get the error object from the middleware if the Handler throws an error.\n *\n * @see {@link https://hono.dev/docs/api/context#error}\n *\n * @example\n * ```ts\n * app.use('*', async (c, next) => {\n * await next()\n * if (c.error) {\n * // do something...\n * }\n * })\n * ```\n */\n error;\n #status;\n #executionCtx;\n #res;\n #layout;\n #renderer;\n #notFoundHandler;\n #preparedHeaders;\n #matchResult;\n #path;\n /**\n * Creates an instance of the Context class.\n *\n * @param req - The Request object.\n * @param options - Optional configuration options for the context.\n */\n constructor(req, options) {\n this.#rawRequest = req;\n if (options) {\n this.#executionCtx = options.executionCtx;\n this.env = options.env;\n this.#notFoundHandler = options.notFoundHandler;\n this.#path = options.path;\n this.#matchResult = options.matchResult;\n }\n }\n /**\n * `.req` is the instance of {@link HonoRequest}.\n */\n get req() {\n this.#req ??= new HonoRequest(this.#rawRequest, this.#path, this.#matchResult);\n return this.#req;\n }\n /**\n * @see {@link https://hono.dev/docs/api/context#event}\n * The FetchEvent associated with the current request.\n *\n * @throws Will throw an error if the context does not have a FetchEvent.\n */\n get event() {\n if (this.#executionCtx && \"respondWith\" in this.#executionCtx) {\n return this.#executionCtx;\n } else {\n throw Error(\"This context has no FetchEvent\");\n }\n }\n /**\n * @see {@link https://hono.dev/docs/api/context#executionctx}\n * The ExecutionContext associated with the current request.\n *\n * @throws Will throw an error if the context does not have an ExecutionContext.\n */\n get executionCtx() {\n if (this.#executionCtx) {\n return this.#executionCtx;\n } else {\n throw Error(\"This context has no ExecutionContext\");\n }\n }\n /**\n * @see {@link https://hono.dev/docs/api/context#res}\n * The Response object for the current request.\n */\n get res() {\n return this.#res ||= createResponseInstance(null, {\n headers: this.#preparedHeaders ??= new Headers()\n });\n }\n /**\n * Sets the Response object for the current request.\n *\n * @param _res - The Response object to set.\n */\n set res(_res) {\n if (this.#res && _res) {\n _res = createResponseInstance(_res.body, _res);\n for (const [k, v] of this.#res.headers.entries()) {\n if (k === \"content-type\") {\n continue;\n }\n if (k === \"set-cookie\") {\n const cookies = this.#res.headers.getSetCookie();\n _res.headers.delete(\"set-cookie\");\n for (const cookie of cookies) {\n _res.headers.append(\"set-cookie\", cookie);\n }\n } else {\n _res.headers.set(k, v);\n }\n }\n }\n this.#res = _res;\n this.finalized = true;\n }\n /**\n * `.render()` can create a response within a layout.\n *\n * @see {@link https://hono.dev/docs/api/context#render-setrenderer}\n *\n * @example\n * ```ts\n * app.get('/', (c) => {\n * return c.render('Hello!')\n * })\n * ```\n */\n render = (...args) => {\n this.#renderer ??= (content) => this.html(content);\n return this.#renderer(...args);\n };\n /**\n * Sets the layout for the response.\n *\n * @param layout - The layout to set.\n * @returns The layout function.\n */\n setLayout = (layout) => this.#layout = layout;\n /**\n * Gets the current layout for the response.\n *\n * @returns The current layout function.\n */\n getLayout = () => this.#layout;\n /**\n * `.setRenderer()` can set the layout in the custom middleware.\n *\n * @see {@link https://hono.dev/docs/api/context#render-setrenderer}\n *\n * @example\n * ```tsx\n * app.use('*', async (c, next) => {\n * c.setRenderer((content) => {\n * return c.html(\n * <html>\n * <body>\n * <p>{content}</p>\n * </body>\n * </html>\n * )\n * })\n * await next()\n * })\n * ```\n */\n setRenderer = (renderer) => {\n this.#renderer = renderer;\n };\n /**\n * `.header()` can set headers.\n *\n * @see {@link https://hono.dev/docs/api/context#header}\n *\n * @example\n * ```ts\n * app.get('/welcome', (c) => {\n * // Set headers\n * c.header('X-Message', 'Hello!')\n * c.header('Content-Type', 'text/plain')\n *\n * return c.body('Thank you for coming')\n * })\n * ```\n */\n header = (name, value, options) => {\n if (this.finalized) {\n this.#res = createResponseInstance(this.#res.body, this.#res);\n }\n const headers = this.#res ? this.#res.headers : this.#preparedHeaders ??= new Headers();\n if (value === void 0) {\n headers.delete(name);\n } else if (options?.append) {\n headers.append(name, value);\n } else {\n headers.set(name, value);\n }\n };\n status = (status) => {\n this.#status = status;\n };\n /**\n * `.set()` can set the value specified by the key.\n *\n * @see {@link https://hono.dev/docs/api/context#set-get}\n *\n * @example\n * ```ts\n * app.use('*', async (c, next) => {\n * c.set('message', 'Hono is hot!!')\n * await next()\n * })\n * ```\n */\n set = (key, value) => {\n this.#var ??= /* @__PURE__ */ new Map();\n this.#var.set(key, value);\n };\n /**\n * `.get()` can use the value specified by the key.\n *\n * @see {@link https://hono.dev/docs/api/context#set-get}\n *\n * @example\n * ```ts\n * app.get('/', (c) => {\n * const message = c.get('message')\n * return c.text(`The message is \"${message}\"`)\n * })\n * ```\n */\n get = (key) => {\n return this.#var ? this.#var.get(key) : void 0;\n };\n /**\n * `.var` can access the value of a variable.\n *\n * @see {@link https://hono.dev/docs/api/context#var}\n *\n * @example\n * ```ts\n * const result = c.var.client.oneMethod()\n * ```\n */\n // c.var.propName is a read-only\n get var() {\n if (!this.#var) {\n return {};\n }\n return Object.fromEntries(this.#var);\n }\n #newResponse(data, arg, headers) {\n const responseHeaders = this.#res ? new Headers(this.#res.headers) : this.#preparedHeaders ?? new Headers();\n if (typeof arg === \"object\" && \"headers\" in arg) {\n const argHeaders = arg.headers instanceof Headers ? arg.headers : new Headers(arg.headers);\n for (const [key, value] of argHeaders) {\n if (key.toLowerCase() === \"set-cookie\") {\n responseHeaders.append(key, value);\n } else {\n responseHeaders.set(key, value);\n }\n }\n }\n if (headers) {\n for (const [k, v] of Object.entries(headers)) {\n if (typeof v === \"string\") {\n responseHeaders.set(k, v);\n } else {\n responseHeaders.delete(k);\n for (const v2 of v) {\n responseHeaders.append(k, v2);\n }\n }\n }\n }\n const status = typeof arg === \"number\" ? arg : arg?.status ?? this.#status;\n return createResponseInstance(data, { status, headers: responseHeaders });\n }\n newResponse = (...args) => this.#newResponse(...args);\n /**\n * `.body()` can return the HTTP response.\n * You can set headers with `.header()` and set HTTP status code with `.status`.\n * This can also be set in `.text()`, `.json()` and so on.\n *\n * @see {@link https://hono.dev/docs/api/context#body}\n *\n * @example\n * ```ts\n * app.get('/welcome', (c) => {\n * // Set headers\n * c.header('X-Message', 'Hello!')\n * c.header('Content-Type', 'text/plain')\n * // Set HTTP status code\n * c.status(201)\n *\n * // Return the response body\n * return c.body('Thank you for coming')\n * })\n * ```\n */\n body = (data, arg, headers) => this.#newResponse(data, arg, headers);\n /**\n * `.text()` can render text as `Content-Type:text/plain`.\n *\n * @see {@link https://hono.dev/docs/api/context#text}\n *\n * @example\n * ```ts\n * app.get('/say', (c) => {\n * return c.text('Hello!')\n * })\n * ```\n */\n text = (text, arg, headers) => {\n return !this.#preparedHeaders && !this.#status && !arg && !headers && !this.finalized ? new Response(text) : this.#newResponse(\n text,\n arg,\n setDefaultContentType(TEXT_PLAIN, headers)\n );\n };\n /**\n * `.json()` can render JSON as `Content-Type:application/json`.\n *\n * @see {@link https://hono.dev/docs/api/context#json}\n *\n * @example\n * ```ts\n * app.get('/api', (c) => {\n * return c.json({ message: 'Hello!' })\n * })\n * ```\n */\n json = (object, arg, headers) => {\n return this.#newResponse(\n JSON.stringify(object),\n arg,\n setDefaultContentType(\"application/json\", headers)\n );\n };\n html = (html, arg, headers) => {\n const res = (html2) => this.#newResponse(html2, arg, setDefaultContentType(\"text/html; charset=UTF-8\", headers));\n return typeof html === \"object\" ? resolveCallback(html, HtmlEscapedCallbackPhase.Stringify, false, {}).then(res) : res(html);\n };\n /**\n * `.redirect()` can Redirect, default status code is 302.\n *\n * @see {@link https://hono.dev/docs/api/context#redirect}\n *\n * @example\n * ```ts\n * app.get('/redirect', (c) => {\n * return c.redirect('/')\n * })\n * app.get('/redirect-permanently', (c) => {\n * return c.redirect('/', 301)\n * })\n * ```\n */\n redirect = (location, status) => {\n const locationString = String(location);\n this.header(\n \"Location\",\n // Multibyes should be encoded\n // eslint-disable-next-line no-control-regex\n !/[^\\x00-\\xFF]/.test(locationString) ? locationString : encodeURI(locationString)\n );\n return this.newResponse(null, status ?? 302);\n };\n /**\n * `.notFound()` can return the Not Found Response.\n *\n * @see {@link https://hono.dev/docs/api/context#notfound}\n *\n * @example\n * ```ts\n * app.get('/notfound', (c) => {\n * return c.notFound()\n * })\n * ```\n */\n notFound = () => {\n this.#notFoundHandler ??= () => createResponseInstance();\n return this.#notFoundHandler(this);\n };\n};\nexport {\n Context,\n TEXT_PLAIN\n};\n","// src/router.ts\nvar METHOD_NAME_ALL = \"ALL\";\nvar METHOD_NAME_ALL_LOWERCASE = \"all\";\nvar METHODS = [\"get\", \"post\", \"put\", \"delete\", \"options\", \"patch\"];\nvar MESSAGE_MATCHER_IS_ALREADY_BUILT = \"Can not add a route since the matcher is already built.\";\nvar UnsupportedPathError = class extends Error {\n};\nexport {\n MESSAGE_MATCHER_IS_ALREADY_BUILT,\n METHODS,\n METHOD_NAME_ALL,\n METHOD_NAME_ALL_LOWERCASE,\n UnsupportedPathError\n};\n","// src/utils/constants.ts\nvar COMPOSED_HANDLER = \"__COMPOSED_HANDLER\";\nexport {\n COMPOSED_HANDLER\n};\n","// src/hono-base.ts\nimport { compose } from \"./compose.js\";\nimport { Context } from \"./context.js\";\nimport { METHODS, METHOD_NAME_ALL, METHOD_NAME_ALL_LOWERCASE } from \"./router.js\";\nimport { COMPOSED_HANDLER } from \"./utils/constants.js\";\nimport { getPath, getPathNoStrict, mergePath } from \"./utils/url.js\";\nvar notFoundHandler = (c) => {\n return c.text(\"404 Not Found\", 404);\n};\nvar errorHandler = (err, c) => {\n if (\"getResponse\" in err) {\n const res = err.getResponse();\n return c.newResponse(res.body, res);\n }\n console.error(err);\n return c.text(\"Internal Server Error\", 500);\n};\nvar Hono = class _Hono {\n get;\n post;\n put;\n delete;\n options;\n patch;\n all;\n on;\n use;\n /*\n This class is like an abstract class and does not have a router.\n To use it, inherit the class and implement router in the constructor.\n */\n router;\n getPath;\n // Cannot use `#` because it requires visibility at JavaScript runtime.\n _basePath = \"/\";\n #path = \"/\";\n routes = [];\n constructor(options = {}) {\n const allMethods = [...METHODS, METHOD_NAME_ALL_LOWERCASE];\n allMethods.forEach((method) => {\n this[method] = (args1, ...args) => {\n if (typeof args1 === \"string\") {\n this.#path = args1;\n } else {\n this.#addRoute(method, this.#path, args1);\n }\n args.forEach((handler) => {\n this.#addRoute(method, this.#path, handler);\n });\n return this;\n };\n });\n this.on = (method, path, ...handlers) => {\n for (const p of [path].flat()) {\n this.#path = p;\n for (const m of [method].flat()) {\n handlers.map((handler) => {\n this.#addRoute(m.toUpperCase(), this.#path, handler);\n });\n }\n }\n return this;\n };\n this.use = (arg1, ...handlers) => {\n if (typeof arg1 === \"string\") {\n this.#path = arg1;\n } else {\n this.#path = \"*\";\n handlers.unshift(arg1);\n }\n handlers.forEach((handler) => {\n this.#addRoute(METHOD_NAME_ALL, this.#path, handler);\n });\n return this;\n };\n const { strict, ...optionsWithoutStrict } = options;\n Object.assign(this, optionsWithoutStrict);\n this.getPath = strict ?? true ? options.getPath ?? getPath : getPathNoStrict;\n }\n #clone() {\n const clone = new _Hono({\n router: this.router,\n getPath: this.getPath\n });\n clone.errorHandler = this.errorHandler;\n clone.#notFoundHandler = this.#notFoundHandler;\n clone.routes = this.routes;\n return clone;\n }\n #notFoundHandler = notFoundHandler;\n // Cannot use `#` because it requires visibility at JavaScript runtime.\n errorHandler = errorHandler;\n /**\n * `.route()` allows grouping other Hono instance in routes.\n *\n * @see {@link https://hono.dev/docs/api/routing#grouping}\n *\n * @param {string} path - base Path\n * @param {Hono} app - other Hono instance\n * @returns {Hono} routed Hono instance\n *\n * @example\n * ```ts\n * const app = new Hono()\n * const app2 = new Hono()\n *\n * app2.get(\"/user\", (c) => c.text(\"user\"))\n * app.route(\"/api\", app2) // GET /api/user\n * ```\n */\n route(path, app) {\n const subApp = this.basePath(path);\n app.routes.map((r) => {\n let handler;\n if (app.errorHandler === errorHandler) {\n handler = r.handler;\n } else {\n handler = async (c, next) => (await compose([], app.errorHandler)(c, () => r.handler(c, next))).res;\n handler[COMPOSED_HANDLER] = r.handler;\n }\n subApp.#addRoute(r.method, r.path, handler, r.basePath);\n });\n return this;\n }\n /**\n * `.basePath()` allows base paths to be specified.\n *\n * @see {@link https://hono.dev/docs/api/routing#base-path}\n *\n * @param {string} path - base Path\n * @returns {Hono} changed Hono instance\n *\n * @example\n * ```ts\n * const api = new Hono().basePath('/api')\n * ```\n */\n basePath(path) {\n const subApp = this.#clone();\n subApp._basePath = mergePath(this._basePath, path);\n return subApp;\n }\n /**\n * `.onError()` handles an error and returns a customized Response.\n *\n * @see {@link https://hono.dev/docs/api/hono#error-handling}\n *\n * @param {ErrorHandler} handler - request Handler for error\n * @returns {Hono} changed Hono instance\n *\n * @example\n * ```ts\n * app.onError((err, c) => {\n * console.error(`${err}`)\n * return c.text('Custom Error Message', 500)\n * })\n * ```\n */\n onError = (handler) => {\n this.errorHandler = handler;\n return this;\n };\n /**\n * `.notFound()` allows you to customize a Not Found Response.\n *\n * @see {@link https://hono.dev/docs/api/hono#not-found}\n *\n * @param {NotFoundHandler} handler - request handler for not-found\n * @returns {Hono} changed Hono instance\n *\n * @example\n * ```ts\n * app.notFound((c) => {\n * return c.text('Custom 404 Message', 404)\n * })\n * ```\n */\n notFound = (handler) => {\n this.#notFoundHandler = handler;\n return this;\n };\n /**\n * `.mount()` allows you to mount applications built with other frameworks into your Hono application.\n *\n * @see {@link https://hono.dev/docs/api/hono#mount}\n *\n * @param {string} path - base Path\n * @param {Function} applicationHandler - other Request Handler\n * @param {MountOptions} [options] - options of `.mount()`\n * @returns {Hono} mounted Hono instance\n *\n * @example\n * ```ts\n * import { Router as IttyRouter } from 'itty-router'\n * import { Hono } from 'hono'\n * // Create itty-router application\n * const ittyRouter = IttyRouter()\n * // GET /itty-router/hello\n * ittyRouter.get('/hello', () => new Response('Hello from itty-router'))\n *\n * const app = new Hono()\n * app.mount('/itty-router', ittyRouter.handle)\n * ```\n *\n * @example\n * ```ts\n * const app = new Hono()\n * // Send the request to another application without modification.\n * app.mount('/app', anotherApp, {\n * replaceRequest: (req) => req,\n * })\n * ```\n */\n mount(path, applicationHandler, options) {\n let replaceRequest;\n let optionHandler;\n if (options) {\n if (typeof options === \"function\") {\n optionHandler = options;\n } else {\n optionHandler = options.optionHandler;\n if (options.replaceRequest === false) {\n replaceRequest = (request) => request;\n } else {\n replaceRequest = options.replaceRequest;\n }\n }\n }\n const getOptions = optionHandler ? (c) => {\n const options2 = optionHandler(c);\n return Array.isArray(options2) ? options2 : [options2];\n } : (c) => {\n let executionContext = void 0;\n try {\n executionContext = c.executionCtx;\n } catch {\n }\n return [c.env, executionContext];\n };\n replaceRequest ||= (() => {\n const mergedPath = mergePath(this._basePath, path);\n const pathPrefixLength = mergedPath === \"/\" ? 0 : mergedPath.length;\n return (request) => {\n const url = new URL(request.url);\n url.pathname = this.getPath(request).slice(pathPrefixLength) || \"/\";\n return new Request(url, request);\n };\n })();\n const handler = async (c, next) => {\n const res = await applicationHandler(replaceRequest(c.req.raw), ...getOptions(c));\n if (res) {\n return res;\n }\n await next();\n };\n this.#addRoute(METHOD_NAME_ALL, mergePath(path, \"*\"), handler);\n return this;\n }\n #addRoute(method, path, handler, baseRoutePath) {\n method = method.toUpperCase();\n path = mergePath(this._basePath, path);\n const r = {\n basePath: baseRoutePath !== void 0 ? mergePath(this._basePath, baseRoutePath) : this._basePath,\n path,\n method,\n handler\n };\n this.router.add(method, path, [handler, r]);\n this.routes.push(r);\n }\n #handleError(err, c) {\n if (err instanceof Error) {\n return this.errorHandler(err, c);\n }\n throw err;\n }\n #dispatch(request, executionCtx, env, method) {\n if (method === \"HEAD\") {\n return (async () => new Response(null, await this.#dispatch(request, executionCtx, env, \"GET\")))();\n }\n const path = this.getPath(request, { env });\n const matchResult = this.router.match(method, path);\n const c = new Context(request, {\n path,\n matchResult,\n env,\n executionCtx,\n notFoundHandler: this.#notFoundHandler\n });\n if (matchResult[0].length === 1) {\n let res;\n try {\n res = matchResult[0][0][0][0](c, async () => {\n c.res = await this.#notFoundHandler(c);\n });\n } catch (err) {\n return this.#handleError(err, c);\n }\n return res instanceof Promise ? res.then(\n (resolved) => resolved || (c.finalized ? c.res : this.#notFoundHandler(c))\n ).catch((err) => this.#handleError(err, c)) : res ?? this.#notFoundHandler(c);\n }\n const composed = compose(matchResult[0], this.errorHandler, this.#notFoundHandler);\n return (async () => {\n try {\n const context = await composed(c);\n if (!context.finalized) {\n throw new Error(\n \"Context is not finalized. Did you forget to return a Response object or `await next()`?\"\n );\n }\n return context.res;\n } catch (err) {\n return this.#handleError(err, c);\n }\n })();\n }\n /**\n * `.fetch()` will be entry point of your app.\n *\n * @see {@link https://hono.dev/docs/api/hono#fetch}\n *\n * @param {Request} request - request Object of request\n * @param {Env} Env - env Object\n * @param {ExecutionContext} - context of execution\n * @returns {Response | Promise<Response>} response of request\n *\n */\n fetch = (request, ...rest) => {\n return this.#dispatch(request, rest[1], rest[0], request.method);\n };\n /**\n * `.request()` is a useful method for testing.\n * You can pass a URL or pathname to send a GET request.\n * app will return a Response object.\n * ```ts\n * test('GET /hello is ok', async () => {\n * const res = await app.request('/hello')\n * expect(res.status).toBe(200)\n * })\n * ```\n * @see https://hono.dev/docs/api/hono#request\n */\n request = (input, requestInit, Env, executionCtx) => {\n if (input instanceof Request) {\n return this.fetch(requestInit ? new Request(input, requestInit) : input, Env, executionCtx);\n }\n input = input.toString();\n return this.fetch(\n new Request(\n /^https?:\\/\\//.test(input) ? input : `http://localhost${mergePath(\"/\", input)}`,\n requestInit\n ),\n Env,\n executionCtx\n );\n };\n /**\n * `.fire()` automatically adds a global fetch event listener.\n * This can be useful for environments that adhere to the Service Worker API, such as non-ES module Cloudflare Workers.\n * @deprecated\n * Use `fire` from `hono/service-worker` instead.\n * ```ts\n * import { Hono } from 'hono'\n * import { fire } from 'hono/service-worker'\n *\n * const app = new Hono()\n * // ...\n * fire(app)\n * ```\n * @see https://hono.dev/docs/api/hono#fire\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API\n * @see https://developers.cloudflare.com/workers/reference/migrate-to-module-workers/\n */\n fire = () => {\n addEventListener(\"fetch\", (event) => {\n event.respondWith(this.#dispatch(event.request, event, void 0, event.request.method));\n });\n };\n};\nexport {\n Hono as HonoBase\n};\n","// src/router/reg-exp-router/matcher.ts\nimport { METHOD_NAME_ALL } from \"../../router.js\";\nvar emptyParam = [];\nfunction match(method, path) {\n const matchers = this.buildAllMatchers();\n const match2 = ((method2, path2) => {\n const matcher = matchers[method2] || matchers[METHOD_NAME_ALL];\n const staticMatch = matcher[2][path2];\n if (staticMatch) {\n return staticMatch;\n }\n const match3 = path2.match(matcher[0]);\n if (!match3) {\n return [[], emptyParam];\n }\n const index = match3.indexOf(\"\", 1);\n return [matcher[1][index], match3];\n });\n this.match = match2;\n return match2(method, path);\n}\nexport {\n emptyParam,\n match\n};\n","// src/router/reg-exp-router/node.ts\nvar LABEL_REG_EXP_STR = \"[^/]+\";\nvar ONLY_WILDCARD_REG_EXP_STR = \".*\";\nvar TAIL_WILDCARD_REG_EXP_STR = \"(?:|/.*)\";\nvar PATH_ERROR = /* @__PURE__ */ Symbol();\nvar regExpMetaChars = new Set(\".\\\\+*[^]$()\");\nfunction compareKey(a, b) {\n if (a.length === 1) {\n return b.length === 1 ? a < b ? -1 : 1 : -1;\n }\n if (b.length === 1) {\n return 1;\n }\n if (a === ONLY_WILDCARD_REG_EXP_STR || a === TAIL_WILDCARD_REG_EXP_STR) {\n return 1;\n } else if (b === ONLY_WILDCARD_REG_EXP_STR || b === TAIL_WILDCARD_REG_EXP_STR) {\n return -1;\n }\n if (a === LABEL_REG_EXP_STR) {\n return 1;\n } else if (b === LABEL_REG_EXP_STR) {\n return -1;\n }\n return a.length === b.length ? a < b ? -1 : 1 : b.length - a.length;\n}\nvar Node = class _Node {\n #index;\n #varIndex;\n #children = /* @__PURE__ */ Object.create(null);\n insert(tokens, index, paramMap, context, pathErrorCheckOnly) {\n if (tokens.length === 0) {\n if (this.#index !== void 0) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n this.#index = index;\n return;\n }\n const [token, ...restTokens] = tokens;\n const pattern = token === \"*\" ? restTokens.length === 0 ? [\"\", \"\", ONLY_WILDCARD_REG_EXP_STR] : [\"\", \"\", LABEL_REG_EXP_STR] : token === \"/*\" ? [\"\", \"\", TAIL_WILDCARD_REG_EXP_STR] : token.match(/^\\:([^\\{\\}]+)(?:\\{(.+)\\})?$/);\n let node;\n if (pattern) {\n const name = pattern[1];\n let regexpStr = pattern[2] || LABEL_REG_EXP_STR;\n if (name && pattern[2]) {\n if (regexpStr === \".*\") {\n throw PATH_ERROR;\n }\n regexpStr = regexpStr.replace(/^\\((?!\\?:)(?=[^)]+\\)$)/, \"(?:\");\n if (/\\((?!\\?:)/.test(regexpStr)) {\n throw PATH_ERROR;\n }\n }\n node = this.#children[regexpStr];\n if (!node) {\n if (Object.keys(this.#children).some(\n (k) => k !== ONLY_WILDCARD_REG_EXP_STR && k !== TAIL_WILDCARD_REG_EXP_STR\n )) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n node = this.#children[regexpStr] = new _Node();\n if (name !== \"\") {\n node.#varIndex = context.varIndex++;\n }\n }\n if (!pathErrorCheckOnly && name !== \"\") {\n paramMap.push([name, node.#varIndex]);\n }\n } else {\n node = this.#children[token];\n if (!node) {\n if (Object.keys(this.#children).some(\n (k) => k.length > 1 && k !== ONLY_WILDCARD_REG_EXP_STR && k !== TAIL_WILDCARD_REG_EXP_STR\n )) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n node = this.#children[token] = new _Node();\n }\n }\n node.insert(restTokens, index, paramMap, context, pathErrorCheckOnly);\n }\n buildRegExpStr() {\n const childKeys = Object.keys(this.#children).sort(compareKey);\n const strList = childKeys.map((k) => {\n const c = this.#children[k];\n return (typeof c.#varIndex === \"number\" ? `(${k})@${c.#varIndex}` : regExpMetaChars.has(k) ? `\\\\${k}` : k) + c.buildRegExpStr();\n });\n if (typeof this.#index === \"number\") {\n strList.unshift(`#${this.#index}`);\n }\n if (strList.length === 0) {\n return \"\";\n }\n if (strList.length === 1) {\n return strList[0];\n }\n return \"(?:\" + strList.join(\"|\") + \")\";\n }\n};\nexport {\n Node,\n PATH_ERROR\n};\n","// src/router/reg-exp-router/trie.ts\nimport { Node } from \"./node.js\";\nvar Trie = class {\n #context = { varIndex: 0 };\n #root = new Node();\n insert(path, index, pathErrorCheckOnly) {\n const paramAssoc = [];\n const groups = [];\n for (let i = 0; ; ) {\n let replaced = false;\n path = path.replace(/\\{[^}]+\\}/g, (m) => {\n const mark = `@\\\\${i}`;\n groups[i] = [mark, m];\n i++;\n replaced = true;\n return mark;\n });\n if (!replaced) {\n break;\n }\n }\n const tokens = path.match(/(?::[^\\/]+)|(?:\\/\\*$)|./g) || [];\n for (let i = groups.length - 1; i >= 0; i--) {\n const [mark] = groups[i];\n for (let j = tokens.length - 1; j >= 0; j--) {\n if (tokens[j].indexOf(mark) !== -1) {\n tokens[j] = tokens[j].replace(mark, groups[i][1]);\n break;\n }\n }\n }\n this.#root.insert(tokens, index, paramAssoc, this.#context, pathErrorCheckOnly);\n return paramAssoc;\n }\n buildRegExp() {\n let regexp = this.#root.buildRegExpStr();\n if (regexp === \"\") {\n return [/^$/, [], []];\n }\n let captureIndex = 0;\n const indexReplacementMap = [];\n const paramReplacementMap = [];\n regexp = regexp.replace(/#(\\d+)|@(\\d+)|\\.\\*\\$/g, (_, handlerIndex, paramIndex) => {\n if (handlerIndex !== void 0) {\n indexReplacementMap[++captureIndex] = Number(handlerIndex);\n return \"$()\";\n }\n if (paramIndex !== void 0) {\n paramReplacementMap[Number(paramIndex)] = ++captureIndex;\n return \"\";\n }\n return \"\";\n });\n return [new RegExp(`^${regexp}`), indexReplacementMap, paramReplacementMap];\n }\n};\nexport {\n Trie\n};\n","// src/router/reg-exp-router/router.ts\nimport {\n MESSAGE_MATCHER_IS_ALREADY_BUILT,\n METHOD_NAME_ALL,\n UnsupportedPathError\n} from \"../../router.js\";\nimport { checkOptionalParameter } from \"../../utils/url.js\";\nimport { match, emptyParam } from \"./matcher.js\";\nimport { PATH_ERROR } from \"./node.js\";\nimport { Trie } from \"./trie.js\";\nvar nullMatcher = [/^$/, [], /* @__PURE__ */ Object.create(null)];\nvar wildcardRegExpCache = /* @__PURE__ */ Object.create(null);\nfunction buildWildcardRegExp(path) {\n return wildcardRegExpCache[path] ??= new RegExp(\n path === \"*\" ? \"\" : `^${path.replace(\n /\\/\\*$|([.\\\\+*[^\\]$()])/g,\n (_, metaChar) => metaChar ? `\\\\${metaChar}` : \"(?:|/.*)\"\n )}$`\n );\n}\nfunction clearWildcardRegExpCache() {\n wildcardRegExpCache = /* @__PURE__ */ Object.create(null);\n}\nfunction buildMatcherFromPreprocessedRoutes(routes) {\n const trie = new Trie();\n const handlerData = [];\n if (routes.length === 0) {\n return nullMatcher;\n }\n const routesWithStaticPathFlag = routes.map(\n (route) => [!/\\*|\\/:/.test(route[0]), ...route]\n ).sort(\n ([isStaticA, pathA], [isStaticB, pathB]) => isStaticA ? 1 : isStaticB ? -1 : pathA.length - pathB.length\n );\n const staticMap = /* @__PURE__ */ Object.create(null);\n for (let i = 0, j = -1, len = routesWithStaticPathFlag.length; i < len; i++) {\n const [pathErrorCheckOnly, path, handlers] = routesWithStaticPathFlag[i];\n if (pathErrorCheckOnly) {\n staticMap[path] = [handlers.map(([h]) => [h, /* @__PURE__ */ Object.create(null)]), emptyParam];\n } else {\n j++;\n }\n let paramAssoc;\n try {\n paramAssoc = trie.insert(path, j, pathErrorCheckOnly);\n } catch (e) {\n throw e === PATH_ERROR ? new UnsupportedPathError(path) : e;\n }\n if (pathErrorCheckOnly) {\n continue;\n }\n handlerData[j] = handlers.map(([h, paramCount]) => {\n const paramIndexMap = /* @__PURE__ */ Object.create(null);\n paramCount -= 1;\n for (; paramCount >= 0; paramCount--) {\n const [key, value] = paramAssoc[paramCount];\n paramIndexMap[key] = value;\n }\n return [h, paramIndexMap];\n });\n }\n const [regexp, indexReplacementMap, paramReplacementMap] = trie.buildRegExp();\n for (let i = 0, len = handlerData.length; i < len; i++) {\n for (let j = 0, len2 = handlerData[i].length; j < len2; j++) {\n const map = handlerData[i][j]?.[1];\n if (!map) {\n continue;\n }\n const keys = Object.keys(map);\n for (let k = 0, len3 = keys.length; k < len3; k++) {\n map[keys[k]] = paramReplacementMap[map[keys[k]]];\n }\n }\n }\n const handlerMap = [];\n for (const i in indexReplacementMap) {\n handlerMap[i] = handlerData[indexReplacementMap[i]];\n }\n return [regexp, handlerMap, staticMap];\n}\nfunction findMiddleware(middleware, path) {\n if (!middleware) {\n return void 0;\n }\n for (const k of Object.keys(middleware).sort((a, b) => b.length - a.length)) {\n if (buildWildcardRegExp(k).test(path)) {\n return [...middleware[k]];\n }\n }\n return void 0;\n}\nvar RegExpRouter = class {\n name = \"RegExpRouter\";\n #middleware;\n #routes;\n constructor() {\n this.#middleware = { [METHOD_NAME_ALL]: /* @__PURE__ */ Object.create(null) };\n this.#routes = { [METHOD_NAME_ALL]: /* @__PURE__ */ Object.create(null) };\n }\n add(method, path, handler) {\n const middleware = this.#middleware;\n const routes = this.#routes;\n if (!middleware || !routes) {\n throw new Error(MESSAGE_MATCHER_IS_ALREADY_BUILT);\n }\n if (!middleware[method]) {\n ;\n [middleware, routes].forEach((handlerMap) => {\n handlerMap[method] = /* @__PURE__ */ Object.create(null);\n Object.keys(handlerMap[METHOD_NAME_ALL]).forEach((p) => {\n handlerMap[method][p] = [...handlerMap[METHOD_NAME_ALL][p]];\n });\n });\n }\n if (path === \"/*\") {\n path = \"*\";\n }\n const paramCount = (path.match(/\\/:/g) || []).length;\n if (/\\*$/.test(path)) {\n const re = buildWildcardRegExp(path);\n if (method === METHOD_NAME_ALL) {\n Object.keys(middleware).forEach((m) => {\n middleware[m][path] ||= findMiddleware(middleware[m], path) || findMiddleware(middleware[METHOD_NAME_ALL], path) || [];\n });\n } else {\n middleware[method][path] ||= findMiddleware(middleware[method], path) || findMiddleware(middleware[METHOD_NAME_ALL], path) || [];\n }\n Object.keys(middleware).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n Object.keys(middleware[m]).forEach((p) => {\n re.test(p) && middleware[m][p].push([handler, paramCount]);\n });\n }\n });\n Object.keys(routes).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n Object.keys(routes[m]).forEach(\n (p) => re.test(p) && routes[m][p].push([handler, paramCount])\n );\n }\n });\n return;\n }\n const paths = checkOptionalParameter(path) || [path];\n for (let i = 0, len = paths.length; i < len; i++) {\n const path2 = paths[i];\n Object.keys(routes).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n routes[m][path2] ||= [\n ...findMiddleware(middleware[m], path2) || findMiddleware(middleware[METHOD_NAME_ALL], path2) || []\n ];\n routes[m][path2].push([handler, paramCount - len + i + 1]);\n }\n });\n }\n }\n match = match;\n buildAllMatchers() {\n const matchers = /* @__PURE__ */ Object.create(null);\n Object.keys(this.#routes).concat(Object.keys(this.#middleware)).forEach((method) => {\n matchers[method] ||= this.#buildMatcher(method);\n });\n this.#middleware = this.#routes = void 0;\n clearWildcardRegExpCache();\n return matchers;\n }\n #buildMatcher(method) {\n const routes = [];\n let hasOwnRoute = method === METHOD_NAME_ALL;\n [this.#middleware, this.#routes].forEach((r) => {\n const ownRoute = r[method] ? Object.keys(r[method]).map((path) => [path, r[method][path]]) : [];\n if (ownRoute.length !== 0) {\n hasOwnRoute ||= true;\n routes.push(...ownRoute);\n } else if (method !== METHOD_NAME_ALL) {\n routes.push(\n ...Object.keys(r[METHOD_NAME_ALL]).map((path) => [path, r[METHOD_NAME_ALL][path]])\n );\n }\n });\n if (!hasOwnRoute) {\n return null;\n } else {\n return buildMatcherFromPreprocessedRoutes(routes);\n }\n }\n};\nexport {\n RegExpRouter\n};\n","// src/router/reg-exp-router/prepared-router.ts\nimport { METHOD_NAME_ALL } from \"../../router.js\";\nimport { match, emptyParam } from \"./matcher.js\";\nimport { RegExpRouter } from \"./router.js\";\nvar PreparedRegExpRouter = class {\n name = \"PreparedRegExpRouter\";\n #matchers;\n #relocateMap;\n constructor(matchers, relocateMap) {\n this.#matchers = matchers;\n this.#relocateMap = relocateMap;\n }\n #addWildcard(method, handlerData) {\n const matcher = this.#matchers[method];\n matcher[1].forEach((list) => list && list.push(handlerData));\n Object.values(matcher[2]).forEach((list) => list[0].push(handlerData));\n }\n #addPath(method, path, handler, indexes, map) {\n const matcher = this.#matchers[method];\n if (!map) {\n matcher[2][path][0].push([handler, {}]);\n } else {\n indexes.forEach((index) => {\n if (typeof index === \"number\") {\n matcher[1][index].push([handler, map]);\n } else {\n ;\n matcher[2][index || path][0].push([handler, map]);\n }\n });\n }\n }\n add(method, path, handler) {\n if (!this.#matchers[method]) {\n const all = this.#matchers[METHOD_NAME_ALL];\n const staticMap = {};\n for (const key in all[2]) {\n staticMap[key] = [all[2][key][0].slice(), emptyParam];\n }\n this.#matchers[method] = [\n all[0],\n all[1].map((list) => Array.isArray(list) ? list.slice() : 0),\n staticMap\n ];\n }\n if (path === \"/*\" || path === \"*\") {\n const handlerData = [handler, {}];\n if (method === METHOD_NAME_ALL) {\n for (const m in this.#matchers) {\n this.#addWildcard(m, handlerData);\n }\n } else {\n this.#addWildcard(method, handlerData);\n }\n return;\n }\n const data = this.#relocateMap[path];\n if (!data) {\n throw new Error(`Path ${path} is not registered`);\n }\n for (const [indexes, map] of data) {\n if (method === METHOD_NAME_ALL) {\n for (const m in this.#matchers) {\n this.#addPath(m, path, handler, indexes, map);\n }\n } else {\n this.#addPath(method, path, handler, indexes, map);\n }\n }\n }\n buildAllMatchers() {\n return this.#matchers;\n }\n match = match;\n};\nvar buildInitParams = ({ paths }) => {\n const RegExpRouterWithMatcherExport = class extends RegExpRouter {\n buildAndExportAllMatchers() {\n return this.buildAllMatchers();\n }\n };\n const router = new RegExpRouterWithMatcherExport();\n for (const path of paths) {\n router.add(METHOD_NAME_ALL, path, path);\n }\n const matchers = router.buildAndExportAllMatchers();\n const all = matchers[METHOD_NAME_ALL];\n const relocateMap = {};\n for (const path of paths) {\n if (path === \"/*\" || path === \"*\") {\n continue;\n }\n all[1].forEach((list, i) => {\n list.forEach(([p, map]) => {\n if (p === path) {\n if (relocateMap[path]) {\n relocateMap[path][0][1] = {\n ...relocateMap[path][0][1],\n ...map\n };\n } else {\n relocateMap[path] = [[[], map]];\n }\n if (relocateMap[path][0][0].findIndex((j) => j === i) === -1) {\n relocateMap[path][0][0].push(i);\n }\n }\n });\n });\n for (const path2 in all[2]) {\n all[2][path2][0].forEach(([p]) => {\n if (p === path) {\n relocateMap[path] ||= [[[]]];\n const value = path2 === path ? \"\" : path2;\n if (relocateMap[path][0][0].findIndex((v) => v === value) === -1) {\n relocateMap[path][0][0].push(value);\n }\n }\n });\n }\n }\n for (let i = 0, len = all[1].length; i < len; i++) {\n all[1][i] = all[1][i] ? [] : 0;\n }\n for (const path in all[2]) {\n all[2][path][0] = [];\n }\n return [matchers, relocateMap];\n};\nvar serializeInitParams = ([matchers, relocateMap]) => {\n const matchersStr = JSON.stringify(\n matchers,\n (_, value) => value instanceof RegExp ? `##${value.toString()}##` : value\n ).replace(/\"##(.+?)##\"/g, (_, str) => str.replace(/\\\\\\\\/g, \"\\\\\"));\n const relocateMapStr = JSON.stringify(relocateMap);\n return `[${matchersStr},${relocateMapStr}]`;\n};\nexport {\n PreparedRegExpRouter,\n buildInitParams,\n serializeInitParams\n};\n","// src/router/reg-exp-router/index.ts\nimport { RegExpRouter } from \"./router.js\";\nimport { PreparedRegExpRouter, buildInitParams, serializeInitParams } from \"./prepared-router.js\";\nexport {\n PreparedRegExpRouter,\n RegExpRouter,\n buildInitParams,\n serializeInitParams\n};\n","// src/router/smart-router/router.ts\nimport { MESSAGE_MATCHER_IS_ALREADY_BUILT, UnsupportedPathError } from \"../../router.js\";\nvar SmartRouter = class {\n name = \"SmartRouter\";\n #routers = [];\n #routes = [];\n constructor(init) {\n this.#routers = init.routers;\n }\n add(method, path, handler) {\n if (!this.#routes) {\n throw new Error(MESSAGE_MATCHER_IS_ALREADY_BUILT);\n }\n this.#routes.push([method, path, handler]);\n }\n match(method, path) {\n if (!this.#routes) {\n throw new Error(\"Fatal error\");\n }\n const routers = this.#routers;\n const routes = this.#routes;\n const len = routers.length;\n let i = 0;\n let res;\n for (; i < len; i++) {\n const router = routers[i];\n try {\n for (let i2 = 0, len2 = routes.length; i2 < len2; i2++) {\n router.add(...routes[i2]);\n }\n res = router.match(method, path);\n } catch (e) {\n if (e instanceof UnsupportedPathError) {\n continue;\n }\n throw e;\n }\n this.match = router.match.bind(router);\n this.#routers = [router];\n this.#routes = void 0;\n break;\n }\n if (i === len) {\n throw new Error(\"Fatal error\");\n }\n this.name = `SmartRouter + ${this.activeRouter.name}`;\n return res;\n }\n get activeRouter() {\n if (this.#routes || this.#routers.length !== 1) {\n throw new Error(\"No active router has been determined yet.\");\n }\n return this.#routers[0];\n }\n};\nexport {\n SmartRouter\n};\n","// src/router/smart-router/index.ts\nimport { SmartRouter } from \"./router.js\";\nexport {\n SmartRouter\n};\n","// src/router/trie-router/node.ts\nimport { METHOD_NAME_ALL } from \"../../router.js\";\nimport { getPattern, splitPath, splitRoutingPath } from \"../../utils/url.js\";\nvar emptyParams = /* @__PURE__ */ Object.create(null);\nvar hasChildren = (children) => {\n for (const _ in children) {\n return true;\n }\n return false;\n};\nvar Node = class _Node {\n #methods;\n #children;\n #patterns;\n #order = 0;\n #params = emptyParams;\n constructor(method, handler, children) {\n this.#children = children || /* @__PURE__ */ Object.create(null);\n this.#methods = [];\n if (method && handler) {\n const m = /* @__PURE__ */ Object.create(null);\n m[method] = { handler, possibleKeys: [], score: 0 };\n this.#methods = [m];\n }\n this.#patterns = [];\n }\n insert(method, path, handler) {\n this.#order = ++this.#order;\n let curNode = this;\n const parts = splitRoutingPath(path);\n const possibleKeys = [];\n for (let i = 0, len = parts.length; i < len; i++) {\n const p = parts[i];\n const nextP = parts[i + 1];\n const pattern = getPattern(p, nextP);\n const key = Array.isArray(pattern) ? pattern[0] : p;\n if (key in curNode.#children) {\n curNode = curNode.#children[key];\n if (pattern) {\n possibleKeys.push(pattern[1]);\n }\n continue;\n }\n curNode.#children[key] = new _Node();\n if (pattern) {\n curNode.#patterns.push(pattern);\n possibleKeys.push(pattern[1]);\n }\n curNode = curNode.#children[key];\n }\n curNode.#methods.push({\n [method]: {\n handler,\n possibleKeys: possibleKeys.filter((v, i, a) => a.indexOf(v) === i),\n score: this.#order\n }\n });\n return curNode;\n }\n #pushHandlerSets(handlerSets, node, method, nodeParams, params) {\n for (let i = 0, len = node.#methods.length; i < len; i++) {\n const m = node.#methods[i];\n const handlerSet = m[method] || m[METHOD_NAME_ALL];\n const processedSet = {};\n if (handlerSet !== void 0) {\n handlerSet.params = /* @__PURE__ */ Object.create(null);\n handlerSets.push(handlerSet);\n if (nodeParams !== emptyParams || params && params !== emptyParams) {\n for (let i2 = 0, len2 = handlerSet.possibleKeys.length; i2 < len2; i2++) {\n const key = handlerSet.possibleKeys[i2];\n const processed = processedSet[handlerSet.score];\n handlerSet.params[key] = params?.[key] && !processed ? params[key] : nodeParams[key] ?? params?.[key];\n processedSet[handlerSet.score] = true;\n }\n }\n }\n }\n }\n search(method, path) {\n const handlerSets = [];\n this.#params = emptyParams;\n const curNode = this;\n let curNodes = [curNode];\n const parts = splitPath(path);\n const curNodesQueue = [];\n const len = parts.length;\n let partOffsets = null;\n for (let i = 0; i < len; i++) {\n const part = parts[i];\n const isLast = i === len - 1;\n const tempNodes = [];\n for (let j = 0, len2 = curNodes.length; j < len2; j++) {\n const node = curNodes[j];\n const nextNode = node.#children[part];\n if (nextNode) {\n nextNode.#params = node.#params;\n if (isLast) {\n if (nextNode.#children[\"*\"]) {\n this.#pushHandlerSets(handlerSets, nextNode.#children[\"*\"], method, node.#params);\n }\n this.#pushHandlerSets(handlerSets, nextNode, method, node.#params);\n } else {\n tempNodes.push(nextNode);\n }\n }\n for (let k = 0, len3 = node.#patterns.length; k < len3; k++) {\n const pattern = node.#patterns[k];\n const params = node.#params === emptyParams ? {} : { ...node.#params };\n if (pattern === \"*\") {\n const astNode = node.#children[\"*\"];\n if (astNode) {\n this.#pushHandlerSets(handlerSets, astNode, method, node.#params);\n astNode.#params = params;\n tempNodes.push(astNode);\n }\n continue;\n }\n const [key, name, matcher] = pattern;\n if (!part && !(matcher instanceof RegExp)) {\n continue;\n }\n const child = node.#children[key];\n if (matcher instanceof RegExp) {\n if (partOffsets === null) {\n partOffsets = new Array(len);\n let offset = path[0] === \"/\" ? 1 : 0;\n for (let p = 0; p < len; p++) {\n partOffsets[p] = offset;\n offset += parts[p].length + 1;\n }\n }\n const restPathString = path.substring(partOffsets[i]);\n const m = matcher.exec(restPathString);\n if (m) {\n params[name] = m[0];\n this.#pushHandlerSets(handlerSets, child, method, node.#params, params);\n if (hasChildren(child.#children)) {\n child.#params = params;\n const componentCount = m[0].match(/\\//)?.length ?? 0;\n const targetCurNodes = curNodesQueue[componentCount] ||= [];\n targetCurNodes.push(child);\n }\n continue;\n }\n }\n if (matcher === true || matcher.test(part)) {\n params[name] = part;\n if (isLast) {\n this.#pushHandlerSets(handlerSets, child, method, params, node.#params);\n if (child.#children[\"*\"]) {\n this.#pushHandlerSets(\n handlerSets,\n child.#children[\"*\"],\n method,\n params,\n node.#params\n );\n }\n } else {\n child.#params = params;\n tempNodes.push(child);\n }\n }\n }\n }\n const shifted = curNodesQueue.shift();\n curNodes = shifted ? tempNodes.concat(shifted) : tempNodes;\n }\n if (handlerSets.length > 1) {\n handlerSets.sort((a, b) => {\n return a.score - b.score;\n });\n }\n return [handlerSets.map(({ handler, params }) => [handler, params])];\n }\n};\nexport {\n Node\n};\n","// src/router/trie-router/router.ts\nimport { checkOptionalParameter } from \"../../utils/url.js\";\nimport { Node } from \"./node.js\";\nvar TrieRouter = class {\n name = \"TrieRouter\";\n #node;\n constructor() {\n this.#node = new Node();\n }\n add(method, path, handler) {\n const results = checkOptionalParameter(path);\n if (results) {\n for (let i = 0, len = results.length; i < len; i++) {\n this.#node.insert(method, results[i], handler);\n }\n return;\n }\n this.#node.insert(method, path, handler);\n }\n match(method, path) {\n return this.#node.search(method, path);\n }\n};\nexport {\n TrieRouter\n};\n","// src/router/trie-router/index.ts\nimport { TrieRouter } from \"./router.js\";\nexport {\n TrieRouter\n};\n","// src/hono.ts\nimport { HonoBase } from \"./hono-base.js\";\nimport { RegExpRouter } from \"./router/reg-exp-router/index.js\";\nimport { SmartRouter } from \"./router/smart-router/index.js\";\nimport { TrieRouter } from \"./router/trie-router/index.js\";\nvar Hono = class extends HonoBase {\n /**\n * Creates an instance of the Hono class.\n *\n * @param options - Optional configuration options for the Hono instance.\n */\n constructor(options = {}) {\n super(options);\n this.router = options.router ?? new SmartRouter({\n routers: [new RegExpRouter(), new TrieRouter()]\n });\n }\n};\nexport {\n Hono\n};\n","// src/index.ts\nimport { Hono } from \"./hono.js\";\nimport { Context } from \"./context.js\";\nexport {\n Context,\n Hono\n};\n","// src/middleware/cors/index.ts\nvar cors = (options) => {\n const opts = {\n origin: \"*\",\n allowMethods: [\"GET\", \"HEAD\", \"PUT\", \"POST\", \"DELETE\", \"PATCH\"],\n allowHeaders: [],\n exposeHeaders: [],\n ...options\n };\n const findAllowOrigin = ((optsOrigin) => {\n if (typeof optsOrigin === \"string\") {\n if (optsOrigin === \"*\") {\n if (opts.credentials) {\n return (origin) => origin || null;\n }\n return () => optsOrigin;\n } else {\n return (origin) => optsOrigin === origin ? origin : null;\n }\n } else if (typeof optsOrigin === \"function\") {\n return optsOrigin;\n } else {\n return (origin) => optsOrigin.includes(origin) ? origin : null;\n }\n })(opts.origin);\n const findAllowMethods = ((optsAllowMethods) => {\n if (typeof optsAllowMethods === \"function\") {\n return optsAllowMethods;\n } else if (Array.isArray(optsAllowMethods)) {\n return () => optsAllowMethods;\n } else {\n return () => [];\n }\n })(opts.allowMethods);\n return async function cors2(c, next) {\n function set(key, value) {\n c.res.headers.set(key, value);\n }\n const allowOrigin = await findAllowOrigin(c.req.header(\"origin\") || \"\", c);\n if (allowOrigin) {\n set(\"Access-Control-Allow-Origin\", allowOrigin);\n }\n if (opts.credentials) {\n set(\"Access-Control-Allow-Credentials\", \"true\");\n }\n if (opts.exposeHeaders?.length) {\n set(\"Access-Control-Expose-Headers\", opts.exposeHeaders.join(\",\"));\n }\n if (c.req.method === \"OPTIONS\") {\n if (opts.origin !== \"*\" || opts.credentials) {\n set(\"Vary\", \"Origin\");\n }\n if (opts.maxAge != null) {\n set(\"Access-Control-Max-Age\", opts.maxAge.toString());\n }\n const allowMethods = await findAllowMethods(c.req.header(\"origin\") || \"\", c);\n if (allowMethods.length) {\n set(\"Access-Control-Allow-Methods\", allowMethods.join(\",\"));\n }\n let headers = opts.allowHeaders;\n if (!headers?.length) {\n const requestHeaders = c.req.header(\"Access-Control-Request-Headers\");\n if (requestHeaders) {\n headers = requestHeaders.split(/\\s*,\\s*/);\n }\n }\n if (headers?.length) {\n set(\"Access-Control-Allow-Headers\", headers.join(\",\"));\n c.res.headers.append(\"Vary\", \"Access-Control-Request-Headers\");\n }\n c.res.headers.delete(\"Content-Length\");\n c.res.headers.delete(\"Content-Type\");\n return new Response(null, {\n headers: c.res.headers,\n status: 204,\n statusText: \"No Content\"\n });\n }\n await next();\n if (opts.origin !== \"*\" || opts.credentials) {\n c.header(\"Vary\", \"Origin\", { append: true });\n }\n };\n};\nexport {\n cors\n};\n","// src/server.ts\nimport { createServer as createServerHTTP } from \"http\";\n\n// src/listener.ts\nimport { Http2ServerRequest as Http2ServerRequest2, constants as h2constants } from \"http2\";\n\n// src/request.ts\nimport { Http2ServerRequest } from \"http2\";\nimport { Readable } from \"stream\";\nvar RequestError = class extends Error {\n constructor(message, options) {\n super(message, options);\n this.name = \"RequestError\";\n }\n};\nvar toRequestError = (e) => {\n if (e instanceof RequestError) {\n return e;\n }\n return new RequestError(e.message, { cause: e });\n};\nvar GlobalRequest = global.Request;\nvar Request = class extends GlobalRequest {\n constructor(input, options) {\n if (typeof input === \"object\" && getRequestCache in input) {\n input = input[getRequestCache]();\n }\n if (typeof options?.body?.getReader !== \"undefined\") {\n ;\n options.duplex ??= \"half\";\n }\n super(input, options);\n }\n};\nvar newHeadersFromIncoming = (incoming) => {\n const headerRecord = [];\n const rawHeaders = incoming.rawHeaders;\n for (let i = 0; i < rawHeaders.length; i += 2) {\n const { [i]: key, [i + 1]: value } = rawHeaders;\n if (key.charCodeAt(0) !== /*:*/\n 58) {\n headerRecord.push([key, value]);\n }\n }\n return new Headers(headerRecord);\n};\nvar wrapBodyStream = Symbol(\"wrapBodyStream\");\nvar newRequestFromIncoming = (method, url, headers, incoming, abortController) => {\n const init = {\n method,\n headers,\n signal: abortController.signal\n };\n if (method === \"TRACE\") {\n init.method = \"GET\";\n const req = new Request(url, init);\n Object.defineProperty(req, \"method\", {\n get() {\n return \"TRACE\";\n }\n });\n return req;\n }\n if (!(method === \"GET\" || method === \"HEAD\")) {\n if (\"rawBody\" in incoming && incoming.rawBody instanceof Buffer) {\n init.body = new ReadableStream({\n start(controller) {\n controller.enqueue(incoming.rawBody);\n controller.close();\n }\n });\n } else if (incoming[wrapBodyStream]) {\n let reader;\n init.body = new ReadableStream({\n async pull(controller) {\n try {\n reader ||= Readable.toWeb(incoming).getReader();\n const { done, value } = await reader.read();\n if (done) {\n controller.close();\n } else {\n controller.enqueue(value);\n }\n } catch (error) {\n controller.error(error);\n }\n }\n });\n } else {\n init.body = Readable.toWeb(incoming);\n }\n }\n return new Request(url, init);\n};\nvar getRequestCache = Symbol(\"getRequestCache\");\nvar requestCache = Symbol(\"requestCache\");\nvar incomingKey = Symbol(\"incomingKey\");\nvar urlKey = Symbol(\"urlKey\");\nvar headersKey = Symbol(\"headersKey\");\nvar abortControllerKey = Symbol(\"abortControllerKey\");\nvar getAbortController = Symbol(\"getAbortController\");\nvar requestPrototype = {\n get method() {\n return this[incomingKey].method || \"GET\";\n },\n get url() {\n return this[urlKey];\n },\n get headers() {\n return this[headersKey] ||= newHeadersFromIncoming(this[incomingKey]);\n },\n [getAbortController]() {\n this[getRequestCache]();\n return this[abortControllerKey];\n },\n [getRequestCache]() {\n this[abortControllerKey] ||= new AbortController();\n return this[requestCache] ||= newRequestFromIncoming(\n this.method,\n this[urlKey],\n this.headers,\n this[incomingKey],\n this[abortControllerKey]\n );\n }\n};\n[\n \"body\",\n \"bodyUsed\",\n \"cache\",\n \"credentials\",\n \"destination\",\n \"integrity\",\n \"mode\",\n \"redirect\",\n \"referrer\",\n \"referrerPolicy\",\n \"signal\",\n \"keepalive\"\n].forEach((k) => {\n Object.defineProperty(requestPrototype, k, {\n get() {\n return this[getRequestCache]()[k];\n }\n });\n});\n[\"arrayBuffer\", \"blob\", \"clone\", \"formData\", \"json\", \"text\"].forEach((k) => {\n Object.defineProperty(requestPrototype, k, {\n value: function() {\n return this[getRequestCache]()[k]();\n }\n });\n});\nObject.defineProperty(requestPrototype, Symbol.for(\"nodejs.util.inspect.custom\"), {\n value: function(depth, options, inspectFn) {\n const props = {\n method: this.method,\n url: this.url,\n headers: this.headers,\n nativeRequest: this[requestCache]\n };\n return `Request (lightweight) ${inspectFn(props, { ...options, depth: depth == null ? null : depth - 1 })}`;\n }\n});\nObject.setPrototypeOf(requestPrototype, Request.prototype);\nvar newRequest = (incoming, defaultHostname) => {\n const req = Object.create(requestPrototype);\n req[incomingKey] = incoming;\n const incomingUrl = incoming.url || \"\";\n if (incomingUrl[0] !== \"/\" && // short-circuit for performance. most requests are relative URL.\n (incomingUrl.startsWith(\"http://\") || incomingUrl.startsWith(\"https://\"))) {\n if (incoming instanceof Http2ServerRequest) {\n throw new RequestError(\"Absolute URL for :path is not allowed in HTTP/2\");\n }\n try {\n const url2 = new URL(incomingUrl);\n req[urlKey] = url2.href;\n } catch (e) {\n throw new RequestError(\"Invalid absolute URL\", { cause: e });\n }\n return req;\n }\n const host = (incoming instanceof Http2ServerRequest ? incoming.authority : incoming.headers.host) || defaultHostname;\n if (!host) {\n throw new RequestError(\"Missing host header\");\n }\n let scheme;\n if (incoming instanceof Http2ServerRequest) {\n scheme = incoming.scheme;\n if (!(scheme === \"http\" || scheme === \"https\")) {\n throw new RequestError(\"Unsupported scheme\");\n }\n } else {\n scheme = incoming.socket && incoming.socket.encrypted ? \"https\" : \"http\";\n }\n const url = new URL(`${scheme}://${host}${incomingUrl}`);\n if (url.hostname.length !== host.length && url.hostname !== host.replace(/:\\d+$/, \"\")) {\n throw new RequestError(\"Invalid host header\");\n }\n req[urlKey] = url.href;\n return req;\n};\n\n// src/response.ts\nvar responseCache = Symbol(\"responseCache\");\nvar getResponseCache = Symbol(\"getResponseCache\");\nvar cacheKey = Symbol(\"cache\");\nvar GlobalResponse = global.Response;\nvar Response2 = class _Response {\n #body;\n #init;\n [getResponseCache]() {\n delete this[cacheKey];\n return this[responseCache] ||= new GlobalResponse(this.#body, this.#init);\n }\n constructor(body, init) {\n let headers;\n this.#body = body;\n if (init instanceof _Response) {\n const cachedGlobalResponse = init[responseCache];\n if (cachedGlobalResponse) {\n this.#init = cachedGlobalResponse;\n this[getResponseCache]();\n return;\n } else {\n this.#init = init.#init;\n headers = new Headers(init.#init.headers);\n }\n } else {\n this.#init = init;\n }\n if (typeof body === \"string\" || typeof body?.getReader !== \"undefined\" || body instanceof Blob || body instanceof Uint8Array) {\n ;\n this[cacheKey] = [init?.status || 200, body, headers || init?.headers];\n }\n }\n get headers() {\n const cache = this[cacheKey];\n if (cache) {\n if (!(cache[2] instanceof Headers)) {\n cache[2] = new Headers(\n cache[2] || { \"content-type\": \"text/plain; charset=UTF-8\" }\n );\n }\n return cache[2];\n }\n return this[getResponseCache]().headers;\n }\n get status() {\n return this[cacheKey]?.[0] ?? this[getResponseCache]().status;\n }\n get ok() {\n const status = this.status;\n return status >= 200 && status < 300;\n }\n};\n[\"body\", \"bodyUsed\", \"redirected\", \"statusText\", \"trailers\", \"type\", \"url\"].forEach((k) => {\n Object.defineProperty(Response2.prototype, k, {\n get() {\n return this[getResponseCache]()[k];\n }\n });\n});\n[\"arrayBuffer\", \"blob\", \"clone\", \"formData\", \"json\", \"text\"].forEach((k) => {\n Object.defineProperty(Response2.prototype, k, {\n value: function() {\n return this[getResponseCache]()[k]();\n }\n });\n});\nObject.defineProperty(Response2.prototype, Symbol.for(\"nodejs.util.inspect.custom\"), {\n value: function(depth, options, inspectFn) {\n const props = {\n status: this.status,\n headers: this.headers,\n ok: this.ok,\n nativeResponse: this[responseCache]\n };\n return `Response (lightweight) ${inspectFn(props, { ...options, depth: depth == null ? null : depth - 1 })}`;\n }\n});\nObject.setPrototypeOf(Response2, GlobalResponse);\nObject.setPrototypeOf(Response2.prototype, GlobalResponse.prototype);\n\n// src/utils.ts\nasync function readWithoutBlocking(readPromise) {\n return Promise.race([readPromise, Promise.resolve().then(() => Promise.resolve(void 0))]);\n}\nfunction writeFromReadableStreamDefaultReader(reader, writable, currentReadPromise) {\n const cancel = (error) => {\n reader.cancel(error).catch(() => {\n });\n };\n writable.on(\"close\", cancel);\n writable.on(\"error\", cancel);\n (currentReadPromise ?? reader.read()).then(flow, handleStreamError);\n return reader.closed.finally(() => {\n writable.off(\"close\", cancel);\n writable.off(\"error\", cancel);\n });\n function handleStreamError(error) {\n if (error) {\n writable.destroy(error);\n }\n }\n function onDrain() {\n reader.read().then(flow, handleStreamError);\n }\n function flow({ done, value }) {\n try {\n if (done) {\n writable.end();\n } else if (!writable.write(value)) {\n writable.once(\"drain\", onDrain);\n } else {\n return reader.read().then(flow, handleStreamError);\n }\n } catch (e) {\n handleStreamError(e);\n }\n }\n}\nfunction writeFromReadableStream(stream, writable) {\n if (stream.locked) {\n throw new TypeError(\"ReadableStream is locked.\");\n } else if (writable.destroyed) {\n return;\n }\n return writeFromReadableStreamDefaultReader(stream.getReader(), writable);\n}\nvar buildOutgoingHttpHeaders = (headers) => {\n const res = {};\n if (!(headers instanceof Headers)) {\n headers = new Headers(headers ?? void 0);\n }\n const cookies = [];\n for (const [k, v] of headers) {\n if (k === \"set-cookie\") {\n cookies.push(v);\n } else {\n res[k] = v;\n }\n }\n if (cookies.length > 0) {\n res[\"set-cookie\"] = cookies;\n }\n res[\"content-type\"] ??= \"text/plain; charset=UTF-8\";\n return res;\n};\n\n// src/utils/response/constants.ts\nvar X_ALREADY_SENT = \"x-hono-already-sent\";\n\n// src/globals.ts\nimport crypto from \"crypto\";\nif (typeof global.crypto === \"undefined\") {\n global.crypto = crypto;\n}\n\n// src/listener.ts\nvar outgoingEnded = Symbol(\"outgoingEnded\");\nvar incomingDraining = Symbol(\"incomingDraining\");\nvar DRAIN_TIMEOUT_MS = 500;\nvar MAX_DRAIN_BYTES = 64 * 1024 * 1024;\nvar drainIncoming = (incoming) => {\n const incomingWithDrainState = incoming;\n if (incoming.destroyed || incomingWithDrainState[incomingDraining]) {\n return;\n }\n incomingWithDrainState[incomingDraining] = true;\n if (incoming instanceof Http2ServerRequest2) {\n try {\n ;\n incoming.stream?.close?.(h2constants.NGHTTP2_NO_ERROR);\n } catch {\n }\n return;\n }\n let bytesRead = 0;\n const cleanup = () => {\n clearTimeout(timer);\n incoming.off(\"data\", onData);\n incoming.off(\"end\", cleanup);\n incoming.off(\"error\", cleanup);\n };\n const forceClose = () => {\n cleanup();\n const socket = incoming.socket;\n if (socket && !socket.destroyed) {\n socket.destroySoon();\n }\n };\n const timer = setTimeout(forceClose, DRAIN_TIMEOUT_MS);\n timer.unref?.();\n const onData = (chunk) => {\n bytesRead += chunk.length;\n if (bytesRead > MAX_DRAIN_BYTES) {\n forceClose();\n }\n };\n incoming.on(\"data\", onData);\n incoming.on(\"end\", cleanup);\n incoming.on(\"error\", cleanup);\n incoming.resume();\n};\nvar handleRequestError = () => new Response(null, {\n status: 400\n});\nvar handleFetchError = (e) => new Response(null, {\n status: e instanceof Error && (e.name === \"TimeoutError\" || e.constructor.name === \"TimeoutError\") ? 504 : 500\n});\nvar handleResponseError = (e, outgoing) => {\n const err = e instanceof Error ? e : new Error(\"unknown error\", { cause: e });\n if (err.code === \"ERR_STREAM_PREMATURE_CLOSE\") {\n console.info(\"The user aborted a request.\");\n } else {\n console.error(e);\n if (!outgoing.headersSent) {\n outgoing.writeHead(500, { \"Content-Type\": \"text/plain\" });\n }\n outgoing.end(`Error: ${err.message}`);\n outgoing.destroy(err);\n }\n};\nvar flushHeaders = (outgoing) => {\n if (\"flushHeaders\" in outgoing && outgoing.writable) {\n outgoing.flushHeaders();\n }\n};\nvar responseViaCache = async (res, outgoing) => {\n let [status, body, header] = res[cacheKey];\n let hasContentLength = false;\n if (!header) {\n header = { \"content-type\": \"text/plain; charset=UTF-8\" };\n } else if (header instanceof Headers) {\n hasContentLength = header.has(\"content-length\");\n header = buildOutgoingHttpHeaders(header);\n } else if (Array.isArray(header)) {\n const headerObj = new Headers(header);\n hasContentLength = headerObj.has(\"content-length\");\n header = buildOutgoingHttpHeaders(headerObj);\n } else {\n for (const key in header) {\n if (key.length === 14 && key.toLowerCase() === \"content-length\") {\n hasContentLength = true;\n break;\n }\n }\n }\n if (!hasContentLength) {\n if (typeof body === \"string\") {\n header[\"Content-Length\"] = Buffer.byteLength(body);\n } else if (body instanceof Uint8Array) {\n header[\"Content-Length\"] = body.byteLength;\n } else if (body instanceof Blob) {\n header[\"Content-Length\"] = body.size;\n }\n }\n outgoing.writeHead(status, header);\n if (typeof body === \"string\" || body instanceof Uint8Array) {\n outgoing.end(body);\n } else if (body instanceof Blob) {\n outgoing.end(new Uint8Array(await body.arrayBuffer()));\n } else {\n flushHeaders(outgoing);\n await writeFromReadableStream(body, outgoing)?.catch(\n (e) => handleResponseError(e, outgoing)\n );\n }\n ;\n outgoing[outgoingEnded]?.();\n};\nvar isPromise = (res) => typeof res.then === \"function\";\nvar responseViaResponseObject = async (res, outgoing, options = {}) => {\n if (isPromise(res)) {\n if (options.errorHandler) {\n try {\n res = await res;\n } catch (err) {\n const errRes = await options.errorHandler(err);\n if (!errRes) {\n return;\n }\n res = errRes;\n }\n } else {\n res = await res.catch(handleFetchError);\n }\n }\n if (cacheKey in res) {\n return responseViaCache(res, outgoing);\n }\n const resHeaderRecord = buildOutgoingHttpHeaders(res.headers);\n if (res.body) {\n const reader = res.body.getReader();\n const values = [];\n let done = false;\n let currentReadPromise = void 0;\n if (resHeaderRecord[\"transfer-encoding\"] !== \"chunked\") {\n let maxReadCount = 2;\n for (let i = 0; i < maxReadCount; i++) {\n currentReadPromise ||= reader.read();\n const chunk = await readWithoutBlocking(currentReadPromise).catch((e) => {\n console.error(e);\n done = true;\n });\n if (!chunk) {\n if (i === 1) {\n await new Promise((resolve) => setTimeout(resolve));\n maxReadCount = 3;\n continue;\n }\n break;\n }\n currentReadPromise = void 0;\n if (chunk.value) {\n values.push(chunk.value);\n }\n if (chunk.done) {\n done = true;\n break;\n }\n }\n if (done && !(\"content-length\" in resHeaderRecord)) {\n resHeaderRecord[\"content-length\"] = values.reduce((acc, value) => acc + value.length, 0);\n }\n }\n outgoing.writeHead(res.status, resHeaderRecord);\n values.forEach((value) => {\n ;\n outgoing.write(value);\n });\n if (done) {\n outgoing.end();\n } else {\n if (values.length === 0) {\n flushHeaders(outgoing);\n }\n await writeFromReadableStreamDefaultReader(reader, outgoing, currentReadPromise);\n }\n } else if (resHeaderRecord[X_ALREADY_SENT]) {\n } else {\n outgoing.writeHead(res.status, resHeaderRecord);\n outgoing.end();\n }\n ;\n outgoing[outgoingEnded]?.();\n};\nvar getRequestListener = (fetchCallback, options = {}) => {\n const autoCleanupIncoming = options.autoCleanupIncoming ?? true;\n if (options.overrideGlobalObjects !== false && global.Request !== Request) {\n Object.defineProperty(global, \"Request\", {\n value: Request\n });\n Object.defineProperty(global, \"Response\", {\n value: Response2\n });\n }\n return async (incoming, outgoing) => {\n let res, req;\n try {\n req = newRequest(incoming, options.hostname);\n let incomingEnded = !autoCleanupIncoming || incoming.method === \"GET\" || incoming.method === \"HEAD\";\n if (!incomingEnded) {\n ;\n incoming[wrapBodyStream] = true;\n incoming.on(\"end\", () => {\n incomingEnded = true;\n });\n if (incoming instanceof Http2ServerRequest2) {\n ;\n outgoing[outgoingEnded] = () => {\n if (!incomingEnded) {\n setTimeout(() => {\n if (!incomingEnded) {\n setTimeout(() => {\n drainIncoming(incoming);\n });\n }\n });\n }\n };\n }\n outgoing.on(\"finish\", () => {\n if (!incomingEnded) {\n drainIncoming(incoming);\n }\n });\n }\n outgoing.on(\"close\", () => {\n const abortController = req[abortControllerKey];\n if (abortController) {\n if (incoming.errored) {\n req[abortControllerKey].abort(incoming.errored.toString());\n } else if (!outgoing.writableFinished) {\n req[abortControllerKey].abort(\"Client connection prematurely closed.\");\n }\n }\n if (!incomingEnded) {\n setTimeout(() => {\n if (!incomingEnded) {\n setTimeout(() => {\n drainIncoming(incoming);\n });\n }\n });\n }\n });\n res = fetchCallback(req, { incoming, outgoing });\n if (cacheKey in res) {\n return responseViaCache(res, outgoing);\n }\n } catch (e) {\n if (!res) {\n if (options.errorHandler) {\n res = await options.errorHandler(req ? e : toRequestError(e));\n if (!res) {\n return;\n }\n } else if (!req) {\n res = handleRequestError();\n } else {\n res = handleFetchError(e);\n }\n } else {\n return handleResponseError(e, outgoing);\n }\n }\n try {\n return await responseViaResponseObject(res, outgoing, options);\n } catch (e) {\n return handleResponseError(e, outgoing);\n }\n };\n};\n\n// src/server.ts\nvar createAdaptorServer = (options) => {\n const fetchCallback = options.fetch;\n const requestListener = getRequestListener(fetchCallback, {\n hostname: options.hostname,\n overrideGlobalObjects: options.overrideGlobalObjects,\n autoCleanupIncoming: options.autoCleanupIncoming\n });\n const createServer = options.createServer || createServerHTTP;\n const server = createServer(options.serverOptions || {}, requestListener);\n return server;\n};\nvar serve = (options, listeningListener) => {\n const server = createAdaptorServer(options);\n server.listen(options?.port ?? 3e3, options.hostname, () => {\n const serverInfo = server.address();\n listeningListener && listeningListener(serverInfo);\n });\n return server;\n};\nexport {\n RequestError,\n createAdaptorServer,\n getRequestListener,\n serve\n};\n","// Server\nexport const PARTY_PORT = parseInt(process.env.PARTY_PORT || '8000', 10);\n\nexport const STALE_THRESHOLD = parseInt(process.env.STALE_THRESHOLD || '3', 10);\n\n// Agent lifecycle\nexport const HEARTBEAT_TIMEOUT = parseFloat(process.env.HEARTBEAT_TIMEOUT || '60');\nexport const CLEANUP_INTERVAL = parseFloat(process.env.CLEANUP_INTERVAL || '60');\n\n// Peer discovery\nexport const DISCOVERY_INTERVAL = parseFloat(process.env.DISCOVERY_INTERVAL || '20');\nexport const REMOTE_STALE_FACTOR = parseInt(process.env.REMOTE_STALE_FACTOR || '3', 10);\nexport const PROBE_TIMEOUT = parseFloat(process.env.PROBE_TIMEOUT || '5');\n","import { existsSync, mkdirSync, appendFileSync, readdirSync, unlinkSync, statSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\n\ntype LogLevel = 'debug' | 'info' | 'warn' | 'error';\n\nconst LEVEL_ORDER: Record<LogLevel, number> = {\n debug: 0,\n info: 1,\n warn: 2,\n error: 3,\n};\n\nfunction getEffectiveLevel(): LogLevel {\n const env = (process.env.LOG_LEVEL || 'info').toLowerCase().trim();\n if (env in LEVEL_ORDER) return env as LogLevel;\n return 'info';\n}\n\nconst effectiveLevel = getEffectiveLevel();\n\n// ---------------------------------------------------------------------------\n// File logging setup\n// ---------------------------------------------------------------------------\n\nconst LOG_DIR = join(homedir(), '.open-party', 'logs');\nconst LOG_RETENTION_DAYS = 7;\n\n/** Ensure log directory exists and prune old log files beyond retention. */\nfunction initLogFile(): void {\n if (!existsSync(LOG_DIR)) {\n mkdirSync(LOG_DIR, { recursive: true });\n return;\n }\n\n // Prune log files older than LOG_RETENTION_DAYS\n try {\n const now = Date.now();\n const cutoff = now - LOG_RETENTION_DAYS * 24 * 60 * 60 * 1000;\n const files = readdirSync(LOG_DIR);\n for (const f of files) {\n if (!f.endsWith('-open-party.log')) continue;\n try {\n const stat = statSync(join(LOG_DIR, f));\n if (stat.mtimeMs < cutoff) {\n unlinkSync(join(LOG_DIR, f));\n }\n } catch {\n // [ANTI-PATTERN IGNORED]: skip individual unreadable files during retention prune\n }\n }\n } catch {\n // [ANTI-PATTERN IGNORED]: best-effort log directory init — console is primary channel\n }\n}\n\n/** Get today's log file path: ~/.open-party/logs/2026-05-31-open-party.log */\nfunction getLogFilePath(): string {\n const d = new Date();\n const yyyy = String(d.getFullYear());\n const mm = String(d.getMonth() + 1).padStart(2, '0');\n const dd = String(d.getDate()).padStart(2, '0');\n return join(LOG_DIR, `${yyyy}-${mm}-${dd}-open-party.log`);\n}\n\n// Initialize on module load\ninitLogFile();\n\n// ---------------------------------------------------------------------------\n// Core helpers\n// ---------------------------------------------------------------------------\n\nfunction shouldLog(level: LogLevel): boolean {\n return LEVEL_ORDER[level] >= LEVEL_ORDER[effectiveLevel];\n}\n\nfunction extractError(err: unknown): string {\n if (err instanceof Error) {\n const stack = err.stack ? `\\n${err.stack}` : '';\n return `${err.message}${stack}`;\n }\n return String(err);\n}\n\nfunction format(level: LogLevel, tag: string, message: string): string {\n const now = new Date();\n // Pad level to fixed width for column alignment\n const levelStr = level.toUpperCase().padEnd(5);\n const yyyy = String(now.getFullYear());\n const mm = String(now.getMonth() + 1).padStart(2, '0');\n const dd = String(now.getDate()).padStart(2, '0');\n const hh = String(now.getHours()).padStart(2, '0');\n const min = String(now.getMinutes()).padStart(2, '0');\n const ss = String(now.getSeconds()).padStart(2, '0');\n const ts = `${yyyy}-${mm}-${dd} ${hh}:${min}:${ss}`;\n return `${ts} [${levelStr}] [${tag}] ${message}`;\n}\n\n/** Write line to both console and today's log file. */\nfunction output(consoleFn: typeof console.log, level: LogLevel, tag: string, message: string): void {\n if (!shouldLog(level)) return;\n const line = format(level, tag, message);\n consoleFn(line);\n // [ANTI-PATTERN IGNORED]: File write is on the hot path but appendFileSync is fast enough\n // for log volumes (<100 writes/sec). The alternative (buffered write) adds complexity\n // without measurable benefit at this scale.\n try {\n appendFileSync(getLogFilePath(), line + '\\n', 'utf-8');\n } catch {\n // [ANTI-PATTERN IGNORED]: File write failure on hot path — console output is primary channel\n }\n}\n\nexport const logger = {\n info(tag: string, message: string, data?: Record<string, unknown>): void {\n output(console.log, 'info', tag, data ? `${message} ${JSON.stringify(data)}` : message);\n },\n\n warn(tag: string, message: string, data?: unknown): void {\n const detail = data instanceof Error ? `: ${extractError(data)}` : data ? ` ${JSON.stringify(data)}` : '';\n output(console.warn, 'warn', tag, message + detail);\n },\n\n error(tag: string, message: string, err?: unknown): void {\n const detail = err ? `: ${extractError(err)}` : '';\n output(console.error, 'error', tag, message + detail);\n },\n\n debug(tag: string, message: string, data?: Record<string, unknown>): void {\n output(console.debug, 'debug', tag, data ? `${message} ${JSON.stringify(data)}` : message);\n },\n};\n","/**\n * Server state persistence via JSON snapshots.\n *\n * Provides atomic write/load of agent registry and ring buffer state\n * so that server state survives restarts.\n *\n * Storage: ~/.open-party/data/snapshot.json (atomic .tmp + rename)\n */\n\nimport { existsSync, readFileSync, writeFileSync, unlinkSync, renameSync, mkdirSync } from 'node:fs';\nimport { join, dirname } from 'node:path';\nimport { homedir } from 'node:os';\nimport type { AgentInfo, AgentBufferSnapshot } from './models.js';\nimport { logger } from './logger.js';\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\nexport interface ServerSnapshot {\n version: number;\n saved_at: number;\n agents: AgentInfo[];\n buffers: Record<string, AgentBufferSnapshot>;\n}\n\n// ---------------------------------------------------------------------------\n// Constants\n// ---------------------------------------------------------------------------\n\nconst CURRENT_SCHEMA_VERSION = 2;\nconst SNAPSHOT_FILE = 'snapshot.json';\nconst SHUTDOWN_MARKER_FILE = 'shutdown-marker.json';\nconst DEFAULT_SNAPSHOT_INTERVAL_MS = 60_000; // 60 seconds\n\n/** Resolve the data directory path. */\nfunction dataDirPath(): string {\n const pluginData = process.env.CLAUDE_PLUGIN_DATA || '';\n if (pluginData) return join(pluginData, 'data');\n return join(homedir(), '.open-party', 'data');\n}\n\n// ---------------------------------------------------------------------------\n// SnapshotManager\n// ---------------------------------------------------------------------------\n\nexport class SnapshotManager {\n private readonly _dir: string;\n private readonly _snapshotPath: string;\n private readonly _markerPath: string;\n\n constructor(dataDir?: string) {\n this._dir = dataDir ?? dataDirPath();\n this._snapshotPath = join(this._dir, SNAPSHOT_FILE);\n this._markerPath = join(this._dir, SHUTDOWN_MARKER_FILE);\n\n mkdirSync(this._dir, { recursive: true });\n\n // Clean up stale .tmp file from interrupted previous write\n const tmpPath = this._snapshotPath + '.tmp';\n try {\n if (existsSync(tmpPath)) {\n unlinkSync(tmpPath);\n }\n } catch (error) {\n logger.warn('Persistence', 'Failed to clean up stale tmp file', error);\n }\n }\n\n // ------------------------------------------------------------------\n // Write / Load\n // ------------------------------------------------------------------\n\n /** Atomically write a snapshot of registry agents and ring buffer state. */\n writeSnapshot(agents: AgentInfo[], buffers: Record<string, AgentBufferSnapshot>): void {\n const snapshot: ServerSnapshot = {\n version: CURRENT_SCHEMA_VERSION,\n saved_at: Date.now(),\n agents,\n buffers,\n };\n\n const serialized = JSON.stringify(snapshot, null, 2);\n const tmpPath = this._snapshotPath + '.tmp';\n\n try {\n writeFileSync(tmpPath, serialized, 'utf-8');\n renameSync(tmpPath, this._snapshotPath);\n } catch (error) {\n logger.error('Persistence', 'Failed to write snapshot', error);\n try { unlinkSync(tmpPath); } catch { /* best-effort cleanup */ }\n throw error;\n }\n }\n\n /** Load and validate snapshot. Returns null if file missing or corrupt. */\n loadSnapshot(): ServerSnapshot | null {\n if (!existsSync(this._snapshotPath)) {\n return null;\n }\n\n try {\n const raw = JSON.parse(readFileSync(this._snapshotPath, 'utf-8'));\n if (!raw || typeof raw !== 'object') {\n throw new Error('Snapshot is not a valid object');\n }\n return {\n version: typeof raw.version === 'number' ? raw.version : CURRENT_SCHEMA_VERSION,\n saved_at: typeof raw.saved_at === 'number' ? raw.saved_at : 0,\n agents: Array.isArray(raw.agents) ? raw.agents : [],\n buffers: raw.buffers && typeof raw.buffers === 'object' && !Array.isArray(raw.buffers)\n ? raw.buffers\n : {},\n };\n } catch (error) {\n logger.warn('Persistence', 'Failed to load snapshot (starting fresh)', error);\n return null;\n }\n }\n\n // ------------------------------------------------------------------\n // Hydration (restore in-memory state from snapshot)\n // ------------------------------------------------------------------\n\n /** Restore agents into registry. Overwrites host_ip with current selfIp. */\n hydrateAgents(registry: import('./registry.js').AgentRegistry, selfIp: string): number {\n const snapshot = this.loadSnapshot();\n if (!snapshot || snapshot.agents.length === 0) return 0;\n\n const now = Date.now() / 1000;\n let count = 0;\n\n for (const agent of snapshot.agents) {\n agent.last_heartbeat = now;\n const info = registry.register({\n agent_id: agent.agent_id,\n display_name: agent.display_name,\n metadata: agent.metadata ?? {},\n });\n info.host_ip = selfIp;\n count++;\n }\n\n return count;\n }\n\n /** Restore ring buffer state into message queue. */\n hydrateBuffers(queue: import('./message-queue.js').MessageQueue): number {\n const snapshot = this.loadSnapshot();\n if (!snapshot || Object.keys(snapshot.buffers).length === 0) return 0;\n\n queue.restoreBufferSnapshots(snapshot.buffers);\n\n let totalEntries = 0;\n for (const snap of Object.values(snapshot.buffers)) {\n totalEntries += snap.entries.length;\n }\n\n return totalEntries;\n }\n\n // ------------------------------------------------------------------\n // Shutdown marker\n // ------------------------------------------------------------------\n\n /** Write shutdown marker to detect interrupted shutdown on next start. */\n writeShutdownMarker(): void {\n try {\n writeFileSync(\n this._markerPath,\n JSON.stringify({ started_at: Date.now() }),\n 'utf-8',\n );\n } catch (error) {\n logger.warn('Persistence', 'Failed to write shutdown marker', error);\n }\n }\n\n /** Remove shutdown marker — called after successful shutdown. */\n removeShutdownMarker(): void {\n try {\n if (existsSync(this._markerPath)) {\n unlinkSync(this._markerPath);\n }\n } catch (error) {\n logger.warn('Persistence', 'Failed to remove shutdown marker', error);\n }\n }\n\n /** Check if a shutdown marker exists (indicates previous shutdown was interrupted). */\n hasShutdownMarker(): boolean {\n return existsSync(this._markerPath);\n }\n\n // ------------------------------------------------------------------\n // Snapshot loop\n // ------------------------------------------------------------------\n\n /**\n * Start periodic snapshot background loop.\n * Writes snapshot every `intervalMs` milliseconds until signal is aborted.\n */\n async startSnapshotLoop(\n signal: AbortSignal,\n getAgents: () => AgentInfo[],\n getBuffers: () => Record<string, AgentBufferSnapshot>,\n intervalMs: number = DEFAULT_SNAPSHOT_INTERVAL_MS,\n ): Promise<void> {\n while (!signal.aborted) {\n try {\n await abortableSleep(intervalMs, signal);\n } catch (e) {\n if (signal.aborted) break;\n throw e;\n }\n\n if (signal.aborted) break;\n\n try {\n this.writeSnapshot(getAgents(), getBuffers());\n } catch (error) {\n // [ANTI-PATTERN IGNORED]: Periodic snapshot failure should not crash the loop\n logger.warn('Persistence', 'Periodic snapshot failed', error);\n }\n }\n }\n}\n\n// ---------------------------------------------------------------------------\n// Utility\n// ---------------------------------------------------------------------------\n\n/** Sleep that respects AbortSignal — throws AbortError when aborted. */\nexport function abortableSleep(ms: number, signal?: AbortSignal): Promise<void> {\n return new Promise((resolve, reject) => {\n const timer = setTimeout(resolve, ms);\n signal?.addEventListener(\n 'abort',\n () => {\n clearTimeout(timer);\n reject(new DOMException('Aborted', 'AbortError'));\n },\n { once: true },\n );\n });\n}\n","/**\n * Per-agent ring buffer with server-side cursor.\n *\n * Unified storage for message queue + history:\n * - `write()` appends entries with monotonic seq numbers\n * - `dequeue()` reads from cursor and advances it (non-destructive)\n * - `getRecent()` returns latest N entries regardless of cursor\n * - Overflow overwrites oldest entries when capacity is reached\n */\n\nimport type { MessageEnvelope, RingBufferEntry, AgentBufferSnapshot } from './models.js';\n\nconst DEFAULT_CAPACITY = 200;\n\nexport class AgentRingBuffer {\n private readonly _buffer: (RingBufferEntry | undefined)[];\n private readonly _capacity: number;\n private _head = 0; // next write position (0 ~ capacity-1)\n private _nextSeq = 1; // next sequence number to assign\n private _count = 0; // valid entries currently in buffer\n private _cursor = 0; // server-side read cursor (last consumed seq)\n\n constructor(capacity: number = DEFAULT_CAPACITY) {\n this._capacity = Math.max(1, capacity);\n this._buffer = new Array(this._capacity);\n }\n\n // ------------------------------------------------------------------\n // Write\n // ------------------------------------------------------------------\n\n /** Write an entry to the buffer. Returns the assigned sequence number. */\n write(direction: 'sent' | 'received', envelope: MessageEnvelope): number {\n const seq = this._nextSeq++;\n const entry: RingBufferEntry = {\n seq,\n direction,\n sender_id: envelope.sender_id,\n recipient_id: envelope.recipient_id,\n summary: envelope.summary,\n content: envelope.content,\n timestamp: envelope.timestamp ?? Date.now() / 1000,\n };\n\n this._buffer[this._head] = entry;\n this._head = (this._head + 1) % this._capacity;\n\n if (this._count < this._capacity) {\n this._count++;\n }\n\n return seq;\n }\n\n // ------------------------------------------------------------------\n // Read (cursor-based — dequeue semantics)\n // ------------------------------------------------------------------\n\n /**\n * Read up to maxCount entries after the cursor, then advance the cursor.\n * Non-destructive: entries remain in the buffer for history queries.\n */\n dequeue(maxCount: number = 50): RingBufferEntry[] {\n const unread = this._readSince(this._cursor);\n if (unread.length === 0) return [];\n\n const taken = unread.slice(0, maxCount);\n // Advance cursor to the last consumed seq\n this._cursor = taken[taken.length - 1].seq;\n return taken;\n }\n\n /**\n * Like dequeue(), but only returns 'received' entries.\n * Cursor advances to the last returned 'received' entry's seq.\n * Used for inbox semantics — agents only see incoming messages.\n */\n dequeueReceived(maxCount: number = 50): RingBufferEntry[] {\n const all = this._readSince(this._cursor);\n if (all.length === 0) return [];\n\n const received = all.filter(e => e.direction === 'received').slice(0, maxCount);\n if (received.length === 0) return [];\n\n // Advance cursor to the last returned entry's seq\n this._cursor = received[received.length - 1].seq;\n return received;\n }\n\n /** Number of unread entries (next_seq - cursor). */\n unreadCount(): number {\n const diff = this._nextSeq - 1 - this._cursor;\n return Math.max(0, diff);\n }\n\n /** Number of unread 'received' entries after cursor. */\n unreadReceivedCount(): number {\n const all = this._readSince(this._cursor);\n let count = 0;\n for (const e of all) {\n if (e.direction === 'received') count++;\n }\n return count;\n }\n\n // ------------------------------------------------------------------\n // Read (non-destructive — no cursor advance)\n // ------------------------------------------------------------------\n\n /** Read all entries with seq > sinceSeq. Does NOT advance cursor. */\n readSince(sinceSeq: number): RingBufferEntry[] {\n return this._readSince(sinceSeq);\n }\n\n /** Get the most recent N entries regardless of cursor. */\n getRecent(limit: number = 20): RingBufferEntry[] {\n const all = this._allSorted();\n return all.slice(-limit);\n }\n\n /** Get total number of valid entries in the buffer. */\n get count(): number {\n return this._count;\n }\n\n // ------------------------------------------------------------------\n // Lifecycle\n // ------------------------------------------------------------------\n\n /** Clear the buffer and reset cursor. */\n clear(): void {\n this._buffer.fill(undefined);\n this._head = 0;\n this._nextSeq = 1;\n this._count = 0;\n this._cursor = 0;\n }\n\n // ------------------------------------------------------------------\n // Snapshot / Restore\n // ------------------------------------------------------------------\n\n /** Export buffer state for persistence. */\n getSnapshot(): AgentBufferSnapshot {\n return {\n entries: this._allSorted(),\n next_seq: this._nextSeq,\n cursor: this._cursor,\n };\n }\n\n /** Restore buffer from a snapshot. */\n restoreFromSnapshot(snap: AgentBufferSnapshot): void {\n this.clear();\n\n // Restore entries into the ring buffer in order\n for (const entry of snap.entries) {\n this._buffer[this._head] = entry;\n this._head = (this._head + 1) % this._capacity;\n this._count++;\n }\n\n this._nextSeq = snap.next_seq;\n this._cursor = snap.cursor;\n }\n\n /** Get the next sequence number that will be assigned. */\n get nextSeq(): number {\n return this._nextSeq;\n }\n\n /** Get the current cursor position. */\n get cursor(): number {\n return this._cursor;\n }\n\n // ------------------------------------------------------------------\n // Private helpers\n // ------------------------------------------------------------------\n\n /**\n * Collect all valid entries sorted by seq.\n * O(count) — scans the ring buffer once.\n */\n private _allSorted(): RingBufferEntry[] {\n const result: RingBufferEntry[] = [];\n for (let i = 0; i < this._capacity; i++) {\n const entry = this._buffer[i];\n if (entry !== undefined) {\n result.push(entry);\n }\n }\n result.sort((a, b) => a.seq - b.seq);\n return result;\n }\n\n /**\n * Read entries with seq > sinceSeq.\n * Uses binary search on sorted entries for efficiency.\n */\n private _readSince(sinceSeq: number): RingBufferEntry[] {\n const all = this._allSorted();\n // Binary search: find first entry with seq > sinceSeq\n let lo = 0;\n let hi = all.length;\n while (lo < hi) {\n const mid = (lo + hi) >>> 1;\n if (all[mid].seq <= sinceSeq) {\n lo = mid + 1;\n } else {\n hi = mid;\n }\n }\n return all.slice(lo);\n }\n}\n","/**\n * Per-agent message queue backed by ring buffers.\n *\n * Unified storage: each agent has one ring buffer that stores both\n * 'sent' and 'received' entries. Dequeue is non-destructive (cursor-based).\n */\n\nimport type { MessageEnvelope, HistoryEntry, AgentBufferSnapshot } from './models.js';\nimport { AgentRingBuffer } from './ring-buffer.js';\n\nconst DEFAULT_CAPACITY = 200;\n\n/** Per-agent message queue stored in memory. */\nexport class MessageQueue {\n private _buffers = new Map<string, AgentRingBuffer>();\n\n private _getOrCreate(agentId: string): AgentRingBuffer {\n let buf = this._buffers.get(agentId);\n if (!buf) {\n buf = new AgentRingBuffer(DEFAULT_CAPACITY);\n this._buffers.set(agentId, buf);\n }\n return buf;\n }\n\n /** Enqueue a message for agentId. Returns the unread count after enqueue. */\n enqueue(agentId: string, envelope: MessageEnvelope): number {\n const buf = this._getOrCreate(agentId);\n buf.write('received', envelope);\n return buf.unreadReceivedCount();\n }\n\n /** Pop up to maxCount received messages for agentId (non-destructive, cursor-based). */\n dequeue(agentId: string, maxCount = 50): MessageEnvelope[] {\n const buf = this._buffers.get(agentId);\n if (!buf) return [];\n return buf.dequeueReceived(maxCount).map(toEnvelope);\n }\n\n /** Return the number of pending received messages for agentId. */\n pendingCount(agentId: string): number {\n return this._buffers.get(agentId)?.unreadReceivedCount() ?? 0;\n }\n\n /** Clean up buffer when agent is removed. */\n removeAgent(agentId: string): void {\n this._buffers.delete(agentId);\n }\n\n /** Record a message in an agent's history (writes to the same ring buffer). */\n logToHistory(agentId: string, direction: 'sent' | 'received', envelope: MessageEnvelope): void {\n const buf = this._getOrCreate(agentId);\n buf.write(direction, envelope);\n }\n\n /** Get recent N history entries for an agent. */\n getHistory(agentId: string, limit = 20): HistoryEntry[] {\n const buf = this._buffers.get(agentId);\n if (!buf) return [];\n return buf.getRecent(limit).map(toHistoryEntry);\n }\n\n /** Clean up history when agent is removed (same as removeAgent — unified storage). */\n removeAgentHistory(agentId: string): void {\n this._buffers.delete(agentId);\n }\n\n /**\n * Return a shallow copy of the full history map (for persistence snapshots).\n * Kept for backward compatibility with persistence v1 consumers.\n */\n getHistorySnapshot(): Record<string, HistoryEntry[]> {\n const copy: Record<string, HistoryEntry[]> = {};\n for (const [agentId, buf] of this._buffers) {\n copy[agentId] = buf.getRecent().map(toHistoryEntry);\n }\n return copy;\n }\n\n /** Return ring buffer snapshots for persistence v2. */\n getBufferSnapshots(): Record<string, AgentBufferSnapshot> {\n const result: Record<string, AgentBufferSnapshot> = {};\n for (const [agentId, buf] of this._buffers) {\n result[agentId] = buf.getSnapshot();\n }\n return result;\n }\n\n /** Restore buffers from v2 snapshots. */\n restoreBufferSnapshots(snapshots: Record<string, AgentBufferSnapshot>): void {\n for (const [agentId, snap] of Object.entries(snapshots)) {\n const buf = new AgentRingBuffer(DEFAULT_CAPACITY);\n buf.restoreFromSnapshot(snap);\n this._buffers.set(agentId, buf);\n }\n }\n}\n\n// ---------------------------------------------------------------------------\n// Conversion helpers\n// ---------------------------------------------------------------------------\n\nfunction toEnvelope(e: import('./models.js').RingBufferEntry): MessageEnvelope {\n return {\n sender_id: e.sender_id,\n recipient_id: e.recipient_id,\n summary: e.summary,\n content: e.content,\n timestamp: e.timestamp,\n };\n}\n\nfunction toHistoryEntry(e: import('./models.js').RingBufferEntry): HistoryEntry {\n return {\n direction: e.direction,\n sender_id: e.sender_id,\n recipient_id: e.recipient_id,\n summary: e.summary,\n content: e.content,\n timestamp: e.timestamp,\n };\n}\n","/**\n * Peer discovery and remote agent cache for cross-host communication.\n *\n * Pull-based discovery loop:\n * 1. Read Tailscale peers via readTailscaleStatus()\n * 2. Probe each peer's /proxy/health to identify Party Servers\n * 3. Fetch agent lists from healthy peers via /proxy/list_agents\n * 4. Maintain a remote agent cache with per-peer reachability tracking\n *\n * Simplified state machine: UNKNOWN → ALIVE → DEAD\n */\n\nimport type { AgentInfo } from './models.js';\nimport { DISCOVERY_INTERVAL, PARTY_PORT, PROBE_TIMEOUT, REMOTE_STALE_FACTOR } from './config.js';\nimport { readTailscaleStatus } from '../infra/tailscale.js';\nimport { abortableSleep } from './persistence.js';\nimport { logger } from './logger.js';\n\n// ---------------------------------------------------------------------------\n// Peer state machine constants\n// ---------------------------------------------------------------------------\n\nconst UNKNOWN = 'UNKNOWN';\nconst ALIVE = 'ALIVE';\nconst DEAD = 'DEAD';\n\nconst MAX_FAILURES = 3;\nconst BACKOFF_BASE = 60;\nconst BACKOFF_CAP = 900;\n\n// ---------------------------------------------------------------------------\n// Data types\n// ---------------------------------------------------------------------------\n\ninterface PeerState {\n ip: string;\n status: string;\n consecutiveFailures: number;\n lastProbeAt: number;\n backoffUntil: number | null;\n}\n\ninterface RemoteAgentEntry {\n agentInfo: AgentInfo;\n sourcePeerIp: string;\n lastSyncedAt: number;\n reachable: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// Error classification for native fetch\n// ---------------------------------------------------------------------------\n\n/** Classify a fetch error as refused (false), timeout/uncertain (null). */\nfunction classifyFetchError(error: unknown): boolean | null {\n if (error instanceof TypeError && /fetch failed/i.test(error.message)) {\n const cause = (error as NodeJS.ErrnoException).cause as { code?: string } | undefined;\n if (cause?.code === 'ECONNREFUSED') return false;\n return null;\n }\n if (error instanceof DOMException && error.name === 'AbortError') return null;\n return null;\n}\n\n// ---------------------------------------------------------------------------\n// PeerDiscovery\n// ---------------------------------------------------------------------------\n\nexport class PeerDiscovery {\n private _selfIp: string;\n private _peers = new Map<string, PeerState>();\n private _remoteAgents = new Map<string, RemoteAgentEntry>();\n\n constructor(selfIp: string) {\n this._selfIp = selfIp;\n }\n\n // ------------------------------------------------------------------\n // Public query API (used by router)\n // ------------------------------------------------------------------\n\n /** Return the peer IP that owns agentId, or undefined. */\n getPeerForAgent(agentId: string): string | undefined {\n return this._remoteAgents.get(agentId)?.sourcePeerIp;\n }\n\n /** Return true if the peer is alive. */\n isPeerReachable(peerIp: string): boolean {\n const ps = this._peers.get(peerIp);\n return ps !== undefined && ps.status === ALIVE;\n }\n\n /** Return all remote agents (including unreachable ones). */\n getAllRemoteAgents(): AgentInfo[] {\n return Array.from(this._remoteAgents.values(), (e) => e.agentInfo);\n }\n\n /** Return only reachable remote agents. */\n getReachableRemoteAgents(): AgentInfo[] {\n return Array.from(this._remoteAgents.values())\n .filter((e) => e.reachable)\n .map((e) => e.agentInfo);\n }\n\n /** Return all known peer states. */\n getPeerStates(): Array<{\n ip: string;\n status: string;\n consecutiveFailures: number;\n lastProbeAt: number;\n backoffUntil: number | null;\n }> {\n return Array.from(this._peers.values()).map((ps) => ({\n ip: ps.ip,\n status: ps.status,\n consecutiveFailures: ps.consecutiveFailures,\n lastProbeAt: ps.lastProbeAt,\n backoffUntil: ps.backoffUntil,\n }));\n }\n\n /** Return remote agent entries with peer mapping info. */\n getRemoteAgentEntries(): Array<{\n agentInfo: AgentInfo;\n sourcePeerIp: string;\n lastSyncedAt: number;\n reachable: boolean;\n }> {\n return Array.from(this._remoteAgents.values()).map((e) => ({\n agentInfo: e.agentInfo,\n sourcePeerIp: e.sourcePeerIp,\n lastSyncedAt: e.lastSyncedAt,\n reachable: e.reachable,\n }));\n }\n\n // ------------------------------------------------------------------\n // Main discovery loop\n // ------------------------------------------------------------------\n\n async runLoop(signal?: AbortSignal): Promise<void> {\n while (!signal?.aborted) {\n try {\n await this.discoveryCycle();\n } catch (e) {\n logger.error('Discovery', 'Cycle failed', e);\n }\n await abortableSleep(DISCOVERY_INTERVAL * 1000, signal);\n }\n }\n\n private async discoveryCycle(): Promise<void> {\n const peerIps = this.getTailscalePeers();\n\n // Add new peers as UNKNOWN\n for (const ip of peerIps) {\n if (!this._peers.has(ip)) {\n this._peers.set(ip, { ip, status: UNKNOWN, consecutiveFailures: 0, lastProbeAt: 0, backoffUntil: null });\n }\n }\n\n const now = performance.now() / 1000;\n\n // Process each peer\n for (const ip of peerIps) {\n const ps = this._peers.get(ip)!;\n\n // Skip DEAD peers still in backoff\n if (ps.status === DEAD) {\n if (ps.backoffUntil !== null && now < ps.backoffUntil) continue;\n ps.status = UNKNOWN;\n }\n\n await this.probePeer(ps);\n }\n\n this.evictDeadAgents();\n this.evictStaleAgents();\n }\n\n // ------------------------------------------------------------------\n // Tailscale peer enumeration\n // ------------------------------------------------------------------\n\n private getTailscalePeers(): string[] {\n let status: Record<string, unknown>;\n try {\n status = readTailscaleStatus();\n } catch (error) {\n logger.warn('Discovery', 'Failed to read Tailscale status', error);\n return [];\n }\n\n const peersRaw = status.Peer as Record<string, Record<string, unknown>> | undefined;\n if (!peersRaw || typeof peersRaw !== 'object') return [];\n\n const ips: string[] = [];\n for (const peer of Object.values(peersRaw)) {\n if (typeof peer !== 'object' || !peer) continue;\n if (!peer.Online) continue;\n if (peer.ExitNode) continue;\n const tailscaleIps = peer.TailscaleIPs as string[] | undefined;\n if (!tailscaleIps) continue;\n for (const ip of tailscaleIps) {\n if (ip.includes('.') && !ip.includes(':')) {\n if (ip !== this._selfIp) ips.push(ip);\n break;\n }\n }\n }\n return ips;\n }\n\n // ------------------------------------------------------------------\n // Peer probing\n // ------------------------------------------------------------------\n\n private async probePeer(ps: PeerState): Promise<void> {\n ps.lastProbeAt = Date.now() / 1000;\n const healthy = await this.checkHealth(ps.ip);\n\n if (healthy === true) {\n await this.handleProbeSuccess(ps);\n } else if (healthy === false) {\n this.handleProbeFailure(ps);\n }\n // null = timeout/uncertain → treat as transient, don't change state\n }\n\n private async checkHealth(ip: string): Promise<boolean | null> {\n const url = `http://${ip}:${PARTY_PORT}/proxy/health`;\n try {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), PROBE_TIMEOUT * 1000);\n const resp = await fetch(url, { signal: controller.signal });\n clearTimeout(timer);\n const data = (await resp.json()) as Record<string, unknown>;\n return resp.status === 200 && 'status' in data;\n } catch (e) {\n return classifyFetchError(e);\n }\n }\n\n // ------------------------------------------------------------------\n // State machine transitions\n // ------------------------------------------------------------------\n\n private async handleProbeSuccess(ps: PeerState): Promise<void> {\n ps.consecutiveFailures = 0;\n ps.backoffUntil = null;\n\n if (ps.status !== ALIVE) {\n const old = ps.status;\n ps.status = ALIVE;\n logger.info('Discovery', `Peer ${ps.ip}: ${old} -> ALIVE`);\n }\n\n await this.syncAgents(ps.ip);\n }\n\n private handleProbeFailure(ps: PeerState): void {\n ps.consecutiveFailures++;\n\n if (ps.consecutiveFailures >= MAX_FAILURES) {\n const old = ps.status;\n ps.status = DEAD;\n if (old !== DEAD) {\n const delay = Math.min(BACKOFF_BASE * Math.pow(2, ps.consecutiveFailures - 1), BACKOFF_CAP);\n ps.backoffUntil = performance.now() / 1000 + delay;\n logger.info('Discovery', `Peer ${ps.ip}: ${old} -> DEAD (backoff ${delay}s)`);\n }\n\n // Mark remote agents as unreachable\n for (const entry of this._remoteAgents.values()) {\n if (entry.sourcePeerIp === ps.ip) {\n entry.reachable = false;\n }\n }\n }\n }\n\n // ------------------------------------------------------------------\n // Agent synchronization\n // ------------------------------------------------------------------\n\n private async syncAgents(peerIp: string): Promise<void> {\n const url = `http://${peerIp}:${PARTY_PORT}/proxy/list_agents`;\n try {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), PROBE_TIMEOUT * 1000);\n const resp = await fetch(url, { signal: controller.signal });\n clearTimeout(timer);\n const data = (await resp.json()) as { agents?: AgentInfo[] };\n const agentsRaw = data.agents ?? [];\n const now = Date.now() / 1000;\n\n const seenIds = new Set<string>();\n for (const a of agentsRaw) {\n seenIds.add(a.agent_id);\n this._remoteAgents.set(a.agent_id, {\n agentInfo: a,\n sourcePeerIp: peerIp,\n lastSyncedAt: now,\n reachable: true,\n });\n }\n\n // Remove agents from this peer no longer present\n for (const [aid, entry] of this._remoteAgents) {\n if (entry.sourcePeerIp === peerIp && !seenIds.has(aid)) {\n this._remoteAgents.delete(aid);\n }\n }\n } catch (error) {\n // [ANTI-PATTERN IGNORED]: Agent sync is best-effort\n logger.warn('Discovery', `Failed to sync agents from ${peerIp}`, error);\n }\n }\n\n // ------------------------------------------------------------------\n // Cleanup\n // ------------------------------------------------------------------\n\n private evictDeadAgents(): void {\n const deadPeers = new Set<string>();\n for (const [ip, ps] of this._peers) {\n if (ps.status === DEAD) deadPeers.add(ip);\n }\n if (!deadPeers.size) return;\n\n for (const [aid, entry] of this._remoteAgents) {\n if (deadPeers.has(entry.sourcePeerIp)) {\n this._remoteAgents.delete(aid);\n }\n }\n }\n\n private evictStaleAgents(): void {\n const threshold = DISCOVERY_INTERVAL * REMOTE_STALE_FACTOR;\n const now = Date.now() / 1000;\n\n for (const [aid, entry] of this._remoteAgents) {\n if (now - entry.lastSyncedAt > threshold) {\n this._remoteAgents.delete(aid);\n }\n }\n }\n}\n","import type { AgentInfo, RegistrationRequest } from './models.js';\nimport { STALE_THRESHOLD } from './config.js';\n\n/** In-memory registry of agents connected to this server. */\nexport class AgentRegistry {\n private _agents = new Map<string, AgentInfo>();\n private _staleCounts = new Map<string, number>();\n private _selfIp: string;\n\n constructor(selfIp: string) {\n this._selfIp = selfIp;\n }\n\n register(req: RegistrationRequest): AgentInfo {\n const now = Date.now() / 1000;\n const info: AgentInfo = {\n agent_id: req.agent_id,\n display_name: req.display_name,\n host_ip: this._selfIp,\n registered_at: now,\n last_heartbeat: now,\n metadata: req.metadata ?? {},\n callback_url: req.callback_url,\n };\n this._agents.set(req.agent_id, info);\n this._staleCounts.set(req.agent_id, 0);\n return info;\n }\n\n remove(agentId: string): boolean {\n const existed = this._agents.delete(agentId);\n this._staleCounts.delete(agentId);\n return existed;\n }\n\n heartbeat(agentId: string): AgentInfo {\n const info = this._agents.get(agentId);\n if (!info) throw new Error(`Agent '${agentId}' not registered`);\n info.last_heartbeat = Date.now() / 1000;\n this._staleCounts.set(agentId, 0);\n return info;\n }\n\n get(agentId: string): AgentInfo | undefined {\n return this._agents.get(agentId);\n }\n\n listAll(): AgentInfo[] {\n return Array.from(this._agents.values());\n }\n\n /** Remove agents whose last heartbeat is older than timeout seconds.\n * Uses a stale counter: an agent must exceed the timeout STALE_THRESHOLD\n * consecutive times before being actually removed. Any heartbeat resets\n * the counter to zero, giving transient network issues room to recover.\n */\n cleanupStale(timeout: number): string[] {\n const now = Date.now() / 1000;\n const toRemove: string[] = [];\n\n for (const [aid, info] of this._agents) {\n if (now - info.last_heartbeat > timeout) {\n const count = (this._staleCounts.get(aid) ?? 0) + 1;\n this._staleCounts.set(aid, count);\n if (count >= STALE_THRESHOLD) {\n toRemove.push(aid);\n }\n } else {\n // Agent is healthy — reset stale counter\n this._staleCounts.set(aid, 0);\n }\n }\n\n for (const aid of toRemove) {\n this._agents.delete(aid);\n this._staleCounts.delete(aid);\n }\n return toRemove;\n }\n}\n","/**\n * Shared state singletons for the Party Server.\n *\n * All mutable state (registry, messageQueue, discovery) is owned here.\n * Lifecycle management (persistence, graceful shutdown) is also exported from here.\n */\nimport { getTailscaleIps } from '../infra/tailscale.js';\nimport { MessageQueue } from './message-queue.js';\nimport { PeerDiscovery } from './peer-discovery.js';\nimport { AgentRegistry } from './registry.js';\nimport type { SnapshotManager, AgentInfo, AgentBufferSnapshot } from './persistence.js';\n\nfunction resolveSelfIp(): string {\n try {\n const ips = getTailscaleIps();\n for (const ip of ips) {\n if (ip.includes('.') && !ip.includes(':')) return ip;\n }\n return ips.length > 0 ? ips[0] : '127.0.0.1';\n } catch {\n return '127.0.0.1';\n }\n}\n\nlet _selfIp = resolveSelfIp();\n\nexport function getSelfIp(): string {\n return _selfIp;\n}\n\nexport function refreshSelfIp(): string {\n _selfIp = resolveSelfIp();\n return _selfIp;\n}\n\nexport const STARTED_AT = Date.now();\nexport const registry = new AgentRegistry(getSelfIp());\nexport const messageQueue = new MessageQueue();\nexport const discovery = new PeerDiscovery(getSelfIp());\n\n// ---------------------------------------------------------------------------\n// Lifecycle management (persistence + graceful shutdown)\n// ---------------------------------------------------------------------------\n\n/** SnapshotManager instance — created during server startup, null before init. */\nexport let snapshotManager: SnapshotManager | null = null;\n\n/** AbortController for discovery loop and snapshot loop — aborted on shutdown. */\nexport const lifecycleController = new AbortController();\n\n/** Initialize the snapshot manager (called once during server startup). */\nexport function initSnapshotManager(mgr: SnapshotManager): void {\n snapshotManager = mgr;\n}\n\n/** Get the current snapshot manager instance (null before initialization). */\nexport function getSnapshotManager(): SnapshotManager | null {\n return snapshotManager;\n}\n","/** Agent registration request. */\nexport interface RegistrationRequest {\n agent_id: string;\n display_name?: string;\n metadata?: Record<string, unknown>;\n callback_url?: string;\n}\n\n/** Heartbeat request. */\nexport interface HeartbeatRequest {\n agent_id: string;\n display_name?: string;\n metadata?: Record<string, unknown>;\n callback_url?: string;\n}\n\n/** Registered agent info (internal — includes host_ip for routing). */\nexport interface AgentInfo {\n agent_id: string;\n display_name?: string;\n host_ip: string;\n registered_at: number;\n last_heartbeat: number;\n metadata: Record<string, unknown>;\n callback_url?: string;\n}\n\n/** Agent info safe to return to agents (no host_ip). */\nexport interface PublicAgentInfo {\n agent_id: string;\n display_name?: string;\n registered_at: number;\n last_heartbeat: number;\n metadata: Record<string, unknown>;\n}\n\n/** Strip host_ip from AgentInfo for agent-facing responses. */\nexport function sanitizeAgentInfo(info: AgentInfo): PublicAgentInfo {\n const { host_ip: _, ...publicInfo } = info;\n return publicInfo;\n}\n\n/** Strip host_ip from an array of AgentInfo. */\nexport function sanitizeAgentList(agents: AgentInfo[]): PublicAgentInfo[] {\n return agents.map(sanitizeAgentInfo);\n}\n\n/** Agent list response. */\nexport interface AgentListResponse {\n agents: AgentInfo[];\n count: number;\n}\n\n/** Remove request. */\nexport interface RemoveRequest {\n agent_id: string;\n}\n\n/** Message envelope. */\nexport interface MessageEnvelope {\n sender_id: string;\n recipient_id?: string; // undefined = broadcast\n group_id?: string;\n summary?: string; // short summary for terminal display\n content: string;\n timestamp?: number;\n}\n\n/** A single entry in an agent's message history. */\nexport interface HistoryEntry {\n direction: 'sent' | 'received';\n sender_id: string;\n recipient_id?: string;\n summary?: string;\n content: string;\n timestamp: number;\n}\n\n/** A single entry in the per-agent ring buffer. */\nexport interface RingBufferEntry {\n seq: number;\n direction: 'sent' | 'received';\n sender_id: string;\n recipient_id?: string;\n summary?: string;\n content: string;\n timestamp: number;\n}\n\n/** Snapshot of an agent's ring buffer (for persistence). */\nexport interface AgentBufferSnapshot {\n entries: RingBufferEntry[];\n next_seq: number;\n cursor: number;\n}\n\n/** Send result. */\nexport interface SendResult {\n status: 'delivered_locally' | 'forwarded' | 'agent_not_found' | 'error' | 'peer_unreachable';\n target?: string;\n error?: string;\n}\n\n\n","/**\n * Shared webhook callback utility.\n *\n * Fire-and-forget POST to an agent's callback URL when a message is delivered.\n * Used by both local delivery (/agent/send) and cross-peer relay (/proxy/receive).\n */\n\nimport { logger } from './logger.js';\n\n/** Webhook callback timeout (ms). */\nconst CALLBACK_TIMEOUT_MS = 5_000;\n\n/**\n * Fire-and-forget POST callback to agent's webhook URL.\n * The message is already safely stored in MessageQueue; callback failure is non-fatal.\n */\nexport function postCallback(callbackUrl: string, payload: Record<string, unknown>): void {\n fetch(callbackUrl, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(payload),\n signal: AbortSignal.timeout(CALLBACK_TIMEOUT_MS),\n }).then((resp) => {\n if (!resp.ok) {\n logger.warn('Webhook', `Callback HTTP error: url=${callbackUrl}, status=${resp.status}`);\n }\n }).catch((err) => {\n logger.warn('Webhook', `Callback failed: url=${callbackUrl}, error=${(err as Error).message}`);\n });\n}\n","import { Hono } from 'hono';\nimport type { MessageEnvelope, RegistrationRequest, HeartbeatRequest, RemoveRequest, SendResult } from '../models.js';\nimport { sanitizeAgentInfo, sanitizeAgentList } from '../models.js';\nimport { PARTY_PORT } from '../config.js';\nimport { logger } from '../logger.js';\nimport { postCallback } from '../callback.js';\n\nconst agentRoutes = new Hono();\n\nasync function forwardToPeer(peerIp: string, envelope: MessageEnvelope): Promise<SendResult> {\n const url = `http://${peerIp}:${PARTY_PORT}/proxy/receive`;\n const payload: Record<string, unknown> = { sender_id: envelope.sender_id, content: envelope.content };\n if (envelope.recipient_id) payload.recipient_id = envelope.recipient_id;\n if (envelope.group_id) payload.group_id = envelope.group_id;\n if (envelope.summary) payload.summary = envelope.summary;\n if (envelope.timestamp) payload.timestamp = envelope.timestamp;\n try {\n await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(payload),\n });\n return { status: 'forwarded', target: peerIp };\n } catch (e) {\n return { status: 'error', target: peerIp, error: (e as Error).message };\n }\n}\n\nagentRoutes.post('/register', async (c) => {\n const { registry } = await import('../state.js');\n const req = await c.req.json<RegistrationRequest>();\n const info = registry.register(req);\n logger.info('Agent', `Registered: ${info.agent_id} (display: \"${info.display_name ?? 'N/A'}\", callback=${info.callback_url ?? 'none'})`);\n return c.json(sanitizeAgentInfo(info));\n});\n\nagentRoutes.post('/remove', async (c) => {\n const { registry, messageQueue } = await import('../state.js');\n const req = await c.req.json<RemoveRequest>();\n const removed = registry.remove(req.agent_id);\n if (removed) {\n messageQueue.removeAgent(req.agent_id);\n messageQueue.removeAgentHistory(req.agent_id);\n }\n logger.info('Agent', removed ? `Removed: ${req.agent_id}` : `Remove failed: ${req.agent_id} (not found)`);\n return c.json({ status: removed ? 'removed' : 'not_found' });\n});\n\nagentRoutes.post('/heartbeat', async (c) => {\n const { registry } = await import('../state.js');\n const req = await c.req.json<HeartbeatRequest>();\n let info;\n try {\n info = registry.heartbeat(req.agent_id);\n // Update callback_url if provided (agent may have restarted on a different port)\n if (req.callback_url) {\n info.callback_url = req.callback_url;\n }\n } catch (err) {\n if (err instanceof Error && err.message.includes('not registered')) {\n // Auto-re-register agents that were cleaned up by stale-agent cleanup\n info = registry.register({\n agent_id: req.agent_id,\n display_name: req.display_name,\n metadata: req.metadata,\n callback_url: req.callback_url,\n });\n logger.info('Agent', `Auto-re-registered: ${req.agent_id} (was cleaned up)`);\n } else {\n throw err;\n }\n }\n logger.info('Agent', `Heartbeat from ${req.agent_id}${req.callback_url ? `, callback=${req.callback_url}` : ''}`);\n return c.json({ status: 'ok', last_heartbeat: info.last_heartbeat });\n});\n\nagentRoutes.get('/list', async (c) => {\n const { registry, discovery } = await import('../state.js');\n const localAgents = registry.listAll();\n const remoteAgents = discovery.getReachableRemoteAgents();\n const allAgents = localAgents.concat(remoteAgents);\n return c.json({ agents: sanitizeAgentList(allAgents), count: allAgents.length });\n});\n\nagentRoutes.post('/send', async (c) => {\n const { registry, messageQueue, discovery } = await import('../state.js');\n const envelope = await c.req.json<MessageEnvelope>();\n const recipient = envelope.recipient_id;\n\n if (!recipient) {\n return c.json({ status: 'error' as const, error: 'recipient_id is required' });\n }\n\n // Check if recipient is local\n const recipientInfo = registry.get(recipient);\n if (recipientInfo) {\n const stamped = { ...envelope, timestamp: envelope.timestamp ?? Date.now() / 1000 };\n const count = messageQueue.enqueue(recipient, stamped);\n messageQueue.logToHistory(envelope.sender_id, 'sent', stamped);\n\n // Webhook callback to notify recipient (fire-and-forget)\n if (recipientInfo.callback_url) {\n const callbackPayload = {\n type: 'message_received',\n recipient_id: recipient,\n sender_id: envelope.sender_id,\n summary: envelope.summary,\n timestamp: stamped.timestamp,\n pending_count: count,\n };\n logger.info('Webhook', `Callback: agent=${recipient}, url=${recipientInfo.callback_url}, sender=${envelope.sender_id}`);\n postCallback(recipientInfo.callback_url, callbackPayload);\n } else {\n logger.debug('Webhook', `No callback_url for agent=${recipient}, skipping webhook`);\n }\n\n logger.info('Agent', `Send ${envelope.sender_id} -> ${recipient}: delivered_locally`);\n return c.json({ status: 'delivered_locally' as const, target: recipient });\n }\n\n // Check remote agent cache\n const peerIp = discovery.getPeerForAgent(recipient);\n if (peerIp) {\n if (discovery.isPeerReachable(peerIp)) {\n const result = await forwardToPeer(peerIp, envelope);\n if (result.status === 'forwarded') {\n messageQueue.logToHistory(envelope.sender_id, 'sent', { ...envelope, timestamp: envelope.timestamp ?? Date.now() / 1000 });\n logger.info('Agent', `Send ${envelope.sender_id} -> ${recipient}: forwarded (peer ${peerIp})`);\n }\n return c.json(result);\n } else {\n logger.info('Agent', `Send ${envelope.sender_id} -> ${recipient}: peer_unreachable (peer ${peerIp})`);\n return c.json({ status: 'peer_unreachable' as const, target: peerIp });\n }\n }\n\n logger.info('Agent', `Send ${envelope.sender_id} -> ${recipient}: agent_not_found`);\n return c.json({ status: 'agent_not_found' as const, target: recipient });\n});\n\nagentRoutes.get('/messages/:agent_id', async (c) => {\n const { messageQueue } = await import('../state.js');\n const agentId = c.req.param('agent_id');\n const maxCount = parseInt(c.req.query('max_count') || '50', 10);\n const msgs = messageQueue.dequeue(agentId, maxCount);\n return c.json({ messages: msgs, count: msgs.length });\n});\n\n/** Get message history for an agent. */\nagentRoutes.get('/history/:agent_id', async (c) => {\n const { messageQueue } = await import('../state.js');\n const agentId = c.req.param('agent_id');\n const limit = parseInt(c.req.query('limit') || '20', 10);\n const history = messageQueue.getHistory(agentId, limit);\n return c.json({ history, count: history.length });\n});\n\nexport { agentRoutes };\n","import { Hono } from 'hono';\r\nimport type { MessageEnvelope, SendResult } from '../models.js';\r\nimport { PARTY_PORT } from '../config.js';\r\nimport { getTailnetHostname } from '../../infra/tailscale.js';\r\nimport { registry, messageQueue, getSelfIp } from '../state.js';\r\nimport { logger } from '../logger.js';\r\nimport { postCallback } from '../callback.js';\r\n\r\nconst proxyRoutes = new Hono();\r\n\r\nproxyRoutes.get('/health', async (c) => {\r\n let hostname = '127.0.0.1';\r\n try {\r\n hostname = getTailnetHostname();\r\n } catch { /* ignore */ }\r\n\r\n return c.json({\r\n status: 'ok',\r\n tailscale_ip: getSelfIp(),\r\n hostname,\r\n agent_count: registry.listAll().length,\r\n });\r\n});\r\n\r\nproxyRoutes.get('/list_agents', async (c) => {\r\n const agents = registry.listAll();\r\n return c.json({ agents, count: agents.length });\r\n});\r\n\r\nproxyRoutes.post('/receive', async (c) => {\r\n const envelope = await c.req.json<MessageEnvelope>();\r\n const stamped = { ...envelope, timestamp: envelope.timestamp ?? Date.now() / 1000 };\r\n\r\n if (envelope.recipient_id) {\r\n const count = messageQueue.enqueue(envelope.recipient_id, stamped);\r\n messageQueue.logToHistory(envelope.recipient_id, 'received', stamped);\r\n logger.info('Proxy', `Received msg ${envelope.sender_id} -> ${envelope.recipient_id}`);\r\n\r\n // Webhook callback to notify recipient (same as local delivery in agent.ts)\r\n const recipientInfo = registry.get(envelope.recipient_id);\r\n if (recipientInfo?.callback_url) {\r\n const callbackPayload = {\r\n type: 'message_received',\r\n recipient_id: envelope.recipient_id,\r\n sender_id: envelope.sender_id,\r\n summary: envelope.summary,\r\n timestamp: stamped.timestamp,\r\n pending_count: count,\r\n };\r\n logger.info('Webhook', `Proxy callback: agent=${envelope.recipient_id}, url=${recipientInfo.callback_url}, sender=${envelope.sender_id}`);\r\n postCallback(recipientInfo.callback_url, callbackPayload);\r\n }\r\n } else {\r\n // Broadcast\r\n for (const agent of registry.listAll()) {\r\n messageQueue.enqueue(agent.agent_id, stamped);\r\n messageQueue.logToHistory(agent.agent_id, 'received', stamped);\r\n }\r\n logger.info('Proxy', `Broadcast from ${envelope.sender_id} to all agents`);\r\n }\r\n return c.json({ status: 'received' });\r\n});\r\n\r\nproxyRoutes.post('/send/:target_ip', async (c) => {\r\n const targetIp = c.req.param('target_ip');\r\n const envelope = await c.req.json<MessageEnvelope>();\r\n\r\n const senderId = envelope.sender_id || getSelfIp();\r\n const url = `http://${targetIp}:${PARTY_PORT}/proxy/receive`;\r\n const payload: Record<string, string> = { sender_id: senderId, content: envelope.content };\r\n if (envelope.recipient_id) payload.recipient_id = envelope.recipient_id;\r\n if (envelope.group_id) payload.group_id = envelope.group_id;\r\n\r\n try {\r\n await fetch(url, {\r\n method: 'POST',\r\n headers: { 'Content-Type': 'application/json' },\r\n body: JSON.stringify(payload),\r\n });\r\n logger.info('Proxy', `Forwarded to ${targetIp}`);\r\n return c.json({ status: 'forwarded' as const, target: targetIp });\r\n } catch (e) {\r\n logger.warn('Proxy', `Forward to ${targetIp} failed: ${(e as Error).message}`);\r\n return c.json({ status: 'error' as const, target: targetIp, error: (e as Error).message });\r\n }\r\n});\r\n\r\nexport { proxyRoutes };\r\n","import { Hono } from 'hono';\nimport { cors } from 'hono/cors';\nimport { serve, type Server } from '@hono/node-server';\nimport { existsSync, mkdirSync, writeFileSync, unlinkSync } from 'node:fs';\nimport { join, dirname } from 'node:path';\nimport { homedir } from 'node:os';\nimport { PARTY_PORT, CLEANUP_INTERVAL, HEARTBEAT_TIMEOUT } from './config.js';\nimport { abortableSleep, SnapshotManager } from './persistence.js';\nimport { logger } from './logger.js';\nimport {\n getSelfIp,\n discovery,\n registry,\n messageQueue,\n lifecycleController,\n initSnapshotManager,\n getSnapshotManager,\n} from './state.js';\nimport { agentRoutes } from './routes/agent.js';\nimport { proxyRoutes } from './routes/proxy.js';\n\n// ---------------------------------------------------------------------------\n// Background cleanup task\n// ---------------------------------------------------------------------------\n\nasync function periodicCleanup(): Promise<void> {\n while (!lifecycleController.signal.aborted) {\n try {\n const removed = registry.cleanupStale(HEARTBEAT_TIMEOUT);\n if (removed.length > 0) {\n logger.info('Cleanup', `Removed ${removed.length} stale agent(s): ${removed.join(', ')}`);\n for (const aid of removed) {\n messageQueue.removeAgent(aid);\n messageQueue.removeAgentHistory(aid);\n }\n }\n } catch (e) {\n logger.error('Cleanup', 'Error during cleanup', e);\n }\n await abortableSleep(CLEANUP_INTERVAL * 1000, lifecycleController.signal);\n }\n}\n\n// ---------------------------------------------------------------------------\n// App\n// ---------------------------------------------------------------------------\n\nconst app = new Hono();\n\napp.use('*', cors());\n\n// Request logging middleware\napp.use('*', async (c, next) => {\n const start = Date.now();\n await next();\n const ms = Date.now() - start;\n const ip = c.req.header('x-forwarded-for')?.split(',')[0]?.trim()\n ?? c.info?.remote?.address\n ?? 'unknown';\n const path = c.req.path;\n\n if (path === '/proxy/health') {\n logger.debug('HTTP', `${c.req.method} ${path} ${c.res.status} ${ms}ms ${ip}`);\n } else {\n logger.info('HTTP', `${c.req.method} ${path} ${c.res.status} ${ms}ms ${ip}`);\n }\n});\n\n// Centralized error handler\napp.onError((err, c) => {\n logger.error('HTTP', `${c.req.method} ${c.req.path} failed (${err.status ?? 500}): ${err.message}`, err);\n return c.json({\n status: 'error',\n error: (err.status ?? 500) >= 500 ? 'Internal server error' : err.message,\n }, err.status ?? 500);\n});\n\napp.route('/agent', agentRoutes);\napp.route('/proxy', proxyRoutes);\n\n// ---------------------------------------------------------------------------\n// PID file self-management (so `stop` and `status` always find us)\n// ---------------------------------------------------------------------------\n\nfunction pidFilePath(): string {\n const pluginData = process.env.CLAUDE_PLUGIN_DATA || '';\n if (pluginData) return join(pluginData, 'server.pid');\n return join(homedir(), '.open-party', 'server.pid');\n}\n\n// ---------------------------------------------------------------------------\n// Graceful shutdown\n// ---------------------------------------------------------------------------\n\nlet shutdownInitiated = false;\n\n/**\n * Perform ordered graceful shutdown.\n *\n * Sequence (referencing src-example/services/infrastructure/GracefulShutdown.ts):\n * 1. Guard against re-entry\n * 2. Abort background loops (discovery + snapshot)\n * 3. Cancel pending debounced snapshot\n * 4. Write final snapshot to disk\n * 5. Close HTTP server (with Windows socket-release delays)\n * 6. Clean up markers + PID file\n * 7. Exit\n */\nasync function performShutdown(server: Server, pidPath: string): Promise<void> {\n if (shutdownInitiated) return;\n shutdownInitiated = true;\n\n logger.info('Shutdown', 'Shutting down Party Server...');\n\n try {\n // Step 1-2: Abort background loops\n lifecycleController.abort();\n\n // Step 3: Final snapshot flush\n try {\n getSnapshotManager()?.writeSnapshot(registry.listAll(), messageQueue.getHistorySnapshot());\n logger.info('Shutdown', 'Final snapshot written.');\n } catch (error) {\n logger.error('Shutdown', 'Failed to write final snapshot', error);\n }\n\n // Step 5: Close HTTP server (referencing GracefulShutdown.ts closeHttpServer pattern)\n if (server.closeAllConnections) {\n server.closeAllConnections();\n }\n\n // Windows-specific: give OS time to release socket handles\n if (process.platform === 'win32') {\n await new Promise((r) => setTimeout(r, 500));\n }\n\n await new Promise<void>((resolve, reject) => {\n server.close((err) => (err ? reject(err) : resolve()));\n });\n\n // Windows-specific: ensure port is fully released (zombie port prevention)\n if (process.platform === 'win32') {\n await new Promise((r) => setTimeout(r, 500));\n }\n\n // Step 6: Cleanup\n getSnapshotManager()?.removeShutdownMarker();\n try {\n unlinkSync(pidPath);\n } catch {\n // [ANTI-PATTERN IGNORED]: PID file may already be gone during shutdown\n }\n\n logger.info('Shutdown', 'Party Server shut down cleanly.');\n } catch (error) {\n logger.error('Shutdown', 'Error during shutdown sequence', error);\n } finally {\n process.exit(0);\n }\n}\n\n// ---------------------------------------------------------------------------\n// Entry point\n// ---------------------------------------------------------------------------\n\nasync function main() {\n // Write PID file so CLI commands can find this process\n const pidPath = pidFilePath();\n mkdirSync(dirname(pidPath), { recursive: true });\n writeFileSync(pidPath, String(process.pid));\n\n // Initialize persistence\n initSnapshotManager(new SnapshotManager());\n const sm = getSnapshotManager()!;\n\n // Load and recover state from previous snapshot\n let recoveredAgents = 0;\n let recoveredHistoryEntries = 0;\n\n if (sm.hasShutdownMarker()) {\n logger.info('Recovery', 'Previous shutdown was interrupted (shutdown marker found).');\n }\n\n const savedSnapshot = sm.loadSnapshot();\n if (savedSnapshot) {\n recoveredAgents = sm.hydrateAgents(registry, getSelfIp());\n recoveredHistoryEntries = sm.hydrateBuffers(messageQueue);\n\n if (recoveredAgents > 0 || recoveredHistoryEntries > 0) {\n logger.info(\n 'Recovery',\n `Recovered ${recoveredAgents} agent(s), ${recoveredHistoryEntries} history entry/entries.`,\n );\n }\n }\n\n logger.info('Server', `Starting Party Server on port ${PARTY_PORT} (Tailscale IP: ${getSelfIp()})`);\n\n // Ignore SIGHUP so the process survives when the parent terminal exits\n process.on('SIGHUP', () => {});\n\n const server = serve({ fetch: app.fetch, port: PARTY_PORT });\n\n // Start background tasks with AbortSignal support\n const discoveryPromise = discovery.runLoop(lifecycleController.signal);\n const cleanupPromise = periodicCleanup();\n\n // Start periodic snapshot loop\n const snapshotLoopPromise = sm.startSnapshotLoop(\n lifecycleController.signal,\n () => registry.listAll(),\n () => messageQueue.getBufferSnapshots(),\n );\n\n // Register signal handlers for graceful shutdown\n const shutdownHandler = () => void performShutdown(server, pidPath);\n process.on('SIGINT', shutdownHandler);\n process.on('SIGTERM', shutdownHandler);\n\n // POST /api/shutdown endpoint (referencing Server.ts pattern)\n app.post('/api/shutdown', (c) => {\n void performShutdown(server, pidPath);\n return c.json({ status: 'shutting_down' });\n });\n\n await Promise.race([discoveryPromise, cleanupPromise, snapshotLoopPromise]);\n}\n\nmain().catch((e) => {\n logger.error('Server', 'Fatal error', e);\n process.exit(1);\n});\n\n// Catch unhandled errors that would silently crash the process\nprocess.on('uncaughtException', (e) => {\n logger.error('Server', 'Uncaught exception', e);\n});\nprocess.on('unhandledRejection', (e) => {\n logger.error('Server', 'Unhandled rejection', e);\n});\n","/**\n * `open-party setup` — install Open Party plugin into Claude Code.\n *\n * Steps:\n * 1. Build plugin package (tsup + build-plugin.mjs)\n * 2. Copy to ~/.claude/plugins/cache/\n * 3. Register in installed_plugins.json + settings.json\n * 4. Start Party Server\n */\n\nimport { existsSync, readFileSync, writeFileSync, mkdirSync, readdirSync, statSync } from 'node:fs';\nimport { join, dirname, resolve } from 'node:path';\nimport { homedir, platform } from 'node:os';\nimport { execSync } from 'node:child_process';\nimport { green, red, cyan, bold } from './tty-utils.js';\nimport { spawnServerInBackground, waitForServerReady, resolvePort } from './server-utils.js';\n\nconst IS_WIN = platform() === 'win32';\nconst ROOT = resolve(import.meta.dirname ?? '.', '..', '..');\n\n// ---------------------------------------------------------------------------\n// Platform-safe file operations\n// ---------------------------------------------------------------------------\n\nfunction sh(cmd: string): void {\n execSync(cmd, { stdio: 'inherit', shell: IS_WIN });\n}\n\nfunction safeRm(target: string): void {\n if (!existsSync(target)) return;\n if (IS_WIN) {\n const isDir = statSync(target).isDirectory();\n sh(isDir ? `rd /s /q \"${target}\"` : `del /f /q \"${target}\"`);\n } else {\n sh(`rm -rf \"${target}\"`);\n }\n}\n\nfunction safeCp(src: string, dst: string): void {\n ensureDir(dst);\n if (IS_WIN) {\n const isDir = statSync(src).isDirectory();\n sh(isDir ? `xcopy \"${src}\" \"${dst}\\\\\" /E /I /Y /Q >nul 2>&1` : `copy /y \"${src}\" \"${dst}\" >nul 2>&1`);\n } else {\n sh(`cp -r \"${src}\" \"${dst}\"`);\n }\n}\n\nfunction ensureDir(filePath: string): void {\n const dir = dirname(filePath);\n if (!existsSync(dir)) mkdirSync(dir, { recursive: true });\n}\n\nfunction readJsonFile<T>(filePath: string, fallback: T): T {\n if (!existsSync(filePath)) return fallback;\n try { return JSON.parse(readFileSync(filePath, 'utf-8')) as T; }\n catch { return fallback; }\n}\n\nfunction writeJsonFile(filePath: string, data: unknown): void {\n ensureDir(filePath);\n writeFileSync(filePath, JSON.stringify(data, null, 2) + '\\n');\n}\n\n// ---------------------------------------------------------------------------\n// Plugin directory discovery\n// ---------------------------------------------------------------------------\n\nfunction findPluginDistDir(): string | null {\n const distDir = join(ROOT, 'dist', 'claude-code');\n if (!existsSync(distDir)) return null;\n\n try {\n const entries = readdirSync(distDir);\n const dirs = entries.filter((e) => e.startsWith('open-party-'));\n if (dirs.length === 0) return null;\n const pluginDir = join(distDir, dirs[dirs.length - 1]);\n if (existsSync(join(pluginDir, '.claude-plugin', 'plugin.json'))) return pluginDir;\n } catch { /* ignore */ }\n return null;\n}\n\nfunction getPluginVersion(pluginDir: string): string {\n const manifest = readJsonFile<{ version?: string }>(join(pluginDir, '.claude-plugin', 'plugin.json'), {});\n if (manifest.version) return manifest.version;\n try {\n const pkg = JSON.parse(readFileSync(join(ROOT, 'package.json'), 'utf-8'));\n if (pkg.version) return pkg.version;\n } catch { /* ignore */ }\n return '0.0.0';\n}\n\n// ---------------------------------------------------------------------------\n// Claude Code plugin installation\n// ---------------------------------------------------------------------------\n\nfunction installToClaudeCode(): boolean {\n const pluginDir = findPluginDistDir();\n if (!pluginDir) {\n console.log(`${red('Plugin package not found. Run \"npm run build:plugin\" first.')}`);\n return false;\n }\n\n const version = getPluginVersion(pluginDir);\n console.log(`Installing Open Party v${version} into Claude Code...\\n`);\n\n // Step 1: Copy plugin to ~/.claude/plugins/cache/\n const installDir = join(homedir(), '.claude', 'plugins', 'cache', 'open-party', 'open-party', version);\n if (existsSync(installDir)) safeRm(installDir);\n mkdirSync(installDir, { recursive: true });\n safeCp(pluginDir, installDir);\n\n // Step 2: Register marketplace\n registerMarketplace(version, pluginDir);\n\n // Step 3: Register in installed_plugins.json\n const pluginsJsonPath = join(homedir(), '.claude', 'plugins', 'installed_plugins.json');\n const pluginsData = readJsonFile<{ version: number; plugins: Record<string, unknown[]> }>(\n pluginsJsonPath, { version: 2, plugins: {} },\n );\n if (!pluginsData.plugins) pluginsData.plugins = {};\n // Clean up old format\n delete pluginsData.plugins['open-party@local'];\n pluginsData.plugins['open-party@open-party'] = [{\n scope: 'user',\n installPath: installDir,\n version,\n installedAt: new Date().toISOString(),\n lastUpdated: new Date().toISOString(),\n }];\n writeJsonFile(pluginsJsonPath, pluginsData);\n\n // Step 4: Enable in settings.json + remove old MCP entry\n const settingsPath = join(homedir(), '.claude', 'settings.json');\n const settings = readJsonFile<Record<string, unknown>>(settingsPath, {});\n\n if ((settings.mcpServers as Record<string, unknown>)?.['open-party']) {\n delete (settings.mcpServers as Record<string, unknown>)['open-party'];\n }\n\n if (!settings.enabledPlugins) settings.enabledPlugins = {};\n delete (settings.enabledPlugins as Record<string, unknown>)['open-party@local'];\n (settings.enabledPlugins as Record<string, boolean>)['open-party@open-party'] = true;\n\n writeJsonFile(settingsPath, settings);\n\n console.log(`${green('Plugin installed successfully.')}`);\n console.log(` Path: ${installDir}\\n`);\n return true;\n}\n\nfunction registerMarketplace(version: string, pluginDir: string): void {\n const marketplaceDir = join(homedir(), '.claude', 'plugins', 'marketplaces', 'open-party');\n const marketplacePluginDir = join(marketplaceDir, '.claude-plugin');\n if (!existsSync(marketplacePluginDir)) mkdirSync(marketplacePluginDir, { recursive: true });\n\n writeJsonFile(join(marketplacePluginDir, 'marketplace.json'), {\n name: 'open-party',\n owner: { name: 'Feynman Zhang' },\n metadata: {\n description: 'Decentralized Agent communication network for Claude Code',\n homepage: 'https://github.com/FeynmanZhang/open-party',\n },\n plugins: [{\n name: 'open-party', version, source: './plugin',\n description: 'Decentralized Agent communication network for Claude Code',\n }],\n });\n\n // Copy plugin files to marketplace\n const pluginSourceDir = join(marketplaceDir, 'plugin');\n if (existsSync(pluginSourceDir)) safeRm(pluginSourceDir);\n mkdirSync(pluginSourceDir, { recursive: true });\n safeCp(pluginDir, pluginSourceDir);\n\n // Register in known_marketplaces.json\n const knownPath = join(homedir(), '.claude', 'plugins', 'known_marketplaces.json');\n const known = readJsonFile<Record<string, unknown>>(knownPath, {});\n known['open-party'] = {\n source: { source: 'github', repo: 'FeynmanZhang/open-party' },\n installLocation: marketplaceDir,\n lastUpdated: new Date().toISOString(),\n };\n writeJsonFile(knownPath, known);\n}\n\n// ---------------------------------------------------------------------------\n// Build\n// ---------------------------------------------------------------------------\n\nfunction buildPlugin(): boolean {\n console.log(`${bold(cyan('Building plugin...'))}\\n`);\n try {\n execSync('node scripts/build-plugin.mjs', { cwd: ROOT, stdio: 'inherit' });\n return true;\n } catch {\n console.log(`${red('Build failed.')}`);\n return false;\n }\n}\n\n// ---------------------------------------------------------------------------\n// Main\n// ---------------------------------------------------------------------------\n\nexport async function setupCommand(): Promise<void> {\n console.log(`\\n${bold(cyan('Open Party Setup'))}\\n`);\n\n // Step 1: Build (skip if pre-built plugin already exists in dist/)\n const existingPlugin = findPluginDistDir();\n if (!existingPlugin) {\n if (!buildPlugin()) {\n process.exit(1);\n }\n } else {\n console.log(`${green('Pre-built plugin found, skipping build.')}\\n`);\n }\n\n // Step 2: Install to Claude Code\n if (!installToClaudeCode()) {\n process.exit(1);\n }\n\n // Step 3: Start Party Server\n console.log(`${bold(cyan('Starting Party Server...'))}\\n`);\n const port = resolvePort([]);\n try {\n spawnServerInBackground(port);\n await waitForServerReady(port, 15_000);\n console.log(`${green('Party Server started on port ' + port)}.\\n`);\n } catch (error) {\n console.log(`${red('Failed to start Party Server:')} ${error instanceof Error ? error.message : String(error)}`);\n console.log(' You can start it manually with: open-party start');\n }\n\n console.log(`${green('Setup complete!')}`);\n console.log(' Restart Claude Code to load the plugin.');\n console.log(` Use ${cyan('open-party agents')} to see who's online.\\n`);\n}\n","/**\n * Terminal UI utilities for interactive CLI prompts.\n *\n * Provides arrow-key selectors (select / multiSelect), text input (prompt),\n * and ANSI color helpers.\n */\n\nimport { createInterface, type Interface } from 'node:readline';\n\n// ---------------------------------------------------------------------------\n// Colors\n// ---------------------------------------------------------------------------\n\nexport function cyan(text: string): string {\n return `\\x1b[36m${text}\\x1b[0m`;\n}\nexport function green(text: string): string {\n return `\\x1b[32m${text}\\x1b[0m`;\n}\nexport function yellow(text: string): string {\n return `\\x1b[33m${text}\\x1b[0m`;\n}\nexport function red(text: string): string {\n return `\\x1b[31m${text}\\x1b[0m`;\n}\nexport function bold(text: string): string {\n return `\\x1b[1m${text}\\x1b[0m`;\n}\nexport function dim(text: string): string {\n return `\\x1b[2m${text}\\x1b[0m`;\n}\n\n// ---------------------------------------------------------------------------\n// Readline lifecycle\n// ---------------------------------------------------------------------------\n\nexport function createRl(): Interface {\n return createInterface({ input: process.stdin, output: process.stdout });\n}\n\nexport function closeRl(rl: Interface): void {\n rl.close();\n}\n\n// ---------------------------------------------------------------------------\n// Text prompt (for secrets, auth keys, etc.)\n// ---------------------------------------------------------------------------\n\nexport async function prompt(question: string): Promise<string> {\n // If a prior select()/multiSelect() left readline's keypress emitter\n // active on stdin, readline.createInterface would double-echo each char.\n // Remove the leftover keypress handlers so the new interface starts clean.\n if (process.stdin.isTTY) {\n process.stdin.removeAllListeners('keypress');\n // The internal converter (_keypressWrapper) listens on _newListener to\n // re-attach; briefly pause/resume to break the cycle.\n process.stdin.pause();\n }\n const rl = createInterface({ input: process.stdin, output: process.stdout });\n return new Promise<string>((resolve) => {\n rl.question(question, (answer) => {\n rl.close();\n resolve(answer.trim());\n });\n });\n}\n\n// ---------------------------------------------------------------------------\n// Arrow-key single select\n// ---------------------------------------------------------------------------\n\nexport interface SelectOption<T> {\n label: string;\n value: T;\n hint?: string;\n}\n\nexport async function select<T>(\n options: SelectOption<T>[],\n opts?: { message?: string },\n): Promise<T> {\n if (options.length === 0) throw new Error('select() requires at least one option');\n if (options.length === 1) return options[0].value;\n\n const message = opts?.message ?? '';\n\n // Ensure stdin is in raw mode for key-by-key input\n const wasRaw = process.stdin.isRaw;\n if (process.stdin.isTTY) process.stdin.setRawMode(true);\n\n try {\n let cursor = 0;\n\n const render = () => {\n // Move cursor up N lines, clear, and redraw\n const lines = options.length + (message ? 1 : 0);\n process.stdout.write(`\\x1b[${lines}A\\x1b[0J`);\n\n if (message) {\n process.stdout.write(`${message}\\n`);\n }\n for (let i = 0; i < options.length; i++) {\n const opt = options[i];\n const prefix = i === cursor ? `${cyan('❯')} ` : ' ';\n const label = i === cursor ? bold(opt.label) : opt.label;\n const hintStr = opt.hint ? ` ${dim(opt.hint)}` : '';\n process.stdout.write(`${prefix}${label}${hintStr}\\n`);\n }\n };\n\n // Initial render\n if (message) {\n process.stdout.write(`${message}\\n`);\n }\n for (let i = 0; i < options.length; i++) {\n const opt = options[i];\n const prefix = i === cursor ? `${cyan('❯')} ` : ' ';\n const label = i === cursor ? bold(opt.label) : opt.label;\n const hintStr = opt.hint ? ` ${dim(opt.hint)}` : '';\n process.stdout.write(`${prefix}${label}${hintStr}\\n`);\n }\n\n return new Promise<T>((resolve) => {\n const onKey = (ch: string, key: { name?: string; sequence?: string }) => {\n if (key.name === 'up' || key.sequence === '\\x1b[A') {\n cursor = (cursor - 1 + options.length) % options.length;\n render();\n } else if (key.name === 'down' || key.sequence === '\\x1b[B') {\n cursor = (cursor + 1) % options.length;\n render();\n } else if (key.name === 'return' || key.sequence === '\\r') {\n process.stdin.removeListener('keypress', onKey);\n process.stdout.write('\\n');\n resolve(options[cursor].value);\n }\n };\n\n process.stdin.on('keypress', onKey);\n // Emit keypress events on stdin\n if (process.stdin.isTTY) {\n process.stdin.resume();\n }\n });\n } finally {\n if (process.stdin.isTTY) process.stdin.setRawMode(wasRaw ?? false);\n }\n}\n\n// ---------------------------------------------------------------------------\n// Arrow-key multi-select (space to toggle, enter to confirm)\n// ---------------------------------------------------------------------------\n\nexport interface MultiSelectOption<T> {\n label: string;\n value: T;\n}\n\nexport async function multiSelect<T>(\n options: MultiSelectOption<T>[],\n opts?: { message?: string },\n): Promise<T[]> {\n if (options.length === 0) return [];\n\n const message = opts?.message ?? '';\n\n const wasRaw = process.stdin.isRaw;\n if (process.stdin.isTTY) process.stdin.setRawMode(true);\n\n try {\n let cursor = 0;\n const selected = new Set<number>();\n\n const render = () => {\n const lines = options.length + (message ? 1 : 0) + 1; // +1 for instruction line\n process.stdout.write(`\\x1b[${lines}A\\x1b[0J`);\n\n if (message) {\n process.stdout.write(`${message}\\n`);\n }\n process.stdout.write(`${dim(' ↑/↓ navigate, space to select, enter to confirm')}\\n`);\n for (let i = 0; i < options.length; i++) {\n const opt = options[i];\n const prefix = i === cursor ? `${cyan('❯')} ` : ' ';\n const check = selected.has(i) ? green('◉') : '○';\n const label = i === cursor ? bold(opt.label) : opt.label;\n process.stdout.write(`${prefix}${check} ${label}\\n`);\n }\n };\n\n // Initial render\n if (message) {\n process.stdout.write(`${message}\\n`);\n }\n process.stdout.write(`${dim(' ↑/↓ navigate, space to select, enter to confirm')}\\n`);\n for (let i = 0; i < options.length; i++) {\n const opt = options[i];\n const prefix = i === cursor ? `${cyan('❯')} ` : ' ';\n const check = selected.has(i) ? green('◉') : '○';\n const label = i === cursor ? bold(opt.label) : opt.label;\n process.stdout.write(`${prefix}${check} ${label}\\n`);\n }\n\n return new Promise<T[]>((resolve) => {\n const onKey = (_ch: string, key: { name?: string; sequence?: string }) => {\n if (key.name === 'up' || key.sequence === '\\x1b[A') {\n cursor = (cursor - 1 + options.length) % options.length;\n render();\n } else if (key.name === 'down' || key.sequence === '\\x1b[B') {\n cursor = (cursor + 1) % options.length;\n render();\n } else if (key.name === 'space') {\n if (selected.has(cursor)) {\n selected.delete(cursor);\n } else {\n selected.add(cursor);\n }\n render();\n } else if (key.name === 'return' || key.sequence === '\\r') {\n process.stdin.removeListener('keypress', onKey);\n process.stdout.write('\\n');\n const result = Array.from(selected)\n .sort((a, b) => a - b)\n .map((i) => options[i].value);\n resolve(result);\n }\n };\n\n process.stdin.on('keypress', onKey);\n if (process.stdin.isTTY) {\n process.stdin.resume();\n }\n });\n } finally {\n if (process.stdin.isTTY) process.stdin.setRawMode(wasRaw ?? false);\n }\n}","/**\n * Shared utilities for CLI server lifecycle management.\n *\n * Provides PID file management, process detection, health checks,\n * server spawning, and argument parsing for the open-party CLI.\n */\n\nimport { spawn, execSync } from 'node:child_process';\nimport { existsSync, readFileSync, writeFileSync, unlinkSync, mkdirSync, openSync } from 'node:fs';\nimport { join, dirname, resolve } from 'node:path';\nimport { homedir } from 'node:os';\nimport { fileURLToPath } from 'node:url';\n\n// ---------------------------------------------------------------------------\n// Paths\n// ---------------------------------------------------------------------------\n\nconst __dirname = dirname(fileURLToPath(import.meta.url));\n\nexport function pidFilePath(): string {\n const pluginData = process.env.CLAUDE_PLUGIN_DATA || '';\n if (pluginData) return join(pluginData, 'server.pid');\n return join(homedir(), '.open-party', 'server.pid');\n}\n\nexport function logFilePath(): string {\n const pluginData = process.env.CLAUDE_PLUGIN_DATA || '';\n if (pluginData) return join(pluginData, 'server.log');\n return join(homedir(), '.open-party', 'server.log');\n}\n\nfunction serverScriptPath(): string {\n // When bundled, __dirname is dist/cli/ — party-server.js is at dist/party-server.js\n return resolve(__dirname, '..', 'party-server.js');\n}\n\n// ---------------------------------------------------------------------------\n// PID file management\n// ---------------------------------------------------------------------------\n\nexport function readPid(): number | null {\n const path = pidFilePath();\n if (!existsSync(path)) return null;\n try {\n return parseInt(readFileSync(path, 'utf-8').trim(), 10);\n } catch {\n // [ANTI-PATTERN IGNORED]: PID file may not exist or be readable on first run\n return null;\n }\n}\n\nexport function writePid(pid: number): void {\n const path = pidFilePath();\n const dir = dirname(path);\n if (!existsSync(dir)) mkdirSync(dir, { recursive: true });\n writeFileSync(path, String(pid));\n}\n\nexport function removePidFile(): void {\n try { unlinkSync(pidFilePath()); } catch { /* [ANTI-PATTERN IGNORED]: PID file removal is best-effort, missing file is normal */ }\n}\n\n// ---------------------------------------------------------------------------\n// Process detection\n// ---------------------------------------------------------------------------\n\nexport function isProcessRunning(pid: number): boolean {\n if (process.platform === 'win32') {\n try {\n const output = execSync(`tasklist /FI \"PID eq ${pid}\" /NH`, {\n encoding: 'utf-8',\n windowsHide: true,\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n return output.includes(String(pid));\n } catch {\n // [ANTI-PATTERN IGNORED]: Process check on Windows — tasklist failure means process not found\n return false;\n }\n }\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n // [ANTI-PATTERN IGNORED]: signal 0 probe — failure means process not running\n return false;\n }\n}\n\n// ---------------------------------------------------------------------------\n// Health checks\n// ---------------------------------------------------------------------------\n\nexport function resolvePort(): number {\n return parseInt(process.env.PARTY_PORT || '8000', 10);\n}\n\nasync function fetchJson(url: string, timeoutMs: number = 2000): Promise<Record<string, unknown> | null> {\n try {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), timeoutMs);\n const resp = await fetch(url, { signal: controller.signal });\n clearTimeout(timer);\n if (!resp.ok) return null;\n return (await resp.json()) as Record<string, unknown>;\n } catch {\n // [ANTI-PATTERN IGNORED]: Health check — failure means server not reachable, null is the correct signal\n return null;\n }\n}\n\nexport async function isServerHealthy(port?: number): Promise<boolean> {\n const p = port ?? resolvePort();\n const data = await fetchJson(`http://127.0.0.1:${p}/proxy/health`);\n return data !== null && data.status === 'ok';\n}\n\nexport async function getServerHealth(port?: number): Promise<Record<string, unknown> | null> {\n const p = port ?? resolvePort();\n return fetchJson(`http://127.0.0.1:${p}/proxy/health`);\n}\n\nexport async function getServerOverview(port?: number): Promise<Record<string, unknown> | null> {\n const p = port ?? resolvePort();\n return fetchJson(`http://127.0.0.1:${p}/dashboard/api/overview`, 3000);\n}\n\n// ---------------------------------------------------------------------------\n// Server spawning\n// ---------------------------------------------------------------------------\n\nexport async function spawnServerInBackground(port: number): Promise<{ pid: number; ok: boolean }> {\n const script = serverScriptPath();\n if (!existsSync(script)) {\n console.error(`Server script not found: ${script}`);\n return { pid: 0, ok: false };\n }\n\n // Redirect stdout/stderr to log file\n const logPath = logFilePath();\n mkdirSync(dirname(logPath), { recursive: true });\n const logFd = openSync(logPath, 'a');\n\n const env = { ...process.env, PARTY_PORT: String(port) };\n const proc = spawn(process.execPath, [script], {\n stdio: ['ignore', logFd, logFd],\n detached: true,\n windowsHide: true,\n env,\n });\n proc.unref();\n\n const pid = proc.pid!;\n writePid(pid);\n\n proc.on('error', (err) => {\n console.error(`Failed to start server: ${err.message}`);\n });\n\n return { pid, ok: true };\n}\n\nexport async function waitForServerReady(port: number, timeoutMs: number = 10_000): Promise<boolean> {\n const deadline = Date.now() + timeoutMs;\n while (Date.now() < deadline) {\n if (await isServerHealthy(port)) return true;\n\n // Check if the spawned process is still alive (only if we have a PID)\n const pid = readPid();\n if (pid !== null && !isProcessRunning(pid)) {\n return false; // Process crashed\n }\n\n await sleep(500);\n }\n return false;\n}\n\n// ---------------------------------------------------------------------------\n// Process killing\n// ---------------------------------------------------------------------------\n\nexport function killServer(pid: number): void {\n try {\n if (process.platform === 'win32') {\n execSync(`taskkill /F /T /PID ${pid}`, { stdio: 'ignore', windowsHide: true });\n } else {\n process.kill(pid, 'SIGTERM');\n }\n } catch (error) {\n // The process may have already exited — that's the expected case when shutting down.\n // No action needed regardless of outcome.\n void error;\n }\n}\n\n/** Find the PID of the process listening on `port`. Returns null if none found. */\nexport function findPidByPort(port: number): number | null {\n try {\n if (process.platform === 'win32') {\n const output = execSync(\n `netstat -ano -p tcp | findstr \"LISTENING\" | findstr \":${port} \"`,\n { encoding: 'utf-8', windowsHide: true, stdio: ['pipe', 'pipe', 'pipe'] },\n );\n // netstat output: \" TCP 127.0.0.1:8000 0.0.0.0:0 LISTENING 12345\"\n const match = output.trim().match(/\\s(\\d+)\\s*$/);\n return match ? parseInt(match[1], 10) : null;\n }\n // macOS / Linux\n const output = execSync(`lsof -t -i :${port} -sTCP:LISTEN`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n const pid = parseInt(output.trim().split('\\n')[0], 10);\n return Number.isFinite(pid) && pid > 0 ? pid : null;\n } catch {\n // [ANTI-PATTERN IGNORED]: Port lookup — failure means no listener found\n return null;\n }\n}\n\n// ---------------------------------------------------------------------------\n// Argument parsing\n// ---------------------------------------------------------------------------\n\n/** Extract the value following a flag, e.g. extractFlagValue(['--agent-id', 'foo'], '--agent-id') → 'foo' */\nexport function extractFlagValue(args: string[], flag: string): string | undefined {\n for (let i = 0; i < args.length; i++) {\n if (args[i] === flag) return args[i + 1];\n }\n return undefined;\n}\n\nexport interface StartOptions {\n daemon: boolean;\n port: number | null; // null = use env/default\n}\n\nexport function parseStartArgs(args: string[]): StartOptions {\n let daemon = false;\n let port: number | null = null;\n\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '-d' || args[i] === '--daemon') {\n daemon = true;\n } else if (args[i] === '-p' || args[i] === '--port') {\n const val = args[++i];\n if (val) port = parseInt(val, 10);\n } else if (args[i].startsWith('--port=')) {\n port = parseInt(args[i].split('=')[1], 10);\n }\n }\n\n return { daemon, port };\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}","/**\n * `open-party login` — standalone Tailscale login command.\n *\n * Allows users to login to Tailscale after skipping it during setup,\n * or to re-authenticate if their session expired.\n */\n\nimport {\n getTailscaleInstallationStatus,\n} from '../infra/tailscale.js';\nimport { interactiveLogin, authKeyLogin } from './tailscale-login.js';\nimport { red, green, yellow, cyan, bold, select } from './tty-utils.js';\n\nexport async function loginCommand(): Promise<void> {\n const status = getTailscaleInstallationStatus();\n\n if (status.state === 'connected') {\n console.log(`${green('✅ Tailscale is already connected!')}`);\n console.log(` IP: ${status.tailscale_ip} Hostname: ${status.hostname}`);\n return;\n }\n\n if (status.state === 'not_installed') {\n console.log(`${red('❌ Tailscale is not installed.')}`);\n console.log(' Install it first: https://tailscale.com/download');\n console.log(` Then run: ${cyan('open-party login')}`);\n return;\n }\n\n // not_connected\n console.log(`${yellow('🔒 Tailscale is installed but not connected.')}\\n`);\n\n type LoginChoice = 'interactive' | 'authkey';\n const options: { label: string; value: LoginChoice; hint?: string }[] = [\n { label: 'Interactive login', value: 'interactive', hint: 'opens browser to authenticate' },\n { label: 'Auth key', value: 'authkey', hint: 'from network creator' },\n ];\n\n const choice = await select(options, { message: 'Choose a login method:' });\n\n if (choice === 'interactive') {\n await interactiveLogin(status.binary);\n } else {\n await authKeyLogin(status.binary);\n }\n}","/**\n * Shared Tailscale login logic for CLI commands.\n *\n * Extracted from setup.ts so both `setup` and `login` can reuse it.\n */\n\nimport { spawn } from 'node:child_process';\nimport {\n joinTailnet,\n resetTailscaleBinaryCache,\n getTailscaleInstallationStatus,\n} from '../infra/tailscale.js';\nimport { prompt, green, yellow, red, bold, cyan } from './tty-utils.js';\n\n// ---------------------------------------------------------------------------\n// Interactive login (opens browser)\n// ---------------------------------------------------------------------------\n\nexport async function interactiveLogin(binary: string): Promise<boolean> {\n console.log(`\\n${cyan('Running interactive login...')}`);\n console.log('A browser window should open. Authenticate in the browser, then return here.\\n');\n\n const child = spawn(binary, ['login'], { stdio: 'inherit' });\n\n const exitCode = await new Promise<number | null>((resolve) => {\n child.on('close', resolve);\n });\n\n resetTailscaleBinaryCache();\n const status = getTailscaleInstallationStatus();\n\n if (exitCode === 0 && status.state === 'connected') {\n console.log(`\\n${green('✅ Login successful!')} IP: ${status.tailscale_ip}`);\n showAuthKeyTip();\n return true;\n }\n\n console.log(`\\n${yellow('⚠️ Login may not have completed. Status: ' + status.state)}`);\n console.log(' Try running: open-party login');\n return false;\n}\n\n// ---------------------------------------------------------------------------\n// Auth key login\n// ---------------------------------------------------------------------------\n\nexport async function authKeyLogin(binary: string): Promise<boolean> {\n console.log('');\n console.log('Ask the network creator to generate an Auth Key at:');\n console.log(`${cyan(' https://login.tailscale.com/admin/settings/keys')}\\n`);\n\n const authKey = await prompt('Enter Auth Key: ');\n if (!authKey) {\n console.log(yellow('No auth key provided, skipping login.'));\n return false;\n }\n\n const result = joinTailnet(authKey);\n\n if (result.success) {\n resetTailscaleBinaryCache();\n const status = getTailscaleInstallationStatus();\n console.log(`\\n${green('✅ Login successful!')} IP: ${status.state === 'connected' ? status.tailscale_ip : 'unknown'}`);\n showAuthKeyTip();\n return true;\n }\n\n console.log(`\\n${red('❌ Login failed:')}\\n${result.output}`);\n console.log(' Check your auth key and try again.');\n return false;\n}\n\n// ---------------------------------------------------------------------------\n// Auth key sharing tip\n// ---------------------------------------------------------------------------\n\nexport function showAuthKeyTip(): void {\n console.log('');\n console.log(`${bold('💡 To share network access with teammates:')}`);\n console.log(' 1. Go to https://login.tailscale.com/admin/settings/keys');\n console.log(' 2. Generate an Auth Key');\n console.log(' 3. Share it with teammates — they can run: open-party login');\n}","/**\n * `open-party logout` — log out of the current Tailscale network.\n *\n * Disconnects from Tailscale and invalidates the node key,\n * requiring re-authentication to reconnect.\n */\n\nimport { getTailscaleInstallationStatus, logoutTailscale } from '../infra/tailscale.js';\nimport { select, green, red, yellow } from './tty-utils.js';\n\nexport async function logoutCommand(): Promise<void> {\n const status = getTailscaleInstallationStatus();\n\n if (status.state === 'not_installed') {\n console.log(red('❌ Tailscale is not installed.'));\n return;\n }\n\n if (status.state === 'not_connected') {\n console.log(yellow('⚠️ Tailscale is not connected — nothing to log out from.'));\n return;\n }\n\n // connected — confirm before logging out\n type LogoutChoice = 'logout' | 'cancel';\n const choice = await select<LogoutChoice>(\n [\n { label: 'Log out (remove credentials)', value: 'logout', hint: 'need to re-authenticate next time' },\n { label: 'Cancel', value: 'cancel' },\n ],\n { message: 'Are you sure you want to log out?' },\n );\n\n if (choice === 'cancel') return;\n\n console.log('Logging out of Tailscale...');\n const result = logoutTailscale();\n\n if (result.success) {\n console.log(green('✅ Logged out successfully.'));\n console.log(' To reconnect, run: open-party login');\n } else {\n console.log(red('❌ Logout failed:'), result.output);\n }\n}","/**\n * Start the Party Server.\n *\n * Supports foreground mode (default) and daemon mode (--daemon / -d).\n * Use --port / -p to override PARTY_PORT for a single invocation.\n */\n\nimport {\n parseStartArgs,\n resolvePort,\n isServerHealthy,\n readPid,\n isProcessRunning,\n removePidFile,\n spawnServerInBackground,\n waitForServerReady,\n logFilePath,\n writePid,\n} from './server-utils.js';\n\nexport async function startServer(args: string[] = []): Promise<void> {\n const opts = parseStartArgs(args);\n const port = opts.port ?? resolvePort();\n\n if (opts.daemon) {\n await startDaemon(port);\n } else {\n await startForeground();\n }\n}\n\n// ---------------------------------------------------------------------------\n// Foreground mode — server runs in current process\n// ---------------------------------------------------------------------------\n\nasync function startForeground(): Promise<void> {\n // Write PID file so `stop` and `status` can find this process\n writePid(process.pid);\n\n // Clean up PID file on any exit\n process.on('exit', () => {\n removePidFile();\n });\n\n // Dynamic import — the server module self-starts on import\n await import('../server/index.js');\n}\n\n// ---------------------------------------------------------------------------\n// Daemon mode — server runs in a detached background process\n// ---------------------------------------------------------------------------\n\nasync function startDaemon(port: number): Promise<void> {\n // Already running?\n if (await isServerHealthy(port)) {\n const pid = readPid();\n console.log(`Party Server is already running (PID ${pid ?? 'unknown'}, port ${port}).`);\n process.exit(0);\n }\n\n // Clean up stale PID file\n const existingPid = readPid();\n if (existingPid !== null && !isProcessRunning(existingPid)) {\n removePidFile();\n }\n\n // Spawn\n const { pid, ok } = await spawnServerInBackground(port);\n if (!ok) {\n process.exit(1);\n }\n\n // Wait for ready\n console.log(`Starting Party Server in background (PID ${pid})...`);\n const ready = await waitForServerReady(port);\n\n if (ready) {\n console.log(`Party Server is running on port ${port}.`);\n console.log(` Dashboard: http://127.0.0.1:${port}/dashboard`);\n console.log(` Logs: ${logFilePath()}`);\n console.log(` Use 'open-party stop' to stop the server.`);\n } else {\n console.error('Party Server failed to start within timeout.');\n console.error(`Check logs: ${logFilePath()}`);\n process.exit(1);\n }\n}","/**\n * Stop the Party Server.\n *\n * Strategy (referencing src-example/services/infrastructure/HealthMonitor.ts httpShutdown pattern):\n * 1. Try POST /api/shutdown for graceful shutdown (8s timeout)\n * 2. Wait for process exit\n * 3. Fallback to taskkill /F /T (force kill) if graceful fails\n */\n\nimport { readPid, isProcessRunning, killServer, removePidFile, isServerHealthy, resolvePort, findPidByPort } from './server-utils.js';\n\n/** Try graceful shutdown via HTTP endpoint. Returns true if server acknowledged. */\nasync function stopServerGracefully(pid: number, port: number): Promise<boolean> {\n try {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), 8000);\n const resp = await fetch(`http://127.0.0.1:${port}/api/shutdown`, {\n method: 'POST',\n signal: controller.signal,\n });\n clearTimeout(timer);\n return resp.ok;\n } catch {\n // ECONNREFUSED = already stopped; timeout = not responding — both mean fallback needed\n return false;\n }\n}\n\n/** Wait up to `timeoutMs` for a process to exit. Returns true if it exited. */\nasync function waitForProcessExit(pid: number, timeoutMs: number = 10_000): Promise<boolean> {\n const deadline = Date.now() + timeoutMs;\n while (Date.now() < deadline) {\n if (!isProcessRunning(pid)) return true;\n await new Promise((r) => setTimeout(r, 200));\n }\n return false;\n}\n\nexport async function stopServer(): Promise<void> {\n const pid = readPid();\n const port = resolvePort();\n\n // No PID file — check if a server is still responding on port\n if (pid === null) {\n const healthy = await isServerHealthy(port);\n if (healthy) {\n const foundPid = findPidByPort(port);\n if (foundPid !== null && isProcessRunning(foundPid)) {\n console.log(`No PID file found, but a server is responding on port ${port} (PID ${foundPid}).`);\n console.log(`Stopping by port lookup...`);\n killServer(foundPid);\n const stillUp = await isServerHealthy(port);\n if (!stillUp) {\n console.log('Party Server stopped.');\n return;\n }\n console.warn(`Process ${foundPid} was killed, but port ${port} is still responding.`);\n } else {\n console.log(`No PID file found, and no process found on port ${port}.`);\n }\n } else {\n console.log('Party Server is not running (no PID file found).');\n }\n return;\n }\n\n if (!isProcessRunning(pid)) {\n // Stale PID file — process is dead\n console.log(`Stale PID file found (PID ${pid} is not running). Cleaning up.`);\n removePidFile();\n return;\n }\n\n // Process is alive — try graceful shutdown first\n console.log(`Stopping Party Server (PID ${pid})...`);\n\n const gracefulOk = await stopServerGracefully(pid, port);\n if (gracefulOk) {\n // Server accepted shutdown request — wait for process exit\n const exited = await waitForProcessExit(pid);\n if (exited) {\n removePidFile();\n console.log('Party Server stopped gracefully.');\n return;\n }\n // Graceful ack'd but didn't exit in time — fall through to force kill\n console.warn('Graceful shutdown timed out, falling back to force kill...');\n }\n\n // Fallback: force kill\n killServer(pid);\n removePidFile();\n\n // Verify it's actually down\n const stillUp = await isServerHealthy(port);\n if (stillUp) {\n console.warn(`Process ${pid} was killed, but port ${port} is still responding.`);\n console.warn('Another process may be using this port.');\n } else {\n console.log('Party Server stopped.');\n }\n}","/**\n * Show the status of the Party Server.\n *\n * Displays PID, port, uptime, agent count, and Tailscale info\n * when the server is running. Handles four states:\n * 1. Running & healthy\n * 2. Process alive but not yet healthy (starting up)\n * 3. Stale PID file (process dead)\n * 4. Not running (no PID file)\n */\n\nimport {\n readPid,\n isProcessRunning,\n isServerHealthy,\n getServerHealth,\n getServerOverview,\n resolvePort,\n} from './server-utils.js';\n\nexport async function statusCommand(): Promise<void> {\n const port = resolvePort();\n const pid = readPid();\n\n let processAlive = false;\n if (pid !== null) {\n processAlive = isProcessRunning(pid);\n }\n\n const healthy = await isServerHealthy(port);\n\n if (healthy) {\n const health = await getServerHealth(port);\n const overview = await getServerOverview(port);\n\n console.log('Party Server is running.');\n console.log(` PID: ${pid ?? 'unknown (no PID file)'}`);\n console.log(` Port: ${port}`);\n console.log(` Tailscale IP: ${(health as any)?.tailscale_ip ?? 'N/A'}`);\n console.log(` Hostname: ${(health as any)?.hostname ?? 'N/A'}`);\n\n if (overview) {\n const server = overview.server as Record<string, unknown> | undefined;\n const agents = overview.agents as Record<string, unknown> | undefined;\n if (server?.uptime_seconds != null) {\n const uptime = server.uptime_seconds as number;\n const mins = Math.floor(uptime / 60);\n const secs = Math.floor(uptime % 60);\n console.log(` Uptime: ${mins}m ${secs}s`);\n }\n console.log(` Local agents: ${(agents?.local_count as number) ?? 'N/A'}`);\n console.log(` Remote agents: ${(agents?.remote_count as number) ?? 'N/A'}`);\n } else {\n console.log(` Local agents: ${(health as any)?.agent_count ?? 'N/A'}`);\n }\n\n console.log(` Dashboard: http://127.0.0.1:${port}/dashboard`);\n } else if (processAlive && pid !== null) {\n // PID file has a live process but health check fails\n console.log('Party Server process exists but is not responding on health endpoint.');\n console.log(` PID: ${pid}`);\n console.log(' The server may be starting up or has crashed.');\n console.log(` Logs: ~/.open-party/server.log`);\n } else if (pid !== null) {\n console.log('Party Server is NOT running (stale PID file).');\n console.log(` PID file references PID ${pid}, which is not a live process.`);\n console.log(' Use: open-party start to start the server.');\n } else {\n console.log('Party Server is NOT running.');\n console.log(' No PID file found.');\n console.log(' Use: open-party start to start the server.');\n }\n}","/**\n * `open-party --version` / `open-party -v` — show version number.\n */\n\nimport { readFileSync } from 'node:fs';\nimport { resolve, dirname } from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\nexport function showVersion(): void {\n // tsup bundles to dist/cli/index.js, package.json is at the project root: ../../package.json\n // When installed via npm: <pkg-root>/dist/cli/index.js → <pkg-root>/package.json\n const pkgPath = resolve(dirname(fileURLToPath(import.meta.url)), '..', '..', 'package.json');\n const pkg = JSON.parse(readFileSync(pkgPath, 'utf-8'));\n console.log(`open-party v${pkg.version}`);\n}","/**\n * Party Server HTTP client.\n *\n * Encapsulates all API calls to the Party Server so that hook handlers,\n * MCP servers, plugins, and any other consumer share a single HTTP layer.\n */\n\nexport class PartyHttpClient {\n private baseUrl: string;\n private timeout: number;\n\n constructor(baseUrl = 'http://127.0.0.1:8000', timeout = 5000) {\n this.baseUrl = baseUrl.replace(/\\/$/, '');\n this.timeout = timeout;\n }\n\n // -- Dashboard --\n\n async getOverview(): Promise<Record<string, unknown>> {\n return this.request('/dashboard/api/overview') as Promise<Record<string, unknown>>;\n }\n\n private async request(path: string, options: RequestInit = {}): Promise<unknown> {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), this.timeout);\n try {\n const resp = await fetch(`${this.baseUrl}${path}`, {\n ...options,\n signal: controller.signal,\n headers: {\n 'Content-Type': 'application/json',\n ...(options.headers as Record<string, string> | undefined),\n },\n });\n if (!resp.ok) throw new Error(`HTTP ${resp.status}: ${resp.statusText}`);\n return resp.json();\n } finally {\n clearTimeout(timer);\n }\n }\n\n // -- Agent lifecycle --\n\n async register(agentId: string, displayName?: string, metadata?: Record<string, unknown>, callbackUrl?: string): Promise<Record<string, unknown>> {\n return this.request('/agent/register', {\n method: 'POST',\n body: JSON.stringify({ agent_id: agentId, display_name: displayName, metadata: metadata ?? {}, callback_url: callbackUrl }),\n }) as Promise<Record<string, unknown>>;\n }\n\n async remove(agentId: string): Promise<boolean> {\n const result = await this.request('/agent/remove', {\n method: 'POST',\n body: JSON.stringify({ agent_id: agentId }),\n }) as Record<string, unknown>;\n return result.status === 'removed';\n }\n\n async heartbeat(agentId: string, displayName?: string, metadata?: Record<string, unknown>, callbackUrl?: string): Promise<Record<string, unknown>> {\n return this.request('/agent/heartbeat', {\n method: 'POST',\n body: JSON.stringify({ agent_id: agentId, display_name: displayName, metadata, callback_url: callbackUrl }),\n }) as Promise<Record<string, unknown>>;\n }\n\n async listAgents(): Promise<Record<string, unknown>[]> {\n const result = await this.request('/agent/list') as Record<string, unknown>;\n return (result.agents as Record<string, unknown>[]) ?? [];\n }\n\n // -- Messaging --\n\n async sendMessage(senderId: string, recipientId: string, content: string, summary?: string): Promise<Record<string, unknown>> {\n return this.request('/agent/send', {\n method: 'POST',\n body: JSON.stringify({ sender_id: senderId, recipient_id: recipientId, content, summary }),\n }) as Promise<Record<string, unknown>>;\n }\n\n async checkMessages(agentId: string): Promise<Record<string, unknown>[]> {\n const result = await this.request(`/agent/messages/${agentId}`) as Record<string, unknown>;\n return (result.messages as Record<string, unknown>[]) ?? [];\n }\n\n /** Get message history for an agent. */\n async getMessageHistory(agentId: string, limit = 20): Promise<Record<string, unknown>[]> {\n const result = await this.request(`/agent/history/${agentId}?limit=${limit}`) as Record<string, unknown>;\n return (result.history as Record<string, unknown>[]) ?? [];\n }\n\n // -- Proxy --\n\n async health(): Promise<Record<string, unknown>> {\n return this.request('/proxy/health') as Promise<Record<string, unknown>>;\n }\n}\n","/**\n * CLI command: list-agents (also aliased as `agents`)\n *\n * List all agents currently online in the Open Party network.\n * Usage: open-party list-agents [--json]\n * open-party agents [--json]\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\n\nexport async function listAgentsCommand(args: string[]): Promise<void> {\n const jsonMode = args.includes('--json');\n const client = new PartyHttpClient();\n\n try {\n await client.health();\n } catch {\n console.log('Party Server is not running.');\n console.log(\" Use 'open-party start' to start it.\");\n return;\n }\n\n try {\n const overview = await client.getOverview();\n const agentsData = overview.agents as Record<string, unknown> | undefined;\n if (!agentsData) {\n console.log('No agent data available.');\n return;\n }\n\n const localAgents = (agentsData.local_agents as Record<string, unknown>[]) ?? [];\n const remoteAgents = (agentsData.remote_agents as Record<string, unknown>[]) ?? [];\n const localCount = (agentsData.local_count as number) ?? localAgents.length;\n const remoteCount = (agentsData.remote_count as number) ?? remoteAgents.length;\n const allAgents = [...localAgents, ...remoteAgents];\n const totalCount = localCount + remoteCount;\n\n if (jsonMode) {\n console.log(JSON.stringify({ agents: allAgents, count: totalCount, local_count: localCount, remote_count: remoteCount }, null, 2));\n return;\n }\n\n if (totalCount === 0) {\n console.log('No agents currently online.');\n return;\n }\n\n // Local agents\n if (localCount === 0) {\n console.log('Local agents: (none)');\n } else {\n console.log(`Local agents (${localCount}):`);\n for (const agent of localAgents) {\n const id = (agent.agent_id as string) ?? '?';\n const name = (agent.display_name as string) ?? id;\n const ago = formatTimeAgo(agent.last_heartbeat as number | undefined);\n console.log(` ${id.padEnd(20)} ${name.padEnd(16)} ${ago}`);\n }\n }\n\n // Remote agents\n if (remoteCount > 0) {\n console.log(`\\nRemote agents (${remoteCount}):`);\n for (const agent of remoteAgents) {\n const id = (agent.agent_id as string) ?? '?';\n const name = (agent.display_name as string) ?? id;\n const via = (agent.source_peer_ip as string) ?? '?';\n const ago = formatTimeAgo(agent.last_heartbeat as number | undefined);\n console.log(` ${id.padEnd(20)} ${name.padEnd(16)} (via ${via}) ${ago}`);\n }\n }\n\n console.log('');\n console.log('Tip: Use `open-party send-message --recipient <id>` to reach any agent above.');\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`Error: ${msg}`);\n process.exit(1);\n }\n}\n\nfunction formatTimeAgo(timestamp: number | undefined): string {\n if (!timestamp) return '—';\n const diff = Date.now() / 1000 - timestamp / 1000;\n if (diff < 60) return 'just now';\n if (diff < 3600) return `${Math.floor(diff / 60)} min ago`;\n if (diff < 86400) return `${Math.floor(diff / 3600)} hr ago`;\n return `${Math.floor(diff / 86400)}d ago`;\n}\n","/**\n * `open-party peers` — list discovered peer nodes.\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\n\ntype PeerStateView = {\n ip: string;\n status: string;\n consecutiveFailures: number;\n lastProbeAt: number;\n backoffUntil: number | null;\n};\n\ntype RemoteAgentEntry = {\n source_peer_ip: string;\n};\n\nexport async function peersCommand(args: string[] = []): Promise<void> {\n const jsonMode = args.includes('--json');\n const client = new PartyHttpClient();\n\n try {\n await client.health();\n } catch {\n console.log('Party Server is not running.');\n console.log(\" Use 'open-party start' to start it.\");\n return;\n }\n\n try {\n const overview = await client.getOverview();\n\n const peers = overview.peers as Record<string, unknown> | undefined;\n if (!peers) {\n console.log('No peer data available.');\n return;\n }\n\n const details = (peers.details as PeerStateView[]) ?? [];\n const remoteAgents = (((overview.agents as Record<string, unknown> | undefined)?.remote_agents) as RemoteAgentEntry[]) ?? [];\n\n // Build map: peer_ip → agent_count\n const peerAgentCounts = new Map<string, number>();\n for (const agent of remoteAgents) {\n const ip = agent.source_peer_ip;\n peerAgentCounts.set(ip, (peerAgentCounts.get(ip) ?? 0) + 1);\n }\n\n const total = (peers.total as number) ?? details.length;\n\n if (jsonMode) {\n console.log(JSON.stringify({\n peers: details.map((p) => ({\n ...p,\n agent_count: peerAgentCounts.get(p.ip) ?? 0,\n })),\n total,\n }, null, 2));\n return;\n }\n\n if (details.length === 0) {\n console.log('No peers discovered yet.');\n return;\n }\n\n console.log(`Peers (${total}):\\n`);\n\n for (const peer of details) {\n const agentCount = peerAgentCounts.get(peer.ip);\n const agentStr = agentCount != null ? String(agentCount) : '—';\n const statusStr = formatStatus(peer.status);\n console.log(` ${peer.ip.padEnd(18)} ${statusStr.padEnd(16)} ${agentStr} agents`);\n }\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`Error: ${msg}`);\n process.exit(1);\n }\n}\n\nfunction formatStatus(status: string): string {\n const map: Record<string, string> = {\n ALIVE: 'Online',\n DEAD: 'Down',\n UNKNOWN: 'Unknown',\n };\n return map[status] ?? status;\n}\n","/**\n * Identity resolution for CLI commands.\n *\n * Resolves the calling agent's identity using a priority chain:\n * 1. --agent-id flag (explicit override)\n * 2. OPEN_PARTY_AGENT_ID environment variable\n * 3. Auto-detect: most recently modified session file in ~/.open-party/sessions/\n * 4. Error + exit guidance\n */\n\nimport { existsSync, readdirSync, readFileSync, statSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\n\nimport { SESSIONS_DIR, readSessionByAgent } from '../client/shared/session-store.js';\n\nexport interface ResolvedIdentity {\n agent_id: string;\n display_name: string;\n server_url: string;\n}\n\n/**\n * Resolve agent identity from the session store.\n *\n * Priority:\n * 1. explicitAgentId (from --agent-id flag)\n * 2. OPEN_PARTY_AGENT_ID env var\n * 3. Most recent session file by mtime\n *\n * @throws If no identity can be resolved.\n */\nexport function resolveIdentity(explicitAgentId?: string | null): ResolvedIdentity {\n // 1. Explicit flag\n if (explicitAgentId) {\n const session = readSessionByAgent(explicitAgentId);\n if (!session) {\n console.error(`Error: Agent \"${explicitAgentId}\" not found in session store.`);\n console.error('Run \"open-party setup\" to register, or use --agent-id with a known ID.');\n process.exit(1);\n }\n return {\n agent_id: explicitAgentId,\n display_name: (session.display_name as string) || explicitAgentId,\n server_url: (session.server_url as string) || 'http://127.0.0.1:8000',\n };\n }\n\n // 2. Environment variable\n const envId = process.env.OPEN_PARTY_AGENT_ID;\n if (envId) {\n const session = readSessionByAgent(envId);\n if (!session) {\n console.error(`Error: Agent \"${envId}\" (from OPEN_PARTY_AGENT_ID) not found in session store.`);\n process.exit(1);\n }\n return {\n agent_id: envId,\n display_name: (session.display_name as string) || envId,\n server_url: (session.server_url as string) || 'http://127.0.0.1:8000',\n };\n }\n\n // 3. Auto-detect: most recent session by mtime\n if (!existsSync(SESSIONS_DIR)) {\n console.error('Error: No Open Party session found.');\n console.error('Run \"open-party setup\" to get started, or provide --agent-id.');\n process.exit(1);\n }\n\n const files = readdirSync(SESSIONS_DIR).filter((f) => f.endsWith('.json'));\n if (files.length === 0) {\n console.error('Error: No active Open Party sessions.');\n console.error('Run \"open-party setup\" to register, or provide --agent-id.');\n process.exit(1);\n }\n\n // Sort by mtime descending — most recently modified first\n const sorted = files.sort((a, b) =>\n statSync(join(SESSIONS_DIR, b)).mtimeMs - statSync(join(SESSIONS_DIR, a)).mtimeMs,\n );\n\n const latestFile = sorted[0];\n const raw = JSON.parse(readFileSync(join(SESSIONS_DIR, latestFile), 'utf-8'));\n\n return {\n agent_id: raw.agent_id as string,\n display_name: (raw.display_name as string) || raw.agent_id,\n server_url: (raw.server_url as string) || 'http://127.0.0.1:8000',\n };\n}\n","/**\n * Shared filesystem session store for Open Party adapters.\n *\n * Both OpenClaw and Claude Code adapters persist session data\n * (agent_id, display_name, server_url) to ~/.open-party/ so that\n * agent identity survives runtime restarts.\n */\n\nimport { existsSync, mkdirSync, readFileSync, readdirSync, unlinkSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\n\nconst SESSION_DIR = join(homedir(), '.open-party');\nexport const SESSIONS_DIR = join(SESSION_DIR, 'sessions');\nexport const AGENTS_DIR = join(SESSION_DIR, 'agents');\n\n/** Create directory if it doesn't exist. */\nexport function ensureDir(dir: string): void {\n if (!existsSync(dir)) mkdirSync(dir, { recursive: true });\n}\n\n/** Write forward (session→agent) and reverse (agent→session) mappings. */\nexport function writeSession(sessionId: string, agentId: string, displayName: string, serverUrl: string, sessionKey?: string, online?: boolean): void {\n ensureDir(SESSIONS_DIR);\n ensureDir(AGENTS_DIR);\n\n const sessionData = { agent_id: agentId, display_name: displayName, server_url: serverUrl, session_id: sessionId, session_key: sessionKey, online: online ?? false };\n writeFileSync(join(SESSIONS_DIR, `${sessionId}.json`), JSON.stringify(sessionData));\n writeFileSync(join(AGENTS_DIR, `${agentId}.json`), JSON.stringify({ session_id: sessionId }));\n}\n\n/** Update the online status of a session by agent_id. */\nexport function updateOnlineStatus(agentId: string, online: boolean): void {\n const session = readSessionByAgent(agentId);\n if (!session) return;\n const sessionId = session.session_id as string;\n const path = join(SESSIONS_DIR, `${sessionId}.json`);\n if (!existsSync(path)) return;\n const data = JSON.parse(readFileSync(path, 'utf-8'));\n data.online = online;\n writeFileSync(path, JSON.stringify(data));\n}\n\n/** Read session info by session_id (forward lookup). */\nexport function readSession(sessionId: string): Record<string, string> | undefined {\n const path = join(SESSIONS_DIR, `${sessionId}.json`);\n if (!existsSync(path)) return undefined;\n return JSON.parse(readFileSync(path, 'utf-8'));\n}\n\n/** Read session info by agent_id (reverse lookup via agents/ mapping). */\nexport function readSessionByAgent(agentId: string): Record<string, string> | undefined {\n const mappingPath = join(AGENTS_DIR, `${agentId}.json`);\n if (!existsSync(mappingPath)) return undefined;\n const mapping = JSON.parse(readFileSync(mappingPath, 'utf-8'));\n return readSession(mapping.session_id);\n}\n\n/** Remove forward and reverse mappings for a session. */\nexport function clearSession(sessionId: string): void {\n const sessionPath = join(SESSIONS_DIR, `${sessionId}.json`);\n if (!existsSync(sessionPath)) return;\n\n const sessionData = JSON.parse(readFileSync(sessionPath, 'utf-8'));\n const agentId: string | undefined = sessionData.agent_id;\n\n try { unlinkSync(sessionPath); } catch { /* ignore */ }\n if (agentId) {\n try { unlinkSync(join(AGENTS_DIR, `${agentId}.json`)); } catch { /* ignore */ }\n }\n}\n\n/** Find any active session (for commands that need \"the current session\"). */\nexport function findAnySession(): Record<string, string> | undefined {\n if (!existsSync(SESSIONS_DIR)) return undefined;\n const files = readdirSync(SESSIONS_DIR).filter((f) => f.endsWith('.json'));\n if (files.length === 0) return undefined;\n return readSession(files[0].slice(0, -5));\n}\n\n/** Clear all sessions and agent mappings (e.g., on gateway restart). */\nexport function clearAllSessions(): void {\n if (existsSync(SESSIONS_DIR)) {\n for (const f of readdirSync(SESSIONS_DIR).filter((f) => f.endsWith('.json'))) {\n try { unlinkSync(join(SESSIONS_DIR, f)); } catch { /* ignore */ }\n }\n }\n if (existsSync(AGENTS_DIR)) {\n for (const f of readdirSync(AGENTS_DIR).filter((f) => f.endsWith('.json'))) {\n try { unlinkSync(join(AGENTS_DIR, f)); } catch { /* ignore */ }\n }\n }\n}\n","/**\n * CLI command: send-message\n *\n * Send a message to another agent on the Open Party network.\n * Usage: open-party send-message --recipient <id> --content <text> [--summary <text>] [--agent-id <id>] [--json]\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\nimport { resolveIdentity } from './identity.js';\nimport { extractFlagValue } from './server-utils.js';\n\nexport async function sendMessageCommand(args: string[]): Promise<void> {\n const jsonMode = args.includes('--json');\n const recipient = extractFlagValue(args, '--recipient');\n const content = extractFlagValue(args, '--content');\n const summary = extractFlagValue(args, '--summary');\n const agentId = extractFlagValue(args, '--agent-id');\n\n if (!recipient || !content) {\n console.error('Usage: open-party send-message --recipient <agent-id> --content <message> [--summary <text>] [--agent-id <id>] [--json]');\n process.exit(1);\n }\n\n const identity = resolveIdentity(agentId ?? null);\n const client = new PartyHttpClient(identity.server_url);\n\n try {\n const result = await client.sendMessage(identity.agent_id, recipient, content, summary);\n\n if (jsonMode) {\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n const status = result.status as string;\n if (status === 'delivered_locally' || status === 'forwarded') {\n console.log(`[Sent] to ${recipient}`);\n } else if (status === 'agent_not_found') {\n console.error(`[Warning] ${recipient} not found. Use \\`open-party list-agents\\` to see who's online.`);\n process.exit(1);\n } else {\n console.log(`[${status}] to ${recipient}`);\n }\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`Error: ${msg}`);\n process.exit(1);\n }\n}\n","/**\n * CLI command: check-messages\n *\n * Pull unread messages and optionally show message history.\n * Usage: open-party check-messages [--agent-id <id>] [--history] [--limit N] [--json]\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\nimport { resolveIdentity } from './identity.js';\nimport { extractFlagValue } from './server-utils.js';\n\nexport async function checkMessagesCommand(args: string[]): Promise<void> {\n const jsonMode = args.includes('--json');\n const showHistory = args.includes('--history');\n const agentIdFlag = extractFlagValue(args, '--agent-id');\n const limitStr = extractFlagValue(args, '--limit');\n const limit = limitStr ? Math.min(Math.max(parseInt(limitStr, 10), 1), 50) : 10;\n\n const identity = resolveIdentity(agentIdFlag);\n const client = new PartyHttpClient(identity.server_url);\n\n try {\n // Unread messages\n const messages = await client.checkMessages(identity.agent_id);\n\n if (jsonMode) {\n const result: Record<string, unknown> = { messages, count: messages.length };\n if (showHistory) {\n const history = await client.getMessageHistory(identity.agent_id, limit);\n result.history = history;\n result.history_count = history.length;\n }\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n if (messages.length > 0) {\n console.log(`New Messages (${messages.length})`);\n for (const msg of messages) {\n console.log('');\n console.log('---');\n console.log(`From: \\`${msg.sender_id}\\``);\n if (msg.summary) console.log(`Summary: ${msg.summary}`);\n console.log('');\n console.log(`> ${msg.content}`);\n }\n console.log('');\n console.log('Reply with `open-party send-message --recipient <id> --content \"reply\"` if needed.');\n } else {\n console.log('No new messages.');\n }\n\n // History when --history flag is passed\n if (showHistory) {\n const history = await client.getMessageHistory(identity.agent_id, limit);\n\n if (history.length === 0) {\n console.log('\\nNo message history yet.');\n return;\n }\n\n console.log(`\\nMessage History (last ${history.length})`);\n for (const entry of history) {\n console.log('');\n console.log('---');\n const isSent = entry.sender_id === identity.agent_id;\n const arrow = isSent ? '->' : '<-';\n const peer = isSent ? (entry.recipient_id as string) : (entry.sender_id as string);\n console.log(`${arrow} To: \\`${peer}\\``);\n console.log(`> ${entry.content}`);\n }\n }\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`Error: ${msg}`);\n process.exit(1);\n }\n}\n","/**\n * `open-party online` — register this agent with the Party Server.\n *\n * Reads identity from session store, registers with the server,\n * and marks the session as online.\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\nimport { resolveIdentity } from './identity.js';\nimport { updateOnlineStatus } from '../client/shared/session-store.js';\nimport { green, red, cyan, bold } from './tty-utils.js';\n\nfunction parseArgs(args: string[]): { name?: string } {\n const result: { name?: string } = {};\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--name' && args[i + 1]) {\n result.name = args[++i];\n }\n }\n return result;\n}\n\nexport async function onlineCommand(args: string[] = []): Promise<void> {\n const { name } = parseArgs(args);\n const identity = resolveIdentity();\n const displayName = name || identity.display_name;\n\n const client = new PartyHttpClient(identity.server_url);\n\n try {\n await client.health();\n } catch {\n console.log(`${red('Party Server is not running.')}`);\n console.log(\" Use 'open-party start' to start it.\");\n process.exit(1);\n }\n\n try {\n await client.register(identity.agent_id, displayName, { type: 'claude-code' });\n updateOnlineStatus(identity.agent_id, true);\n console.log(`${green(bold('Online'))} ${identity.agent_id} (${displayName})`);\n console.log(` Use ${cyan('open-party agents')} to see who else is online.`);\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`${red('Failed to go online:')} ${msg}`);\n process.exit(1);\n }\n}\n","/**\n * `open-party offline` — unregister this agent from the Party Server.\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\nimport { resolveIdentity } from './identity.js';\nimport { updateOnlineStatus } from '../client/shared/session-store.js';\nimport { green, red, yellow, bold } from './tty-utils.js';\n\nexport async function offlineCommand(): Promise<void> {\n const identity = resolveIdentity();\n const client = new PartyHttpClient(identity.server_url);\n\n try {\n await client.health();\n } catch {\n // Server not running — agent is already effectively offline\n updateOnlineStatus(identity.agent_id, false);\n console.log(`${yellow('Party Server is not running.')} Marked as offline.`);\n return;\n }\n\n try {\n await client.remove(identity.agent_id);\n updateOnlineStatus(identity.agent_id, false);\n console.log(`${green(bold('Offline'))} ${identity.agent_id} (${identity.display_name})`);\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`${red('Failed to go offline:')} ${msg}`);\n process.exit(1);\n }\n}\n","/**\n * Command registry for the Open Party CLI.\n *\n * Each command registers its metadata here so that help text,\n * per-command help, and validation can be generated from a single source.\n */\n\nexport interface CommandOption {\n flags: string;\n description: string;\n}\n\nexport interface CommandDef {\n name: string;\n alias?: string;\n description: string;\n usage: string;\n options?: CommandOption[];\n examples?: string[];\n}\n\nexport const COMMANDS: CommandDef[] = [\n {\n name: 'setup',\n description: 'Build & install plugin into Claude Code, then start server',\n usage: 'open-party setup',\n },\n {\n name: 'start',\n description: 'Start the Party Server (default when no command given)',\n usage: 'open-party start [-d] [-p <port>]',\n options: [\n { flags: '-d, --daemon', description: 'Run in background (daemon mode)' },\n { flags: '-p, --port <port>', description: 'Override port (default: 8000, env: PARTY_PORT)' },\n ],\n examples: [\n 'open-party start',\n 'open-party start -d',\n 'open-party start -d -p 9000',\n ],\n },\n {\n name: 'stop',\n description: 'Stop the Party Server',\n usage: 'open-party stop',\n },\n {\n name: 'status',\n description: 'Show server status',\n usage: 'open-party status',\n },\n {\n name: 'login',\n description: 'Login to Tailscale network',\n usage: 'open-party login',\n },\n {\n name: 'logout',\n description: 'Log out of Tailscale network',\n usage: 'open-party logout',\n },\n {\n name: 'agents',\n alias: 'list-agents',\n description: 'List online agents (local + remote, with status)',\n usage: 'open-party agents [--json]',\n options: [\n { flags: '--json', description: 'Output raw JSON response' },\n ],\n examples: [\n 'open-party agents',\n 'open-party agents --json',\n ],\n },\n {\n name: 'peers',\n description: 'List discovered peer nodes',\n usage: 'open-party peers [--json]',\n options: [\n { flags: '--json', description: 'Output raw JSON response' },\n ],\n },\n {\n name: 'send-message',\n description: 'Send a message to an agent',\n usage: 'open-party send-message --recipient <id> --content <text> [options]',\n options: [\n { flags: '--recipient <id>', description: 'Target agent ID (required)' },\n { flags: '--content <text>', description: 'Message content (required)' },\n { flags: '--summary <text>', description: 'Optional one-line summary' },\n { flags: '--agent-id <id>', description: 'Override sender identity' },\n { flags: '--json', description: 'Output raw JSON response' },\n ],\n examples: [\n 'open-party send-message --recipient <id> --content \"hello\"',\n 'open-party send-message --recipient <id> --content \"hi\" --summary \"Greeting\"',\n ],\n },\n {\n name: 'online',\n description: 'Go online — register this agent with the Party Server',\n usage: 'open-party online [--name <name>]',\n options: [\n { flags: '--name <name>', description: 'Override display name' },\n ],\n examples: [\n 'open-party online',\n 'open-party online --name \"my-agent\"',\n ],\n },\n {\n name: 'offline',\n description: 'Go offline — unregister from the Party Server',\n usage: 'open-party offline',\n },\n {\n name: 'check-messages',\n description: 'Check for new messages (add --history to include history)',\n usage: 'open-party check-messages [--agent-id <id>] [--history] [--limit N] [--json]',\n options: [\n { flags: '--agent-id <id>', description: 'Override agent identity' },\n { flags: '--history', description: 'Also show message history' },\n { flags: '--limit N', description: 'Number of history messages (default: 10, max: 50)' },\n { flags: '--json', description: 'Output raw JSON response' },\n ],\n examples: [\n 'open-party check-messages',\n 'open-party check-messages --history',\n 'open-party check-messages --history --limit 20',\n ],\n },\n];\n\n/** Find a command definition by name or alias. */\nexport function findCommand(name: string): CommandDef | undefined {\n return COMMANDS.find(\n (c) => c.name === name || c.alias === name,\n );\n}\n","/**\n * Open Party CLI — decentralized Agent communication network.\n */\n\nimport { setupCommand } from './setup.js';\nimport { loginCommand } from './login.js';\nimport { logoutCommand } from './logout.js';\nimport { startServer } from './start-server.js';\nimport { stopServer } from './stop-server.js';\nimport { statusCommand } from './status.js';\nimport { showVersion } from './version.js';\nimport { listAgentsCommand } from './list-agents.js';\nimport { peersCommand } from './peers.js';\nimport { sendMessageCommand } from './send-message.js';\nimport { checkMessagesCommand } from './check-messages.js';\nimport { onlineCommand } from './online.js';\nimport { offlineCommand } from './offline.js';\nimport { COMMANDS, findCommand } from './registry.js';\n\nfunction showHelp(commandName?: string): void {\n if (commandName) {\n const cmd = findCommand(commandName);\n if (!cmd) {\n console.log(`Unknown command: ${commandName}\\n`);\n showHelp();\n return;\n }\n\n // Per-command help\n console.log(`Usage: ${cmd.usage}`);\n console.log('');\n console.log(cmd.description);\n if (cmd.alias) {\n console.log(`Alias: ${cmd.alias}`);\n }\n\n if (cmd.options && cmd.options.length > 0) {\n console.log('');\n console.log('Options:');\n for (const opt of cmd.options) {\n console.log(` ${opt.flags.padEnd(24)} ${opt.description}`);\n }\n }\n\n if (cmd.examples && cmd.examples.length > 0) {\n console.log('');\n console.log('Examples:');\n for (const ex of cmd.examples) {\n console.log(` ${ex}`);\n }\n }\n\n return;\n }\n\n // Top-level help\n const lines: string[] = ['Usage: open-party <command> [options]', '', 'Commands:'];\n for (const cmd of COMMANDS) {\n const label = cmd.alias ? `${cmd.name}, ${cmd.alias}` : cmd.name;\n lines.push(` ${label.padEnd(22)} ${cmd.description}`);\n }\n\n lines.push('');\n lines.push('Global options:');\n lines.push(' -v, --version Show version number');\n lines.push('');\n lines.push('Run \"open-party help <command>\" for details on a specific command.');\n\n console.log(lines.join('\\n'));\n}\n\nconst args = process.argv.slice(2);\nconst command = args[0] ?? 'start';\nconst commandArgs = args.slice(1);\n\nasync function main(): Promise<void> {\n // Handle global flags before command dispatch\n if (command === '--version' || command === '-v') {\n showVersion();\n process.exit(0);\n }\n\n // Per-command --help flag\n if (commandArgs.includes('--help') || commandArgs.includes('-h')) {\n showHelp(command);\n process.exit(0);\n }\n\n switch (command) {\n case 'setup':\n await setupCommand();\n break;\n case 'login':\n await loginCommand();\n break;\n case 'logout':\n await logoutCommand();\n break;\n case 'start':\n await startServer(commandArgs);\n break;\n case 'stop':\n await stopServer();\n break;\n case 'status':\n await statusCommand();\n break;\n case 'agents':\n case 'list-agents':\n await listAgentsCommand(commandArgs);\n break;\n case 'peers':\n await peersCommand(commandArgs);\n break;\n case 'send-message':\n await sendMessageCommand(commandArgs);\n break;\n case 'check-messages':\n await checkMessagesCommand(commandArgs);\n break;\n case 'online':\n await onlineCommand(commandArgs);\n break;\n case 'offline':\n await offlineCommand();\n break;\n case 'help':\n case '--help':\n case '-h':\n showHelp(args[1]);\n break;\n default:\n console.log(`Unknown command: ${command}\\n`);\n showHelp();\n process.exit(1);\n }\n}\n\nmain().catch((e) => {\n console.error('Fatal error:', e);\n process.exit(1);\n});\n"],"mappings":"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","names":["execSync","existsSync","join","raw","output","match","cacheKey","raw","args","init_constants","init_constants","args","app","init_router","init_router","init_router","init_router","init_router","Node","init_node","_Node","init_router","init_node","Node","init_router","Hono","Request","init_dist","resolve","existsSync","mkdirSync","readdirSync","unlinkSync","statSync","join","homedir","existsSync","readFileSync","writeFileSync","unlinkSync","mkdirSync","join","homedir","resolve","raw","registry","DEFAULT_CAPACITY","Hono","registry","messageQueue","discovery","Hono","mkdirSync","writeFileSync","unlinkSync","join","dirname","homedir","pidFilePath","resolve","init_dist","Hono","existsSync","readFileSync","writeFileSync","mkdirSync","join","dirname","resolve","homedir","execSync","resolve","output","match","args","resolve","resolve","execSync","existsSync","dirname","mkdirSync","readFileSync","writeFileSync","join","homedir","spawn","spawn","resolve","args","pid","stillUp","readFileSync","resolve","dirname","fileURLToPath","args","args","existsSync","readdirSync","readFileSync","statSync","join","existsSync","mkdirSync","readFileSync","readdirSync","unlinkSync","writeFileSync","join","homedir","join","existsSync","readFileSync","writeFileSync","existsSync","readdirSync","statSync","join","raw","readFileSync","args","args","args","main"]}
1
+ {"version":3,"sources":["../../src/infra/tailscale.ts","../../node_modules/hono/dist/compose.js","../../node_modules/hono/dist/http-exception.js","../../node_modules/hono/dist/request/constants.js","../../node_modules/hono/dist/utils/body.js","../../node_modules/hono/dist/utils/url.js","../../node_modules/hono/dist/request.js","../../node_modules/hono/dist/utils/html.js","../../node_modules/hono/dist/context.js","../../node_modules/hono/dist/router.js","../../node_modules/hono/dist/utils/constants.js","../../node_modules/hono/dist/hono-base.js","../../node_modules/hono/dist/router/reg-exp-router/matcher.js","../../node_modules/hono/dist/router/reg-exp-router/node.js","../../node_modules/hono/dist/router/reg-exp-router/trie.js","../../node_modules/hono/dist/router/reg-exp-router/router.js","../../node_modules/hono/dist/router/reg-exp-router/prepared-router.js","../../node_modules/hono/dist/router/reg-exp-router/index.js","../../node_modules/hono/dist/router/smart-router/router.js","../../node_modules/hono/dist/router/smart-router/index.js","../../node_modules/hono/dist/router/trie-router/node.js","../../node_modules/hono/dist/router/trie-router/router.js","../../node_modules/hono/dist/router/trie-router/index.js","../../node_modules/hono/dist/hono.js","../../node_modules/hono/dist/index.js","../../node_modules/hono/dist/middleware/cors/index.js","../../node_modules/@hono/node-server/dist/index.mjs","../../src/server/config.ts","../../src/server/logger.ts","../../src/server/persistence.ts","../../src/server/ring-buffer.ts","../../src/server/message-queue.ts","../../src/server/peer-discovery.ts","../../src/server/registry.ts","../../src/server/state.ts","../../src/server/models.ts","../../src/server/callback.ts","../../src/server/routes/agent.ts","../../src/server/routes/proxy.ts","../../src/server/index.ts","../../src/cli/setup.ts","../../src/cli/tty-utils.ts","../../src/cli/server-utils.ts","../../src/cli/login.ts","../../src/cli/tailscale-login.ts","../../src/cli/logout.ts","../../src/cli/start-server.ts","../../src/cli/stop-server.ts","../../src/cli/status.ts","../../src/cli/version.ts","../../src/client/shared/client.ts","../../src/cli/list-agents.ts","../../src/cli/peers.ts","../../src/cli/identity.ts","../../src/client/shared/session-store.ts","../../src/cli/send-message.ts","../../src/cli/check-messages.ts","../../src/cli/online.ts","../../src/cli/offline.ts","../../src/cli/registry.ts","../../src/cli/index.ts"],"sourcesContent":["/**\r\n * Tailscale integration for the Party Server.\r\n *\r\n * - Binary discovery and caching\r\n * - Tailnet hostname / IP resolution\r\n * - Status JSON reading (network topology)\r\n * - IP → identity whois with TTL cache\r\n * - Funnel / Serve lifecycle management\r\n */\r\n\r\nimport { execFileSync, execSync } from 'node:child_process';\r\nimport { existsSync } from 'node:fs';\r\nimport { join } from 'node:path';\r\n\r\n// ---------------------------------------------------------------------------\r\n// Helpers\r\n// ---------------------------------------------------------------------------\r\n\r\n/** Extract the first valid JSON object from possibly noisy CLI output. */\r\nfunction parsePossiblyNoisyJson(raw: string): Record<string, unknown> {\r\n const trimmed = raw.trim();\r\n const start = trimmed.indexOf('{');\r\n const end = trimmed.lastIndexOf('}');\r\n if (start >= 0 && end > start) {\r\n return JSON.parse(trimmed.slice(start, end + 1));\r\n }\r\n return JSON.parse(trimmed);\r\n}\r\n\r\n/** Run a command synchronously and return stdout. Throws on non-zero exit. */\r\nfunction runExec(cmd: string[], timeout = 5000): string {\r\n return execFileSync(cmd[0], cmd.slice(1), {\r\n timeout,\r\n encoding: 'utf-8',\r\n stdio: ['pipe', 'pipe', 'pipe'],\r\n windowsHide: true,\r\n });\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Binary discovery\r\n// ---------------------------------------------------------------------------\r\n\r\nlet cachedBinary: string | null = null;\r\n\r\n/** Return true if path exists and can respond to --version. */\r\nfunction checkBinary(path: string, timeout = 3000): boolean {\r\n if (!path || !existsSync(path)) return false;\r\n try {\r\n execFileSync(path, ['--version'], { timeout, encoding: 'utf-8', stdio: 'pipe', windowsHide: true });\r\n return true;\r\n } catch {\r\n // [ANTI-PATTERN IGNORED]: Binary probe — failure means binary invalid, false is correct signal\r\n return false;\r\n }\r\n}\r\n\r\n/** Locate the tailscale binary using multiple strategies. */\r\nfunction findTailscaleBinary(): string | null {\r\n // Strategy 1 – PATH lookup\r\n try {\r\n const which = process.platform === 'win32' ? 'where' : 'which';\r\n const result = execFileSync(which, ['tailscale'], { timeout: 3000, encoding: 'utf-8', stdio: 'pipe', windowsHide: true });\r\n const fromPath = result.trim().split(/\\r?\\n/)[0];\r\n if (fromPath && checkBinary(fromPath)) return fromPath;\r\n } catch {\r\n // [ANTI-PATTERN IGNORED]: PATH probe — not found means not installed via PATH\r\n }\r\n\r\n // Strategy 2 – Known platform paths\r\n const knownPaths = process.platform === 'win32'\r\n ? [\r\n join(process.env.ProgramFiles || 'C:\\\\Program Files', 'Tailscale', 'tailscale.exe'),\r\n join(process.env['ProgramFiles(x86)'] || 'C:\\\\Program Files (x86)', 'Tailscale', 'tailscale.exe'),\r\n join(process.env.LOCALAPPDATA || '', 'Tailscale', 'tailscale.exe'),\r\n ]\r\n : [\r\n '/Applications/Tailscale.app/Contents/MacOS/Tailscale',\r\n '/usr/bin/tailscale',\r\n '/usr/local/bin/tailscale',\r\n ];\r\n\r\n for (const candidate of knownPaths) {\r\n if (checkBinary(candidate)) return candidate;\r\n }\r\n\r\n // Strategy 3 – find in /Applications (macOS only)\r\n if (process.platform !== 'win32') {\r\n try {\r\n const result = execSync(\r\n 'find /Applications -maxdepth 3 -name Tailscale -path \"*/Tailscale.app/Contents/MacOS/Tailscale\"',\r\n { timeout: 5000, encoding: 'utf-8' },\r\n );\r\n const first = result.trim().split('\\n')[0];\r\n if (first && checkBinary(first)) return first;\r\n } catch {\r\n // [ANTI-PATTERN IGNORED]: macOS app search — not found is expected on non-macOS\r\n }\r\n }\r\n\r\n return null;\r\n}\r\n\r\n/** Return a cached tailscale binary path, discovering it on the first call. */\r\nexport function getTailscaleBinary(): string {\r\n const forced = (process.env.OPENCLAW_TEST_TAILSCALE_BINARY ?? '').trim();\r\n if (forced) {\r\n cachedBinary = forced;\r\n return forced;\r\n }\r\n if (cachedBinary !== null) return cachedBinary;\r\n cachedBinary = findTailscaleBinary() ?? (process.platform === 'win32' ? 'tailscale.exe' : 'tailscale');\r\n return cachedBinary;\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Status & hostname\r\n// ---------------------------------------------------------------------------\r\n\r\n/** Run `tailscale status --json` and return the parsed result. */\r\nexport function readTailscaleStatus(timeout = 5000): Record<string, unknown> {\r\n const binary = getTailscaleBinary();\r\n const stdout = runExec([binary, 'status', '--json'], timeout);\r\n return stdout.trim() ? parsePossiblyNoisyJson(stdout) : {};\r\n}\r\n\r\n/** Derive the current device's tailnet hostname or fall back to its first Tailscale IP. */\r\nexport function getTailnetHostname(binary?: string): string {\r\n const candidates = binary\r\n ? [binary]\r\n : [\r\n getTailscaleBinary(),\r\n '/Applications/Tailscale.app/Contents/MacOS/Tailscale',\r\n ];\r\n\r\n let lastErr: Error | null = null;\r\n for (const candidate of candidates) {\r\n if (candidate.startsWith('/') && !existsSync(candidate)) continue;\r\n try {\r\n const stdout = runExec([candidate, 'status', '--json'], 5000);\r\n const parsed = stdout.trim() ? parsePossiblyNoisyJson(stdout) : {};\r\n const selfInfo = (parsed.Self ?? {}) as Record<string, unknown>;\r\n\r\n const dns = selfInfo.DNSName as string | undefined;\r\n if (typeof dns === 'string' && dns) return dns.replace(/\\.$/, '');\r\n\r\n const ips = selfInfo.TailscaleIPs as string[] | undefined;\r\n if (ips && ips.length > 0) return ips[0];\r\n\r\n throw new Error('Could not determine Tailscale DNS or IP');\r\n } catch (exc) {\r\n // [ANTI-PATTERN IGNORED]: Trying multiple binary candidates — lastErr tracks best error for final throw\r\n lastErr = exc as Error;\r\n }\r\n }\r\n throw lastErr ?? new Error('Could not determine Tailscale DNS or IP');\r\n}\r\n\r\n/** Return the list of Tailscale IPs for the current device. */\r\nexport function getTailscaleIps(): string[] {\r\n const status = readTailscaleStatus();\r\n const selfInfo = status.Self as Record<string, unknown> | undefined;\r\n if (selfInfo && Array.isArray(selfInfo.TailscaleIPs)) {\r\n return selfInfo.TailscaleIPs as string[];\r\n }\r\n return [];\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Whois with TTL cache\r\n// ---------------------------------------------------------------------------\r\n\r\nexport class WhoisIdentity {\r\n constructor(\r\n public readonly login: string,\r\n public readonly name?: string,\r\n ) {}\r\n}\r\n\r\ninterface CacheEntry {\r\n value: WhoisIdentity | null;\r\n expiresAt: number;\r\n}\r\n\r\nconst whoisCache = new Map<string, CacheEntry>();\r\n\r\n/** Best-effort extraction of login/name from tailscale whois JSON. */\r\nfunction parseWhoisIdentity(payload: Record<string, unknown>): WhoisIdentity | null {\r\n const userProfile =\r\n (payload.UserProfile as Record<string, unknown>) ??\r\n (payload.userProfile as Record<string, unknown>) ??\r\n (payload.User as Record<string, unknown>) ??\r\n {};\r\n\r\n const login =\r\n (userProfile.LoginName as string) ||\r\n (userProfile.Login as string) ||\r\n (userProfile.login as string) ||\r\n (payload.LoginName as string) ||\r\n (payload.login as string);\r\n\r\n if (typeof login !== 'string' || !login.trim()) return null;\r\n\r\n const rawName =\r\n (userProfile.DisplayName as string) ||\r\n (userProfile.Name as string) ||\r\n (userProfile.displayName as string) ||\r\n (payload.DisplayName as string) ||\r\n (payload.name as string);\r\n\r\n const name = typeof rawName === 'string' ? rawName.trim() : undefined;\r\n return new WhoisIdentity(login.trim(), name);\r\n}\r\n\r\n/** Resolve an IP to a WhoisIdentity via `tailscale whois --json`. */\r\nexport function readWhoisIdentity(\r\n ip: string,\r\n timeout = 5000,\r\n cacheTtl = 60,\r\n errorTtl = 5,\r\n): WhoisIdentity | null {\r\n const normalized = ip.trim();\r\n if (!normalized) return null;\r\n\r\n const now = performance.now() / 1000;\r\n const cached = whoisCache.get(normalized);\r\n if (cached) {\r\n if (cached.expiresAt > now) return cached.value;\r\n whoisCache.delete(normalized);\r\n }\r\n\r\n const binary = getTailscaleBinary();\r\n let identity: WhoisIdentity | null = null;\r\n try {\r\n const stdout = runExec([binary, 'whois', '--json', normalized], timeout);\r\n const parsed = stdout.trim() ? parsePossiblyNoisyJson(stdout) : {};\r\n identity = parseWhoisIdentity(parsed);\r\n } catch (error) {\r\n // [ANTI-PATTERN IGNORED]: Whois lookup failure — cached as null with short TTL, correct degradation\r\n console.error('[Tailscale] Whois lookup failed for', normalized, error instanceof Error ? error.message : error);\r\n }\r\n\r\n const ttl = identity ? cacheTtl : errorTtl;\r\n whoisCache.set(normalized, { value: identity, expiresAt: now + ttl });\r\n return identity;\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Funnel / Serve lifecycle\r\n// ---------------------------------------------------------------------------\r\n\r\nconst PERMISSION_KEYWORDS = [\r\n 'permission denied',\r\n 'access denied',\r\n 'operation not permitted',\r\n 'not permitted',\r\n 'requires root',\r\n 'must be run as root',\r\n 'must be run with sudo',\r\n 'requires sudo',\r\n 'need sudo',\r\n];\r\n\r\n/** Run cmd; on permission errors retry with sudo -n. */\r\nfunction execWithSudoFallback(cmd: string[], timeout = 15000): string {\r\n try {\r\n return runExec(cmd, timeout);\r\n } catch (exc: unknown) {\r\n const err = exc as { stderr?: string };\r\n const stderrLower = (err.stderr ?? '').toLowerCase();\r\n if (PERMISSION_KEYWORDS.some((kw) => stderrLower.includes(kw))) {\r\n try {\r\n return runExec(['sudo', '-n', ...cmd], timeout);\r\n } catch {\r\n // [ANTI-PATTERN IGNORED]: Sudo fallback also failed — throw original error\r\n }\r\n }\r\n throw exc;\r\n }\r\n}\r\n\r\n/** Enable `tailscale serve` on port (background mode). */\r\nexport function enableServe(port: number, timeout = 15000): void {\r\n const binary = getTailscaleBinary();\r\n execWithSudoFallback([binary, 'serve', '--bg', '--yes', String(port)], timeout);\r\n}\r\n\r\n/** Reset `tailscale serve`. */\r\nexport function disableServe(timeout = 15000): void {\r\n const binary = getTailscaleBinary();\r\n execWithSudoFallback([binary, 'serve', 'reset'], timeout);\r\n}\r\n\r\n/** Enable `tailscale funnel` on port (background mode). */\r\nexport function enableFunnel(port: number, timeout = 15000): void {\r\n const binary = getTailscaleBinary();\r\n execWithSudoFallback([binary, 'funnel', '--bg', '--yes', String(port)], timeout);\r\n}\r\n\r\n/** Reset `tailscale funnel`. */\r\nexport function disableFunnel(timeout = 15000): void {\r\n const binary = getTailscaleBinary();\r\n execWithSudoFallback([binary, 'funnel', 'reset'], timeout);\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Network join & connection status\r\n// ---------------------------------------------------------------------------\r\n\r\n/** Join a Tailscale network using an auth key. */\r\nexport function joinTailnet(\r\n authKey: string,\r\n timeout = 30000,\r\n): { success: boolean; output: string } {\r\n const binary = getTailscaleBinary();\r\n try {\r\n const output = execWithSudoFallback(\r\n [binary, 'up', '--authkey', authKey],\r\n timeout,\r\n );\r\n return { success: true, output: output.trim() };\r\n } catch (e) {\r\n // [ANTI-PATTERN IGNORED]: Tailscale command failure — stderr/message extracted for user-facing error return\r\n const err = e as { stderr?: string; message?: string };\r\n return { success: false, output: (err.stderr ?? err.message ?? '').trim() };\r\n }\r\n}\r\n\r\n/** Get the current Tailscale connection status. */\r\nexport function getTailscaleConnectionStatus(): {\r\n connected: boolean;\r\n tailscale_ip: string | null;\r\n hostname: string | null;\r\n error?: string;\r\n} {\r\n try {\r\n const status = readTailscaleStatus();\r\n const self = (status.Self ?? {}) as Record<string, unknown>;\r\n const online = self.Online === true;\r\n const ips = self.TailscaleIPs as string[] | undefined;\r\n const dns = (self.DNSName as string | undefined)?.replace(/\\.$/, '');\r\n return {\r\n connected: online,\r\n tailscale_ip: ips?.[0] ?? null,\r\n hostname: dns ?? null,\r\n };\r\n } catch (error) {\r\n console.error('[Tailscale] Failed to get connection status:', error);\r\n return {\r\n connected: false,\r\n tailscale_ip: null,\r\n hostname: null,\r\n error: error instanceof Error ? error.message : String(error),\r\n };\r\n }\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Tri-state installation status & install instructions\r\n// ---------------------------------------------------------------------------\r\n\r\nexport type TailscaleState =\r\n | { state: 'not_installed'; platform: string }\r\n | { state: 'not_connected'; binary: string; error?: string }\r\n | { state: 'connected'; binary: string; tailscale_ip: string; hostname: string };\r\n\r\n/** Detect Tailscale installation status as one of three states. */\r\nexport function getTailscaleInstallationStatus(): TailscaleState {\r\n // Bypass cache so we always get the real on-disk state\r\n const binary = findTailscaleBinary();\r\n if (!binary) {\r\n return { state: 'not_installed', platform: process.platform };\r\n }\r\n\r\n try {\r\n const status = readTailscaleStatus();\r\n const self = (status.Self ?? {}) as Record<string, unknown>;\r\n const online = self.Online === true;\r\n\r\n if (online) {\r\n const ips = self.TailscaleIPs as string[] | undefined;\r\n const dns = (self.DNSName as string | undefined)?.replace(/\\.$/, '');\r\n return {\r\n state: 'connected',\r\n binary,\r\n tailscale_ip: ips?.[0] ?? '127.0.0.1',\r\n hostname: dns ?? null!,\r\n };\r\n }\r\n\r\n return { state: 'not_connected', binary };\r\n } catch (error) {\r\n console.error('[Tailscale] Failed to get installation status:', error);\r\n return {\r\n state: 'not_connected' as const,\r\n binary,\r\n error: error instanceof Error ? error.message : String(error),\r\n };\r\n }\r\n}\r\n\r\n/** Clear the cached binary path so the next detection re-scans the filesystem. */\r\nexport function resetTailscaleBinaryCache(): void {\r\n cachedBinary = null;\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Logout (full de-authentication)\r\n// ---------------------------------------------------------------------------\r\n\r\n/** Run `tailscale logout` — disconnects and invalidates the node key. */\r\nexport function logoutTailscale(timeout = 15000): { success: boolean; output: string } {\r\n const binary = getTailscaleBinary();\r\n try {\r\n const output = runExec([binary, 'logout'], timeout);\r\n resetTailscaleBinaryCache();\r\n return { success: true, output: output.trim() };\r\n } catch (e) {\r\n // [ANTI-PATTERN IGNORED]: Tailscale command failure — stderr/message extracted for user-facing error return\r\n const err = e as { stderr?: string; message?: string };\r\n return { success: false, output: (err.stderr ?? err.message ?? '').trim() };\r\n }\r\n}\r\n\r\n// ---------------------------------------------------------------------------\r\n// Interactive login (browser-based authentication)\r\n// ---------------------------------------------------------------------------\r\n\r\nimport { type ChildProcess, spawn as nodeSpawn } from 'node:child_process';\r\n\r\nexport interface InteractiveLoginResult {\r\n success: boolean;\r\n url?: string;\r\n output: string;\r\n}\r\n\r\n/**\r\n * Start `tailscale login` as a background child process.\r\n *\r\n * `tailscale login` prints an auth URL to stdout, then blocks until the\r\n * user completes authentication in the browser. This function parses that\r\n * URL and returns it immediately — the caller is responsible for polling\r\n * connection status separately (e.g. via `getTailscaleInstallationStatus()`).\r\n *\r\n * The returned `process` reference lets the caller kill it if needed.\r\n */\r\nexport function startInteractiveLogin(): {\r\n promise: Promise<InteractiveLoginResult>;\r\n process: ChildProcess;\r\n} {\r\n const binary = getTailscaleBinary();\r\n const child = nodeSpawn(binary, ['login'], {\r\n stdio: ['pipe', 'pipe', 'pipe'],\r\n windowsHide: true,\r\n });\r\n\r\n const urlRegex = /https:\\/\\/login\\.tailscale\\.com\\/a\\/[^\\s]+/;\r\n\r\n const promise = new Promise<InteractiveLoginResult>((resolve) => {\r\n let stdout = '';\r\n let resolved = false;\r\n\r\n const done = (result: InteractiveLoginResult) => {\r\n if (resolved) return;\r\n resolved = true;\r\n resolve(result);\r\n };\r\n\r\n child.stdout?.on('data', (data: Buffer) => {\r\n stdout += data.toString();\r\n const match = stdout.match(urlRegex);\r\n if (match) {\r\n done({ success: true, url: match[0], output: stdout.trim() });\r\n }\r\n });\r\n\r\n child.stderr?.on('data', (data: Buffer) => {\r\n stdout += data.toString();\r\n });\r\n\r\n child.on('close', (code) => {\r\n if (code === 0) {\r\n done({ success: true, output: stdout.trim() });\r\n } else {\r\n done({ success: false, output: stdout.trim() || `Exited with code ${code}` });\r\n }\r\n });\r\n\r\n child.on('error', (err) => {\r\n done({ success: false, output: err.message });\r\n });\r\n\r\n // Timeout: give up if no URL appears within 30s\r\n setTimeout(() => {\r\n done({ success: false, output: 'Timeout waiting for login URL' });\r\n try { child.kill(); } catch {\r\n // [ANTI-PATTERN IGNORED]: Kill may fail if process already exited\r\n }\r\n }, 30000);\r\n });\r\n\r\n return { promise, process: child };\r\n}\r\n\r\n/** Return platform-specific install instructions for Tailscale. */\r\nexport function getInstallInstructions(platform: string): {\r\n os: string;\r\n download_url: string;\r\n commands: string[];\r\n needs_sudo: boolean;\r\n} {\r\n switch (platform) {\r\n case 'linux':\r\n return {\r\n os: 'linux',\r\n download_url: 'https://tailscale.com/download/linux',\r\n commands: ['curl -fsSL https://tailscale.com/install.sh | sh'],\r\n needs_sudo: true,\r\n };\r\n case 'darwin':\r\n return {\r\n os: 'macOS',\r\n download_url: 'https://tailscale.com/download/mac',\r\n commands: ['brew install tailscale'],\r\n needs_sudo: false,\r\n };\r\n case 'win32':\r\n return {\r\n os: 'windows',\r\n download_url: 'https://tailscale.com/download/windows',\r\n commands: ['winget install Tailscale.Tailscale'],\r\n needs_sudo: false,\r\n };\r\n default:\r\n return {\r\n os: platform,\r\n download_url: 'https://tailscale.com/download/',\r\n commands: [],\r\n needs_sudo: false,\r\n };\r\n }\r\n}\r\n","// src/compose.ts\nvar compose = (middleware, onError, onNotFound) => {\n return (context, next) => {\n let index = -1;\n return dispatch(0);\n async function dispatch(i) {\n if (i <= index) {\n throw new Error(\"next() called multiple times\");\n }\n index = i;\n let res;\n let isError = false;\n let handler;\n if (middleware[i]) {\n handler = middleware[i][0][0];\n context.req.routeIndex = i;\n } else {\n handler = i === middleware.length && next || void 0;\n }\n if (handler) {\n try {\n res = await handler(context, () => dispatch(i + 1));\n } catch (err) {\n if (err instanceof Error && onError) {\n context.error = err;\n res = await onError(err, context);\n isError = true;\n } else {\n throw err;\n }\n }\n } else {\n if (context.finalized === false && onNotFound) {\n res = await onNotFound(context);\n }\n }\n if (res && (context.finalized === false || isError)) {\n context.res = res;\n }\n return context;\n }\n };\n};\nexport {\n compose\n};\n","// src/http-exception.ts\nvar HTTPException = class extends Error {\n res;\n status;\n /**\n * Creates an instance of `HTTPException`.\n * @param status - HTTP status code for the exception. Defaults to 500.\n * @param options - Additional options for the exception.\n */\n constructor(status = 500, options) {\n super(options?.message, { cause: options?.cause });\n this.res = options?.res;\n this.status = status;\n }\n /**\n * Returns the response object associated with the exception.\n * If a response object is not provided, a new response is created with the error message and status code.\n * @returns The response object.\n */\n getResponse() {\n if (this.res) {\n const newResponse = new Response(this.res.body, {\n status: this.status,\n headers: this.res.headers\n });\n return newResponse;\n }\n return new Response(this.message, {\n status: this.status\n });\n }\n};\nexport {\n HTTPException\n};\n","// src/request/constants.ts\nvar GET_MATCH_RESULT = /* @__PURE__ */ Symbol();\nexport {\n GET_MATCH_RESULT\n};\n","// src/utils/body.ts\nimport { HonoRequest } from \"../request.js\";\nvar parseBody = async (request, options = /* @__PURE__ */ Object.create(null)) => {\n const { all = false, dot = false } = options;\n const headers = request instanceof HonoRequest ? request.raw.headers : request.headers;\n const contentType = headers.get(\"Content-Type\");\n if (contentType?.startsWith(\"multipart/form-data\") || contentType?.startsWith(\"application/x-www-form-urlencoded\")) {\n return parseFormData(request, { all, dot });\n }\n return {};\n};\nasync function parseFormData(request, options) {\n const formData = await request.formData();\n if (formData) {\n return convertFormDataToBodyData(formData, options);\n }\n return {};\n}\nfunction convertFormDataToBodyData(formData, options) {\n const form = /* @__PURE__ */ Object.create(null);\n formData.forEach((value, key) => {\n const shouldParseAllValues = options.all || key.endsWith(\"[]\");\n if (!shouldParseAllValues) {\n form[key] = value;\n } else {\n handleParsingAllValues(form, key, value);\n }\n });\n if (options.dot) {\n Object.entries(form).forEach(([key, value]) => {\n const shouldParseDotValues = key.includes(\".\");\n if (shouldParseDotValues) {\n handleParsingNestedValues(form, key, value);\n delete form[key];\n }\n });\n }\n return form;\n}\nvar handleParsingAllValues = (form, key, value) => {\n if (form[key] !== void 0) {\n if (Array.isArray(form[key])) {\n ;\n form[key].push(value);\n } else {\n form[key] = [form[key], value];\n }\n } else {\n if (!key.endsWith(\"[]\")) {\n form[key] = value;\n } else {\n form[key] = [value];\n }\n }\n};\nvar handleParsingNestedValues = (form, key, value) => {\n if (/(?:^|\\.)__proto__\\./.test(key)) {\n return;\n }\n let nestedForm = form;\n const keys = key.split(\".\");\n keys.forEach((key2, index) => {\n if (index === keys.length - 1) {\n nestedForm[key2] = value;\n } else {\n if (!nestedForm[key2] || typeof nestedForm[key2] !== \"object\" || Array.isArray(nestedForm[key2]) || nestedForm[key2] instanceof File) {\n nestedForm[key2] = /* @__PURE__ */ Object.create(null);\n }\n nestedForm = nestedForm[key2];\n }\n });\n};\nexport {\n parseBody\n};\n","// src/utils/url.ts\nvar splitPath = (path) => {\n const paths = path.split(\"/\");\n if (paths[0] === \"\") {\n paths.shift();\n }\n return paths;\n};\nvar splitRoutingPath = (routePath) => {\n const { groups, path } = extractGroupsFromPath(routePath);\n const paths = splitPath(path);\n return replaceGroupMarks(paths, groups);\n};\nvar extractGroupsFromPath = (path) => {\n const groups = [];\n path = path.replace(/\\{[^}]+\\}/g, (match, index) => {\n const mark = `@${index}`;\n groups.push([mark, match]);\n return mark;\n });\n return { groups, path };\n};\nvar replaceGroupMarks = (paths, groups) => {\n for (let i = groups.length - 1; i >= 0; i--) {\n const [mark] = groups[i];\n for (let j = paths.length - 1; j >= 0; j--) {\n if (paths[j].includes(mark)) {\n paths[j] = paths[j].replace(mark, groups[i][1]);\n break;\n }\n }\n }\n return paths;\n};\nvar patternCache = {};\nvar getPattern = (label, next) => {\n if (label === \"*\") {\n return \"*\";\n }\n const match = label.match(/^\\:([^\\{\\}]+)(?:\\{(.+)\\})?$/);\n if (match) {\n const cacheKey = `${label}#${next}`;\n if (!patternCache[cacheKey]) {\n if (match[2]) {\n patternCache[cacheKey] = next && next[0] !== \":\" && next[0] !== \"*\" ? [cacheKey, match[1], new RegExp(`^${match[2]}(?=/${next})`)] : [label, match[1], new RegExp(`^${match[2]}$`)];\n } else {\n patternCache[cacheKey] = [label, match[1], true];\n }\n }\n return patternCache[cacheKey];\n }\n return null;\n};\nvar tryDecode = (str, decoder) => {\n try {\n return decoder(str);\n } catch {\n return str.replace(/(?:%[0-9A-Fa-f]{2})+/g, (match) => {\n try {\n return decoder(match);\n } catch {\n return match;\n }\n });\n }\n};\nvar tryDecodeURI = (str) => tryDecode(str, decodeURI);\nvar getPath = (request) => {\n const url = request.url;\n const start = url.indexOf(\"/\", url.indexOf(\":\") + 4);\n let i = start;\n for (; i < url.length; i++) {\n const charCode = url.charCodeAt(i);\n if (charCode === 37) {\n const queryIndex = url.indexOf(\"?\", i);\n const hashIndex = url.indexOf(\"#\", i);\n const end = queryIndex === -1 ? hashIndex === -1 ? void 0 : hashIndex : hashIndex === -1 ? queryIndex : Math.min(queryIndex, hashIndex);\n const path = url.slice(start, end);\n return tryDecodeURI(path.includes(\"%25\") ? path.replace(/%25/g, \"%2525\") : path);\n } else if (charCode === 63 || charCode === 35) {\n break;\n }\n }\n return url.slice(start, i);\n};\nvar getQueryStrings = (url) => {\n const queryIndex = url.indexOf(\"?\", 8);\n return queryIndex === -1 ? \"\" : \"?\" + url.slice(queryIndex + 1);\n};\nvar getPathNoStrict = (request) => {\n const result = getPath(request);\n return result.length > 1 && result.at(-1) === \"/\" ? result.slice(0, -1) : result;\n};\nvar mergePath = (base, sub, ...rest) => {\n if (rest.length) {\n sub = mergePath(sub, ...rest);\n }\n return `${base?.[0] === \"/\" ? \"\" : \"/\"}${base}${sub === \"/\" ? \"\" : `${base?.at(-1) === \"/\" ? \"\" : \"/\"}${sub?.[0] === \"/\" ? sub.slice(1) : sub}`}`;\n};\nvar checkOptionalParameter = (path) => {\n if (path.charCodeAt(path.length - 1) !== 63 || !path.includes(\":\")) {\n return null;\n }\n const segments = path.split(\"/\");\n const results = [];\n let basePath = \"\";\n segments.forEach((segment) => {\n if (segment !== \"\" && !/\\:/.test(segment)) {\n basePath += \"/\" + segment;\n } else if (/\\:/.test(segment)) {\n if (/\\?/.test(segment)) {\n if (results.length === 0 && basePath === \"\") {\n results.push(\"/\");\n } else {\n results.push(basePath);\n }\n const optionalSegment = segment.replace(\"?\", \"\");\n basePath += \"/\" + optionalSegment;\n results.push(basePath);\n } else {\n basePath += \"/\" + segment;\n }\n }\n });\n return results.filter((v, i, a) => a.indexOf(v) === i);\n};\nvar _decodeURI = (value) => {\n if (!/[%+]/.test(value)) {\n return value;\n }\n if (value.indexOf(\"+\") !== -1) {\n value = value.replace(/\\+/g, \" \");\n }\n return value.indexOf(\"%\") !== -1 ? tryDecode(value, decodeURIComponent_) : value;\n};\nvar _getQueryParam = (url, key, multiple) => {\n let encoded;\n if (!multiple && key && !/[%+]/.test(key)) {\n let keyIndex2 = url.indexOf(\"?\", 8);\n if (keyIndex2 === -1) {\n return void 0;\n }\n if (!url.startsWith(key, keyIndex2 + 1)) {\n keyIndex2 = url.indexOf(`&${key}`, keyIndex2 + 1);\n }\n while (keyIndex2 !== -1) {\n const trailingKeyCode = url.charCodeAt(keyIndex2 + key.length + 1);\n if (trailingKeyCode === 61) {\n const valueIndex = keyIndex2 + key.length + 2;\n const endIndex = url.indexOf(\"&\", valueIndex);\n return _decodeURI(url.slice(valueIndex, endIndex === -1 ? void 0 : endIndex));\n } else if (trailingKeyCode == 38 || isNaN(trailingKeyCode)) {\n return \"\";\n }\n keyIndex2 = url.indexOf(`&${key}`, keyIndex2 + 1);\n }\n encoded = /[%+]/.test(url);\n if (!encoded) {\n return void 0;\n }\n }\n const results = {};\n encoded ??= /[%+]/.test(url);\n let keyIndex = url.indexOf(\"?\", 8);\n while (keyIndex !== -1) {\n const nextKeyIndex = url.indexOf(\"&\", keyIndex + 1);\n let valueIndex = url.indexOf(\"=\", keyIndex);\n if (valueIndex > nextKeyIndex && nextKeyIndex !== -1) {\n valueIndex = -1;\n }\n let name = url.slice(\n keyIndex + 1,\n valueIndex === -1 ? nextKeyIndex === -1 ? void 0 : nextKeyIndex : valueIndex\n );\n if (encoded) {\n name = _decodeURI(name);\n }\n keyIndex = nextKeyIndex;\n if (name === \"\") {\n continue;\n }\n let value;\n if (valueIndex === -1) {\n value = \"\";\n } else {\n value = url.slice(valueIndex + 1, nextKeyIndex === -1 ? void 0 : nextKeyIndex);\n if (encoded) {\n value = _decodeURI(value);\n }\n }\n if (multiple) {\n if (!(results[name] && Array.isArray(results[name]))) {\n results[name] = [];\n }\n ;\n results[name].push(value);\n } else {\n results[name] ??= value;\n }\n }\n return key ? results[key] : results;\n};\nvar getQueryParam = _getQueryParam;\nvar getQueryParams = (url, key) => {\n return _getQueryParam(url, key, true);\n};\nvar decodeURIComponent_ = decodeURIComponent;\nexport {\n checkOptionalParameter,\n decodeURIComponent_,\n getPath,\n getPathNoStrict,\n getPattern,\n getQueryParam,\n getQueryParams,\n getQueryStrings,\n mergePath,\n splitPath,\n splitRoutingPath,\n tryDecode,\n tryDecodeURI\n};\n","// src/request.ts\nimport { HTTPException } from \"./http-exception.js\";\nimport { GET_MATCH_RESULT } from \"./request/constants.js\";\nimport { parseBody } from \"./utils/body.js\";\nimport { decodeURIComponent_, getQueryParam, getQueryParams, tryDecode } from \"./utils/url.js\";\nvar tryDecodeURIComponent = (str) => tryDecode(str, decodeURIComponent_);\nvar HonoRequest = class {\n /**\n * `.raw` can get the raw Request object.\n *\n * @see {@link https://hono.dev/docs/api/request#raw}\n *\n * @example\n * ```ts\n * // For Cloudflare Workers\n * app.post('/', async (c) => {\n * const metadata = c.req.raw.cf?.hostMetadata?\n * ...\n * })\n * ```\n */\n raw;\n #validatedData;\n // Short name of validatedData\n #matchResult;\n routeIndex = 0;\n /**\n * `.path` can get the pathname of the request.\n *\n * @see {@link https://hono.dev/docs/api/request#path}\n *\n * @example\n * ```ts\n * app.get('/about/me', (c) => {\n * const pathname = c.req.path // `/about/me`\n * })\n * ```\n */\n path;\n bodyCache = {};\n constructor(request, path = \"/\", matchResult = [[]]) {\n this.raw = request;\n this.path = path;\n this.#matchResult = matchResult;\n this.#validatedData = {};\n }\n param(key) {\n return key ? this.#getDecodedParam(key) : this.#getAllDecodedParams();\n }\n #getDecodedParam(key) {\n const paramKey = this.#matchResult[0][this.routeIndex][1][key];\n const param = this.#getParamValue(paramKey);\n return param && /\\%/.test(param) ? tryDecodeURIComponent(param) : param;\n }\n #getAllDecodedParams() {\n const decoded = {};\n const keys = Object.keys(this.#matchResult[0][this.routeIndex][1]);\n for (const key of keys) {\n const value = this.#getParamValue(this.#matchResult[0][this.routeIndex][1][key]);\n if (value !== void 0) {\n decoded[key] = /\\%/.test(value) ? tryDecodeURIComponent(value) : value;\n }\n }\n return decoded;\n }\n #getParamValue(paramKey) {\n return this.#matchResult[1] ? this.#matchResult[1][paramKey] : paramKey;\n }\n query(key) {\n return getQueryParam(this.url, key);\n }\n queries(key) {\n return getQueryParams(this.url, key);\n }\n header(name) {\n if (name) {\n return this.raw.headers.get(name) ?? void 0;\n }\n const headerData = {};\n this.raw.headers.forEach((value, key) => {\n headerData[key] = value;\n });\n return headerData;\n }\n async parseBody(options) {\n return parseBody(this, options);\n }\n #cachedBody = (key) => {\n const { bodyCache, raw } = this;\n const cachedBody = bodyCache[key];\n if (cachedBody) {\n return cachedBody;\n }\n const anyCachedKey = Object.keys(bodyCache)[0];\n if (anyCachedKey) {\n return bodyCache[anyCachedKey].then((body) => {\n if (anyCachedKey === \"json\") {\n body = JSON.stringify(body);\n }\n return new Response(body)[key]();\n });\n }\n return bodyCache[key] = raw[key]();\n };\n /**\n * `.json()` can parse Request body of type `application/json`\n *\n * @see {@link https://hono.dev/docs/api/request#json}\n *\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.json()\n * })\n * ```\n */\n json() {\n return this.#cachedBody(\"text\").then((text) => JSON.parse(text));\n }\n /**\n * `.text()` can parse Request body of type `text/plain`\n *\n * @see {@link https://hono.dev/docs/api/request#text}\n *\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.text()\n * })\n * ```\n */\n text() {\n return this.#cachedBody(\"text\");\n }\n /**\n * `.arrayBuffer()` parse Request body as an `ArrayBuffer`\n *\n * @see {@link https://hono.dev/docs/api/request#arraybuffer}\n *\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.arrayBuffer()\n * })\n * ```\n */\n arrayBuffer() {\n return this.#cachedBody(\"arrayBuffer\");\n }\n /**\n * `.bytes()` parses the request body as a `Uint8Array`.\n *\n * @see {@link https://hono.dev/docs/api/request#bytes}\n *\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.bytes()\n * })\n * ```\n */\n bytes() {\n return this.#cachedBody(\"arrayBuffer\").then((buffer) => new Uint8Array(buffer));\n }\n /**\n * Parses the request body as a `Blob`.\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.blob();\n * });\n * ```\n * @see https://hono.dev/docs/api/request#blob\n */\n blob() {\n return this.#cachedBody(\"blob\");\n }\n /**\n * Parses the request body as `FormData`.\n * @example\n * ```ts\n * app.post('/entry', async (c) => {\n * const body = await c.req.formData();\n * });\n * ```\n * @see https://hono.dev/docs/api/request#formdata\n */\n formData() {\n return this.#cachedBody(\"formData\");\n }\n /**\n * Adds validated data to the request.\n *\n * @param target - The target of the validation.\n * @param data - The validated data to add.\n */\n addValidatedData(target, data) {\n this.#validatedData[target] = data;\n }\n valid(target) {\n return this.#validatedData[target];\n }\n /**\n * `.url()` can get the request url strings.\n *\n * @see {@link https://hono.dev/docs/api/request#url}\n *\n * @example\n * ```ts\n * app.get('/about/me', (c) => {\n * const url = c.req.url // `http://localhost:8787/about/me`\n * ...\n * })\n * ```\n */\n get url() {\n return this.raw.url;\n }\n /**\n * `.method()` can get the method name of the request.\n *\n * @see {@link https://hono.dev/docs/api/request#method}\n *\n * @example\n * ```ts\n * app.get('/about/me', (c) => {\n * const method = c.req.method // `GET`\n * })\n * ```\n */\n get method() {\n return this.raw.method;\n }\n get [GET_MATCH_RESULT]() {\n return this.#matchResult;\n }\n /**\n * `.matchedRoutes()` can return a matched route in the handler\n *\n * @deprecated\n *\n * Use matchedRoutes helper defined in \"hono/route\" instead.\n *\n * @see {@link https://hono.dev/docs/api/request#matchedroutes}\n *\n * @example\n * ```ts\n * app.use('*', async function logger(c, next) {\n * await next()\n * c.req.matchedRoutes.forEach(({ handler, method, path }, i) => {\n * const name = handler.name || (handler.length < 2 ? '[handler]' : '[middleware]')\n * console.log(\n * method,\n * ' ',\n * path,\n * ' '.repeat(Math.max(10 - path.length, 0)),\n * name,\n * i === c.req.routeIndex ? '<- respond from here' : ''\n * )\n * })\n * })\n * ```\n */\n get matchedRoutes() {\n return this.#matchResult[0].map(([[, route]]) => route);\n }\n /**\n * `routePath()` can retrieve the path registered within the handler\n *\n * @deprecated\n *\n * Use routePath helper defined in \"hono/route\" instead.\n *\n * @see {@link https://hono.dev/docs/api/request#routepath}\n *\n * @example\n * ```ts\n * app.get('/posts/:id', (c) => {\n * return c.json({ path: c.req.routePath })\n * })\n * ```\n */\n get routePath() {\n return this.#matchResult[0].map(([[, route]]) => route)[this.routeIndex].path;\n }\n};\nvar cloneRawRequest = async (req) => {\n if (!req.raw.bodyUsed) {\n return req.raw.clone();\n }\n const cacheKey = Object.keys(req.bodyCache)[0];\n if (!cacheKey) {\n throw new HTTPException(500, {\n message: \"Cannot clone request: body was already consumed and not cached. Please use HonoRequest methods (e.g., req.json(), req.text()) instead of consuming req.raw directly.\"\n });\n }\n const requestInit = {\n body: await req[cacheKey](),\n cache: req.raw.cache,\n credentials: req.raw.credentials,\n headers: req.header(),\n integrity: req.raw.integrity,\n keepalive: req.raw.keepalive,\n method: req.method,\n mode: req.raw.mode,\n redirect: req.raw.redirect,\n referrer: req.raw.referrer,\n referrerPolicy: req.raw.referrerPolicy,\n signal: req.raw.signal\n };\n return new Request(req.url, requestInit);\n};\nexport {\n HonoRequest,\n cloneRawRequest\n};\n","// src/utils/html.ts\nvar HtmlEscapedCallbackPhase = {\n Stringify: 1,\n BeforeStream: 2,\n Stream: 3\n};\nvar raw = (value, callbacks) => {\n const escapedString = new String(value);\n escapedString.isEscaped = true;\n escapedString.callbacks = callbacks;\n return escapedString;\n};\nvar escapeRe = /[&<>'\"]/;\nvar stringBufferToString = async (buffer, callbacks) => {\n let str = \"\";\n callbacks ||= [];\n const resolvedBuffer = await Promise.all(buffer);\n for (let i = resolvedBuffer.length - 1; ; i--) {\n str += resolvedBuffer[i];\n i--;\n if (i < 0) {\n break;\n }\n let r = resolvedBuffer[i];\n if (typeof r === \"object\") {\n callbacks.push(...r.callbacks || []);\n }\n const isEscaped = r.isEscaped;\n r = await (typeof r === \"object\" ? r.toString() : r);\n if (typeof r === \"object\") {\n callbacks.push(...r.callbacks || []);\n }\n if (r.isEscaped ?? isEscaped) {\n str += r;\n } else {\n const buf = [str];\n escapeToBuffer(r, buf);\n str = buf[0];\n }\n }\n return raw(str, callbacks);\n};\nvar escapeToBuffer = (str, buffer) => {\n const match = str.search(escapeRe);\n if (match === -1) {\n buffer[0] += str;\n return;\n }\n let escape;\n let index;\n let lastIndex = 0;\n for (index = match; index < str.length; index++) {\n switch (str.charCodeAt(index)) {\n case 34:\n escape = \"&quot;\";\n break;\n case 39:\n escape = \"&#39;\";\n break;\n case 38:\n escape = \"&amp;\";\n break;\n case 60:\n escape = \"&lt;\";\n break;\n case 62:\n escape = \"&gt;\";\n break;\n default:\n continue;\n }\n buffer[0] += str.substring(lastIndex, index) + escape;\n lastIndex = index + 1;\n }\n buffer[0] += str.substring(lastIndex, index);\n};\nvar resolveCallbackSync = (str) => {\n const callbacks = str.callbacks;\n if (!callbacks?.length) {\n return str;\n }\n const buffer = [str];\n const context = {};\n callbacks.forEach((c) => c({ phase: HtmlEscapedCallbackPhase.Stringify, buffer, context }));\n return buffer[0];\n};\nvar resolveCallback = async (str, phase, preserveCallbacks, context, buffer) => {\n if (typeof str === \"object\" && !(str instanceof String)) {\n if (!(str instanceof Promise)) {\n str = str.toString();\n }\n if (str instanceof Promise) {\n str = await str;\n }\n }\n const callbacks = str.callbacks;\n if (!callbacks?.length) {\n return Promise.resolve(str);\n }\n if (buffer) {\n buffer[0] += str;\n } else {\n buffer = [str];\n }\n const resStr = Promise.all(callbacks.map((c) => c({ phase, buffer, context }))).then(\n (res) => Promise.all(\n res.filter(Boolean).map((str2) => resolveCallback(str2, phase, false, context, buffer))\n ).then(() => buffer[0])\n );\n if (preserveCallbacks) {\n return raw(await resStr, callbacks);\n } else {\n return resStr;\n }\n};\nexport {\n HtmlEscapedCallbackPhase,\n escapeToBuffer,\n raw,\n resolveCallback,\n resolveCallbackSync,\n stringBufferToString\n};\n","// src/context.ts\nimport { HonoRequest } from \"./request.js\";\nimport { HtmlEscapedCallbackPhase, resolveCallback } from \"./utils/html.js\";\nvar TEXT_PLAIN = \"text/plain; charset=UTF-8\";\nvar setDefaultContentType = (contentType, headers) => {\n return {\n \"Content-Type\": contentType,\n ...headers\n };\n};\nvar createResponseInstance = (body, init) => new Response(body, init);\nvar Context = class {\n #rawRequest;\n #req;\n /**\n * `.env` can get bindings (environment variables, secrets, KV namespaces, D1 database, R2 bucket etc.) in Cloudflare Workers.\n *\n * @see {@link https://hono.dev/docs/api/context#env}\n *\n * @example\n * ```ts\n * // Environment object for Cloudflare Workers\n * app.get('*', async c => {\n * const counter = c.env.COUNTER\n * })\n * ```\n */\n env = {};\n #var;\n finalized = false;\n /**\n * `.error` can get the error object from the middleware if the Handler throws an error.\n *\n * @see {@link https://hono.dev/docs/api/context#error}\n *\n * @example\n * ```ts\n * app.use('*', async (c, next) => {\n * await next()\n * if (c.error) {\n * // do something...\n * }\n * })\n * ```\n */\n error;\n #status;\n #executionCtx;\n #res;\n #layout;\n #renderer;\n #notFoundHandler;\n #preparedHeaders;\n #matchResult;\n #path;\n /**\n * Creates an instance of the Context class.\n *\n * @param req - The Request object.\n * @param options - Optional configuration options for the context.\n */\n constructor(req, options) {\n this.#rawRequest = req;\n if (options) {\n this.#executionCtx = options.executionCtx;\n this.env = options.env;\n this.#notFoundHandler = options.notFoundHandler;\n this.#path = options.path;\n this.#matchResult = options.matchResult;\n }\n }\n /**\n * `.req` is the instance of {@link HonoRequest}.\n */\n get req() {\n this.#req ??= new HonoRequest(this.#rawRequest, this.#path, this.#matchResult);\n return this.#req;\n }\n /**\n * @see {@link https://hono.dev/docs/api/context#event}\n * The FetchEvent associated with the current request.\n *\n * @throws Will throw an error if the context does not have a FetchEvent.\n */\n get event() {\n if (this.#executionCtx && \"respondWith\" in this.#executionCtx) {\n return this.#executionCtx;\n } else {\n throw Error(\"This context has no FetchEvent\");\n }\n }\n /**\n * @see {@link https://hono.dev/docs/api/context#executionctx}\n * The ExecutionContext associated with the current request.\n *\n * @throws Will throw an error if the context does not have an ExecutionContext.\n */\n get executionCtx() {\n if (this.#executionCtx) {\n return this.#executionCtx;\n } else {\n throw Error(\"This context has no ExecutionContext\");\n }\n }\n /**\n * @see {@link https://hono.dev/docs/api/context#res}\n * The Response object for the current request.\n */\n get res() {\n return this.#res ||= createResponseInstance(null, {\n headers: this.#preparedHeaders ??= new Headers()\n });\n }\n /**\n * Sets the Response object for the current request.\n *\n * @param _res - The Response object to set.\n */\n set res(_res) {\n if (this.#res && _res) {\n _res = createResponseInstance(_res.body, _res);\n for (const [k, v] of this.#res.headers.entries()) {\n if (k === \"content-type\") {\n continue;\n }\n if (k === \"set-cookie\") {\n const cookies = this.#res.headers.getSetCookie();\n _res.headers.delete(\"set-cookie\");\n for (const cookie of cookies) {\n _res.headers.append(\"set-cookie\", cookie);\n }\n } else {\n _res.headers.set(k, v);\n }\n }\n }\n this.#res = _res;\n this.finalized = true;\n }\n /**\n * `.render()` can create a response within a layout.\n *\n * @see {@link https://hono.dev/docs/api/context#render-setrenderer}\n *\n * @example\n * ```ts\n * app.get('/', (c) => {\n * return c.render('Hello!')\n * })\n * ```\n */\n render = (...args) => {\n this.#renderer ??= (content) => this.html(content);\n return this.#renderer(...args);\n };\n /**\n * Sets the layout for the response.\n *\n * @param layout - The layout to set.\n * @returns The layout function.\n */\n setLayout = (layout) => this.#layout = layout;\n /**\n * Gets the current layout for the response.\n *\n * @returns The current layout function.\n */\n getLayout = () => this.#layout;\n /**\n * `.setRenderer()` can set the layout in the custom middleware.\n *\n * @see {@link https://hono.dev/docs/api/context#render-setrenderer}\n *\n * @example\n * ```tsx\n * app.use('*', async (c, next) => {\n * c.setRenderer((content) => {\n * return c.html(\n * <html>\n * <body>\n * <p>{content}</p>\n * </body>\n * </html>\n * )\n * })\n * await next()\n * })\n * ```\n */\n setRenderer = (renderer) => {\n this.#renderer = renderer;\n };\n /**\n * `.header()` can set headers.\n *\n * @see {@link https://hono.dev/docs/api/context#header}\n *\n * @example\n * ```ts\n * app.get('/welcome', (c) => {\n * // Set headers\n * c.header('X-Message', 'Hello!')\n * c.header('Content-Type', 'text/plain')\n *\n * return c.body('Thank you for coming')\n * })\n * ```\n */\n header = (name, value, options) => {\n if (this.finalized) {\n this.#res = createResponseInstance(this.#res.body, this.#res);\n }\n const headers = this.#res ? this.#res.headers : this.#preparedHeaders ??= new Headers();\n if (value === void 0) {\n headers.delete(name);\n } else if (options?.append) {\n headers.append(name, value);\n } else {\n headers.set(name, value);\n }\n };\n status = (status) => {\n this.#status = status;\n };\n /**\n * `.set()` can set the value specified by the key.\n *\n * @see {@link https://hono.dev/docs/api/context#set-get}\n *\n * @example\n * ```ts\n * app.use('*', async (c, next) => {\n * c.set('message', 'Hono is hot!!')\n * await next()\n * })\n * ```\n */\n set = (key, value) => {\n this.#var ??= /* @__PURE__ */ new Map();\n this.#var.set(key, value);\n };\n /**\n * `.get()` can use the value specified by the key.\n *\n * @see {@link https://hono.dev/docs/api/context#set-get}\n *\n * @example\n * ```ts\n * app.get('/', (c) => {\n * const message = c.get('message')\n * return c.text(`The message is \"${message}\"`)\n * })\n * ```\n */\n get = (key) => {\n return this.#var ? this.#var.get(key) : void 0;\n };\n /**\n * `.var` can access the value of a variable.\n *\n * @see {@link https://hono.dev/docs/api/context#var}\n *\n * @example\n * ```ts\n * const result = c.var.client.oneMethod()\n * ```\n */\n // c.var.propName is a read-only\n get var() {\n if (!this.#var) {\n return {};\n }\n return Object.fromEntries(this.#var);\n }\n #newResponse(data, arg, headers) {\n const responseHeaders = this.#res ? new Headers(this.#res.headers) : this.#preparedHeaders ?? new Headers();\n if (typeof arg === \"object\" && \"headers\" in arg) {\n const argHeaders = arg.headers instanceof Headers ? arg.headers : new Headers(arg.headers);\n for (const [key, value] of argHeaders) {\n if (key.toLowerCase() === \"set-cookie\") {\n responseHeaders.append(key, value);\n } else {\n responseHeaders.set(key, value);\n }\n }\n }\n if (headers) {\n for (const [k, v] of Object.entries(headers)) {\n if (typeof v === \"string\") {\n responseHeaders.set(k, v);\n } else {\n responseHeaders.delete(k);\n for (const v2 of v) {\n responseHeaders.append(k, v2);\n }\n }\n }\n }\n const status = typeof arg === \"number\" ? arg : arg?.status ?? this.#status;\n return createResponseInstance(data, { status, headers: responseHeaders });\n }\n newResponse = (...args) => this.#newResponse(...args);\n /**\n * `.body()` can return the HTTP response.\n * You can set headers with `.header()` and set HTTP status code with `.status`.\n * This can also be set in `.text()`, `.json()` and so on.\n *\n * @see {@link https://hono.dev/docs/api/context#body}\n *\n * @example\n * ```ts\n * app.get('/welcome', (c) => {\n * // Set headers\n * c.header('X-Message', 'Hello!')\n * c.header('Content-Type', 'text/plain')\n * // Set HTTP status code\n * c.status(201)\n *\n * // Return the response body\n * return c.body('Thank you for coming')\n * })\n * ```\n */\n body = (data, arg, headers) => this.#newResponse(data, arg, headers);\n /**\n * `.text()` can render text as `Content-Type:text/plain`.\n *\n * @see {@link https://hono.dev/docs/api/context#text}\n *\n * @example\n * ```ts\n * app.get('/say', (c) => {\n * return c.text('Hello!')\n * })\n * ```\n */\n text = (text, arg, headers) => {\n return !this.#preparedHeaders && !this.#status && !arg && !headers && !this.finalized ? new Response(text) : this.#newResponse(\n text,\n arg,\n setDefaultContentType(TEXT_PLAIN, headers)\n );\n };\n /**\n * `.json()` can render JSON as `Content-Type:application/json`.\n *\n * @see {@link https://hono.dev/docs/api/context#json}\n *\n * @example\n * ```ts\n * app.get('/api', (c) => {\n * return c.json({ message: 'Hello!' })\n * })\n * ```\n */\n json = (object, arg, headers) => {\n return this.#newResponse(\n JSON.stringify(object),\n arg,\n setDefaultContentType(\"application/json\", headers)\n );\n };\n html = (html, arg, headers) => {\n const res = (html2) => this.#newResponse(html2, arg, setDefaultContentType(\"text/html; charset=UTF-8\", headers));\n return typeof html === \"object\" ? resolveCallback(html, HtmlEscapedCallbackPhase.Stringify, false, {}).then(res) : res(html);\n };\n /**\n * `.redirect()` can Redirect, default status code is 302.\n *\n * @see {@link https://hono.dev/docs/api/context#redirect}\n *\n * @example\n * ```ts\n * app.get('/redirect', (c) => {\n * return c.redirect('/')\n * })\n * app.get('/redirect-permanently', (c) => {\n * return c.redirect('/', 301)\n * })\n * ```\n */\n redirect = (location, status) => {\n const locationString = String(location);\n this.header(\n \"Location\",\n // Multibyes should be encoded\n // eslint-disable-next-line no-control-regex\n !/[^\\x00-\\xFF]/.test(locationString) ? locationString : encodeURI(locationString)\n );\n return this.newResponse(null, status ?? 302);\n };\n /**\n * `.notFound()` can return the Not Found Response.\n *\n * @see {@link https://hono.dev/docs/api/context#notfound}\n *\n * @example\n * ```ts\n * app.get('/notfound', (c) => {\n * return c.notFound()\n * })\n * ```\n */\n notFound = () => {\n this.#notFoundHandler ??= () => createResponseInstance();\n return this.#notFoundHandler(this);\n };\n};\nexport {\n Context,\n TEXT_PLAIN\n};\n","// src/router.ts\nvar METHOD_NAME_ALL = \"ALL\";\nvar METHOD_NAME_ALL_LOWERCASE = \"all\";\nvar METHODS = [\"get\", \"post\", \"put\", \"delete\", \"options\", \"patch\"];\nvar MESSAGE_MATCHER_IS_ALREADY_BUILT = \"Can not add a route since the matcher is already built.\";\nvar UnsupportedPathError = class extends Error {\n};\nexport {\n MESSAGE_MATCHER_IS_ALREADY_BUILT,\n METHODS,\n METHOD_NAME_ALL,\n METHOD_NAME_ALL_LOWERCASE,\n UnsupportedPathError\n};\n","// src/utils/constants.ts\nvar COMPOSED_HANDLER = \"__COMPOSED_HANDLER\";\nexport {\n COMPOSED_HANDLER\n};\n","// src/hono-base.ts\nimport { compose } from \"./compose.js\";\nimport { Context } from \"./context.js\";\nimport { METHODS, METHOD_NAME_ALL, METHOD_NAME_ALL_LOWERCASE } from \"./router.js\";\nimport { COMPOSED_HANDLER } from \"./utils/constants.js\";\nimport { getPath, getPathNoStrict, mergePath } from \"./utils/url.js\";\nvar notFoundHandler = (c) => {\n return c.text(\"404 Not Found\", 404);\n};\nvar errorHandler = (err, c) => {\n if (\"getResponse\" in err) {\n const res = err.getResponse();\n return c.newResponse(res.body, res);\n }\n console.error(err);\n return c.text(\"Internal Server Error\", 500);\n};\nvar Hono = class _Hono {\n get;\n post;\n put;\n delete;\n options;\n patch;\n all;\n on;\n use;\n /*\n This class is like an abstract class and does not have a router.\n To use it, inherit the class and implement router in the constructor.\n */\n router;\n getPath;\n // Cannot use `#` because it requires visibility at JavaScript runtime.\n _basePath = \"/\";\n #path = \"/\";\n routes = [];\n constructor(options = {}) {\n const allMethods = [...METHODS, METHOD_NAME_ALL_LOWERCASE];\n allMethods.forEach((method) => {\n this[method] = (args1, ...args) => {\n if (typeof args1 === \"string\") {\n this.#path = args1;\n } else {\n this.#addRoute(method, this.#path, args1);\n }\n args.forEach((handler) => {\n this.#addRoute(method, this.#path, handler);\n });\n return this;\n };\n });\n this.on = (method, path, ...handlers) => {\n for (const p of [path].flat()) {\n this.#path = p;\n for (const m of [method].flat()) {\n handlers.map((handler) => {\n this.#addRoute(m.toUpperCase(), this.#path, handler);\n });\n }\n }\n return this;\n };\n this.use = (arg1, ...handlers) => {\n if (typeof arg1 === \"string\") {\n this.#path = arg1;\n } else {\n this.#path = \"*\";\n handlers.unshift(arg1);\n }\n handlers.forEach((handler) => {\n this.#addRoute(METHOD_NAME_ALL, this.#path, handler);\n });\n return this;\n };\n const { strict, ...optionsWithoutStrict } = options;\n Object.assign(this, optionsWithoutStrict);\n this.getPath = strict ?? true ? options.getPath ?? getPath : getPathNoStrict;\n }\n #clone() {\n const clone = new _Hono({\n router: this.router,\n getPath: this.getPath\n });\n clone.errorHandler = this.errorHandler;\n clone.#notFoundHandler = this.#notFoundHandler;\n clone.routes = this.routes;\n return clone;\n }\n #notFoundHandler = notFoundHandler;\n // Cannot use `#` because it requires visibility at JavaScript runtime.\n errorHandler = errorHandler;\n /**\n * `.route()` allows grouping other Hono instance in routes.\n *\n * @see {@link https://hono.dev/docs/api/routing#grouping}\n *\n * @param {string} path - base Path\n * @param {Hono} app - other Hono instance\n * @returns {Hono} routed Hono instance\n *\n * @example\n * ```ts\n * const app = new Hono()\n * const app2 = new Hono()\n *\n * app2.get(\"/user\", (c) => c.text(\"user\"))\n * app.route(\"/api\", app2) // GET /api/user\n * ```\n */\n route(path, app) {\n const subApp = this.basePath(path);\n app.routes.map((r) => {\n let handler;\n if (app.errorHandler === errorHandler) {\n handler = r.handler;\n } else {\n handler = async (c, next) => (await compose([], app.errorHandler)(c, () => r.handler(c, next))).res;\n handler[COMPOSED_HANDLER] = r.handler;\n }\n subApp.#addRoute(r.method, r.path, handler, r.basePath);\n });\n return this;\n }\n /**\n * `.basePath()` allows base paths to be specified.\n *\n * @see {@link https://hono.dev/docs/api/routing#base-path}\n *\n * @param {string} path - base Path\n * @returns {Hono} changed Hono instance\n *\n * @example\n * ```ts\n * const api = new Hono().basePath('/api')\n * ```\n */\n basePath(path) {\n const subApp = this.#clone();\n subApp._basePath = mergePath(this._basePath, path);\n return subApp;\n }\n /**\n * `.onError()` handles an error and returns a customized Response.\n *\n * @see {@link https://hono.dev/docs/api/hono#error-handling}\n *\n * @param {ErrorHandler} handler - request Handler for error\n * @returns {Hono} changed Hono instance\n *\n * @example\n * ```ts\n * app.onError((err, c) => {\n * console.error(`${err}`)\n * return c.text('Custom Error Message', 500)\n * })\n * ```\n */\n onError = (handler) => {\n this.errorHandler = handler;\n return this;\n };\n /**\n * `.notFound()` allows you to customize a Not Found Response.\n *\n * @see {@link https://hono.dev/docs/api/hono#not-found}\n *\n * @param {NotFoundHandler} handler - request handler for not-found\n * @returns {Hono} changed Hono instance\n *\n * @example\n * ```ts\n * app.notFound((c) => {\n * return c.text('Custom 404 Message', 404)\n * })\n * ```\n */\n notFound = (handler) => {\n this.#notFoundHandler = handler;\n return this;\n };\n /**\n * `.mount()` allows you to mount applications built with other frameworks into your Hono application.\n *\n * @see {@link https://hono.dev/docs/api/hono#mount}\n *\n * @param {string} path - base Path\n * @param {Function} applicationHandler - other Request Handler\n * @param {MountOptions} [options] - options of `.mount()`\n * @returns {Hono} mounted Hono instance\n *\n * @example\n * ```ts\n * import { Router as IttyRouter } from 'itty-router'\n * import { Hono } from 'hono'\n * // Create itty-router application\n * const ittyRouter = IttyRouter()\n * // GET /itty-router/hello\n * ittyRouter.get('/hello', () => new Response('Hello from itty-router'))\n *\n * const app = new Hono()\n * app.mount('/itty-router', ittyRouter.handle)\n * ```\n *\n * @example\n * ```ts\n * const app = new Hono()\n * // Send the request to another application without modification.\n * app.mount('/app', anotherApp, {\n * replaceRequest: (req) => req,\n * })\n * ```\n */\n mount(path, applicationHandler, options) {\n let replaceRequest;\n let optionHandler;\n if (options) {\n if (typeof options === \"function\") {\n optionHandler = options;\n } else {\n optionHandler = options.optionHandler;\n if (options.replaceRequest === false) {\n replaceRequest = (request) => request;\n } else {\n replaceRequest = options.replaceRequest;\n }\n }\n }\n const getOptions = optionHandler ? (c) => {\n const options2 = optionHandler(c);\n return Array.isArray(options2) ? options2 : [options2];\n } : (c) => {\n let executionContext = void 0;\n try {\n executionContext = c.executionCtx;\n } catch {\n }\n return [c.env, executionContext];\n };\n replaceRequest ||= (() => {\n const mergedPath = mergePath(this._basePath, path);\n const pathPrefixLength = mergedPath === \"/\" ? 0 : mergedPath.length;\n return (request) => {\n const url = new URL(request.url);\n url.pathname = this.getPath(request).slice(pathPrefixLength) || \"/\";\n return new Request(url, request);\n };\n })();\n const handler = async (c, next) => {\n const res = await applicationHandler(replaceRequest(c.req.raw), ...getOptions(c));\n if (res) {\n return res;\n }\n await next();\n };\n this.#addRoute(METHOD_NAME_ALL, mergePath(path, \"*\"), handler);\n return this;\n }\n #addRoute(method, path, handler, baseRoutePath) {\n method = method.toUpperCase();\n path = mergePath(this._basePath, path);\n const r = {\n basePath: baseRoutePath !== void 0 ? mergePath(this._basePath, baseRoutePath) : this._basePath,\n path,\n method,\n handler\n };\n this.router.add(method, path, [handler, r]);\n this.routes.push(r);\n }\n #handleError(err, c) {\n if (err instanceof Error) {\n return this.errorHandler(err, c);\n }\n throw err;\n }\n #dispatch(request, executionCtx, env, method) {\n if (method === \"HEAD\") {\n return (async () => new Response(null, await this.#dispatch(request, executionCtx, env, \"GET\")))();\n }\n const path = this.getPath(request, { env });\n const matchResult = this.router.match(method, path);\n const c = new Context(request, {\n path,\n matchResult,\n env,\n executionCtx,\n notFoundHandler: this.#notFoundHandler\n });\n if (matchResult[0].length === 1) {\n let res;\n try {\n res = matchResult[0][0][0][0](c, async () => {\n c.res = await this.#notFoundHandler(c);\n });\n } catch (err) {\n return this.#handleError(err, c);\n }\n return res instanceof Promise ? res.then(\n (resolved) => resolved || (c.finalized ? c.res : this.#notFoundHandler(c))\n ).catch((err) => this.#handleError(err, c)) : res ?? this.#notFoundHandler(c);\n }\n const composed = compose(matchResult[0], this.errorHandler, this.#notFoundHandler);\n return (async () => {\n try {\n const context = await composed(c);\n if (!context.finalized) {\n throw new Error(\n \"Context is not finalized. Did you forget to return a Response object or `await next()`?\"\n );\n }\n return context.res;\n } catch (err) {\n return this.#handleError(err, c);\n }\n })();\n }\n /**\n * `.fetch()` will be entry point of your app.\n *\n * @see {@link https://hono.dev/docs/api/hono#fetch}\n *\n * @param {Request} request - request Object of request\n * @param {Env} Env - env Object\n * @param {ExecutionContext} - context of execution\n * @returns {Response | Promise<Response>} response of request\n *\n */\n fetch = (request, ...rest) => {\n return this.#dispatch(request, rest[1], rest[0], request.method);\n };\n /**\n * `.request()` is a useful method for testing.\n * You can pass a URL or pathname to send a GET request.\n * app will return a Response object.\n * ```ts\n * test('GET /hello is ok', async () => {\n * const res = await app.request('/hello')\n * expect(res.status).toBe(200)\n * })\n * ```\n * @see https://hono.dev/docs/api/hono#request\n */\n request = (input, requestInit, Env, executionCtx) => {\n if (input instanceof Request) {\n return this.fetch(requestInit ? new Request(input, requestInit) : input, Env, executionCtx);\n }\n input = input.toString();\n return this.fetch(\n new Request(\n /^https?:\\/\\//.test(input) ? input : `http://localhost${mergePath(\"/\", input)}`,\n requestInit\n ),\n Env,\n executionCtx\n );\n };\n /**\n * `.fire()` automatically adds a global fetch event listener.\n * This can be useful for environments that adhere to the Service Worker API, such as non-ES module Cloudflare Workers.\n * @deprecated\n * Use `fire` from `hono/service-worker` instead.\n * ```ts\n * import { Hono } from 'hono'\n * import { fire } from 'hono/service-worker'\n *\n * const app = new Hono()\n * // ...\n * fire(app)\n * ```\n * @see https://hono.dev/docs/api/hono#fire\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API\n * @see https://developers.cloudflare.com/workers/reference/migrate-to-module-workers/\n */\n fire = () => {\n addEventListener(\"fetch\", (event) => {\n event.respondWith(this.#dispatch(event.request, event, void 0, event.request.method));\n });\n };\n};\nexport {\n Hono as HonoBase\n};\n","// src/router/reg-exp-router/matcher.ts\nimport { METHOD_NAME_ALL } from \"../../router.js\";\nvar emptyParam = [];\nfunction match(method, path) {\n const matchers = this.buildAllMatchers();\n const match2 = ((method2, path2) => {\n const matcher = matchers[method2] || matchers[METHOD_NAME_ALL];\n const staticMatch = matcher[2][path2];\n if (staticMatch) {\n return staticMatch;\n }\n const match3 = path2.match(matcher[0]);\n if (!match3) {\n return [[], emptyParam];\n }\n const index = match3.indexOf(\"\", 1);\n return [matcher[1][index], match3];\n });\n this.match = match2;\n return match2(method, path);\n}\nexport {\n emptyParam,\n match\n};\n","// src/router/reg-exp-router/node.ts\nvar LABEL_REG_EXP_STR = \"[^/]+\";\nvar ONLY_WILDCARD_REG_EXP_STR = \".*\";\nvar TAIL_WILDCARD_REG_EXP_STR = \"(?:|/.*)\";\nvar PATH_ERROR = /* @__PURE__ */ Symbol();\nvar regExpMetaChars = new Set(\".\\\\+*[^]$()\");\nfunction compareKey(a, b) {\n if (a.length === 1) {\n return b.length === 1 ? a < b ? -1 : 1 : -1;\n }\n if (b.length === 1) {\n return 1;\n }\n if (a === ONLY_WILDCARD_REG_EXP_STR || a === TAIL_WILDCARD_REG_EXP_STR) {\n return 1;\n } else if (b === ONLY_WILDCARD_REG_EXP_STR || b === TAIL_WILDCARD_REG_EXP_STR) {\n return -1;\n }\n if (a === LABEL_REG_EXP_STR) {\n return 1;\n } else if (b === LABEL_REG_EXP_STR) {\n return -1;\n }\n return a.length === b.length ? a < b ? -1 : 1 : b.length - a.length;\n}\nvar Node = class _Node {\n #index;\n #varIndex;\n #children = /* @__PURE__ */ Object.create(null);\n insert(tokens, index, paramMap, context, pathErrorCheckOnly) {\n if (tokens.length === 0) {\n if (this.#index !== void 0) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n this.#index = index;\n return;\n }\n const [token, ...restTokens] = tokens;\n const pattern = token === \"*\" ? restTokens.length === 0 ? [\"\", \"\", ONLY_WILDCARD_REG_EXP_STR] : [\"\", \"\", LABEL_REG_EXP_STR] : token === \"/*\" ? [\"\", \"\", TAIL_WILDCARD_REG_EXP_STR] : token.match(/^\\:([^\\{\\}]+)(?:\\{(.+)\\})?$/);\n let node;\n if (pattern) {\n const name = pattern[1];\n let regexpStr = pattern[2] || LABEL_REG_EXP_STR;\n if (name && pattern[2]) {\n if (regexpStr === \".*\") {\n throw PATH_ERROR;\n }\n regexpStr = regexpStr.replace(/^\\((?!\\?:)(?=[^)]+\\)$)/, \"(?:\");\n if (/\\((?!\\?:)/.test(regexpStr)) {\n throw PATH_ERROR;\n }\n }\n node = this.#children[regexpStr];\n if (!node) {\n if (Object.keys(this.#children).some(\n (k) => k !== ONLY_WILDCARD_REG_EXP_STR && k !== TAIL_WILDCARD_REG_EXP_STR\n )) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n node = this.#children[regexpStr] = new _Node();\n if (name !== \"\") {\n node.#varIndex = context.varIndex++;\n }\n }\n if (!pathErrorCheckOnly && name !== \"\") {\n paramMap.push([name, node.#varIndex]);\n }\n } else {\n node = this.#children[token];\n if (!node) {\n if (Object.keys(this.#children).some(\n (k) => k.length > 1 && k !== ONLY_WILDCARD_REG_EXP_STR && k !== TAIL_WILDCARD_REG_EXP_STR\n )) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n node = this.#children[token] = new _Node();\n }\n }\n node.insert(restTokens, index, paramMap, context, pathErrorCheckOnly);\n }\n buildRegExpStr() {\n const childKeys = Object.keys(this.#children).sort(compareKey);\n const strList = childKeys.map((k) => {\n const c = this.#children[k];\n return (typeof c.#varIndex === \"number\" ? `(${k})@${c.#varIndex}` : regExpMetaChars.has(k) ? `\\\\${k}` : k) + c.buildRegExpStr();\n });\n if (typeof this.#index === \"number\") {\n strList.unshift(`#${this.#index}`);\n }\n if (strList.length === 0) {\n return \"\";\n }\n if (strList.length === 1) {\n return strList[0];\n }\n return \"(?:\" + strList.join(\"|\") + \")\";\n }\n};\nexport {\n Node,\n PATH_ERROR\n};\n","// src/router/reg-exp-router/trie.ts\nimport { Node } from \"./node.js\";\nvar Trie = class {\n #context = { varIndex: 0 };\n #root = new Node();\n insert(path, index, pathErrorCheckOnly) {\n const paramAssoc = [];\n const groups = [];\n for (let i = 0; ; ) {\n let replaced = false;\n path = path.replace(/\\{[^}]+\\}/g, (m) => {\n const mark = `@\\\\${i}`;\n groups[i] = [mark, m];\n i++;\n replaced = true;\n return mark;\n });\n if (!replaced) {\n break;\n }\n }\n const tokens = path.match(/(?::[^\\/]+)|(?:\\/\\*$)|./g) || [];\n for (let i = groups.length - 1; i >= 0; i--) {\n const [mark] = groups[i];\n for (let j = tokens.length - 1; j >= 0; j--) {\n if (tokens[j].indexOf(mark) !== -1) {\n tokens[j] = tokens[j].replace(mark, groups[i][1]);\n break;\n }\n }\n }\n this.#root.insert(tokens, index, paramAssoc, this.#context, pathErrorCheckOnly);\n return paramAssoc;\n }\n buildRegExp() {\n let regexp = this.#root.buildRegExpStr();\n if (regexp === \"\") {\n return [/^$/, [], []];\n }\n let captureIndex = 0;\n const indexReplacementMap = [];\n const paramReplacementMap = [];\n regexp = regexp.replace(/#(\\d+)|@(\\d+)|\\.\\*\\$/g, (_, handlerIndex, paramIndex) => {\n if (handlerIndex !== void 0) {\n indexReplacementMap[++captureIndex] = Number(handlerIndex);\n return \"$()\";\n }\n if (paramIndex !== void 0) {\n paramReplacementMap[Number(paramIndex)] = ++captureIndex;\n return \"\";\n }\n return \"\";\n });\n return [new RegExp(`^${regexp}`), indexReplacementMap, paramReplacementMap];\n }\n};\nexport {\n Trie\n};\n","// src/router/reg-exp-router/router.ts\nimport {\n MESSAGE_MATCHER_IS_ALREADY_BUILT,\n METHOD_NAME_ALL,\n UnsupportedPathError\n} from \"../../router.js\";\nimport { checkOptionalParameter } from \"../../utils/url.js\";\nimport { match, emptyParam } from \"./matcher.js\";\nimport { PATH_ERROR } from \"./node.js\";\nimport { Trie } from \"./trie.js\";\nvar nullMatcher = [/^$/, [], /* @__PURE__ */ Object.create(null)];\nvar wildcardRegExpCache = /* @__PURE__ */ Object.create(null);\nfunction buildWildcardRegExp(path) {\n return wildcardRegExpCache[path] ??= new RegExp(\n path === \"*\" ? \"\" : `^${path.replace(\n /\\/\\*$|([.\\\\+*[^\\]$()])/g,\n (_, metaChar) => metaChar ? `\\\\${metaChar}` : \"(?:|/.*)\"\n )}$`\n );\n}\nfunction clearWildcardRegExpCache() {\n wildcardRegExpCache = /* @__PURE__ */ Object.create(null);\n}\nfunction buildMatcherFromPreprocessedRoutes(routes) {\n const trie = new Trie();\n const handlerData = [];\n if (routes.length === 0) {\n return nullMatcher;\n }\n const routesWithStaticPathFlag = routes.map(\n (route) => [!/\\*|\\/:/.test(route[0]), ...route]\n ).sort(\n ([isStaticA, pathA], [isStaticB, pathB]) => isStaticA ? 1 : isStaticB ? -1 : pathA.length - pathB.length\n );\n const staticMap = /* @__PURE__ */ Object.create(null);\n for (let i = 0, j = -1, len = routesWithStaticPathFlag.length; i < len; i++) {\n const [pathErrorCheckOnly, path, handlers] = routesWithStaticPathFlag[i];\n if (pathErrorCheckOnly) {\n staticMap[path] = [handlers.map(([h]) => [h, /* @__PURE__ */ Object.create(null)]), emptyParam];\n } else {\n j++;\n }\n let paramAssoc;\n try {\n paramAssoc = trie.insert(path, j, pathErrorCheckOnly);\n } catch (e) {\n throw e === PATH_ERROR ? new UnsupportedPathError(path) : e;\n }\n if (pathErrorCheckOnly) {\n continue;\n }\n handlerData[j] = handlers.map(([h, paramCount]) => {\n const paramIndexMap = /* @__PURE__ */ Object.create(null);\n paramCount -= 1;\n for (; paramCount >= 0; paramCount--) {\n const [key, value] = paramAssoc[paramCount];\n paramIndexMap[key] = value;\n }\n return [h, paramIndexMap];\n });\n }\n const [regexp, indexReplacementMap, paramReplacementMap] = trie.buildRegExp();\n for (let i = 0, len = handlerData.length; i < len; i++) {\n for (let j = 0, len2 = handlerData[i].length; j < len2; j++) {\n const map = handlerData[i][j]?.[1];\n if (!map) {\n continue;\n }\n const keys = Object.keys(map);\n for (let k = 0, len3 = keys.length; k < len3; k++) {\n map[keys[k]] = paramReplacementMap[map[keys[k]]];\n }\n }\n }\n const handlerMap = [];\n for (const i in indexReplacementMap) {\n handlerMap[i] = handlerData[indexReplacementMap[i]];\n }\n return [regexp, handlerMap, staticMap];\n}\nfunction findMiddleware(middleware, path) {\n if (!middleware) {\n return void 0;\n }\n for (const k of Object.keys(middleware).sort((a, b) => b.length - a.length)) {\n if (buildWildcardRegExp(k).test(path)) {\n return [...middleware[k]];\n }\n }\n return void 0;\n}\nvar RegExpRouter = class {\n name = \"RegExpRouter\";\n #middleware;\n #routes;\n constructor() {\n this.#middleware = { [METHOD_NAME_ALL]: /* @__PURE__ */ Object.create(null) };\n this.#routes = { [METHOD_NAME_ALL]: /* @__PURE__ */ Object.create(null) };\n }\n add(method, path, handler) {\n const middleware = this.#middleware;\n const routes = this.#routes;\n if (!middleware || !routes) {\n throw new Error(MESSAGE_MATCHER_IS_ALREADY_BUILT);\n }\n if (!middleware[method]) {\n ;\n [middleware, routes].forEach((handlerMap) => {\n handlerMap[method] = /* @__PURE__ */ Object.create(null);\n Object.keys(handlerMap[METHOD_NAME_ALL]).forEach((p) => {\n handlerMap[method][p] = [...handlerMap[METHOD_NAME_ALL][p]];\n });\n });\n }\n if (path === \"/*\") {\n path = \"*\";\n }\n const paramCount = (path.match(/\\/:/g) || []).length;\n if (/\\*$/.test(path)) {\n const re = buildWildcardRegExp(path);\n if (method === METHOD_NAME_ALL) {\n Object.keys(middleware).forEach((m) => {\n middleware[m][path] ||= findMiddleware(middleware[m], path) || findMiddleware(middleware[METHOD_NAME_ALL], path) || [];\n });\n } else {\n middleware[method][path] ||= findMiddleware(middleware[method], path) || findMiddleware(middleware[METHOD_NAME_ALL], path) || [];\n }\n Object.keys(middleware).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n Object.keys(middleware[m]).forEach((p) => {\n re.test(p) && middleware[m][p].push([handler, paramCount]);\n });\n }\n });\n Object.keys(routes).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n Object.keys(routes[m]).forEach(\n (p) => re.test(p) && routes[m][p].push([handler, paramCount])\n );\n }\n });\n return;\n }\n const paths = checkOptionalParameter(path) || [path];\n for (let i = 0, len = paths.length; i < len; i++) {\n const path2 = paths[i];\n Object.keys(routes).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n routes[m][path2] ||= [\n ...findMiddleware(middleware[m], path2) || findMiddleware(middleware[METHOD_NAME_ALL], path2) || []\n ];\n routes[m][path2].push([handler, paramCount - len + i + 1]);\n }\n });\n }\n }\n match = match;\n buildAllMatchers() {\n const matchers = /* @__PURE__ */ Object.create(null);\n Object.keys(this.#routes).concat(Object.keys(this.#middleware)).forEach((method) => {\n matchers[method] ||= this.#buildMatcher(method);\n });\n this.#middleware = this.#routes = void 0;\n clearWildcardRegExpCache();\n return matchers;\n }\n #buildMatcher(method) {\n const routes = [];\n let hasOwnRoute = method === METHOD_NAME_ALL;\n [this.#middleware, this.#routes].forEach((r) => {\n const ownRoute = r[method] ? Object.keys(r[method]).map((path) => [path, r[method][path]]) : [];\n if (ownRoute.length !== 0) {\n hasOwnRoute ||= true;\n routes.push(...ownRoute);\n } else if (method !== METHOD_NAME_ALL) {\n routes.push(\n ...Object.keys(r[METHOD_NAME_ALL]).map((path) => [path, r[METHOD_NAME_ALL][path]])\n );\n }\n });\n if (!hasOwnRoute) {\n return null;\n } else {\n return buildMatcherFromPreprocessedRoutes(routes);\n }\n }\n};\nexport {\n RegExpRouter\n};\n","// src/router/reg-exp-router/prepared-router.ts\nimport { METHOD_NAME_ALL } from \"../../router.js\";\nimport { match, emptyParam } from \"./matcher.js\";\nimport { RegExpRouter } from \"./router.js\";\nvar PreparedRegExpRouter = class {\n name = \"PreparedRegExpRouter\";\n #matchers;\n #relocateMap;\n constructor(matchers, relocateMap) {\n this.#matchers = matchers;\n this.#relocateMap = relocateMap;\n }\n #addWildcard(method, handlerData) {\n const matcher = this.#matchers[method];\n matcher[1].forEach((list) => list && list.push(handlerData));\n Object.values(matcher[2]).forEach((list) => list[0].push(handlerData));\n }\n #addPath(method, path, handler, indexes, map) {\n const matcher = this.#matchers[method];\n if (!map) {\n matcher[2][path][0].push([handler, {}]);\n } else {\n indexes.forEach((index) => {\n if (typeof index === \"number\") {\n matcher[1][index].push([handler, map]);\n } else {\n ;\n matcher[2][index || path][0].push([handler, map]);\n }\n });\n }\n }\n add(method, path, handler) {\n if (!this.#matchers[method]) {\n const all = this.#matchers[METHOD_NAME_ALL];\n const staticMap = {};\n for (const key in all[2]) {\n staticMap[key] = [all[2][key][0].slice(), emptyParam];\n }\n this.#matchers[method] = [\n all[0],\n all[1].map((list) => Array.isArray(list) ? list.slice() : 0),\n staticMap\n ];\n }\n if (path === \"/*\" || path === \"*\") {\n const handlerData = [handler, {}];\n if (method === METHOD_NAME_ALL) {\n for (const m in this.#matchers) {\n this.#addWildcard(m, handlerData);\n }\n } else {\n this.#addWildcard(method, handlerData);\n }\n return;\n }\n const data = this.#relocateMap[path];\n if (!data) {\n throw new Error(`Path ${path} is not registered`);\n }\n for (const [indexes, map] of data) {\n if (method === METHOD_NAME_ALL) {\n for (const m in this.#matchers) {\n this.#addPath(m, path, handler, indexes, map);\n }\n } else {\n this.#addPath(method, path, handler, indexes, map);\n }\n }\n }\n buildAllMatchers() {\n return this.#matchers;\n }\n match = match;\n};\nvar buildInitParams = ({ paths }) => {\n const RegExpRouterWithMatcherExport = class extends RegExpRouter {\n buildAndExportAllMatchers() {\n return this.buildAllMatchers();\n }\n };\n const router = new RegExpRouterWithMatcherExport();\n for (const path of paths) {\n router.add(METHOD_NAME_ALL, path, path);\n }\n const matchers = router.buildAndExportAllMatchers();\n const all = matchers[METHOD_NAME_ALL];\n const relocateMap = {};\n for (const path of paths) {\n if (path === \"/*\" || path === \"*\") {\n continue;\n }\n all[1].forEach((list, i) => {\n list.forEach(([p, map]) => {\n if (p === path) {\n if (relocateMap[path]) {\n relocateMap[path][0][1] = {\n ...relocateMap[path][0][1],\n ...map\n };\n } else {\n relocateMap[path] = [[[], map]];\n }\n if (relocateMap[path][0][0].findIndex((j) => j === i) === -1) {\n relocateMap[path][0][0].push(i);\n }\n }\n });\n });\n for (const path2 in all[2]) {\n all[2][path2][0].forEach(([p]) => {\n if (p === path) {\n relocateMap[path] ||= [[[]]];\n const value = path2 === path ? \"\" : path2;\n if (relocateMap[path][0][0].findIndex((v) => v === value) === -1) {\n relocateMap[path][0][0].push(value);\n }\n }\n });\n }\n }\n for (let i = 0, len = all[1].length; i < len; i++) {\n all[1][i] = all[1][i] ? [] : 0;\n }\n for (const path in all[2]) {\n all[2][path][0] = [];\n }\n return [matchers, relocateMap];\n};\nvar serializeInitParams = ([matchers, relocateMap]) => {\n const matchersStr = JSON.stringify(\n matchers,\n (_, value) => value instanceof RegExp ? `##${value.toString()}##` : value\n ).replace(/\"##(.+?)##\"/g, (_, str) => str.replace(/\\\\\\\\/g, \"\\\\\"));\n const relocateMapStr = JSON.stringify(relocateMap);\n return `[${matchersStr},${relocateMapStr}]`;\n};\nexport {\n PreparedRegExpRouter,\n buildInitParams,\n serializeInitParams\n};\n","// src/router/reg-exp-router/index.ts\nimport { RegExpRouter } from \"./router.js\";\nimport { PreparedRegExpRouter, buildInitParams, serializeInitParams } from \"./prepared-router.js\";\nexport {\n PreparedRegExpRouter,\n RegExpRouter,\n buildInitParams,\n serializeInitParams\n};\n","// src/router/smart-router/router.ts\nimport { MESSAGE_MATCHER_IS_ALREADY_BUILT, UnsupportedPathError } from \"../../router.js\";\nvar SmartRouter = class {\n name = \"SmartRouter\";\n #routers = [];\n #routes = [];\n constructor(init) {\n this.#routers = init.routers;\n }\n add(method, path, handler) {\n if (!this.#routes) {\n throw new Error(MESSAGE_MATCHER_IS_ALREADY_BUILT);\n }\n this.#routes.push([method, path, handler]);\n }\n match(method, path) {\n if (!this.#routes) {\n throw new Error(\"Fatal error\");\n }\n const routers = this.#routers;\n const routes = this.#routes;\n const len = routers.length;\n let i = 0;\n let res;\n for (; i < len; i++) {\n const router = routers[i];\n try {\n for (let i2 = 0, len2 = routes.length; i2 < len2; i2++) {\n router.add(...routes[i2]);\n }\n res = router.match(method, path);\n } catch (e) {\n if (e instanceof UnsupportedPathError) {\n continue;\n }\n throw e;\n }\n this.match = router.match.bind(router);\n this.#routers = [router];\n this.#routes = void 0;\n break;\n }\n if (i === len) {\n throw new Error(\"Fatal error\");\n }\n this.name = `SmartRouter + ${this.activeRouter.name}`;\n return res;\n }\n get activeRouter() {\n if (this.#routes || this.#routers.length !== 1) {\n throw new Error(\"No active router has been determined yet.\");\n }\n return this.#routers[0];\n }\n};\nexport {\n SmartRouter\n};\n","// src/router/smart-router/index.ts\nimport { SmartRouter } from \"./router.js\";\nexport {\n SmartRouter\n};\n","// src/router/trie-router/node.ts\nimport { METHOD_NAME_ALL } from \"../../router.js\";\nimport { getPattern, splitPath, splitRoutingPath } from \"../../utils/url.js\";\nvar emptyParams = /* @__PURE__ */ Object.create(null);\nvar hasChildren = (children) => {\n for (const _ in children) {\n return true;\n }\n return false;\n};\nvar Node = class _Node {\n #methods;\n #children;\n #patterns;\n #order = 0;\n #params = emptyParams;\n constructor(method, handler, children) {\n this.#children = children || /* @__PURE__ */ Object.create(null);\n this.#methods = [];\n if (method && handler) {\n const m = /* @__PURE__ */ Object.create(null);\n m[method] = { handler, possibleKeys: [], score: 0 };\n this.#methods = [m];\n }\n this.#patterns = [];\n }\n insert(method, path, handler) {\n this.#order = ++this.#order;\n let curNode = this;\n const parts = splitRoutingPath(path);\n const possibleKeys = [];\n for (let i = 0, len = parts.length; i < len; i++) {\n const p = parts[i];\n const nextP = parts[i + 1];\n const pattern = getPattern(p, nextP);\n const key = Array.isArray(pattern) ? pattern[0] : p;\n if (key in curNode.#children) {\n curNode = curNode.#children[key];\n if (pattern) {\n possibleKeys.push(pattern[1]);\n }\n continue;\n }\n curNode.#children[key] = new _Node();\n if (pattern) {\n curNode.#patterns.push(pattern);\n possibleKeys.push(pattern[1]);\n }\n curNode = curNode.#children[key];\n }\n curNode.#methods.push({\n [method]: {\n handler,\n possibleKeys: possibleKeys.filter((v, i, a) => a.indexOf(v) === i),\n score: this.#order\n }\n });\n return curNode;\n }\n #pushHandlerSets(handlerSets, node, method, nodeParams, params) {\n for (let i = 0, len = node.#methods.length; i < len; i++) {\n const m = node.#methods[i];\n const handlerSet = m[method] || m[METHOD_NAME_ALL];\n const processedSet = {};\n if (handlerSet !== void 0) {\n handlerSet.params = /* @__PURE__ */ Object.create(null);\n handlerSets.push(handlerSet);\n if (nodeParams !== emptyParams || params && params !== emptyParams) {\n for (let i2 = 0, len2 = handlerSet.possibleKeys.length; i2 < len2; i2++) {\n const key = handlerSet.possibleKeys[i2];\n const processed = processedSet[handlerSet.score];\n handlerSet.params[key] = params?.[key] && !processed ? params[key] : nodeParams[key] ?? params?.[key];\n processedSet[handlerSet.score] = true;\n }\n }\n }\n }\n }\n search(method, path) {\n const handlerSets = [];\n this.#params = emptyParams;\n const curNode = this;\n let curNodes = [curNode];\n const parts = splitPath(path);\n const curNodesQueue = [];\n const len = parts.length;\n let partOffsets = null;\n for (let i = 0; i < len; i++) {\n const part = parts[i];\n const isLast = i === len - 1;\n const tempNodes = [];\n for (let j = 0, len2 = curNodes.length; j < len2; j++) {\n const node = curNodes[j];\n const nextNode = node.#children[part];\n if (nextNode) {\n nextNode.#params = node.#params;\n if (isLast) {\n if (nextNode.#children[\"*\"]) {\n this.#pushHandlerSets(handlerSets, nextNode.#children[\"*\"], method, node.#params);\n }\n this.#pushHandlerSets(handlerSets, nextNode, method, node.#params);\n } else {\n tempNodes.push(nextNode);\n }\n }\n for (let k = 0, len3 = node.#patterns.length; k < len3; k++) {\n const pattern = node.#patterns[k];\n const params = node.#params === emptyParams ? {} : { ...node.#params };\n if (pattern === \"*\") {\n const astNode = node.#children[\"*\"];\n if (astNode) {\n this.#pushHandlerSets(handlerSets, astNode, method, node.#params);\n astNode.#params = params;\n tempNodes.push(astNode);\n }\n continue;\n }\n const [key, name, matcher] = pattern;\n if (!part && !(matcher instanceof RegExp)) {\n continue;\n }\n const child = node.#children[key];\n if (matcher instanceof RegExp) {\n if (partOffsets === null) {\n partOffsets = new Array(len);\n let offset = path[0] === \"/\" ? 1 : 0;\n for (let p = 0; p < len; p++) {\n partOffsets[p] = offset;\n offset += parts[p].length + 1;\n }\n }\n const restPathString = path.substring(partOffsets[i]);\n const m = matcher.exec(restPathString);\n if (m) {\n params[name] = m[0];\n this.#pushHandlerSets(handlerSets, child, method, node.#params, params);\n if (hasChildren(child.#children)) {\n child.#params = params;\n const componentCount = m[0].match(/\\//)?.length ?? 0;\n const targetCurNodes = curNodesQueue[componentCount] ||= [];\n targetCurNodes.push(child);\n }\n continue;\n }\n }\n if (matcher === true || matcher.test(part)) {\n params[name] = part;\n if (isLast) {\n this.#pushHandlerSets(handlerSets, child, method, params, node.#params);\n if (child.#children[\"*\"]) {\n this.#pushHandlerSets(\n handlerSets,\n child.#children[\"*\"],\n method,\n params,\n node.#params\n );\n }\n } else {\n child.#params = params;\n tempNodes.push(child);\n }\n }\n }\n }\n const shifted = curNodesQueue.shift();\n curNodes = shifted ? tempNodes.concat(shifted) : tempNodes;\n }\n if (handlerSets.length > 1) {\n handlerSets.sort((a, b) => {\n return a.score - b.score;\n });\n }\n return [handlerSets.map(({ handler, params }) => [handler, params])];\n }\n};\nexport {\n Node\n};\n","// src/router/trie-router/router.ts\nimport { checkOptionalParameter } from \"../../utils/url.js\";\nimport { Node } from \"./node.js\";\nvar TrieRouter = class {\n name = \"TrieRouter\";\n #node;\n constructor() {\n this.#node = new Node();\n }\n add(method, path, handler) {\n const results = checkOptionalParameter(path);\n if (results) {\n for (let i = 0, len = results.length; i < len; i++) {\n this.#node.insert(method, results[i], handler);\n }\n return;\n }\n this.#node.insert(method, path, handler);\n }\n match(method, path) {\n return this.#node.search(method, path);\n }\n};\nexport {\n TrieRouter\n};\n","// src/router/trie-router/index.ts\nimport { TrieRouter } from \"./router.js\";\nexport {\n TrieRouter\n};\n","// src/hono.ts\nimport { HonoBase } from \"./hono-base.js\";\nimport { RegExpRouter } from \"./router/reg-exp-router/index.js\";\nimport { SmartRouter } from \"./router/smart-router/index.js\";\nimport { TrieRouter } from \"./router/trie-router/index.js\";\nvar Hono = class extends HonoBase {\n /**\n * Creates an instance of the Hono class.\n *\n * @param options - Optional configuration options for the Hono instance.\n */\n constructor(options = {}) {\n super(options);\n this.router = options.router ?? new SmartRouter({\n routers: [new RegExpRouter(), new TrieRouter()]\n });\n }\n};\nexport {\n Hono\n};\n","// src/index.ts\nimport { Hono } from \"./hono.js\";\nimport { Context } from \"./context.js\";\nexport {\n Context,\n Hono\n};\n","// src/middleware/cors/index.ts\nvar cors = (options) => {\n const opts = {\n origin: \"*\",\n allowMethods: [\"GET\", \"HEAD\", \"PUT\", \"POST\", \"DELETE\", \"PATCH\"],\n allowHeaders: [],\n exposeHeaders: [],\n ...options\n };\n const findAllowOrigin = ((optsOrigin) => {\n if (typeof optsOrigin === \"string\") {\n if (optsOrigin === \"*\") {\n if (opts.credentials) {\n return (origin) => origin || null;\n }\n return () => optsOrigin;\n } else {\n return (origin) => optsOrigin === origin ? origin : null;\n }\n } else if (typeof optsOrigin === \"function\") {\n return optsOrigin;\n } else {\n return (origin) => optsOrigin.includes(origin) ? origin : null;\n }\n })(opts.origin);\n const findAllowMethods = ((optsAllowMethods) => {\n if (typeof optsAllowMethods === \"function\") {\n return optsAllowMethods;\n } else if (Array.isArray(optsAllowMethods)) {\n return () => optsAllowMethods;\n } else {\n return () => [];\n }\n })(opts.allowMethods);\n return async function cors2(c, next) {\n function set(key, value) {\n c.res.headers.set(key, value);\n }\n const allowOrigin = await findAllowOrigin(c.req.header(\"origin\") || \"\", c);\n if (allowOrigin) {\n set(\"Access-Control-Allow-Origin\", allowOrigin);\n }\n if (opts.credentials) {\n set(\"Access-Control-Allow-Credentials\", \"true\");\n }\n if (opts.exposeHeaders?.length) {\n set(\"Access-Control-Expose-Headers\", opts.exposeHeaders.join(\",\"));\n }\n if (c.req.method === \"OPTIONS\") {\n if (opts.origin !== \"*\" || opts.credentials) {\n set(\"Vary\", \"Origin\");\n }\n if (opts.maxAge != null) {\n set(\"Access-Control-Max-Age\", opts.maxAge.toString());\n }\n const allowMethods = await findAllowMethods(c.req.header(\"origin\") || \"\", c);\n if (allowMethods.length) {\n set(\"Access-Control-Allow-Methods\", allowMethods.join(\",\"));\n }\n let headers = opts.allowHeaders;\n if (!headers?.length) {\n const requestHeaders = c.req.header(\"Access-Control-Request-Headers\");\n if (requestHeaders) {\n headers = requestHeaders.split(/\\s*,\\s*/);\n }\n }\n if (headers?.length) {\n set(\"Access-Control-Allow-Headers\", headers.join(\",\"));\n c.res.headers.append(\"Vary\", \"Access-Control-Request-Headers\");\n }\n c.res.headers.delete(\"Content-Length\");\n c.res.headers.delete(\"Content-Type\");\n return new Response(null, {\n headers: c.res.headers,\n status: 204,\n statusText: \"No Content\"\n });\n }\n await next();\n if (opts.origin !== \"*\" || opts.credentials) {\n c.header(\"Vary\", \"Origin\", { append: true });\n }\n };\n};\nexport {\n cors\n};\n","// src/server.ts\nimport { createServer as createServerHTTP } from \"http\";\n\n// src/listener.ts\nimport { Http2ServerRequest as Http2ServerRequest2, constants as h2constants } from \"http2\";\n\n// src/request.ts\nimport { Http2ServerRequest } from \"http2\";\nimport { Readable } from \"stream\";\nvar RequestError = class extends Error {\n constructor(message, options) {\n super(message, options);\n this.name = \"RequestError\";\n }\n};\nvar toRequestError = (e) => {\n if (e instanceof RequestError) {\n return e;\n }\n return new RequestError(e.message, { cause: e });\n};\nvar GlobalRequest = global.Request;\nvar Request = class extends GlobalRequest {\n constructor(input, options) {\n if (typeof input === \"object\" && getRequestCache in input) {\n input = input[getRequestCache]();\n }\n if (typeof options?.body?.getReader !== \"undefined\") {\n ;\n options.duplex ??= \"half\";\n }\n super(input, options);\n }\n};\nvar newHeadersFromIncoming = (incoming) => {\n const headerRecord = [];\n const rawHeaders = incoming.rawHeaders;\n for (let i = 0; i < rawHeaders.length; i += 2) {\n const { [i]: key, [i + 1]: value } = rawHeaders;\n if (key.charCodeAt(0) !== /*:*/\n 58) {\n headerRecord.push([key, value]);\n }\n }\n return new Headers(headerRecord);\n};\nvar wrapBodyStream = Symbol(\"wrapBodyStream\");\nvar newRequestFromIncoming = (method, url, headers, incoming, abortController) => {\n const init = {\n method,\n headers,\n signal: abortController.signal\n };\n if (method === \"TRACE\") {\n init.method = \"GET\";\n const req = new Request(url, init);\n Object.defineProperty(req, \"method\", {\n get() {\n return \"TRACE\";\n }\n });\n return req;\n }\n if (!(method === \"GET\" || method === \"HEAD\")) {\n if (\"rawBody\" in incoming && incoming.rawBody instanceof Buffer) {\n init.body = new ReadableStream({\n start(controller) {\n controller.enqueue(incoming.rawBody);\n controller.close();\n }\n });\n } else if (incoming[wrapBodyStream]) {\n let reader;\n init.body = new ReadableStream({\n async pull(controller) {\n try {\n reader ||= Readable.toWeb(incoming).getReader();\n const { done, value } = await reader.read();\n if (done) {\n controller.close();\n } else {\n controller.enqueue(value);\n }\n } catch (error) {\n controller.error(error);\n }\n }\n });\n } else {\n init.body = Readable.toWeb(incoming);\n }\n }\n return new Request(url, init);\n};\nvar getRequestCache = Symbol(\"getRequestCache\");\nvar requestCache = Symbol(\"requestCache\");\nvar incomingKey = Symbol(\"incomingKey\");\nvar urlKey = Symbol(\"urlKey\");\nvar headersKey = Symbol(\"headersKey\");\nvar abortControllerKey = Symbol(\"abortControllerKey\");\nvar getAbortController = Symbol(\"getAbortController\");\nvar requestPrototype = {\n get method() {\n return this[incomingKey].method || \"GET\";\n },\n get url() {\n return this[urlKey];\n },\n get headers() {\n return this[headersKey] ||= newHeadersFromIncoming(this[incomingKey]);\n },\n [getAbortController]() {\n this[getRequestCache]();\n return this[abortControllerKey];\n },\n [getRequestCache]() {\n this[abortControllerKey] ||= new AbortController();\n return this[requestCache] ||= newRequestFromIncoming(\n this.method,\n this[urlKey],\n this.headers,\n this[incomingKey],\n this[abortControllerKey]\n );\n }\n};\n[\n \"body\",\n \"bodyUsed\",\n \"cache\",\n \"credentials\",\n \"destination\",\n \"integrity\",\n \"mode\",\n \"redirect\",\n \"referrer\",\n \"referrerPolicy\",\n \"signal\",\n \"keepalive\"\n].forEach((k) => {\n Object.defineProperty(requestPrototype, k, {\n get() {\n return this[getRequestCache]()[k];\n }\n });\n});\n[\"arrayBuffer\", \"blob\", \"clone\", \"formData\", \"json\", \"text\"].forEach((k) => {\n Object.defineProperty(requestPrototype, k, {\n value: function() {\n return this[getRequestCache]()[k]();\n }\n });\n});\nObject.defineProperty(requestPrototype, Symbol.for(\"nodejs.util.inspect.custom\"), {\n value: function(depth, options, inspectFn) {\n const props = {\n method: this.method,\n url: this.url,\n headers: this.headers,\n nativeRequest: this[requestCache]\n };\n return `Request (lightweight) ${inspectFn(props, { ...options, depth: depth == null ? null : depth - 1 })}`;\n }\n});\nObject.setPrototypeOf(requestPrototype, Request.prototype);\nvar newRequest = (incoming, defaultHostname) => {\n const req = Object.create(requestPrototype);\n req[incomingKey] = incoming;\n const incomingUrl = incoming.url || \"\";\n if (incomingUrl[0] !== \"/\" && // short-circuit for performance. most requests are relative URL.\n (incomingUrl.startsWith(\"http://\") || incomingUrl.startsWith(\"https://\"))) {\n if (incoming instanceof Http2ServerRequest) {\n throw new RequestError(\"Absolute URL for :path is not allowed in HTTP/2\");\n }\n try {\n const url2 = new URL(incomingUrl);\n req[urlKey] = url2.href;\n } catch (e) {\n throw new RequestError(\"Invalid absolute URL\", { cause: e });\n }\n return req;\n }\n const host = (incoming instanceof Http2ServerRequest ? incoming.authority : incoming.headers.host) || defaultHostname;\n if (!host) {\n throw new RequestError(\"Missing host header\");\n }\n let scheme;\n if (incoming instanceof Http2ServerRequest) {\n scheme = incoming.scheme;\n if (!(scheme === \"http\" || scheme === \"https\")) {\n throw new RequestError(\"Unsupported scheme\");\n }\n } else {\n scheme = incoming.socket && incoming.socket.encrypted ? \"https\" : \"http\";\n }\n const url = new URL(`${scheme}://${host}${incomingUrl}`);\n if (url.hostname.length !== host.length && url.hostname !== host.replace(/:\\d+$/, \"\")) {\n throw new RequestError(\"Invalid host header\");\n }\n req[urlKey] = url.href;\n return req;\n};\n\n// src/response.ts\nvar responseCache = Symbol(\"responseCache\");\nvar getResponseCache = Symbol(\"getResponseCache\");\nvar cacheKey = Symbol(\"cache\");\nvar GlobalResponse = global.Response;\nvar Response2 = class _Response {\n #body;\n #init;\n [getResponseCache]() {\n delete this[cacheKey];\n return this[responseCache] ||= new GlobalResponse(this.#body, this.#init);\n }\n constructor(body, init) {\n let headers;\n this.#body = body;\n if (init instanceof _Response) {\n const cachedGlobalResponse = init[responseCache];\n if (cachedGlobalResponse) {\n this.#init = cachedGlobalResponse;\n this[getResponseCache]();\n return;\n } else {\n this.#init = init.#init;\n headers = new Headers(init.#init.headers);\n }\n } else {\n this.#init = init;\n }\n if (typeof body === \"string\" || typeof body?.getReader !== \"undefined\" || body instanceof Blob || body instanceof Uint8Array) {\n ;\n this[cacheKey] = [init?.status || 200, body, headers || init?.headers];\n }\n }\n get headers() {\n const cache = this[cacheKey];\n if (cache) {\n if (!(cache[2] instanceof Headers)) {\n cache[2] = new Headers(\n cache[2] || { \"content-type\": \"text/plain; charset=UTF-8\" }\n );\n }\n return cache[2];\n }\n return this[getResponseCache]().headers;\n }\n get status() {\n return this[cacheKey]?.[0] ?? this[getResponseCache]().status;\n }\n get ok() {\n const status = this.status;\n return status >= 200 && status < 300;\n }\n};\n[\"body\", \"bodyUsed\", \"redirected\", \"statusText\", \"trailers\", \"type\", \"url\"].forEach((k) => {\n Object.defineProperty(Response2.prototype, k, {\n get() {\n return this[getResponseCache]()[k];\n }\n });\n});\n[\"arrayBuffer\", \"blob\", \"clone\", \"formData\", \"json\", \"text\"].forEach((k) => {\n Object.defineProperty(Response2.prototype, k, {\n value: function() {\n return this[getResponseCache]()[k]();\n }\n });\n});\nObject.defineProperty(Response2.prototype, Symbol.for(\"nodejs.util.inspect.custom\"), {\n value: function(depth, options, inspectFn) {\n const props = {\n status: this.status,\n headers: this.headers,\n ok: this.ok,\n nativeResponse: this[responseCache]\n };\n return `Response (lightweight) ${inspectFn(props, { ...options, depth: depth == null ? null : depth - 1 })}`;\n }\n});\nObject.setPrototypeOf(Response2, GlobalResponse);\nObject.setPrototypeOf(Response2.prototype, GlobalResponse.prototype);\n\n// src/utils.ts\nasync function readWithoutBlocking(readPromise) {\n return Promise.race([readPromise, Promise.resolve().then(() => Promise.resolve(void 0))]);\n}\nfunction writeFromReadableStreamDefaultReader(reader, writable, currentReadPromise) {\n const cancel = (error) => {\n reader.cancel(error).catch(() => {\n });\n };\n writable.on(\"close\", cancel);\n writable.on(\"error\", cancel);\n (currentReadPromise ?? reader.read()).then(flow, handleStreamError);\n return reader.closed.finally(() => {\n writable.off(\"close\", cancel);\n writable.off(\"error\", cancel);\n });\n function handleStreamError(error) {\n if (error) {\n writable.destroy(error);\n }\n }\n function onDrain() {\n reader.read().then(flow, handleStreamError);\n }\n function flow({ done, value }) {\n try {\n if (done) {\n writable.end();\n } else if (!writable.write(value)) {\n writable.once(\"drain\", onDrain);\n } else {\n return reader.read().then(flow, handleStreamError);\n }\n } catch (e) {\n handleStreamError(e);\n }\n }\n}\nfunction writeFromReadableStream(stream, writable) {\n if (stream.locked) {\n throw new TypeError(\"ReadableStream is locked.\");\n } else if (writable.destroyed) {\n return;\n }\n return writeFromReadableStreamDefaultReader(stream.getReader(), writable);\n}\nvar buildOutgoingHttpHeaders = (headers) => {\n const res = {};\n if (!(headers instanceof Headers)) {\n headers = new Headers(headers ?? void 0);\n }\n const cookies = [];\n for (const [k, v] of headers) {\n if (k === \"set-cookie\") {\n cookies.push(v);\n } else {\n res[k] = v;\n }\n }\n if (cookies.length > 0) {\n res[\"set-cookie\"] = cookies;\n }\n res[\"content-type\"] ??= \"text/plain; charset=UTF-8\";\n return res;\n};\n\n// src/utils/response/constants.ts\nvar X_ALREADY_SENT = \"x-hono-already-sent\";\n\n// src/globals.ts\nimport crypto from \"crypto\";\nif (typeof global.crypto === \"undefined\") {\n global.crypto = crypto;\n}\n\n// src/listener.ts\nvar outgoingEnded = Symbol(\"outgoingEnded\");\nvar incomingDraining = Symbol(\"incomingDraining\");\nvar DRAIN_TIMEOUT_MS = 500;\nvar MAX_DRAIN_BYTES = 64 * 1024 * 1024;\nvar drainIncoming = (incoming) => {\n const incomingWithDrainState = incoming;\n if (incoming.destroyed || incomingWithDrainState[incomingDraining]) {\n return;\n }\n incomingWithDrainState[incomingDraining] = true;\n if (incoming instanceof Http2ServerRequest2) {\n try {\n ;\n incoming.stream?.close?.(h2constants.NGHTTP2_NO_ERROR);\n } catch {\n }\n return;\n }\n let bytesRead = 0;\n const cleanup = () => {\n clearTimeout(timer);\n incoming.off(\"data\", onData);\n incoming.off(\"end\", cleanup);\n incoming.off(\"error\", cleanup);\n };\n const forceClose = () => {\n cleanup();\n const socket = incoming.socket;\n if (socket && !socket.destroyed) {\n socket.destroySoon();\n }\n };\n const timer = setTimeout(forceClose, DRAIN_TIMEOUT_MS);\n timer.unref?.();\n const onData = (chunk) => {\n bytesRead += chunk.length;\n if (bytesRead > MAX_DRAIN_BYTES) {\n forceClose();\n }\n };\n incoming.on(\"data\", onData);\n incoming.on(\"end\", cleanup);\n incoming.on(\"error\", cleanup);\n incoming.resume();\n};\nvar handleRequestError = () => new Response(null, {\n status: 400\n});\nvar handleFetchError = (e) => new Response(null, {\n status: e instanceof Error && (e.name === \"TimeoutError\" || e.constructor.name === \"TimeoutError\") ? 504 : 500\n});\nvar handleResponseError = (e, outgoing) => {\n const err = e instanceof Error ? e : new Error(\"unknown error\", { cause: e });\n if (err.code === \"ERR_STREAM_PREMATURE_CLOSE\") {\n console.info(\"The user aborted a request.\");\n } else {\n console.error(e);\n if (!outgoing.headersSent) {\n outgoing.writeHead(500, { \"Content-Type\": \"text/plain\" });\n }\n outgoing.end(`Error: ${err.message}`);\n outgoing.destroy(err);\n }\n};\nvar flushHeaders = (outgoing) => {\n if (\"flushHeaders\" in outgoing && outgoing.writable) {\n outgoing.flushHeaders();\n }\n};\nvar responseViaCache = async (res, outgoing) => {\n let [status, body, header] = res[cacheKey];\n let hasContentLength = false;\n if (!header) {\n header = { \"content-type\": \"text/plain; charset=UTF-8\" };\n } else if (header instanceof Headers) {\n hasContentLength = header.has(\"content-length\");\n header = buildOutgoingHttpHeaders(header);\n } else if (Array.isArray(header)) {\n const headerObj = new Headers(header);\n hasContentLength = headerObj.has(\"content-length\");\n header = buildOutgoingHttpHeaders(headerObj);\n } else {\n for (const key in header) {\n if (key.length === 14 && key.toLowerCase() === \"content-length\") {\n hasContentLength = true;\n break;\n }\n }\n }\n if (!hasContentLength) {\n if (typeof body === \"string\") {\n header[\"Content-Length\"] = Buffer.byteLength(body);\n } else if (body instanceof Uint8Array) {\n header[\"Content-Length\"] = body.byteLength;\n } else if (body instanceof Blob) {\n header[\"Content-Length\"] = body.size;\n }\n }\n outgoing.writeHead(status, header);\n if (typeof body === \"string\" || body instanceof Uint8Array) {\n outgoing.end(body);\n } else if (body instanceof Blob) {\n outgoing.end(new Uint8Array(await body.arrayBuffer()));\n } else {\n flushHeaders(outgoing);\n await writeFromReadableStream(body, outgoing)?.catch(\n (e) => handleResponseError(e, outgoing)\n );\n }\n ;\n outgoing[outgoingEnded]?.();\n};\nvar isPromise = (res) => typeof res.then === \"function\";\nvar responseViaResponseObject = async (res, outgoing, options = {}) => {\n if (isPromise(res)) {\n if (options.errorHandler) {\n try {\n res = await res;\n } catch (err) {\n const errRes = await options.errorHandler(err);\n if (!errRes) {\n return;\n }\n res = errRes;\n }\n } else {\n res = await res.catch(handleFetchError);\n }\n }\n if (cacheKey in res) {\n return responseViaCache(res, outgoing);\n }\n const resHeaderRecord = buildOutgoingHttpHeaders(res.headers);\n if (res.body) {\n const reader = res.body.getReader();\n const values = [];\n let done = false;\n let currentReadPromise = void 0;\n if (resHeaderRecord[\"transfer-encoding\"] !== \"chunked\") {\n let maxReadCount = 2;\n for (let i = 0; i < maxReadCount; i++) {\n currentReadPromise ||= reader.read();\n const chunk = await readWithoutBlocking(currentReadPromise).catch((e) => {\n console.error(e);\n done = true;\n });\n if (!chunk) {\n if (i === 1) {\n await new Promise((resolve) => setTimeout(resolve));\n maxReadCount = 3;\n continue;\n }\n break;\n }\n currentReadPromise = void 0;\n if (chunk.value) {\n values.push(chunk.value);\n }\n if (chunk.done) {\n done = true;\n break;\n }\n }\n if (done && !(\"content-length\" in resHeaderRecord)) {\n resHeaderRecord[\"content-length\"] = values.reduce((acc, value) => acc + value.length, 0);\n }\n }\n outgoing.writeHead(res.status, resHeaderRecord);\n values.forEach((value) => {\n ;\n outgoing.write(value);\n });\n if (done) {\n outgoing.end();\n } else {\n if (values.length === 0) {\n flushHeaders(outgoing);\n }\n await writeFromReadableStreamDefaultReader(reader, outgoing, currentReadPromise);\n }\n } else if (resHeaderRecord[X_ALREADY_SENT]) {\n } else {\n outgoing.writeHead(res.status, resHeaderRecord);\n outgoing.end();\n }\n ;\n outgoing[outgoingEnded]?.();\n};\nvar getRequestListener = (fetchCallback, options = {}) => {\n const autoCleanupIncoming = options.autoCleanupIncoming ?? true;\n if (options.overrideGlobalObjects !== false && global.Request !== Request) {\n Object.defineProperty(global, \"Request\", {\n value: Request\n });\n Object.defineProperty(global, \"Response\", {\n value: Response2\n });\n }\n return async (incoming, outgoing) => {\n let res, req;\n try {\n req = newRequest(incoming, options.hostname);\n let incomingEnded = !autoCleanupIncoming || incoming.method === \"GET\" || incoming.method === \"HEAD\";\n if (!incomingEnded) {\n ;\n incoming[wrapBodyStream] = true;\n incoming.on(\"end\", () => {\n incomingEnded = true;\n });\n if (incoming instanceof Http2ServerRequest2) {\n ;\n outgoing[outgoingEnded] = () => {\n if (!incomingEnded) {\n setTimeout(() => {\n if (!incomingEnded) {\n setTimeout(() => {\n drainIncoming(incoming);\n });\n }\n });\n }\n };\n }\n outgoing.on(\"finish\", () => {\n if (!incomingEnded) {\n drainIncoming(incoming);\n }\n });\n }\n outgoing.on(\"close\", () => {\n const abortController = req[abortControllerKey];\n if (abortController) {\n if (incoming.errored) {\n req[abortControllerKey].abort(incoming.errored.toString());\n } else if (!outgoing.writableFinished) {\n req[abortControllerKey].abort(\"Client connection prematurely closed.\");\n }\n }\n if (!incomingEnded) {\n setTimeout(() => {\n if (!incomingEnded) {\n setTimeout(() => {\n drainIncoming(incoming);\n });\n }\n });\n }\n });\n res = fetchCallback(req, { incoming, outgoing });\n if (cacheKey in res) {\n return responseViaCache(res, outgoing);\n }\n } catch (e) {\n if (!res) {\n if (options.errorHandler) {\n res = await options.errorHandler(req ? e : toRequestError(e));\n if (!res) {\n return;\n }\n } else if (!req) {\n res = handleRequestError();\n } else {\n res = handleFetchError(e);\n }\n } else {\n return handleResponseError(e, outgoing);\n }\n }\n try {\n return await responseViaResponseObject(res, outgoing, options);\n } catch (e) {\n return handleResponseError(e, outgoing);\n }\n };\n};\n\n// src/server.ts\nvar createAdaptorServer = (options) => {\n const fetchCallback = options.fetch;\n const requestListener = getRequestListener(fetchCallback, {\n hostname: options.hostname,\n overrideGlobalObjects: options.overrideGlobalObjects,\n autoCleanupIncoming: options.autoCleanupIncoming\n });\n const createServer = options.createServer || createServerHTTP;\n const server = createServer(options.serverOptions || {}, requestListener);\n return server;\n};\nvar serve = (options, listeningListener) => {\n const server = createAdaptorServer(options);\n server.listen(options?.port ?? 3e3, options.hostname, () => {\n const serverInfo = server.address();\n listeningListener && listeningListener(serverInfo);\n });\n return server;\n};\nexport {\n RequestError,\n createAdaptorServer,\n getRequestListener,\n serve\n};\n","// Server\nexport const PARTY_PORT = parseInt(process.env.PARTY_PORT || '8000', 10);\n\nexport const STALE_THRESHOLD = parseInt(process.env.STALE_THRESHOLD || '3', 10);\n\n// Agent lifecycle\nexport const HEARTBEAT_TIMEOUT = parseFloat(process.env.HEARTBEAT_TIMEOUT || '60');\nexport const CLEANUP_INTERVAL = parseFloat(process.env.CLEANUP_INTERVAL || '60');\n\n// Peer discovery\nexport const DISCOVERY_INTERVAL = parseFloat(process.env.DISCOVERY_INTERVAL || '20');\nexport const REMOTE_STALE_FACTOR = parseInt(process.env.REMOTE_STALE_FACTOR || '3', 10);\nexport const PROBE_TIMEOUT = parseFloat(process.env.PROBE_TIMEOUT || '5');\n","import { existsSync, mkdirSync, appendFileSync, readdirSync, unlinkSync, statSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\n\ntype LogLevel = 'debug' | 'info' | 'warn' | 'error';\n\nconst LEVEL_ORDER: Record<LogLevel, number> = {\n debug: 0,\n info: 1,\n warn: 2,\n error: 3,\n};\n\nfunction getEffectiveLevel(): LogLevel {\n const env = (process.env.LOG_LEVEL || 'info').toLowerCase().trim();\n if (env in LEVEL_ORDER) return env as LogLevel;\n return 'info';\n}\n\nconst effectiveLevel = getEffectiveLevel();\n\n// ---------------------------------------------------------------------------\n// File logging setup\n// ---------------------------------------------------------------------------\n\nconst LOG_DIR = join(homedir(), '.open-party', 'logs');\nconst LOG_RETENTION_DAYS = 7;\n\n/** Ensure log directory exists and prune old log files beyond retention. */\nfunction initLogFile(): void {\n if (!existsSync(LOG_DIR)) {\n mkdirSync(LOG_DIR, { recursive: true });\n return;\n }\n\n // Prune log files older than LOG_RETENTION_DAYS\n try {\n const now = Date.now();\n const cutoff = now - LOG_RETENTION_DAYS * 24 * 60 * 60 * 1000;\n const files = readdirSync(LOG_DIR);\n for (const f of files) {\n if (!f.endsWith('-open-party.log')) continue;\n try {\n const stat = statSync(join(LOG_DIR, f));\n if (stat.mtimeMs < cutoff) {\n unlinkSync(join(LOG_DIR, f));\n }\n } catch {\n // [ANTI-PATTERN IGNORED]: skip individual unreadable files during retention prune\n }\n }\n } catch {\n // [ANTI-PATTERN IGNORED]: best-effort log directory init — console is primary channel\n }\n}\n\n/** Get today's log file path: ~/.open-party/logs/2026-05-31-open-party.log */\nfunction getLogFilePath(): string {\n const d = new Date();\n const yyyy = String(d.getFullYear());\n const mm = String(d.getMonth() + 1).padStart(2, '0');\n const dd = String(d.getDate()).padStart(2, '0');\n return join(LOG_DIR, `${yyyy}-${mm}-${dd}-open-party.log`);\n}\n\n// Initialize on module load\ninitLogFile();\n\n// ---------------------------------------------------------------------------\n// Core helpers\n// ---------------------------------------------------------------------------\n\nfunction shouldLog(level: LogLevel): boolean {\n return LEVEL_ORDER[level] >= LEVEL_ORDER[effectiveLevel];\n}\n\nfunction extractError(err: unknown): string {\n if (err instanceof Error) {\n const stack = err.stack ? `\\n${err.stack}` : '';\n return `${err.message}${stack}`;\n }\n return String(err);\n}\n\nfunction format(level: LogLevel, tag: string, message: string): string {\n const now = new Date();\n // Pad level to fixed width for column alignment\n const levelStr = level.toUpperCase().padEnd(5);\n const yyyy = String(now.getFullYear());\n const mm = String(now.getMonth() + 1).padStart(2, '0');\n const dd = String(now.getDate()).padStart(2, '0');\n const hh = String(now.getHours()).padStart(2, '0');\n const min = String(now.getMinutes()).padStart(2, '0');\n const ss = String(now.getSeconds()).padStart(2, '0');\n const ts = `${yyyy}-${mm}-${dd} ${hh}:${min}:${ss}`;\n return `${ts} [${levelStr}] [${tag}] ${message}`;\n}\n\n/** Write line to both console and today's log file. */\nfunction output(consoleFn: typeof console.log, level: LogLevel, tag: string, message: string): void {\n if (!shouldLog(level)) return;\n const line = format(level, tag, message);\n consoleFn(line);\n // [ANTI-PATTERN IGNORED]: File write is on the hot path but appendFileSync is fast enough\n // for log volumes (<100 writes/sec). The alternative (buffered write) adds complexity\n // without measurable benefit at this scale.\n try {\n appendFileSync(getLogFilePath(), line + '\\n', 'utf-8');\n } catch {\n // [ANTI-PATTERN IGNORED]: File write failure on hot path — console output is primary channel\n }\n}\n\nexport const logger = {\n info(tag: string, message: string, data?: Record<string, unknown>): void {\n output(console.log, 'info', tag, data ? `${message} ${JSON.stringify(data)}` : message);\n },\n\n warn(tag: string, message: string, data?: unknown): void {\n const detail = data instanceof Error ? `: ${extractError(data)}` : data ? ` ${JSON.stringify(data)}` : '';\n output(console.warn, 'warn', tag, message + detail);\n },\n\n error(tag: string, message: string, err?: unknown): void {\n const detail = err ? `: ${extractError(err)}` : '';\n output(console.error, 'error', tag, message + detail);\n },\n\n debug(tag: string, message: string, data?: Record<string, unknown>): void {\n output(console.debug, 'debug', tag, data ? `${message} ${JSON.stringify(data)}` : message);\n },\n};\n","/**\n * Server state persistence via JSON snapshots.\n *\n * Provides atomic write/load of agent registry and ring buffer state\n * so that server state survives restarts.\n *\n * Storage: ~/.open-party/data/snapshot.json (atomic .tmp + rename)\n */\n\nimport { existsSync, readFileSync, writeFileSync, unlinkSync, renameSync, mkdirSync } from 'node:fs';\nimport { join, dirname } from 'node:path';\nimport { homedir } from 'node:os';\nimport type { AgentInfo, AgentBufferSnapshot } from './models.js';\nimport { logger } from './logger.js';\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\nexport interface ServerSnapshot {\n version: number;\n saved_at: number;\n agents: AgentInfo[];\n buffers: Record<string, AgentBufferSnapshot>;\n}\n\n// ---------------------------------------------------------------------------\n// Constants\n// ---------------------------------------------------------------------------\n\nconst CURRENT_SCHEMA_VERSION = 2;\nconst SNAPSHOT_FILE = 'snapshot.json';\nconst SHUTDOWN_MARKER_FILE = 'shutdown-marker.json';\nconst DEFAULT_SNAPSHOT_INTERVAL_MS = 60_000; // 60 seconds\n\n/** Resolve the data directory path. */\nfunction dataDirPath(): string {\n const pluginData = process.env.CLAUDE_PLUGIN_DATA || '';\n if (pluginData) return join(pluginData, 'data');\n return join(homedir(), '.open-party', 'data');\n}\n\n// ---------------------------------------------------------------------------\n// SnapshotManager\n// ---------------------------------------------------------------------------\n\nexport class SnapshotManager {\n private readonly _dir: string;\n private readonly _snapshotPath: string;\n private readonly _markerPath: string;\n\n constructor(dataDir?: string) {\n this._dir = dataDir ?? dataDirPath();\n this._snapshotPath = join(this._dir, SNAPSHOT_FILE);\n this._markerPath = join(this._dir, SHUTDOWN_MARKER_FILE);\n\n mkdirSync(this._dir, { recursive: true });\n\n // Clean up stale .tmp file from interrupted previous write\n const tmpPath = this._snapshotPath + '.tmp';\n try {\n if (existsSync(tmpPath)) {\n unlinkSync(tmpPath);\n }\n } catch (error) {\n logger.warn('Persistence', 'Failed to clean up stale tmp file', error);\n }\n }\n\n // ------------------------------------------------------------------\n // Write / Load\n // ------------------------------------------------------------------\n\n /** Atomically write a snapshot of registry agents and ring buffer state. */\n writeSnapshot(agents: AgentInfo[], buffers: Record<string, AgentBufferSnapshot>): void {\n const snapshot: ServerSnapshot = {\n version: CURRENT_SCHEMA_VERSION,\n saved_at: Date.now(),\n agents,\n buffers,\n };\n\n const serialized = JSON.stringify(snapshot, null, 2);\n const tmpPath = this._snapshotPath + '.tmp';\n\n try {\n writeFileSync(tmpPath, serialized, 'utf-8');\n renameSync(tmpPath, this._snapshotPath);\n } catch (error) {\n logger.error('Persistence', 'Failed to write snapshot', error);\n try { unlinkSync(tmpPath); } catch { /* best-effort cleanup */ }\n throw error;\n }\n }\n\n /** Load and validate snapshot. Returns null if file missing or corrupt. */\n loadSnapshot(): ServerSnapshot | null {\n if (!existsSync(this._snapshotPath)) {\n return null;\n }\n\n try {\n const raw = JSON.parse(readFileSync(this._snapshotPath, 'utf-8'));\n if (!raw || typeof raw !== 'object') {\n throw new Error('Snapshot is not a valid object');\n }\n return {\n version: typeof raw.version === 'number' ? raw.version : CURRENT_SCHEMA_VERSION,\n saved_at: typeof raw.saved_at === 'number' ? raw.saved_at : 0,\n agents: Array.isArray(raw.agents) ? raw.agents : [],\n buffers: raw.buffers && typeof raw.buffers === 'object' && !Array.isArray(raw.buffers)\n ? raw.buffers\n : {},\n };\n } catch (error) {\n logger.warn('Persistence', 'Failed to load snapshot (starting fresh)', error);\n return null;\n }\n }\n\n // ------------------------------------------------------------------\n // Hydration (restore in-memory state from snapshot)\n // ------------------------------------------------------------------\n\n /** Restore agents into registry. Overwrites host_ip with current selfIp. */\n hydrateAgents(registry: import('./registry.js').AgentRegistry, selfIp: string): number {\n const snapshot = this.loadSnapshot();\n if (!snapshot || snapshot.agents.length === 0) return 0;\n\n const now = Date.now() / 1000;\n let count = 0;\n\n for (const agent of snapshot.agents) {\n agent.last_heartbeat = now;\n const info = registry.register({\n agent_id: agent.agent_id,\n display_name: agent.display_name,\n metadata: agent.metadata ?? {},\n });\n info.host_ip = selfIp;\n count++;\n }\n\n return count;\n }\n\n /** Restore ring buffer state into message queue. */\n hydrateBuffers(queue: import('./message-queue.js').MessageQueue): number {\n const snapshot = this.loadSnapshot();\n if (!snapshot || Object.keys(snapshot.buffers).length === 0) return 0;\n\n queue.restoreBufferSnapshots(snapshot.buffers);\n\n let totalEntries = 0;\n for (const snap of Object.values(snapshot.buffers)) {\n totalEntries += snap.entries.length;\n }\n\n return totalEntries;\n }\n\n // ------------------------------------------------------------------\n // Shutdown marker\n // ------------------------------------------------------------------\n\n /** Write shutdown marker to detect interrupted shutdown on next start. */\n writeShutdownMarker(): void {\n try {\n writeFileSync(\n this._markerPath,\n JSON.stringify({ started_at: Date.now() }),\n 'utf-8',\n );\n } catch (error) {\n logger.warn('Persistence', 'Failed to write shutdown marker', error);\n }\n }\n\n /** Remove shutdown marker — called after successful shutdown. */\n removeShutdownMarker(): void {\n try {\n if (existsSync(this._markerPath)) {\n unlinkSync(this._markerPath);\n }\n } catch (error) {\n logger.warn('Persistence', 'Failed to remove shutdown marker', error);\n }\n }\n\n /** Check if a shutdown marker exists (indicates previous shutdown was interrupted). */\n hasShutdownMarker(): boolean {\n return existsSync(this._markerPath);\n }\n\n // ------------------------------------------------------------------\n // Snapshot loop\n // ------------------------------------------------------------------\n\n /**\n * Start periodic snapshot background loop.\n * Writes snapshot every `intervalMs` milliseconds until signal is aborted.\n */\n async startSnapshotLoop(\n signal: AbortSignal,\n getAgents: () => AgentInfo[],\n getBuffers: () => Record<string, AgentBufferSnapshot>,\n intervalMs: number = DEFAULT_SNAPSHOT_INTERVAL_MS,\n ): Promise<void> {\n while (!signal.aborted) {\n try {\n await abortableSleep(intervalMs, signal);\n } catch (e) {\n if (signal.aborted) break;\n throw e;\n }\n\n if (signal.aborted) break;\n\n try {\n this.writeSnapshot(getAgents(), getBuffers());\n } catch (error) {\n // [ANTI-PATTERN IGNORED]: Periodic snapshot failure should not crash the loop\n logger.warn('Persistence', 'Periodic snapshot failed', error);\n }\n }\n }\n}\n\n// ---------------------------------------------------------------------------\n// Utility\n// ---------------------------------------------------------------------------\n\n/** Sleep that respects AbortSignal — throws AbortError when aborted. */\nexport function abortableSleep(ms: number, signal?: AbortSignal): Promise<void> {\n return new Promise((resolve, reject) => {\n const timer = setTimeout(resolve, ms);\n signal?.addEventListener(\n 'abort',\n () => {\n clearTimeout(timer);\n reject(new DOMException('Aborted', 'AbortError'));\n },\n { once: true },\n );\n });\n}\n","/**\n * Per-agent ring buffer with server-side cursor.\n *\n * Unified storage for message queue + history:\n * - `write()` appends entries with monotonic seq numbers\n * - `dequeue()` reads from cursor and advances it (non-destructive)\n * - `getRecent()` returns latest N entries regardless of cursor\n * - Overflow overwrites oldest entries when capacity is reached\n */\n\nimport type { MessageEnvelope, RingBufferEntry, AgentBufferSnapshot } from './models.js';\n\nconst DEFAULT_CAPACITY = 200;\n\nexport class AgentRingBuffer {\n private readonly _buffer: (RingBufferEntry | undefined)[];\n private readonly _capacity: number;\n private _head = 0; // next write position (0 ~ capacity-1)\n private _nextSeq = 1; // next sequence number to assign\n private _count = 0; // valid entries currently in buffer\n private _cursor = 0; // server-side read cursor (last consumed seq)\n\n constructor(capacity: number = DEFAULT_CAPACITY) {\n this._capacity = Math.max(1, capacity);\n this._buffer = new Array(this._capacity);\n }\n\n // ------------------------------------------------------------------\n // Write\n // ------------------------------------------------------------------\n\n /** Write an entry to the buffer. Returns the assigned sequence number. */\n write(direction: 'sent' | 'received', envelope: MessageEnvelope): number {\n const seq = this._nextSeq++;\n const entry: RingBufferEntry = {\n seq,\n direction,\n sender_id: envelope.sender_id,\n recipient_id: envelope.recipient_id,\n summary: envelope.summary,\n content: envelope.content,\n timestamp: envelope.timestamp ?? Date.now() / 1000,\n };\n\n this._buffer[this._head] = entry;\n this._head = (this._head + 1) % this._capacity;\n\n if (this._count < this._capacity) {\n this._count++;\n }\n\n return seq;\n }\n\n // ------------------------------------------------------------------\n // Read (cursor-based — dequeue semantics)\n // ------------------------------------------------------------------\n\n /**\n * Read up to maxCount entries after the cursor, then advance the cursor.\n * Non-destructive: entries remain in the buffer for history queries.\n */\n dequeue(maxCount: number = 50): RingBufferEntry[] {\n const unread = this._readSince(this._cursor);\n if (unread.length === 0) return [];\n\n const taken = unread.slice(0, maxCount);\n // Advance cursor to the last consumed seq\n this._cursor = taken[taken.length - 1].seq;\n return taken;\n }\n\n /**\n * Like dequeue(), but only returns 'received' entries.\n * Cursor advances to the last returned 'received' entry's seq.\n * Used for inbox semantics — agents only see incoming messages.\n */\n dequeueReceived(maxCount: number = 50): RingBufferEntry[] {\n const all = this._readSince(this._cursor);\n if (all.length === 0) return [];\n\n const received = all.filter(e => e.direction === 'received').slice(0, maxCount);\n if (received.length === 0) return [];\n\n // Advance cursor to the last returned entry's seq\n this._cursor = received[received.length - 1].seq;\n return received;\n }\n\n /** Number of unread entries (next_seq - cursor). */\n unreadCount(): number {\n const diff = this._nextSeq - 1 - this._cursor;\n return Math.max(0, diff);\n }\n\n /** Number of unread 'received' entries after cursor. */\n unreadReceivedCount(): number {\n const all = this._readSince(this._cursor);\n let count = 0;\n for (const e of all) {\n if (e.direction === 'received') count++;\n }\n return count;\n }\n\n // ------------------------------------------------------------------\n // Read (non-destructive — no cursor advance)\n // ------------------------------------------------------------------\n\n /** Read all entries with seq > sinceSeq. Does NOT advance cursor. */\n readSince(sinceSeq: number): RingBufferEntry[] {\n return this._readSince(sinceSeq);\n }\n\n /** Get the most recent N entries regardless of cursor. */\n getRecent(limit: number = 20): RingBufferEntry[] {\n const all = this._allSorted();\n return all.slice(-limit);\n }\n\n /** Get total number of valid entries in the buffer. */\n get count(): number {\n return this._count;\n }\n\n // ------------------------------------------------------------------\n // Lifecycle\n // ------------------------------------------------------------------\n\n /** Clear the buffer and reset cursor. */\n clear(): void {\n this._buffer.fill(undefined);\n this._head = 0;\n this._nextSeq = 1;\n this._count = 0;\n this._cursor = 0;\n }\n\n // ------------------------------------------------------------------\n // Snapshot / Restore\n // ------------------------------------------------------------------\n\n /** Export buffer state for persistence. */\n getSnapshot(): AgentBufferSnapshot {\n return {\n entries: this._allSorted(),\n next_seq: this._nextSeq,\n cursor: this._cursor,\n };\n }\n\n /** Restore buffer from a snapshot. */\n restoreFromSnapshot(snap: AgentBufferSnapshot): void {\n this.clear();\n\n // Restore entries into the ring buffer in order\n for (const entry of snap.entries) {\n this._buffer[this._head] = entry;\n this._head = (this._head + 1) % this._capacity;\n this._count++;\n }\n\n this._nextSeq = snap.next_seq;\n this._cursor = snap.cursor;\n }\n\n /** Get the next sequence number that will be assigned. */\n get nextSeq(): number {\n return this._nextSeq;\n }\n\n /** Get the current cursor position. */\n get cursor(): number {\n return this._cursor;\n }\n\n // ------------------------------------------------------------------\n // Private helpers\n // ------------------------------------------------------------------\n\n /**\n * Collect all valid entries sorted by seq.\n * O(count) — scans the ring buffer once.\n */\n private _allSorted(): RingBufferEntry[] {\n const result: RingBufferEntry[] = [];\n for (let i = 0; i < this._capacity; i++) {\n const entry = this._buffer[i];\n if (entry !== undefined) {\n result.push(entry);\n }\n }\n result.sort((a, b) => a.seq - b.seq);\n return result;\n }\n\n /**\n * Read entries with seq > sinceSeq.\n * Uses binary search on sorted entries for efficiency.\n */\n private _readSince(sinceSeq: number): RingBufferEntry[] {\n const all = this._allSorted();\n // Binary search: find first entry with seq > sinceSeq\n let lo = 0;\n let hi = all.length;\n while (lo < hi) {\n const mid = (lo + hi) >>> 1;\n if (all[mid].seq <= sinceSeq) {\n lo = mid + 1;\n } else {\n hi = mid;\n }\n }\n return all.slice(lo);\n }\n}\n","/**\n * Per-agent message queue backed by ring buffers.\n *\n * Unified storage: each agent has one ring buffer that stores both\n * 'sent' and 'received' entries. Dequeue is non-destructive (cursor-based).\n */\n\nimport type { MessageEnvelope, HistoryEntry, AgentBufferSnapshot } from './models.js';\nimport { AgentRingBuffer } from './ring-buffer.js';\n\nconst DEFAULT_CAPACITY = 200;\n\n/** Per-agent message queue stored in memory. */\nexport class MessageQueue {\n private _buffers = new Map<string, AgentRingBuffer>();\n\n private _getOrCreate(agentId: string): AgentRingBuffer {\n let buf = this._buffers.get(agentId);\n if (!buf) {\n buf = new AgentRingBuffer(DEFAULT_CAPACITY);\n this._buffers.set(agentId, buf);\n }\n return buf;\n }\n\n /** Enqueue a message for agentId. Returns the unread count after enqueue. */\n enqueue(agentId: string, envelope: MessageEnvelope): number {\n const buf = this._getOrCreate(agentId);\n buf.write('received', envelope);\n return buf.unreadReceivedCount();\n }\n\n /** Pop up to maxCount received messages for agentId (non-destructive, cursor-based). */\n dequeue(agentId: string, maxCount = 50): MessageEnvelope[] {\n const buf = this._buffers.get(agentId);\n if (!buf) return [];\n return buf.dequeueReceived(maxCount).map(toEnvelope);\n }\n\n /** Return the number of pending received messages for agentId. */\n pendingCount(agentId: string): number {\n return this._buffers.get(agentId)?.unreadReceivedCount() ?? 0;\n }\n\n /** Clean up buffer when agent is removed. */\n removeAgent(agentId: string): void {\n this._buffers.delete(agentId);\n }\n\n /** Record a message in an agent's history (writes to the same ring buffer). */\n logToHistory(agentId: string, direction: 'sent' | 'received', envelope: MessageEnvelope): void {\n const buf = this._getOrCreate(agentId);\n buf.write(direction, envelope);\n }\n\n /** Get recent N history entries for an agent. */\n getHistory(agentId: string, limit = 20): HistoryEntry[] {\n const buf = this._buffers.get(agentId);\n if (!buf) return [];\n return buf.getRecent(limit).map(toHistoryEntry);\n }\n\n /** Clean up history when agent is removed (same as removeAgent — unified storage). */\n removeAgentHistory(agentId: string): void {\n this._buffers.delete(agentId);\n }\n\n /**\n * Return a shallow copy of the full history map (for persistence snapshots).\n * Kept for backward compatibility with persistence v1 consumers.\n */\n getHistorySnapshot(): Record<string, HistoryEntry[]> {\n const copy: Record<string, HistoryEntry[]> = {};\n for (const [agentId, buf] of this._buffers) {\n copy[agentId] = buf.getRecent().map(toHistoryEntry);\n }\n return copy;\n }\n\n /** Return ring buffer snapshots for persistence v2. */\n getBufferSnapshots(): Record<string, AgentBufferSnapshot> {\n const result: Record<string, AgentBufferSnapshot> = {};\n for (const [agentId, buf] of this._buffers) {\n result[agentId] = buf.getSnapshot();\n }\n return result;\n }\n\n /** Restore buffers from v2 snapshots. */\n restoreBufferSnapshots(snapshots: Record<string, AgentBufferSnapshot>): void {\n for (const [agentId, snap] of Object.entries(snapshots)) {\n const buf = new AgentRingBuffer(DEFAULT_CAPACITY);\n buf.restoreFromSnapshot(snap);\n this._buffers.set(agentId, buf);\n }\n }\n}\n\n// ---------------------------------------------------------------------------\n// Conversion helpers\n// ---------------------------------------------------------------------------\n\nfunction toEnvelope(e: import('./models.js').RingBufferEntry): MessageEnvelope {\n return {\n sender_id: e.sender_id,\n recipient_id: e.recipient_id,\n summary: e.summary,\n content: e.content,\n timestamp: e.timestamp,\n };\n}\n\nfunction toHistoryEntry(e: import('./models.js').RingBufferEntry): HistoryEntry {\n return {\n direction: e.direction,\n sender_id: e.sender_id,\n recipient_id: e.recipient_id,\n summary: e.summary,\n content: e.content,\n timestamp: e.timestamp,\n };\n}\n","/**\n * Peer discovery and remote agent cache for cross-host communication.\n *\n * Pull-based discovery loop:\n * 1. Read Tailscale peers via readTailscaleStatus()\n * 2. Probe each peer's /proxy/health to identify Party Servers\n * 3. Fetch agent lists from healthy peers via /proxy/list_agents\n * 4. Maintain a remote agent cache with per-peer reachability tracking\n *\n * Simplified state machine: UNKNOWN → ALIVE → DEAD\n */\n\nimport type { AgentInfo } from './models.js';\nimport { DISCOVERY_INTERVAL, PARTY_PORT, PROBE_TIMEOUT, REMOTE_STALE_FACTOR } from './config.js';\nimport { readTailscaleStatus } from '../infra/tailscale.js';\nimport { abortableSleep } from './persistence.js';\nimport { logger } from './logger.js';\n\n// ---------------------------------------------------------------------------\n// Peer state machine constants\n// ---------------------------------------------------------------------------\n\nconst UNKNOWN = 'UNKNOWN';\nconst ALIVE = 'ALIVE';\nconst DEAD = 'DEAD';\n\nconst MAX_FAILURES = 3;\nconst BACKOFF_BASE = 60;\nconst BACKOFF_CAP = 900;\n\n// ---------------------------------------------------------------------------\n// Data types\n// ---------------------------------------------------------------------------\n\ninterface PeerState {\n ip: string;\n status: string;\n consecutiveFailures: number;\n lastProbeAt: number;\n backoffUntil: number | null;\n}\n\ninterface RemoteAgentEntry {\n agentInfo: AgentInfo;\n sourcePeerIp: string;\n lastSyncedAt: number;\n reachable: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// Error classification for native fetch\n// ---------------------------------------------------------------------------\n\n/** Classify a fetch error as refused (false), timeout/uncertain (null). */\nfunction classifyFetchError(error: unknown): boolean | null {\n if (error instanceof TypeError && /fetch failed/i.test(error.message)) {\n const cause = (error as NodeJS.ErrnoException).cause as { code?: string } | undefined;\n if (cause?.code === 'ECONNREFUSED') return false;\n return null;\n }\n if (error instanceof DOMException && error.name === 'AbortError') return null;\n return null;\n}\n\n// ---------------------------------------------------------------------------\n// PeerDiscovery\n// ---------------------------------------------------------------------------\n\nexport class PeerDiscovery {\n private _selfIp: string;\n private _peers = new Map<string, PeerState>();\n private _remoteAgents = new Map<string, RemoteAgentEntry>();\n\n constructor(selfIp: string) {\n this._selfIp = selfIp;\n }\n\n // ------------------------------------------------------------------\n // Public query API (used by router)\n // ------------------------------------------------------------------\n\n /** Return the peer IP that owns agentId, or undefined. */\n getPeerForAgent(agentId: string): string | undefined {\n return this._remoteAgents.get(agentId)?.sourcePeerIp;\n }\n\n /** Return true if the peer is alive. */\n isPeerReachable(peerIp: string): boolean {\n const ps = this._peers.get(peerIp);\n return ps !== undefined && ps.status === ALIVE;\n }\n\n /** Return all remote agents (including unreachable ones). */\n getAllRemoteAgents(): AgentInfo[] {\n return Array.from(this._remoteAgents.values(), (e) => e.agentInfo);\n }\n\n /** Return only reachable remote agents. */\n getReachableRemoteAgents(): AgentInfo[] {\n return Array.from(this._remoteAgents.values())\n .filter((e) => e.reachable)\n .map((e) => e.agentInfo);\n }\n\n /** Return all known peer states. */\n getPeerStates(): Array<{\n ip: string;\n status: string;\n consecutiveFailures: number;\n lastProbeAt: number;\n backoffUntil: number | null;\n }> {\n return Array.from(this._peers.values()).map((ps) => ({\n ip: ps.ip,\n status: ps.status,\n consecutiveFailures: ps.consecutiveFailures,\n lastProbeAt: ps.lastProbeAt,\n backoffUntil: ps.backoffUntil,\n }));\n }\n\n /** Return remote agent entries with peer mapping info. */\n getRemoteAgentEntries(): Array<{\n agentInfo: AgentInfo;\n sourcePeerIp: string;\n lastSyncedAt: number;\n reachable: boolean;\n }> {\n return Array.from(this._remoteAgents.values()).map((e) => ({\n agentInfo: e.agentInfo,\n sourcePeerIp: e.sourcePeerIp,\n lastSyncedAt: e.lastSyncedAt,\n reachable: e.reachable,\n }));\n }\n\n // ------------------------------------------------------------------\n // Main discovery loop\n // ------------------------------------------------------------------\n\n async runLoop(signal?: AbortSignal): Promise<void> {\n while (!signal?.aborted) {\n try {\n await this.discoveryCycle();\n } catch (e) {\n logger.error('Discovery', 'Cycle failed', e);\n }\n await abortableSleep(DISCOVERY_INTERVAL * 1000, signal);\n }\n }\n\n private async discoveryCycle(): Promise<void> {\n const peerIps = this.getTailscalePeers();\n\n // Add new peers as UNKNOWN\n for (const ip of peerIps) {\n if (!this._peers.has(ip)) {\n this._peers.set(ip, { ip, status: UNKNOWN, consecutiveFailures: 0, lastProbeAt: 0, backoffUntil: null });\n }\n }\n\n const now = performance.now() / 1000;\n\n // Process each peer\n for (const ip of peerIps) {\n const ps = this._peers.get(ip)!;\n\n // Skip DEAD peers still in backoff\n if (ps.status === DEAD) {\n if (ps.backoffUntil !== null && now < ps.backoffUntil) continue;\n ps.status = UNKNOWN;\n }\n\n await this.probePeer(ps);\n }\n\n this.evictDeadAgents();\n this.evictStaleAgents();\n }\n\n // ------------------------------------------------------------------\n // Tailscale peer enumeration\n // ------------------------------------------------------------------\n\n private getTailscalePeers(): string[] {\n let status: Record<string, unknown>;\n try {\n status = readTailscaleStatus();\n } catch (error) {\n logger.warn('Discovery', 'Failed to read Tailscale status', error);\n return [];\n }\n\n const peersRaw = status.Peer as Record<string, Record<string, unknown>> | undefined;\n if (!peersRaw || typeof peersRaw !== 'object') return [];\n\n const ips: string[] = [];\n for (const peer of Object.values(peersRaw)) {\n if (typeof peer !== 'object' || !peer) continue;\n if (!peer.Online) continue;\n if (peer.ExitNode) continue;\n const tailscaleIps = peer.TailscaleIPs as string[] | undefined;\n if (!tailscaleIps) continue;\n for (const ip of tailscaleIps) {\n if (ip.includes('.') && !ip.includes(':')) {\n if (ip !== this._selfIp) ips.push(ip);\n break;\n }\n }\n }\n return ips;\n }\n\n // ------------------------------------------------------------------\n // Peer probing\n // ------------------------------------------------------------------\n\n private async probePeer(ps: PeerState): Promise<void> {\n ps.lastProbeAt = Date.now() / 1000;\n const healthy = await this.checkHealth(ps.ip);\n\n if (healthy === true) {\n await this.handleProbeSuccess(ps);\n } else if (healthy === false) {\n this.handleProbeFailure(ps);\n }\n // null = timeout/uncertain → treat as transient, don't change state\n }\n\n private async checkHealth(ip: string): Promise<boolean | null> {\n const url = `http://${ip}:${PARTY_PORT}/proxy/health`;\n try {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), PROBE_TIMEOUT * 1000);\n const resp = await fetch(url, { signal: controller.signal });\n clearTimeout(timer);\n const data = (await resp.json()) as Record<string, unknown>;\n return resp.status === 200 && 'status' in data;\n } catch (e) {\n return classifyFetchError(e);\n }\n }\n\n // ------------------------------------------------------------------\n // State machine transitions\n // ------------------------------------------------------------------\n\n private async handleProbeSuccess(ps: PeerState): Promise<void> {\n ps.consecutiveFailures = 0;\n ps.backoffUntil = null;\n\n if (ps.status !== ALIVE) {\n const old = ps.status;\n ps.status = ALIVE;\n logger.info('Discovery', `Peer ${ps.ip}: ${old} -> ALIVE`);\n }\n\n await this.syncAgents(ps.ip);\n }\n\n private handleProbeFailure(ps: PeerState): void {\n ps.consecutiveFailures++;\n\n if (ps.consecutiveFailures >= MAX_FAILURES) {\n const old = ps.status;\n ps.status = DEAD;\n if (old !== DEAD) {\n const delay = Math.min(BACKOFF_BASE * Math.pow(2, ps.consecutiveFailures - 1), BACKOFF_CAP);\n ps.backoffUntil = performance.now() / 1000 + delay;\n logger.info('Discovery', `Peer ${ps.ip}: ${old} -> DEAD (backoff ${delay}s)`);\n }\n\n // Mark remote agents as unreachable\n for (const entry of this._remoteAgents.values()) {\n if (entry.sourcePeerIp === ps.ip) {\n entry.reachable = false;\n }\n }\n }\n }\n\n // ------------------------------------------------------------------\n // Agent synchronization\n // ------------------------------------------------------------------\n\n private async syncAgents(peerIp: string): Promise<void> {\n const url = `http://${peerIp}:${PARTY_PORT}/proxy/list_agents`;\n try {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), PROBE_TIMEOUT * 1000);\n const resp = await fetch(url, { signal: controller.signal });\n clearTimeout(timer);\n const data = (await resp.json()) as { agents?: AgentInfo[] };\n const agentsRaw = data.agents ?? [];\n const now = Date.now() / 1000;\n\n const seenIds = new Set<string>();\n for (const a of agentsRaw) {\n seenIds.add(a.agent_id);\n this._remoteAgents.set(a.agent_id, {\n agentInfo: a,\n sourcePeerIp: peerIp,\n lastSyncedAt: now,\n reachable: true,\n });\n }\n\n // Remove agents from this peer no longer present\n for (const [aid, entry] of this._remoteAgents) {\n if (entry.sourcePeerIp === peerIp && !seenIds.has(aid)) {\n this._remoteAgents.delete(aid);\n }\n }\n } catch (error) {\n // [ANTI-PATTERN IGNORED]: Agent sync is best-effort\n logger.warn('Discovery', `Failed to sync agents from ${peerIp}`, error);\n }\n }\n\n // ------------------------------------------------------------------\n // Cleanup\n // ------------------------------------------------------------------\n\n private evictDeadAgents(): void {\n const deadPeers = new Set<string>();\n for (const [ip, ps] of this._peers) {\n if (ps.status === DEAD) deadPeers.add(ip);\n }\n if (!deadPeers.size) return;\n\n for (const [aid, entry] of this._remoteAgents) {\n if (deadPeers.has(entry.sourcePeerIp)) {\n this._remoteAgents.delete(aid);\n }\n }\n }\n\n private evictStaleAgents(): void {\n const threshold = DISCOVERY_INTERVAL * REMOTE_STALE_FACTOR;\n const now = Date.now() / 1000;\n\n for (const [aid, entry] of this._remoteAgents) {\n if (now - entry.lastSyncedAt > threshold) {\n this._remoteAgents.delete(aid);\n }\n }\n }\n}\n","import type { AgentInfo, RegistrationRequest } from './models.js';\nimport { STALE_THRESHOLD } from './config.js';\n\n/** In-memory registry of agents connected to this server. */\nexport class AgentRegistry {\n private _agents = new Map<string, AgentInfo>();\n private _staleCounts = new Map<string, number>();\n private _selfIp: string;\n\n constructor(selfIp: string) {\n this._selfIp = selfIp;\n }\n\n register(req: RegistrationRequest): AgentInfo {\n const now = Date.now() / 1000;\n const info: AgentInfo = {\n agent_id: req.agent_id,\n display_name: req.display_name,\n host_ip: this._selfIp,\n registered_at: now,\n last_heartbeat: now,\n metadata: req.metadata ?? {},\n callback_url: req.callback_url,\n };\n this._agents.set(req.agent_id, info);\n this._staleCounts.set(req.agent_id, 0);\n return info;\n }\n\n remove(agentId: string): boolean {\n const existed = this._agents.delete(agentId);\n this._staleCounts.delete(agentId);\n return existed;\n }\n\n heartbeat(agentId: string): AgentInfo {\n const info = this._agents.get(agentId);\n if (!info) throw new Error(`Agent '${agentId}' not registered`);\n info.last_heartbeat = Date.now() / 1000;\n this._staleCounts.set(agentId, 0);\n return info;\n }\n\n get(agentId: string): AgentInfo | undefined {\n return this._agents.get(agentId);\n }\n\n listAll(): AgentInfo[] {\n return Array.from(this._agents.values());\n }\n\n /** Remove agents whose last heartbeat is older than timeout seconds.\n * Uses a stale counter: an agent must exceed the timeout STALE_THRESHOLD\n * consecutive times before being actually removed. Any heartbeat resets\n * the counter to zero, giving transient network issues room to recover.\n */\n cleanupStale(timeout: number): string[] {\n const now = Date.now() / 1000;\n const toRemove: string[] = [];\n\n for (const [aid, info] of this._agents) {\n if (now - info.last_heartbeat > timeout) {\n const count = (this._staleCounts.get(aid) ?? 0) + 1;\n this._staleCounts.set(aid, count);\n if (count >= STALE_THRESHOLD) {\n toRemove.push(aid);\n }\n } else {\n // Agent is healthy — reset stale counter\n this._staleCounts.set(aid, 0);\n }\n }\n\n for (const aid of toRemove) {\n this._agents.delete(aid);\n this._staleCounts.delete(aid);\n }\n return toRemove;\n }\n}\n","/**\n * Shared state singletons for the Party Server.\n *\n * All mutable state (registry, messageQueue, discovery) is owned here.\n * Lifecycle management (persistence, graceful shutdown) is also exported from here.\n */\nimport { getTailscaleIps } from '../infra/tailscale.js';\nimport { MessageQueue } from './message-queue.js';\nimport { PeerDiscovery } from './peer-discovery.js';\nimport { AgentRegistry } from './registry.js';\nimport type { SnapshotManager, AgentInfo, AgentBufferSnapshot } from './persistence.js';\n\nfunction resolveSelfIp(): string {\n try {\n const ips = getTailscaleIps();\n for (const ip of ips) {\n if (ip.includes('.') && !ip.includes(':')) return ip;\n }\n return ips.length > 0 ? ips[0] : '127.0.0.1';\n } catch {\n return '127.0.0.1';\n }\n}\n\nlet _selfIp = resolveSelfIp();\n\nexport function getSelfIp(): string {\n return _selfIp;\n}\n\nexport function refreshSelfIp(): string {\n _selfIp = resolveSelfIp();\n return _selfIp;\n}\n\nexport const STARTED_AT = Date.now();\nexport const registry = new AgentRegistry(getSelfIp());\nexport const messageQueue = new MessageQueue();\nexport const discovery = new PeerDiscovery(getSelfIp());\n\n// ---------------------------------------------------------------------------\n// Lifecycle management (persistence + graceful shutdown)\n// ---------------------------------------------------------------------------\n\n/** SnapshotManager instance — created during server startup, null before init. */\nexport let snapshotManager: SnapshotManager | null = null;\n\n/** AbortController for discovery loop and snapshot loop — aborted on shutdown. */\nexport const lifecycleController = new AbortController();\n\n/** Initialize the snapshot manager (called once during server startup). */\nexport function initSnapshotManager(mgr: SnapshotManager): void {\n snapshotManager = mgr;\n}\n\n/** Get the current snapshot manager instance (null before initialization). */\nexport function getSnapshotManager(): SnapshotManager | null {\n return snapshotManager;\n}\n","/** Agent registration request. */\nexport interface RegistrationRequest {\n agent_id: string;\n display_name?: string;\n metadata?: Record<string, unknown>;\n callback_url?: string;\n}\n\n/** Heartbeat request. */\nexport interface HeartbeatRequest {\n agent_id: string;\n display_name?: string;\n metadata?: Record<string, unknown>;\n callback_url?: string;\n}\n\n/** Registered agent info (internal — includes host_ip for routing). */\nexport interface AgentInfo {\n agent_id: string;\n display_name?: string;\n host_ip: string;\n registered_at: number;\n last_heartbeat: number;\n metadata: Record<string, unknown>;\n callback_url?: string;\n}\n\n/** Agent info safe to return to agents (no host_ip). */\nexport interface PublicAgentInfo {\n agent_id: string;\n display_name?: string;\n registered_at: number;\n last_heartbeat: number;\n metadata: Record<string, unknown>;\n}\n\n/** Strip host_ip from AgentInfo for agent-facing responses. */\nexport function sanitizeAgentInfo(info: AgentInfo): PublicAgentInfo {\n const { host_ip: _, ...publicInfo } = info;\n return publicInfo;\n}\n\n/** Strip host_ip from an array of AgentInfo. */\nexport function sanitizeAgentList(agents: AgentInfo[]): PublicAgentInfo[] {\n return agents.map(sanitizeAgentInfo);\n}\n\n/** Agent list response. */\nexport interface AgentListResponse {\n agents: AgentInfo[];\n count: number;\n}\n\n/** Remove request. */\nexport interface RemoveRequest {\n agent_id: string;\n}\n\n/** Message envelope. */\nexport interface MessageEnvelope {\n sender_id: string;\n recipient_id?: string; // undefined = broadcast\n group_id?: string;\n summary?: string; // short summary for terminal display\n content: string;\n timestamp?: number;\n}\n\n/** A single entry in an agent's message history. */\nexport interface HistoryEntry {\n direction: 'sent' | 'received';\n sender_id: string;\n recipient_id?: string;\n summary?: string;\n content: string;\n timestamp: number;\n}\n\n/** A single entry in the per-agent ring buffer. */\nexport interface RingBufferEntry {\n seq: number;\n direction: 'sent' | 'received';\n sender_id: string;\n recipient_id?: string;\n summary?: string;\n content: string;\n timestamp: number;\n}\n\n/** Snapshot of an agent's ring buffer (for persistence). */\nexport interface AgentBufferSnapshot {\n entries: RingBufferEntry[];\n next_seq: number;\n cursor: number;\n}\n\n/** Send result. */\nexport interface SendResult {\n status: 'delivered_locally' | 'forwarded' | 'agent_not_found' | 'error' | 'peer_unreachable';\n target?: string;\n error?: string;\n}\n\n\n","/**\n * Shared webhook callback utility.\n *\n * Fire-and-forget POST to an agent's callback URL when a message is delivered.\n * Used by both local delivery (/agent/send) and cross-peer relay (/proxy/receive).\n */\n\nimport { logger } from './logger.js';\n\n/** Webhook callback timeout (ms). */\nconst CALLBACK_TIMEOUT_MS = 5_000;\n\n/**\n * Fire-and-forget POST callback to agent's webhook URL.\n * The message is already safely stored in MessageQueue; callback failure is non-fatal.\n */\nexport function postCallback(callbackUrl: string, payload: Record<string, unknown>): void {\n fetch(callbackUrl, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(payload),\n signal: AbortSignal.timeout(CALLBACK_TIMEOUT_MS),\n }).then((resp) => {\n if (!resp.ok) {\n logger.warn('Webhook', `Callback HTTP error: url=${callbackUrl}, status=${resp.status}`);\n }\n }).catch((err) => {\n logger.warn('Webhook', `Callback failed: url=${callbackUrl}, error=${(err as Error).message}`);\n });\n}\n","import { Hono } from 'hono';\nimport type { MessageEnvelope, RegistrationRequest, HeartbeatRequest, RemoveRequest, SendResult } from '../models.js';\nimport { sanitizeAgentInfo, sanitizeAgentList } from '../models.js';\nimport { PARTY_PORT } from '../config.js';\nimport { logger } from '../logger.js';\nimport { postCallback } from '../callback.js';\n\nconst agentRoutes = new Hono();\n\nasync function forwardToPeer(peerIp: string, envelope: MessageEnvelope): Promise<SendResult> {\n const url = `http://${peerIp}:${PARTY_PORT}/proxy/receive`;\n const payload: Record<string, unknown> = { sender_id: envelope.sender_id, content: envelope.content };\n if (envelope.recipient_id) payload.recipient_id = envelope.recipient_id;\n if (envelope.group_id) payload.group_id = envelope.group_id;\n if (envelope.summary) payload.summary = envelope.summary;\n if (envelope.timestamp) payload.timestamp = envelope.timestamp;\n try {\n await fetch(url, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(payload),\n });\n return { status: 'forwarded', target: peerIp };\n } catch (e) {\n return { status: 'error', target: peerIp, error: (e as Error).message };\n }\n}\n\nagentRoutes.post('/register', async (c) => {\n const { registry } = await import('../state.js');\n const req = await c.req.json<RegistrationRequest>();\n const info = registry.register(req);\n logger.info('Agent', `Registered: ${info.agent_id} (display: \"${info.display_name ?? 'N/A'}\", callback=${info.callback_url ?? 'none'})`);\n return c.json(sanitizeAgentInfo(info));\n});\n\nagentRoutes.post('/remove', async (c) => {\n const { registry, messageQueue } = await import('../state.js');\n const req = await c.req.json<RemoveRequest>();\n const removed = registry.remove(req.agent_id);\n if (removed) {\n messageQueue.removeAgent(req.agent_id);\n messageQueue.removeAgentHistory(req.agent_id);\n }\n logger.info('Agent', removed ? `Removed: ${req.agent_id}` : `Remove failed: ${req.agent_id} (not found)`);\n return c.json({ status: removed ? 'removed' : 'not_found' });\n});\n\nagentRoutes.post('/heartbeat', async (c) => {\n const { registry } = await import('../state.js');\n const req = await c.req.json<HeartbeatRequest>();\n let info;\n try {\n info = registry.heartbeat(req.agent_id);\n // Update callback_url if provided (agent may have restarted on a different port)\n if (req.callback_url) {\n info.callback_url = req.callback_url;\n }\n } catch (err) {\n if (err instanceof Error && err.message.includes('not registered')) {\n // Auto-re-register agents that were cleaned up by stale-agent cleanup\n info = registry.register({\n agent_id: req.agent_id,\n display_name: req.display_name,\n metadata: req.metadata,\n callback_url: req.callback_url,\n });\n logger.info('Agent', `Auto-re-registered: ${req.agent_id} (was cleaned up)`);\n } else {\n throw err;\n }\n }\n logger.info('Agent', `Heartbeat from ${req.agent_id}${req.callback_url ? `, callback=${req.callback_url}` : ''}`);\n return c.json({ status: 'ok', last_heartbeat: info.last_heartbeat });\n});\n\nagentRoutes.get('/list', async (c) => {\n const { registry, discovery } = await import('../state.js');\n const localAgents = registry.listAll();\n const remoteEntries = discovery.getRemoteAgentEntries();\n const remoteAgents = remoteEntries\n .filter((e) => e.reachable)\n .map((e) => ({ ...sanitizeAgentInfo(e.agentInfo), source_peer_ip: e.sourcePeerIp }));\n const allAgents = sanitizeAgentList(localAgents).concat(remoteAgents);\n return c.json({\n agents: allAgents,\n count: allAgents.length,\n local_count: localAgents.length,\n remote_count: remoteAgents.length,\n });\n});\n\nagentRoutes.post('/send', async (c) => {\n const { registry, messageQueue, discovery } = await import('../state.js');\n const envelope = await c.req.json<MessageEnvelope>();\n const recipient = envelope.recipient_id;\n\n if (!recipient) {\n return c.json({ status: 'error' as const, error: 'recipient_id is required' });\n }\n\n // Check if recipient is local\n const recipientInfo = registry.get(recipient);\n if (recipientInfo) {\n const stamped = { ...envelope, timestamp: envelope.timestamp ?? Date.now() / 1000 };\n const count = messageQueue.enqueue(recipient, stamped);\n messageQueue.logToHistory(envelope.sender_id, 'sent', stamped);\n\n // Webhook callback to notify recipient (fire-and-forget)\n if (recipientInfo.callback_url) {\n const callbackPayload = {\n type: 'message_received',\n recipient_id: recipient,\n sender_id: envelope.sender_id,\n summary: envelope.summary,\n timestamp: stamped.timestamp,\n pending_count: count,\n };\n logger.info('Webhook', `Callback: agent=${recipient}, url=${recipientInfo.callback_url}, sender=${envelope.sender_id}`);\n postCallback(recipientInfo.callback_url, callbackPayload);\n } else {\n logger.debug('Webhook', `No callback_url for agent=${recipient}, skipping webhook`);\n }\n\n logger.info('Agent', `Send ${envelope.sender_id} -> ${recipient}: delivered_locally`);\n return c.json({ status: 'delivered_locally' as const, target: recipient });\n }\n\n // Check remote agent cache\n const peerIp = discovery.getPeerForAgent(recipient);\n if (peerIp) {\n if (discovery.isPeerReachable(peerIp)) {\n const result = await forwardToPeer(peerIp, envelope);\n if (result.status === 'forwarded') {\n messageQueue.logToHistory(envelope.sender_id, 'sent', { ...envelope, timestamp: envelope.timestamp ?? Date.now() / 1000 });\n logger.info('Agent', `Send ${envelope.sender_id} -> ${recipient}: forwarded (peer ${peerIp})`);\n }\n return c.json(result);\n } else {\n logger.info('Agent', `Send ${envelope.sender_id} -> ${recipient}: peer_unreachable (peer ${peerIp})`);\n return c.json({ status: 'peer_unreachable' as const, target: peerIp });\n }\n }\n\n logger.info('Agent', `Send ${envelope.sender_id} -> ${recipient}: agent_not_found`);\n return c.json({ status: 'agent_not_found' as const, target: recipient });\n});\n\nagentRoutes.get('/messages/:agent_id', async (c) => {\n const { messageQueue } = await import('../state.js');\n const agentId = c.req.param('agent_id');\n const maxCount = parseInt(c.req.query('max_count') || '50', 10);\n const msgs = messageQueue.dequeue(agentId, maxCount);\n return c.json({ messages: msgs, count: msgs.length });\n});\n\n/** Get message history for an agent. */\nagentRoutes.get('/history/:agent_id', async (c) => {\n const { messageQueue } = await import('../state.js');\n const agentId = c.req.param('agent_id');\n const limit = parseInt(c.req.query('limit') || '20', 10);\n const history = messageQueue.getHistory(agentId, limit);\n return c.json({ history, count: history.length });\n});\n\nexport { agentRoutes };\n","import { Hono } from 'hono';\r\nimport type { MessageEnvelope, SendResult } from '../models.js';\r\nimport { PARTY_PORT } from '../config.js';\r\nimport { getTailnetHostname } from '../../infra/tailscale.js';\r\nimport { registry, messageQueue, getSelfIp } from '../state.js';\r\nimport { logger } from '../logger.js';\r\nimport { postCallback } from '../callback.js';\r\n\r\nconst proxyRoutes = new Hono();\r\n\r\nproxyRoutes.get('/health', async (c) => {\r\n let hostname = '127.0.0.1';\r\n try {\r\n hostname = getTailnetHostname();\r\n } catch { /* ignore */ }\r\n\r\n return c.json({\r\n status: 'ok',\r\n tailscale_ip: getSelfIp(),\r\n hostname,\r\n agent_count: registry.listAll().length,\r\n });\r\n});\r\n\r\nproxyRoutes.get('/list_agents', async (c) => {\r\n const agents = registry.listAll();\r\n return c.json({ agents, count: agents.length });\r\n});\r\n\r\nproxyRoutes.get('/peers', async (c) => {\r\n const { discovery } = await import('../state.js');\r\n const peerStates = discovery.getPeerStates();\r\n return c.json({ peers: peerStates, total: peerStates.length });\r\n});\r\n\r\nproxyRoutes.post('/receive', async (c) => {\r\n const envelope = await c.req.json<MessageEnvelope>();\r\n const stamped = { ...envelope, timestamp: envelope.timestamp ?? Date.now() / 1000 };\r\n\r\n if (envelope.recipient_id) {\r\n const count = messageQueue.enqueue(envelope.recipient_id, stamped);\r\n messageQueue.logToHistory(envelope.recipient_id, 'received', stamped);\r\n logger.info('Proxy', `Received msg ${envelope.sender_id} -> ${envelope.recipient_id}`);\r\n\r\n // Webhook callback to notify recipient (same as local delivery in agent.ts)\r\n const recipientInfo = registry.get(envelope.recipient_id);\r\n if (recipientInfo?.callback_url) {\r\n const callbackPayload = {\r\n type: 'message_received',\r\n recipient_id: envelope.recipient_id,\r\n sender_id: envelope.sender_id,\r\n summary: envelope.summary,\r\n timestamp: stamped.timestamp,\r\n pending_count: count,\r\n };\r\n logger.info('Webhook', `Proxy callback: agent=${envelope.recipient_id}, url=${recipientInfo.callback_url}, sender=${envelope.sender_id}`);\r\n postCallback(recipientInfo.callback_url, callbackPayload);\r\n }\r\n } else {\r\n // Broadcast\r\n for (const agent of registry.listAll()) {\r\n messageQueue.enqueue(agent.agent_id, stamped);\r\n messageQueue.logToHistory(agent.agent_id, 'received', stamped);\r\n }\r\n logger.info('Proxy', `Broadcast from ${envelope.sender_id} to all agents`);\r\n }\r\n return c.json({ status: 'received' });\r\n});\r\n\r\nproxyRoutes.post('/send/:target_ip', async (c) => {\r\n const targetIp = c.req.param('target_ip');\r\n const envelope = await c.req.json<MessageEnvelope>();\r\n\r\n const senderId = envelope.sender_id || getSelfIp();\r\n const url = `http://${targetIp}:${PARTY_PORT}/proxy/receive`;\r\n const payload: Record<string, string> = { sender_id: senderId, content: envelope.content };\r\n if (envelope.recipient_id) payload.recipient_id = envelope.recipient_id;\r\n if (envelope.group_id) payload.group_id = envelope.group_id;\r\n\r\n try {\r\n await fetch(url, {\r\n method: 'POST',\r\n headers: { 'Content-Type': 'application/json' },\r\n body: JSON.stringify(payload),\r\n });\r\n logger.info('Proxy', `Forwarded to ${targetIp}`);\r\n return c.json({ status: 'forwarded' as const, target: targetIp });\r\n } catch (e) {\r\n logger.warn('Proxy', `Forward to ${targetIp} failed: ${(e as Error).message}`);\r\n return c.json({ status: 'error' as const, target: targetIp, error: (e as Error).message });\r\n }\r\n});\r\n\r\nexport { proxyRoutes };\r\n","import { Hono } from 'hono';\nimport { cors } from 'hono/cors';\nimport { serve, type Server } from '@hono/node-server';\nimport { existsSync, mkdirSync, writeFileSync, unlinkSync } from 'node:fs';\nimport { join, dirname } from 'node:path';\nimport { homedir } from 'node:os';\nimport { PARTY_PORT, CLEANUP_INTERVAL, HEARTBEAT_TIMEOUT } from './config.js';\nimport { abortableSleep, SnapshotManager } from './persistence.js';\nimport { logger } from './logger.js';\nimport {\n getSelfIp,\n discovery,\n registry,\n messageQueue,\n lifecycleController,\n initSnapshotManager,\n getSnapshotManager,\n} from './state.js';\nimport { agentRoutes } from './routes/agent.js';\nimport { proxyRoutes } from './routes/proxy.js';\n\n// ---------------------------------------------------------------------------\n// Background cleanup task\n// ---------------------------------------------------------------------------\n\nasync function periodicCleanup(): Promise<void> {\n while (!lifecycleController.signal.aborted) {\n try {\n const removed = registry.cleanupStale(HEARTBEAT_TIMEOUT);\n if (removed.length > 0) {\n logger.info('Cleanup', `Removed ${removed.length} stale agent(s): ${removed.join(', ')}`);\n for (const aid of removed) {\n messageQueue.removeAgent(aid);\n messageQueue.removeAgentHistory(aid);\n }\n }\n } catch (e) {\n logger.error('Cleanup', 'Error during cleanup', e);\n }\n await abortableSleep(CLEANUP_INTERVAL * 1000, lifecycleController.signal);\n }\n}\n\n// ---------------------------------------------------------------------------\n// App\n// ---------------------------------------------------------------------------\n\nconst app = new Hono();\n\napp.use('*', cors());\n\n// Request logging middleware\napp.use('*', async (c, next) => {\n const start = Date.now();\n await next();\n const ms = Date.now() - start;\n const ip = c.req.header('x-forwarded-for')?.split(',')[0]?.trim()\n ?? c.info?.remote?.address\n ?? 'unknown';\n const path = c.req.path;\n\n if (path === '/proxy/health') {\n logger.debug('HTTP', `${c.req.method} ${path} ${c.res.status} ${ms}ms ${ip}`);\n } else {\n logger.info('HTTP', `${c.req.method} ${path} ${c.res.status} ${ms}ms ${ip}`);\n }\n});\n\n// Centralized error handler\napp.onError((err, c) => {\n logger.error('HTTP', `${c.req.method} ${c.req.path} failed (${err.status ?? 500}): ${err.message}`, err);\n return c.json({\n status: 'error',\n error: (err.status ?? 500) >= 500 ? 'Internal server error' : err.message,\n }, err.status ?? 500);\n});\n\napp.route('/agent', agentRoutes);\napp.route('/proxy', proxyRoutes);\n\n// ---------------------------------------------------------------------------\n// PID file self-management (so `stop` and `status` always find us)\n// ---------------------------------------------------------------------------\n\nfunction pidFilePath(): string {\n const pluginData = process.env.CLAUDE_PLUGIN_DATA || '';\n if (pluginData) return join(pluginData, 'server.pid');\n return join(homedir(), '.open-party', 'server.pid');\n}\n\n// ---------------------------------------------------------------------------\n// Graceful shutdown\n// ---------------------------------------------------------------------------\n\nlet shutdownInitiated = false;\n\n/**\n * Perform ordered graceful shutdown.\n *\n * Sequence (referencing src-example/services/infrastructure/GracefulShutdown.ts):\n * 1. Guard against re-entry\n * 2. Abort background loops (discovery + snapshot)\n * 3. Cancel pending debounced snapshot\n * 4. Write final snapshot to disk\n * 5. Close HTTP server (with Windows socket-release delays)\n * 6. Clean up markers + PID file\n * 7. Exit\n */\nasync function performShutdown(server: Server, pidPath: string): Promise<void> {\n if (shutdownInitiated) return;\n shutdownInitiated = true;\n\n logger.info('Shutdown', 'Shutting down Party Server...');\n\n try {\n // Step 1-2: Abort background loops\n lifecycleController.abort();\n\n // Step 3: Final snapshot flush\n try {\n getSnapshotManager()?.writeSnapshot(registry.listAll(), messageQueue.getHistorySnapshot());\n logger.info('Shutdown', 'Final snapshot written.');\n } catch (error) {\n logger.error('Shutdown', 'Failed to write final snapshot', error);\n }\n\n // Step 5: Close HTTP server (referencing GracefulShutdown.ts closeHttpServer pattern)\n if (server.closeAllConnections) {\n server.closeAllConnections();\n }\n\n // Windows-specific: give OS time to release socket handles\n if (process.platform === 'win32') {\n await new Promise((r) => setTimeout(r, 500));\n }\n\n await new Promise<void>((resolve, reject) => {\n server.close((err) => (err ? reject(err) : resolve()));\n });\n\n // Windows-specific: ensure port is fully released (zombie port prevention)\n if (process.platform === 'win32') {\n await new Promise((r) => setTimeout(r, 500));\n }\n\n // Step 6: Cleanup\n getSnapshotManager()?.removeShutdownMarker();\n try {\n unlinkSync(pidPath);\n } catch {\n // [ANTI-PATTERN IGNORED]: PID file may already be gone during shutdown\n }\n\n logger.info('Shutdown', 'Party Server shut down cleanly.');\n } catch (error) {\n logger.error('Shutdown', 'Error during shutdown sequence', error);\n } finally {\n process.exit(0);\n }\n}\n\n// ---------------------------------------------------------------------------\n// Entry point\n// ---------------------------------------------------------------------------\n\nasync function main() {\n // Write PID file so CLI commands can find this process\n const pidPath = pidFilePath();\n mkdirSync(dirname(pidPath), { recursive: true });\n writeFileSync(pidPath, String(process.pid));\n\n // Initialize persistence\n initSnapshotManager(new SnapshotManager());\n const sm = getSnapshotManager()!;\n\n // Load and recover state from previous snapshot\n let recoveredAgents = 0;\n let recoveredHistoryEntries = 0;\n\n if (sm.hasShutdownMarker()) {\n logger.info('Recovery', 'Previous shutdown was interrupted (shutdown marker found).');\n }\n\n const savedSnapshot = sm.loadSnapshot();\n if (savedSnapshot) {\n recoveredAgents = sm.hydrateAgents(registry, getSelfIp());\n recoveredHistoryEntries = sm.hydrateBuffers(messageQueue);\n\n if (recoveredAgents > 0 || recoveredHistoryEntries > 0) {\n logger.info(\n 'Recovery',\n `Recovered ${recoveredAgents} agent(s), ${recoveredHistoryEntries} history entry/entries.`,\n );\n }\n }\n\n logger.info('Server', `Starting Party Server on port ${PARTY_PORT} (Tailscale IP: ${getSelfIp()})`);\n\n // Ignore SIGHUP so the process survives when the parent terminal exits\n process.on('SIGHUP', () => {});\n\n const server = serve({ fetch: app.fetch, port: PARTY_PORT });\n\n // Start background tasks with AbortSignal support\n const discoveryPromise = discovery.runLoop(lifecycleController.signal);\n const cleanupPromise = periodicCleanup();\n\n // Start periodic snapshot loop\n const snapshotLoopPromise = sm.startSnapshotLoop(\n lifecycleController.signal,\n () => registry.listAll(),\n () => messageQueue.getBufferSnapshots(),\n );\n\n // Register signal handlers for graceful shutdown\n const shutdownHandler = () => void performShutdown(server, pidPath);\n process.on('SIGINT', shutdownHandler);\n process.on('SIGTERM', shutdownHandler);\n\n // POST /api/shutdown endpoint (referencing Server.ts pattern)\n app.post('/api/shutdown', (c) => {\n void performShutdown(server, pidPath);\n return c.json({ status: 'shutting_down' });\n });\n\n await Promise.race([discoveryPromise, cleanupPromise, snapshotLoopPromise]);\n}\n\nmain().catch((e) => {\n logger.error('Server', 'Fatal error', e);\n process.exit(1);\n});\n\n// Catch unhandled errors that would silently crash the process\nprocess.on('uncaughtException', (e) => {\n logger.error('Server', 'Uncaught exception', e);\n});\nprocess.on('unhandledRejection', (e) => {\n logger.error('Server', 'Unhandled rejection', e);\n});\n","/**\n * `open-party setup` — install Open Party plugin into Claude Code.\n *\n * Steps:\n * 1. Build plugin package (tsup + build-plugin.mjs)\n * 2. Copy to ~/.claude/plugins/cache/\n * 3. Register in installed_plugins.json + settings.json\n * 4. Start Party Server\n */\n\nimport { existsSync, readFileSync, writeFileSync, mkdirSync, readdirSync, statSync } from 'node:fs';\nimport { join, dirname, resolve } from 'node:path';\nimport { homedir, platform } from 'node:os';\nimport { execSync } from 'node:child_process';\nimport { green, red, cyan, bold } from './tty-utils.js';\nimport { spawnServerInBackground, waitForServerReady, resolvePort } from './server-utils.js';\n\nconst IS_WIN = platform() === 'win32';\nconst ROOT = resolve(import.meta.dirname ?? '.', '..', '..');\n\n// ---------------------------------------------------------------------------\n// Platform-safe file operations\n// ---------------------------------------------------------------------------\n\nfunction sh(cmd: string): void {\n execSync(cmd, { stdio: 'inherit', shell: IS_WIN });\n}\n\nfunction safeRm(target: string): void {\n if (!existsSync(target)) return;\n if (IS_WIN) {\n const isDir = statSync(target).isDirectory();\n sh(isDir ? `rd /s /q \"${target}\"` : `del /f /q \"${target}\"`);\n } else {\n sh(`rm -rf \"${target}\"`);\n }\n}\n\nfunction safeCp(src: string, dst: string): void {\n ensureDir(dst);\n if (IS_WIN) {\n const isDir = statSync(src).isDirectory();\n sh(isDir ? `xcopy \"${src}\" \"${dst}\\\\\" /E /I /Y /Q >nul 2>&1` : `copy /y \"${src}\" \"${dst}\" >nul 2>&1`);\n } else {\n sh(`cp -r \"${src}\" \"${dst}\"`);\n }\n}\n\nfunction ensureDir(filePath: string): void {\n const dir = dirname(filePath);\n if (!existsSync(dir)) mkdirSync(dir, { recursive: true });\n}\n\nfunction readJsonFile<T>(filePath: string, fallback: T): T {\n if (!existsSync(filePath)) return fallback;\n try { return JSON.parse(readFileSync(filePath, 'utf-8')) as T; }\n catch { return fallback; }\n}\n\nfunction writeJsonFile(filePath: string, data: unknown): void {\n ensureDir(filePath);\n writeFileSync(filePath, JSON.stringify(data, null, 2) + '\\n');\n}\n\n// ---------------------------------------------------------------------------\n// Plugin directory discovery\n// ---------------------------------------------------------------------------\n\nfunction findPluginDistDir(): string | null {\n const distDir = join(ROOT, 'dist', 'claude-code');\n if (!existsSync(distDir)) return null;\n\n try {\n const entries = readdirSync(distDir);\n const dirs = entries.filter((e) => e.startsWith('open-party-'));\n if (dirs.length === 0) return null;\n const pluginDir = join(distDir, dirs[dirs.length - 1]);\n if (existsSync(join(pluginDir, '.claude-plugin', 'plugin.json'))) return pluginDir;\n } catch { /* ignore */ }\n return null;\n}\n\nfunction getPluginVersion(pluginDir: string): string {\n const manifest = readJsonFile<{ version?: string }>(join(pluginDir, '.claude-plugin', 'plugin.json'), {});\n if (manifest.version) return manifest.version;\n try {\n const pkg = JSON.parse(readFileSync(join(ROOT, 'package.json'), 'utf-8'));\n if (pkg.version) return pkg.version;\n } catch { /* ignore */ }\n return '0.0.0';\n}\n\n// ---------------------------------------------------------------------------\n// Claude Code plugin installation\n// ---------------------------------------------------------------------------\n\nfunction installToClaudeCode(): boolean {\n const pluginDir = findPluginDistDir();\n if (!pluginDir) {\n console.log(`${red('Plugin package not found. Run \"npm run build:plugin\" first.')}`);\n return false;\n }\n\n const version = getPluginVersion(pluginDir);\n console.log(`Installing Open Party v${version} into Claude Code...\\n`);\n\n // Step 1: Copy plugin to ~/.claude/plugins/cache/\n const installDir = join(homedir(), '.claude', 'plugins', 'cache', 'open-party', 'open-party', version);\n if (existsSync(installDir)) safeRm(installDir);\n mkdirSync(installDir, { recursive: true });\n safeCp(pluginDir, installDir);\n\n // Step 2: Register marketplace\n registerMarketplace(version, pluginDir);\n\n // Step 3: Register in installed_plugins.json\n const pluginsJsonPath = join(homedir(), '.claude', 'plugins', 'installed_plugins.json');\n const pluginsData = readJsonFile<{ version: number; plugins: Record<string, unknown[]> }>(\n pluginsJsonPath, { version: 2, plugins: {} },\n );\n if (!pluginsData.plugins) pluginsData.plugins = {};\n // Clean up old format\n delete pluginsData.plugins['open-party@local'];\n pluginsData.plugins['open-party@open-party'] = [{\n scope: 'user',\n installPath: installDir,\n version,\n installedAt: new Date().toISOString(),\n lastUpdated: new Date().toISOString(),\n }];\n writeJsonFile(pluginsJsonPath, pluginsData);\n\n // Step 4: Enable in settings.json + remove old MCP entry\n const settingsPath = join(homedir(), '.claude', 'settings.json');\n const settings = readJsonFile<Record<string, unknown>>(settingsPath, {});\n\n if ((settings.mcpServers as Record<string, unknown>)?.['open-party']) {\n delete (settings.mcpServers as Record<string, unknown>)['open-party'];\n }\n\n if (!settings.enabledPlugins) settings.enabledPlugins = {};\n delete (settings.enabledPlugins as Record<string, unknown>)['open-party@local'];\n (settings.enabledPlugins as Record<string, boolean>)['open-party@open-party'] = true;\n\n writeJsonFile(settingsPath, settings);\n\n console.log(`${green('Plugin installed successfully.')}`);\n console.log(` Path: ${installDir}\\n`);\n return true;\n}\n\nfunction registerMarketplace(version: string, pluginDir: string): void {\n const marketplaceDir = join(homedir(), '.claude', 'plugins', 'marketplaces', 'open-party');\n const marketplacePluginDir = join(marketplaceDir, '.claude-plugin');\n if (!existsSync(marketplacePluginDir)) mkdirSync(marketplacePluginDir, { recursive: true });\n\n writeJsonFile(join(marketplacePluginDir, 'marketplace.json'), {\n name: 'open-party',\n owner: { name: 'Feynman Zhang' },\n metadata: {\n description: 'Decentralized Agent communication network for Claude Code',\n homepage: 'https://github.com/FeynmanZhang/open-party',\n },\n plugins: [{\n name: 'open-party', version, source: './plugin',\n description: 'Decentralized Agent communication network for Claude Code',\n }],\n });\n\n // Copy plugin files to marketplace\n const pluginSourceDir = join(marketplaceDir, 'plugin');\n if (existsSync(pluginSourceDir)) safeRm(pluginSourceDir);\n mkdirSync(pluginSourceDir, { recursive: true });\n safeCp(pluginDir, pluginSourceDir);\n\n // Register in known_marketplaces.json\n const knownPath = join(homedir(), '.claude', 'plugins', 'known_marketplaces.json');\n const known = readJsonFile<Record<string, unknown>>(knownPath, {});\n known['open-party'] = {\n source: { source: 'github', repo: 'FeynmanZhang/open-party' },\n installLocation: marketplaceDir,\n lastUpdated: new Date().toISOString(),\n };\n writeJsonFile(knownPath, known);\n}\n\n// ---------------------------------------------------------------------------\n// Build\n// ---------------------------------------------------------------------------\n\nfunction buildPlugin(): boolean {\n console.log(`${bold(cyan('Building plugin...'))}\\n`);\n try {\n execSync('node scripts/build-plugin.mjs', { cwd: ROOT, stdio: 'inherit' });\n return true;\n } catch {\n console.log(`${red('Build failed.')}`);\n return false;\n }\n}\n\n// ---------------------------------------------------------------------------\n// Main\n// ---------------------------------------------------------------------------\n\nexport async function setupCommand(): Promise<void> {\n console.log(`\\n${bold(cyan('Open Party Setup'))}\\n`);\n\n // Step 1: Build (skip if pre-built plugin already exists in dist/)\n const existingPlugin = findPluginDistDir();\n if (!existingPlugin) {\n if (!buildPlugin()) {\n process.exit(1);\n }\n } else {\n console.log(`${green('Pre-built plugin found, skipping build.')}\\n`);\n }\n\n // Step 2: Install to Claude Code\n if (!installToClaudeCode()) {\n process.exit(1);\n }\n\n // Step 3: Start Party Server\n console.log(`${bold(cyan('Starting Party Server...'))}\\n`);\n const port = resolvePort([]);\n try {\n spawnServerInBackground(port);\n await waitForServerReady(port, 15_000);\n console.log(`${green('Party Server started on port ' + port)}.\\n`);\n } catch (error) {\n console.log(`${red('Failed to start Party Server:')} ${error instanceof Error ? error.message : String(error)}`);\n console.log(' You can start it manually with: open-party start');\n }\n\n console.log(`${green('Setup complete!')}`);\n console.log(' Restart Claude Code to load the plugin.');\n console.log(` Use ${cyan('open-party agents')} to see who's online.\\n`);\n}\n","/**\n * Terminal UI utilities for interactive CLI prompts.\n *\n * Provides arrow-key selectors (select / multiSelect), text input (prompt),\n * and ANSI color helpers.\n */\n\nimport { createInterface, emitKeypressEvents, type Interface } from 'node:readline';\n\n// ---------------------------------------------------------------------------\n// Colors\n// ---------------------------------------------------------------------------\n\nexport function cyan(text: string): string {\n return `\\x1b[36m${text}\\x1b[0m`;\n}\nexport function green(text: string): string {\n return `\\x1b[32m${text}\\x1b[0m`;\n}\nexport function yellow(text: string): string {\n return `\\x1b[33m${text}\\x1b[0m`;\n}\nexport function red(text: string): string {\n return `\\x1b[31m${text}\\x1b[0m`;\n}\nexport function bold(text: string): string {\n return `\\x1b[1m${text}\\x1b[0m`;\n}\nexport function dim(text: string): string {\n return `\\x1b[2m${text}\\x1b[0m`;\n}\n\n// ---------------------------------------------------------------------------\n// Readline lifecycle\n// ---------------------------------------------------------------------------\n\nexport function createRl(): Interface {\n return createInterface({ input: process.stdin, output: process.stdout });\n}\n\nexport function closeRl(rl: Interface): void {\n rl.close();\n}\n\n// ---------------------------------------------------------------------------\n// Text prompt (for secrets, auth keys, etc.)\n// ---------------------------------------------------------------------------\n\nexport async function prompt(question: string): Promise<string> {\n // If a prior select()/multiSelect() left readline's keypress emitter\n // active on stdin, readline.createInterface would double-echo each char.\n // Remove the leftover keypress handlers so the new interface starts clean.\n if (process.stdin.isTTY) {\n process.stdin.removeAllListeners('keypress');\n // The internal converter (_keypressWrapper) listens on _newListener to\n // re-attach; briefly pause/resume to break the cycle.\n process.stdin.pause();\n }\n const rl = createInterface({ input: process.stdin, output: process.stdout });\n return new Promise<string>((resolve) => {\n rl.question(question, (answer) => {\n rl.close();\n resolve(answer.trim());\n });\n });\n}\n\n// ---------------------------------------------------------------------------\n// Arrow-key single select\n// ---------------------------------------------------------------------------\n\nexport interface SelectOption<T> {\n label: string;\n value: T;\n hint?: string;\n}\n\nexport async function select<T>(\n options: SelectOption<T>[],\n opts?: { message?: string },\n): Promise<T> {\n if (options.length === 0) throw new Error('select() requires at least one option');\n if (options.length === 1) return options[0].value;\n\n const message = opts?.message ?? '';\n\n // Ensure stdin is in raw mode for key-by-key input\n const wasRaw = process.stdin.isRaw;\n if (process.stdin.isTTY) {\n process.stdin.setRawMode(true);\n emitKeypressEvents(process.stdin);\n }\n\n try {\n let cursor = 0;\n\n const render = () => {\n // Move cursor up N lines, clear, and redraw\n const lines = options.length + (message ? 1 : 0);\n process.stdout.write(`\\x1b[${lines}A\\x1b[0J`);\n\n if (message) {\n process.stdout.write(`${message}\\n`);\n }\n for (let i = 0; i < options.length; i++) {\n const opt = options[i];\n const prefix = i === cursor ? `${cyan('❯')} ` : ' ';\n const label = i === cursor ? bold(opt.label) : opt.label;\n const hintStr = opt.hint ? ` ${dim(opt.hint)}` : '';\n process.stdout.write(`${prefix}${label}${hintStr}\\n`);\n }\n };\n\n // Initial render\n if (message) {\n process.stdout.write(`${message}\\n`);\n }\n for (let i = 0; i < options.length; i++) {\n const opt = options[i];\n const prefix = i === cursor ? `${cyan('❯')} ` : ' ';\n const label = i === cursor ? bold(opt.label) : opt.label;\n const hintStr = opt.hint ? ` ${dim(opt.hint)}` : '';\n process.stdout.write(`${prefix}${label}${hintStr}\\n`);\n }\n\n return new Promise<T>((resolve) => {\n const onKey = (ch: string, key: { name?: string; sequence?: string }) => {\n if (key.name === 'up' || key.sequence === '\\x1b[A') {\n cursor = (cursor - 1 + options.length) % options.length;\n render();\n } else if (key.name === 'down' || key.sequence === '\\x1b[B') {\n cursor = (cursor + 1) % options.length;\n render();\n } else if (key.name === 'return' || key.sequence === '\\r') {\n process.stdin.removeListener('keypress', onKey);\n process.stdout.write('\\n');\n resolve(options[cursor].value);\n }\n };\n\n process.stdin.on('keypress', onKey);\n // Emit keypress events on stdin\n if (process.stdin.isTTY) {\n process.stdin.resume();\n }\n });\n } finally {\n if (process.stdin.isTTY) process.stdin.setRawMode(wasRaw ?? false);\n }\n}\n\n// ---------------------------------------------------------------------------\n// Arrow-key multi-select (space to toggle, enter to confirm)\n// ---------------------------------------------------------------------------\n\nexport interface MultiSelectOption<T> {\n label: string;\n value: T;\n}\n\nexport async function multiSelect<T>(\n options: MultiSelectOption<T>[],\n opts?: { message?: string },\n): Promise<T[]> {\n if (options.length === 0) return [];\n\n const message = opts?.message ?? '';\n\n const wasRaw = process.stdin.isRaw;\n if (process.stdin.isTTY) {\n process.stdin.setRawMode(true);\n emitKeypressEvents(process.stdin);\n }\n\n try {\n let cursor = 0;\n const selected = new Set<number>();\n\n const render = () => {\n const lines = options.length + (message ? 1 : 0) + 1; // +1 for instruction line\n process.stdout.write(`\\x1b[${lines}A\\x1b[0J`);\n\n if (message) {\n process.stdout.write(`${message}\\n`);\n }\n process.stdout.write(`${dim(' ↑/↓ navigate, space to select, enter to confirm')}\\n`);\n for (let i = 0; i < options.length; i++) {\n const opt = options[i];\n const prefix = i === cursor ? `${cyan('❯')} ` : ' ';\n const check = selected.has(i) ? green('◉') : '○';\n const label = i === cursor ? bold(opt.label) : opt.label;\n process.stdout.write(`${prefix}${check} ${label}\\n`);\n }\n };\n\n // Initial render\n if (message) {\n process.stdout.write(`${message}\\n`);\n }\n process.stdout.write(`${dim(' ↑/↓ navigate, space to select, enter to confirm')}\\n`);\n for (let i = 0; i < options.length; i++) {\n const opt = options[i];\n const prefix = i === cursor ? `${cyan('❯')} ` : ' ';\n const check = selected.has(i) ? green('◉') : '○';\n const label = i === cursor ? bold(opt.label) : opt.label;\n process.stdout.write(`${prefix}${check} ${label}\\n`);\n }\n\n return new Promise<T[]>((resolve) => {\n const onKey = (_ch: string, key: { name?: string; sequence?: string }) => {\n if (key.name === 'up' || key.sequence === '\\x1b[A') {\n cursor = (cursor - 1 + options.length) % options.length;\n render();\n } else if (key.name === 'down' || key.sequence === '\\x1b[B') {\n cursor = (cursor + 1) % options.length;\n render();\n } else if (key.name === 'space') {\n if (selected.has(cursor)) {\n selected.delete(cursor);\n } else {\n selected.add(cursor);\n }\n render();\n } else if (key.name === 'return' || key.sequence === '\\r') {\n process.stdin.removeListener('keypress', onKey);\n process.stdout.write('\\n');\n const result = Array.from(selected)\n .sort((a, b) => a - b)\n .map((i) => options[i].value);\n resolve(result);\n }\n };\n\n process.stdin.on('keypress', onKey);\n if (process.stdin.isTTY) {\n process.stdin.resume();\n }\n });\n } finally {\n if (process.stdin.isTTY) process.stdin.setRawMode(wasRaw ?? false);\n }\n}","/**\n * Shared utilities for CLI server lifecycle management.\n *\n * Provides PID file management, process detection, health checks,\n * server spawning, and argument parsing for the open-party CLI.\n */\n\nimport { spawn, execSync } from 'node:child_process';\nimport { existsSync, readFileSync, writeFileSync, unlinkSync, mkdirSync, openSync } from 'node:fs';\nimport { join, dirname, resolve } from 'node:path';\nimport { homedir } from 'node:os';\nimport { fileURLToPath } from 'node:url';\n\n// ---------------------------------------------------------------------------\n// Paths\n// ---------------------------------------------------------------------------\n\nconst __dirname = dirname(fileURLToPath(import.meta.url));\n\nexport function pidFilePath(): string {\n const pluginData = process.env.CLAUDE_PLUGIN_DATA || '';\n if (pluginData) return join(pluginData, 'server.pid');\n return join(homedir(), '.open-party', 'server.pid');\n}\n\nexport function logFilePath(): string {\n const pluginData = process.env.CLAUDE_PLUGIN_DATA || '';\n if (pluginData) return join(pluginData, 'server.log');\n return join(homedir(), '.open-party', 'server.log');\n}\n\nfunction serverScriptPath(): string {\n // When bundled, __dirname is dist/cli/ — party-server.js is at dist/party-server.js\n return resolve(__dirname, '..', 'party-server.js');\n}\n\n// ---------------------------------------------------------------------------\n// PID file management\n// ---------------------------------------------------------------------------\n\nexport function readPid(): number | null {\n const path = pidFilePath();\n if (!existsSync(path)) return null;\n try {\n return parseInt(readFileSync(path, 'utf-8').trim(), 10);\n } catch {\n // [ANTI-PATTERN IGNORED]: PID file may not exist or be readable on first run\n return null;\n }\n}\n\nexport function writePid(pid: number): void {\n const path = pidFilePath();\n const dir = dirname(path);\n if (!existsSync(dir)) mkdirSync(dir, { recursive: true });\n writeFileSync(path, String(pid));\n}\n\nexport function removePidFile(): void {\n try { unlinkSync(pidFilePath()); } catch { /* [ANTI-PATTERN IGNORED]: PID file removal is best-effort, missing file is normal */ }\n}\n\n// ---------------------------------------------------------------------------\n// Process detection\n// ---------------------------------------------------------------------------\n\nexport function isProcessRunning(pid: number): boolean {\n if (process.platform === 'win32') {\n try {\n const output = execSync(`tasklist /FI \"PID eq ${pid}\" /NH`, {\n encoding: 'utf-8',\n windowsHide: true,\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n return output.includes(String(pid));\n } catch {\n // [ANTI-PATTERN IGNORED]: Process check on Windows — tasklist failure means process not found\n return false;\n }\n }\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n // [ANTI-PATTERN IGNORED]: signal 0 probe — failure means process not running\n return false;\n }\n}\n\n// ---------------------------------------------------------------------------\n// Health checks\n// ---------------------------------------------------------------------------\n\nexport function resolvePort(): number {\n return parseInt(process.env.PARTY_PORT || '8000', 10);\n}\n\nasync function fetchJson(url: string, timeoutMs: number = 2000): Promise<Record<string, unknown> | null> {\n try {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), timeoutMs);\n const resp = await fetch(url, { signal: controller.signal });\n clearTimeout(timer);\n if (!resp.ok) return null;\n return (await resp.json()) as Record<string, unknown>;\n } catch {\n // [ANTI-PATTERN IGNORED]: Health check — failure means server not reachable, null is the correct signal\n return null;\n }\n}\n\nexport async function isServerHealthy(port?: number): Promise<boolean> {\n const p = port ?? resolvePort();\n const data = await fetchJson(`http://127.0.0.1:${p}/proxy/health`);\n return data !== null && data.status === 'ok';\n}\n\nexport async function getServerHealth(port?: number): Promise<Record<string, unknown> | null> {\n const p = port ?? resolvePort();\n return fetchJson(`http://127.0.0.1:${p}/proxy/health`);\n}\n\nexport async function getServerOverview(port?: number): Promise<Record<string, unknown> | null> {\n const p = port ?? resolvePort();\n return fetchJson(`http://127.0.0.1:${p}/dashboard/api/overview`, 3000);\n}\n\n// ---------------------------------------------------------------------------\n// Server spawning\n// ---------------------------------------------------------------------------\n\nexport async function spawnServerInBackground(port: number): Promise<{ pid: number; ok: boolean }> {\n const script = serverScriptPath();\n if (!existsSync(script)) {\n console.error(`Server script not found: ${script}`);\n return { pid: 0, ok: false };\n }\n\n // Redirect stdout/stderr to log file\n const logPath = logFilePath();\n mkdirSync(dirname(logPath), { recursive: true });\n const logFd = openSync(logPath, 'a');\n\n const env = { ...process.env, PARTY_PORT: String(port) };\n const proc = spawn(process.execPath, [script], {\n stdio: ['ignore', logFd, logFd],\n detached: true,\n windowsHide: true,\n env,\n });\n proc.unref();\n\n const pid = proc.pid!;\n writePid(pid);\n\n proc.on('error', (err) => {\n console.error(`Failed to start server: ${err.message}`);\n });\n\n return { pid, ok: true };\n}\n\nexport async function waitForServerReady(port: number, timeoutMs: number = 10_000): Promise<boolean> {\n const deadline = Date.now() + timeoutMs;\n while (Date.now() < deadline) {\n if (await isServerHealthy(port)) return true;\n\n // Check if the spawned process is still alive (only if we have a PID)\n const pid = readPid();\n if (pid !== null && !isProcessRunning(pid)) {\n return false; // Process crashed\n }\n\n await sleep(500);\n }\n return false;\n}\n\n// ---------------------------------------------------------------------------\n// Process killing\n// ---------------------------------------------------------------------------\n\nexport function killServer(pid: number): void {\n try {\n if (process.platform === 'win32') {\n execSync(`taskkill /F /T /PID ${pid}`, { stdio: 'ignore', windowsHide: true });\n } else {\n process.kill(pid, 'SIGTERM');\n }\n } catch (error) {\n // The process may have already exited — that's the expected case when shutting down.\n // No action needed regardless of outcome.\n void error;\n }\n}\n\n/** Find the PID of the process listening on `port`. Returns null if none found. */\nexport function findPidByPort(port: number): number | null {\n try {\n if (process.platform === 'win32') {\n const output = execSync(\n `netstat -ano -p tcp | findstr \"LISTENING\" | findstr \":${port} \"`,\n { encoding: 'utf-8', windowsHide: true, stdio: ['pipe', 'pipe', 'pipe'] },\n );\n // netstat output: \" TCP 127.0.0.1:8000 0.0.0.0:0 LISTENING 12345\"\n const match = output.trim().match(/\\s(\\d+)\\s*$/);\n return match ? parseInt(match[1], 10) : null;\n }\n // macOS / Linux\n const output = execSync(`lsof -t -i :${port} -sTCP:LISTEN`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n const pid = parseInt(output.trim().split('\\n')[0], 10);\n return Number.isFinite(pid) && pid > 0 ? pid : null;\n } catch {\n // [ANTI-PATTERN IGNORED]: Port lookup — failure means no listener found\n return null;\n }\n}\n\n// ---------------------------------------------------------------------------\n// Argument parsing\n// ---------------------------------------------------------------------------\n\n/** Extract the value following a flag, e.g. extractFlagValue(['--agent-id', 'foo'], '--agent-id') → 'foo' */\nexport function extractFlagValue(args: string[], flag: string): string | undefined {\n for (let i = 0; i < args.length; i++) {\n if (args[i] === flag) return args[i + 1];\n }\n return undefined;\n}\n\nexport interface StartOptions {\n daemon: boolean;\n port: number | null; // null = use env/default\n}\n\nexport function parseStartArgs(args: string[]): StartOptions {\n let daemon = false;\n let port: number | null = null;\n\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '-d' || args[i] === '--daemon') {\n daemon = true;\n } else if (args[i] === '-p' || args[i] === '--port') {\n const val = args[++i];\n if (val) port = parseInt(val, 10);\n } else if (args[i].startsWith('--port=')) {\n port = parseInt(args[i].split('=')[1], 10);\n }\n }\n\n return { daemon, port };\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}","/**\n * `open-party login` — standalone Tailscale login command.\n *\n * Allows users to login to Tailscale after skipping it during setup,\n * or to re-authenticate if their session expired.\n */\n\nimport {\n getTailscaleInstallationStatus,\n} from '../infra/tailscale.js';\nimport { interactiveLogin, authKeyLogin } from './tailscale-login.js';\nimport { red, green, yellow, cyan, bold, select } from './tty-utils.js';\n\nexport async function loginCommand(): Promise<void> {\n const status = getTailscaleInstallationStatus();\n\n if (status.state === 'connected') {\n console.log(`${green('✅ Tailscale is already connected!')}`);\n console.log(` IP: ${status.tailscale_ip} Hostname: ${status.hostname}`);\n return;\n }\n\n if (status.state === 'not_installed') {\n console.log(`${red('❌ Tailscale is not installed.')}`);\n console.log(' Install it first: https://tailscale.com/download');\n console.log(` Then run: ${cyan('open-party login')}`);\n return;\n }\n\n // not_connected\n console.log(`${yellow('🔒 Tailscale is installed but not connected.')}\\n`);\n\n type LoginChoice = 'interactive' | 'authkey';\n const options: { label: string; value: LoginChoice; hint?: string }[] = [\n { label: 'Interactive login', value: 'interactive', hint: 'opens browser to authenticate' },\n { label: 'Auth key', value: 'authkey', hint: 'from network creator' },\n ];\n\n const choice = await select(options, { message: 'Choose a login method:' });\n\n if (choice === 'interactive') {\n await interactiveLogin(status.binary);\n } else {\n await authKeyLogin(status.binary);\n }\n}","/**\n * Shared Tailscale login logic for CLI commands.\n *\n * Extracted from setup.ts so both `setup` and `login` can reuse it.\n */\n\nimport { spawn } from 'node:child_process';\nimport {\n joinTailnet,\n resetTailscaleBinaryCache,\n getTailscaleInstallationStatus,\n} from '../infra/tailscale.js';\nimport { prompt, green, yellow, red, bold, cyan } from './tty-utils.js';\n\n// ---------------------------------------------------------------------------\n// Interactive login (opens browser)\n// ---------------------------------------------------------------------------\n\nexport async function interactiveLogin(binary: string): Promise<boolean> {\n console.log(`\\n${cyan('Running interactive login...')}`);\n console.log('A browser window should open. Authenticate in the browser, then return here.\\n');\n\n const child = spawn(binary, ['login'], { stdio: 'inherit' });\n\n const exitCode = await new Promise<number | null>((resolve) => {\n child.on('close', resolve);\n });\n\n resetTailscaleBinaryCache();\n const status = getTailscaleInstallationStatus();\n\n if (exitCode === 0 && status.state === 'connected') {\n console.log(`\\n${green('✅ Login successful!')} IP: ${status.tailscale_ip}`);\n showAuthKeyTip();\n return true;\n }\n\n console.log(`\\n${yellow('⚠️ Login may not have completed. Status: ' + status.state)}`);\n console.log(' Try running: open-party login');\n return false;\n}\n\n// ---------------------------------------------------------------------------\n// Auth key login\n// ---------------------------------------------------------------------------\n\nexport async function authKeyLogin(binary: string): Promise<boolean> {\n console.log('');\n console.log('Ask the network creator to generate an Auth Key at:');\n console.log(`${cyan(' https://login.tailscale.com/admin/settings/keys')}\\n`);\n\n const authKey = await prompt('Enter Auth Key: ');\n if (!authKey) {\n console.log(yellow('No auth key provided, skipping login.'));\n return false;\n }\n\n const result = joinTailnet(authKey);\n\n if (result.success) {\n resetTailscaleBinaryCache();\n const status = getTailscaleInstallationStatus();\n console.log(`\\n${green('✅ Login successful!')} IP: ${status.state === 'connected' ? status.tailscale_ip : 'unknown'}`);\n showAuthKeyTip();\n return true;\n }\n\n console.log(`\\n${red('❌ Login failed:')}\\n${result.output}`);\n console.log(' Check your auth key and try again.');\n return false;\n}\n\n// ---------------------------------------------------------------------------\n// Auth key sharing tip\n// ---------------------------------------------------------------------------\n\nexport function showAuthKeyTip(): void {\n console.log('');\n console.log(`${bold('💡 To share network access with teammates:')}`);\n console.log(' 1. Go to https://login.tailscale.com/admin/settings/keys');\n console.log(' 2. Generate an Auth Key');\n console.log(' 3. Share it with teammates — they can run: open-party login');\n}","/**\n * `open-party logout` — log out of the current Tailscale network.\n *\n * Disconnects from Tailscale and invalidates the node key,\n * requiring re-authentication to reconnect.\n */\n\nimport { getTailscaleInstallationStatus, logoutTailscale } from '../infra/tailscale.js';\nimport { select, green, red, yellow } from './tty-utils.js';\n\nexport async function logoutCommand(): Promise<void> {\n const status = getTailscaleInstallationStatus();\n\n if (status.state === 'not_installed') {\n console.log(red('❌ Tailscale is not installed.'));\n return;\n }\n\n if (status.state === 'not_connected') {\n console.log(yellow('⚠️ Tailscale is not connected — nothing to log out from.'));\n return;\n }\n\n // connected — confirm before logging out\n type LogoutChoice = 'logout' | 'cancel';\n const choice = await select<LogoutChoice>(\n [\n { label: 'Log out (remove credentials)', value: 'logout', hint: 'need to re-authenticate next time' },\n { label: 'Cancel', value: 'cancel' },\n ],\n { message: 'Are you sure you want to log out?' },\n );\n\n if (choice === 'cancel') return;\n\n console.log('Logging out of Tailscale...');\n const result = logoutTailscale();\n\n if (result.success) {\n console.log(green('✅ Logged out successfully.'));\n console.log(' To reconnect, run: open-party login');\n } else {\n console.log(red('❌ Logout failed:'), result.output);\n }\n}","/**\n * Start the Party Server.\n *\n * Supports foreground mode (default) and daemon mode (--daemon / -d).\n * Use --port / -p to override PARTY_PORT for a single invocation.\n */\n\nimport {\n parseStartArgs,\n resolvePort,\n isServerHealthy,\n readPid,\n isProcessRunning,\n removePidFile,\n spawnServerInBackground,\n waitForServerReady,\n logFilePath,\n writePid,\n} from './server-utils.js';\n\nexport async function startServer(args: string[] = []): Promise<void> {\n const opts = parseStartArgs(args);\n const port = opts.port ?? resolvePort();\n\n if (opts.daemon) {\n await startDaemon(port);\n } else {\n await startForeground();\n }\n}\n\n// ---------------------------------------------------------------------------\n// Foreground mode — server runs in current process\n// ---------------------------------------------------------------------------\n\nasync function startForeground(): Promise<void> {\n // Write PID file so `stop` and `status` can find this process\n writePid(process.pid);\n\n // Clean up PID file on any exit\n process.on('exit', () => {\n removePidFile();\n });\n\n // Dynamic import — the server module self-starts on import\n await import('../server/index.js');\n}\n\n// ---------------------------------------------------------------------------\n// Daemon mode — server runs in a detached background process\n// ---------------------------------------------------------------------------\n\nasync function startDaemon(port: number): Promise<void> {\n // Already running?\n if (await isServerHealthy(port)) {\n const pid = readPid();\n console.log(`Party Server is already running (PID ${pid ?? 'unknown'}, port ${port}).`);\n process.exit(0);\n }\n\n // Clean up stale PID file\n const existingPid = readPid();\n if (existingPid !== null && !isProcessRunning(existingPid)) {\n removePidFile();\n }\n\n // Spawn\n const { pid, ok } = await spawnServerInBackground(port);\n if (!ok) {\n process.exit(1);\n }\n\n // Wait for ready\n console.log(`Starting Party Server in background (PID ${pid})...`);\n const ready = await waitForServerReady(port);\n\n if (ready) {\n console.log(`Party Server is running on port ${port}.`);\n console.log(` Dashboard: http://127.0.0.1:${port}/dashboard`);\n console.log(` Logs: ${logFilePath()}`);\n console.log(` Use 'open-party stop' to stop the server.`);\n } else {\n console.error('Party Server failed to start within timeout.');\n console.error(`Check logs: ${logFilePath()}`);\n process.exit(1);\n }\n}","/**\n * Stop the Party Server.\n *\n * Strategy (referencing src-example/services/infrastructure/HealthMonitor.ts httpShutdown pattern):\n * 1. Try POST /api/shutdown for graceful shutdown (8s timeout)\n * 2. Wait for process exit\n * 3. Fallback to taskkill /F /T (force kill) if graceful fails\n */\n\nimport { readPid, isProcessRunning, killServer, removePidFile, isServerHealthy, resolvePort, findPidByPort } from './server-utils.js';\n\n/** Try graceful shutdown via HTTP endpoint. Returns true if server acknowledged. */\nasync function stopServerGracefully(pid: number, port: number): Promise<boolean> {\n try {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), 8000);\n const resp = await fetch(`http://127.0.0.1:${port}/api/shutdown`, {\n method: 'POST',\n signal: controller.signal,\n });\n clearTimeout(timer);\n return resp.ok;\n } catch {\n // ECONNREFUSED = already stopped; timeout = not responding — both mean fallback needed\n return false;\n }\n}\n\n/** Wait up to `timeoutMs` for a process to exit. Returns true if it exited. */\nasync function waitForProcessExit(pid: number, timeoutMs: number = 10_000): Promise<boolean> {\n const deadline = Date.now() + timeoutMs;\n while (Date.now() < deadline) {\n if (!isProcessRunning(pid)) return true;\n await new Promise((r) => setTimeout(r, 200));\n }\n return false;\n}\n\nexport async function stopServer(): Promise<void> {\n const pid = readPid();\n const port = resolvePort();\n\n // No PID file — check if a server is still responding on port\n if (pid === null) {\n const healthy = await isServerHealthy(port);\n if (healthy) {\n const foundPid = findPidByPort(port);\n if (foundPid !== null && isProcessRunning(foundPid)) {\n console.log(`No PID file found, but a server is responding on port ${port} (PID ${foundPid}).`);\n console.log(`Stopping by port lookup...`);\n killServer(foundPid);\n const stillUp = await isServerHealthy(port);\n if (!stillUp) {\n console.log('Party Server stopped.');\n return;\n }\n console.warn(`Process ${foundPid} was killed, but port ${port} is still responding.`);\n } else {\n console.log(`No PID file found, and no process found on port ${port}.`);\n }\n } else {\n console.log('Party Server is not running (no PID file found).');\n }\n return;\n }\n\n if (!isProcessRunning(pid)) {\n // Stale PID file — process is dead\n console.log(`Stale PID file found (PID ${pid} is not running). Cleaning up.`);\n removePidFile();\n return;\n }\n\n // Process is alive — try graceful shutdown first\n console.log(`Stopping Party Server (PID ${pid})...`);\n\n const gracefulOk = await stopServerGracefully(pid, port);\n if (gracefulOk) {\n // Server accepted shutdown request — wait for process exit\n const exited = await waitForProcessExit(pid);\n if (exited) {\n removePidFile();\n console.log('Party Server stopped gracefully.');\n return;\n }\n // Graceful ack'd but didn't exit in time — fall through to force kill\n console.warn('Graceful shutdown timed out, falling back to force kill...');\n }\n\n // Fallback: force kill\n killServer(pid);\n removePidFile();\n\n // Verify it's actually down\n const stillUp = await isServerHealthy(port);\n if (stillUp) {\n console.warn(`Process ${pid} was killed, but port ${port} is still responding.`);\n console.warn('Another process may be using this port.');\n } else {\n console.log('Party Server stopped.');\n }\n}","/**\n * Show the status of the Party Server.\n *\n * Displays PID, port, uptime, agent count, and Tailscale info\n * when the server is running. Handles four states:\n * 1. Running & healthy\n * 2. Process alive but not yet healthy (starting up)\n * 3. Stale PID file (process dead)\n * 4. Not running (no PID file)\n */\n\nimport {\n readPid,\n isProcessRunning,\n isServerHealthy,\n getServerHealth,\n getServerOverview,\n resolvePort,\n} from './server-utils.js';\n\nexport async function statusCommand(): Promise<void> {\n const port = resolvePort();\n const pid = readPid();\n\n let processAlive = false;\n if (pid !== null) {\n processAlive = isProcessRunning(pid);\n }\n\n const healthy = await isServerHealthy(port);\n\n if (healthy) {\n const health = await getServerHealth(port);\n const overview = await getServerOverview(port);\n\n console.log('Party Server is running.');\n console.log(` PID: ${pid ?? 'unknown (no PID file)'}`);\n console.log(` Port: ${port}`);\n console.log(` Tailscale IP: ${(health as any)?.tailscale_ip ?? 'N/A'}`);\n console.log(` Hostname: ${(health as any)?.hostname ?? 'N/A'}`);\n\n if (overview) {\n const server = overview.server as Record<string, unknown> | undefined;\n const agents = overview.agents as Record<string, unknown> | undefined;\n if (server?.uptime_seconds != null) {\n const uptime = server.uptime_seconds as number;\n const mins = Math.floor(uptime / 60);\n const secs = Math.floor(uptime % 60);\n console.log(` Uptime: ${mins}m ${secs}s`);\n }\n console.log(` Local agents: ${(agents?.local_count as number) ?? 'N/A'}`);\n console.log(` Remote agents: ${(agents?.remote_count as number) ?? 'N/A'}`);\n } else {\n console.log(` Local agents: ${(health as any)?.agent_count ?? 'N/A'}`);\n }\n\n console.log(` Dashboard: http://127.0.0.1:${port}/dashboard`);\n } else if (processAlive && pid !== null) {\n // PID file has a live process but health check fails\n console.log('Party Server process exists but is not responding on health endpoint.');\n console.log(` PID: ${pid}`);\n console.log(' The server may be starting up or has crashed.');\n console.log(` Logs: ~/.open-party/server.log`);\n } else if (pid !== null) {\n console.log('Party Server is NOT running (stale PID file).');\n console.log(` PID file references PID ${pid}, which is not a live process.`);\n console.log(' Use: open-party start to start the server.');\n } else {\n console.log('Party Server is NOT running.');\n console.log(' No PID file found.');\n console.log(' Use: open-party start to start the server.');\n }\n}","/**\n * `open-party --version` / `open-party -v` — show version number.\n */\n\nimport { readFileSync } from 'node:fs';\nimport { resolve, dirname } from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\nexport function showVersion(): void {\n // tsup bundles to dist/cli/index.js, package.json is at the project root: ../../package.json\n // When installed via npm: <pkg-root>/dist/cli/index.js → <pkg-root>/package.json\n const pkgPath = resolve(dirname(fileURLToPath(import.meta.url)), '..', '..', 'package.json');\n const pkg = JSON.parse(readFileSync(pkgPath, 'utf-8'));\n console.log(`open-party v${pkg.version}`);\n}","/**\n * Party Server HTTP client.\n *\n * Encapsulates all API calls to the Party Server so that hook handlers,\n * MCP servers, plugins, and any other consumer share a single HTTP layer.\n */\n\nexport class PartyHttpClient {\n private baseUrl: string;\n private timeout: number;\n\n constructor(baseUrl = 'http://127.0.0.1:8000', timeout = 5000) {\n this.baseUrl = baseUrl.replace(/\\/$/, '');\n this.timeout = timeout;\n }\n\n // -- Agent lifecycle --\n\n private async request(path: string, options: RequestInit = {}): Promise<unknown> {\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), this.timeout);\n try {\n const resp = await fetch(`${this.baseUrl}${path}`, {\n ...options,\n signal: controller.signal,\n headers: {\n 'Content-Type': 'application/json',\n ...(options.headers as Record<string, string> | undefined),\n },\n });\n if (!resp.ok) throw new Error(`HTTP ${resp.status}: ${resp.statusText}`);\n return resp.json();\n } finally {\n clearTimeout(timer);\n }\n }\n\n async register(agentId: string, displayName?: string, metadata?: Record<string, unknown>, callbackUrl?: string): Promise<Record<string, unknown>> {\n return this.request('/agent/register', {\n method: 'POST',\n body: JSON.stringify({ agent_id: agentId, display_name: displayName, metadata: metadata ?? {}, callback_url: callbackUrl }),\n }) as Promise<Record<string, unknown>>;\n }\n\n async remove(agentId: string): Promise<boolean> {\n const result = await this.request('/agent/remove', {\n method: 'POST',\n body: JSON.stringify({ agent_id: agentId }),\n }) as Record<string, unknown>;\n return result.status === 'removed';\n }\n\n async heartbeat(agentId: string, displayName?: string, metadata?: Record<string, unknown>, callbackUrl?: string): Promise<Record<string, unknown>> {\n return this.request('/agent/heartbeat', {\n method: 'POST',\n body: JSON.stringify({ agent_id: agentId, display_name: displayName, metadata, callback_url: callbackUrl }),\n }) as Promise<Record<string, unknown>>;\n }\n\n async listAgents(): Promise<Record<string, unknown>> {\n return this.request('/agent/list') as Promise<Record<string, unknown>>;\n }\n\n // -- Messaging --\n\n async sendMessage(senderId: string, recipientId: string, content: string, summary?: string): Promise<Record<string, unknown>> {\n return this.request('/agent/send', {\n method: 'POST',\n body: JSON.stringify({ sender_id: senderId, recipient_id: recipientId, content, summary }),\n }) as Promise<Record<string, unknown>>;\n }\n\n async checkMessages(agentId: string): Promise<Record<string, unknown>[]> {\n const result = await this.request(`/agent/messages/${agentId}`) as Record<string, unknown>;\n return (result.messages as Record<string, unknown>[]) ?? [];\n }\n\n /** Get message history for an agent. */\n async getMessageHistory(agentId: string, limit = 20): Promise<Record<string, unknown>[]> {\n const result = await this.request(`/agent/history/${agentId}?limit=${limit}`) as Record<string, unknown>;\n return (result.history as Record<string, unknown>[]) ?? [];\n }\n\n // -- Proxy --\n\n async health(): Promise<Record<string, unknown>> {\n return this.request('/proxy/health') as Promise<Record<string, unknown>>;\n }\n\n async listPeers(): Promise<Record<string, unknown>> {\n return this.request('/proxy/peers') as Promise<Record<string, unknown>>;\n }\n}\n","/**\n * CLI command: list-agents (also aliased as `agents`)\n *\n * List all agents currently online in the Open Party network.\n * Usage: open-party list-agents [--json]\n * open-party agents [--json]\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\n\nexport async function listAgentsCommand(args: string[]): Promise<void> {\n const jsonMode = args.includes('--json');\n const client = new PartyHttpClient();\n\n try {\n await client.health();\n } catch {\n console.log('Party Server is not running.');\n console.log(\" Use 'open-party start' to start it.\");\n return;\n }\n\n try {\n const data = await client.listAgents();\n const allAgents = (data.agents as Record<string, unknown>[]) ?? [];\n const localCount = (data.local_count as number) ?? 0;\n const remoteCount = (data.remote_count as number) ?? 0;\n const localAgents = allAgents.slice(0, localCount);\n const remoteAgents = allAgents.slice(localCount);\n const totalCount = localCount + remoteCount;\n\n if (jsonMode) {\n console.log(JSON.stringify({ agents: allAgents, count: totalCount, local_count: localCount, remote_count: remoteCount }, null, 2));\n return;\n }\n\n if (totalCount === 0) {\n console.log('No agents currently online.');\n return;\n }\n\n // Local agents\n if (localCount === 0) {\n console.log('Local agents: (none)');\n } else {\n console.log(`Local agents (${localCount}):`);\n for (const agent of localAgents) {\n const id = (agent.agent_id as string) ?? '?';\n const name = (agent.display_name as string) ?? id;\n const ago = formatTimeAgo(agent.last_heartbeat as number | undefined);\n console.log(` ${id.padEnd(20)} ${name.padEnd(16)} ${ago}`);\n }\n }\n\n // Remote agents\n if (remoteCount > 0) {\n console.log(`\\nRemote agents (${remoteCount}):`);\n for (const agent of remoteAgents) {\n const id = (agent.agent_id as string) ?? '?';\n const name = (agent.display_name as string) ?? id;\n const via = (agent.source_peer_ip as string) ?? '?';\n const ago = formatTimeAgo(agent.last_heartbeat as number | undefined);\n console.log(` ${id.padEnd(20)} ${name.padEnd(16)} (via ${via}) ${ago}`);\n }\n }\n\n console.log('');\n console.log('Tip: Use `open-party send-message --recipient <id>` to reach any agent above.');\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`Error: ${msg}`);\n process.exit(1);\n }\n}\n\nfunction formatTimeAgo(timestamp: number | undefined): string {\n if (!timestamp) return '—';\n const diff = Date.now() / 1000 - timestamp;\n if (diff < 60) return 'just now';\n if (diff < 3600) return `${Math.floor(diff / 60)} min ago`;\n if (diff < 86400) return `${Math.floor(diff / 3600)} hr ago`;\n return `${Math.floor(diff / 86400)}d ago`;\n}\n","/**\n * `open-party peers` — list discovered peer nodes.\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\n\ntype PeerStateView = {\n ip: string;\n status: string;\n consecutiveFailures: number;\n lastProbeAt: number;\n backoffUntil: number | null;\n};\n\ntype RemoteAgentEntry = {\n source_peer_ip: string;\n};\n\nexport async function peersCommand(args: string[] = []): Promise<void> {\n const jsonMode = args.includes('--json');\n const client = new PartyHttpClient();\n\n try {\n await client.health();\n } catch {\n console.log('Party Server is not running.');\n console.log(\" Use 'open-party start' to start it.\");\n return;\n }\n\n try {\n const [peerData, agentData] = await Promise.all([\n client.listPeers(),\n client.listAgents(),\n ]);\n\n const peers = (peerData.peers as PeerStateView[]) ?? [];\n const remoteAgents = ((agentData.agents as Record<string, unknown>[]) ?? [])\n .filter((a) => a.source_peer_ip) as RemoteAgentEntry[];\n\n // Build map: peer_ip → agent_count\n const peerAgentCounts = new Map<string, number>();\n for (const agent of remoteAgents) {\n const ip = agent.source_peer_ip as string;\n peerAgentCounts.set(ip, (peerAgentCounts.get(ip) ?? 0) + 1);\n }\n\n const total = (peerData.total as number) ?? peers.length;\n\n if (jsonMode) {\n console.log(JSON.stringify({\n peers: peers.map((p) => ({\n ...p,\n agent_count: peerAgentCounts.get(p.ip) ?? 0,\n })),\n total,\n }, null, 2));\n return;\n }\n\n if (peers.length === 0) {\n console.log('No peers discovered yet.');\n return;\n }\n\n console.log(`Peers (${total}):\\n`);\n\n for (const peer of peers) {\n const agentCount = peerAgentCounts.get(peer.ip);\n const agentStr = agentCount != null ? String(agentCount) : '—';\n const statusStr = formatStatus(peer.status);\n console.log(` ${peer.ip.padEnd(18)} ${statusStr.padEnd(16)} ${agentStr} agents`);\n }\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`Error: ${msg}`);\n process.exit(1);\n }\n}\n\nfunction formatStatus(status: string): string {\n const map: Record<string, string> = {\n ALIVE: 'Online',\n DEAD: 'Down',\n UNKNOWN: 'Unknown',\n };\n return map[status] ?? status;\n}\n","/**\n * Identity resolution for CLI commands.\n *\n * Resolves the calling agent's identity using a priority chain:\n * 1. --agent-id flag (explicit override)\n * 2. OPEN_PARTY_AGENT_ID environment variable\n * 3. Auto-detect: most recently modified session file in ~/.open-party/sessions/\n * 4. Error + exit guidance\n */\n\nimport { existsSync, readdirSync, readFileSync, statSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\n\nimport { SESSIONS_DIR, readSessionByAgent } from '../client/shared/session-store.js';\n\nexport interface ResolvedIdentity {\n agent_id: string;\n display_name: string;\n server_url: string;\n}\n\n/**\n * Resolve agent identity from the session store.\n *\n * Priority:\n * 1. explicitAgentId (from --agent-id flag)\n * 2. OPEN_PARTY_AGENT_ID env var\n * 3. Most recent session file by mtime\n *\n * @throws If no identity can be resolved.\n */\nexport function resolveIdentity(explicitAgentId?: string | null): ResolvedIdentity {\n // 1. Explicit flag\n if (explicitAgentId) {\n const session = readSessionByAgent(explicitAgentId);\n if (!session) {\n console.error(`Error: Agent \"${explicitAgentId}\" not found in session store.`);\n console.error('Run \"open-party setup\" to register, or use --agent-id with a known ID.');\n process.exit(1);\n }\n return {\n agent_id: explicitAgentId,\n display_name: (session.display_name as string) || explicitAgentId,\n server_url: (session.server_url as string) || 'http://127.0.0.1:8000',\n };\n }\n\n // 2. Environment variable\n const envId = process.env.OPEN_PARTY_AGENT_ID;\n if (envId) {\n const session = readSessionByAgent(envId);\n if (!session) {\n console.error(`Error: Agent \"${envId}\" (from OPEN_PARTY_AGENT_ID) not found in session store.`);\n process.exit(1);\n }\n return {\n agent_id: envId,\n display_name: (session.display_name as string) || envId,\n server_url: (session.server_url as string) || 'http://127.0.0.1:8000',\n };\n }\n\n // 3. Auto-detect: most recent session by mtime\n if (!existsSync(SESSIONS_DIR)) {\n console.error('Error: No Open Party session found.');\n console.error('Run \"open-party setup\" to get started, or provide --agent-id.');\n process.exit(1);\n }\n\n const files = readdirSync(SESSIONS_DIR).filter((f) => f.endsWith('.json'));\n if (files.length === 0) {\n console.error('Error: No active Open Party sessions.');\n console.error('Run \"open-party setup\" to register, or provide --agent-id.');\n process.exit(1);\n }\n\n // Sort by mtime descending — most recently modified first\n const sorted = files.sort((a, b) =>\n statSync(join(SESSIONS_DIR, b)).mtimeMs - statSync(join(SESSIONS_DIR, a)).mtimeMs,\n );\n\n const latestFile = sorted[0];\n const raw = JSON.parse(readFileSync(join(SESSIONS_DIR, latestFile), 'utf-8'));\n\n return {\n agent_id: raw.agent_id as string,\n display_name: (raw.display_name as string) || raw.agent_id,\n server_url: (raw.server_url as string) || 'http://127.0.0.1:8000',\n };\n}\n","/**\n * Shared filesystem session store for Open Party adapters.\n *\n * Both OpenClaw and Claude Code adapters persist session data\n * (agent_id, display_name, server_url) to ~/.open-party/ so that\n * agent identity survives runtime restarts.\n */\n\nimport { existsSync, mkdirSync, readFileSync, readdirSync, unlinkSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\n\nconst SESSION_DIR = join(homedir(), '.open-party');\nexport const SESSIONS_DIR = join(SESSION_DIR, 'sessions');\nexport const AGENTS_DIR = join(SESSION_DIR, 'agents');\n\n/** Create directory if it doesn't exist. */\nexport function ensureDir(dir: string): void {\n if (!existsSync(dir)) mkdirSync(dir, { recursive: true });\n}\n\n/** Write forward (session→agent) and reverse (agent→session) mappings. */\nexport function writeSession(sessionId: string, agentId: string, displayName: string, serverUrl: string, sessionKey?: string, online?: boolean): void {\n ensureDir(SESSIONS_DIR);\n ensureDir(AGENTS_DIR);\n\n const sessionData = { agent_id: agentId, display_name: displayName, server_url: serverUrl, session_id: sessionId, session_key: sessionKey, online: online ?? false };\n writeFileSync(join(SESSIONS_DIR, `${sessionId}.json`), JSON.stringify(sessionData));\n writeFileSync(join(AGENTS_DIR, `${agentId}.json`), JSON.stringify({ session_id: sessionId }));\n}\n\n/** Update the online status of a session by agent_id. */\nexport function updateOnlineStatus(agentId: string, online: boolean): void {\n const session = readSessionByAgent(agentId);\n if (!session) return;\n const sessionId = session.session_id as string;\n const path = join(SESSIONS_DIR, `${sessionId}.json`);\n if (!existsSync(path)) return;\n const data = JSON.parse(readFileSync(path, 'utf-8'));\n data.online = online;\n writeFileSync(path, JSON.stringify(data));\n}\n\n/** Read session info by session_id (forward lookup). */\nexport function readSession(sessionId: string): Record<string, string> | undefined {\n const path = join(SESSIONS_DIR, `${sessionId}.json`);\n if (!existsSync(path)) return undefined;\n return JSON.parse(readFileSync(path, 'utf-8'));\n}\n\n/** Read session info by agent_id (reverse lookup via agents/ mapping). */\nexport function readSessionByAgent(agentId: string): Record<string, string> | undefined {\n const mappingPath = join(AGENTS_DIR, `${agentId}.json`);\n if (!existsSync(mappingPath)) return undefined;\n const mapping = JSON.parse(readFileSync(mappingPath, 'utf-8'));\n return readSession(mapping.session_id);\n}\n\n/** Remove forward and reverse mappings for a session. */\nexport function clearSession(sessionId: string): void {\n const sessionPath = join(SESSIONS_DIR, `${sessionId}.json`);\n if (!existsSync(sessionPath)) return;\n\n const sessionData = JSON.parse(readFileSync(sessionPath, 'utf-8'));\n const agentId: string | undefined = sessionData.agent_id;\n\n try { unlinkSync(sessionPath); } catch { /* ignore */ }\n if (agentId) {\n try { unlinkSync(join(AGENTS_DIR, `${agentId}.json`)); } catch { /* ignore */ }\n }\n}\n\n/** Find any active session (for commands that need \"the current session\"). */\nexport function findAnySession(): Record<string, string> | undefined {\n if (!existsSync(SESSIONS_DIR)) return undefined;\n const files = readdirSync(SESSIONS_DIR).filter((f) => f.endsWith('.json'));\n if (files.length === 0) return undefined;\n return readSession(files[0].slice(0, -5));\n}\n\n/** Clear all sessions and agent mappings (e.g., on gateway restart). */\nexport function clearAllSessions(): void {\n if (existsSync(SESSIONS_DIR)) {\n for (const f of readdirSync(SESSIONS_DIR).filter((f) => f.endsWith('.json'))) {\n try { unlinkSync(join(SESSIONS_DIR, f)); } catch { /* ignore */ }\n }\n }\n if (existsSync(AGENTS_DIR)) {\n for (const f of readdirSync(AGENTS_DIR).filter((f) => f.endsWith('.json'))) {\n try { unlinkSync(join(AGENTS_DIR, f)); } catch { /* ignore */ }\n }\n }\n}\n","/**\n * CLI command: send-message\n *\n * Send a message to another agent on the Open Party network.\n * Usage: open-party send-message --recipient <id> --content <text> [--summary <text>] [--agent-id <id>] [--json]\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\nimport { resolveIdentity } from './identity.js';\nimport { extractFlagValue } from './server-utils.js';\n\nexport async function sendMessageCommand(args: string[]): Promise<void> {\n const jsonMode = args.includes('--json');\n const recipient = extractFlagValue(args, '--recipient');\n const content = extractFlagValue(args, '--content');\n const summary = extractFlagValue(args, '--summary');\n const agentId = extractFlagValue(args, '--agent-id');\n\n if (!recipient || !content) {\n console.error('Usage: open-party send-message --recipient <agent-id> --content <message> [--summary <text>] [--agent-id <id>] [--json]');\n process.exit(1);\n }\n\n const identity = resolveIdentity(agentId ?? null);\n const client = new PartyHttpClient(identity.server_url);\n\n try {\n const result = await client.sendMessage(identity.agent_id, recipient, content, summary);\n\n if (jsonMode) {\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n const status = result.status as string;\n if (status === 'delivered_locally' || status === 'forwarded') {\n console.log(`[Sent] to ${recipient}`);\n } else if (status === 'agent_not_found') {\n console.error(`[Warning] ${recipient} not found. Use \\`open-party list-agents\\` to see who's online.`);\n process.exit(1);\n } else {\n console.log(`[${status}] to ${recipient}`);\n }\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`Error: ${msg}`);\n process.exit(1);\n }\n}\n","/**\n * CLI command: check-messages\n *\n * Pull unread messages and optionally show message history.\n * Usage: open-party check-messages [--agent-id <id>] [--history] [--limit N] [--json]\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\nimport { resolveIdentity } from './identity.js';\nimport { extractFlagValue } from './server-utils.js';\n\nexport async function checkMessagesCommand(args: string[]): Promise<void> {\n const jsonMode = args.includes('--json');\n const showHistory = args.includes('--history');\n const agentIdFlag = extractFlagValue(args, '--agent-id');\n const limitStr = extractFlagValue(args, '--limit');\n const limit = limitStr ? Math.min(Math.max(parseInt(limitStr, 10), 1), 50) : 10;\n\n const identity = resolveIdentity(agentIdFlag);\n const client = new PartyHttpClient(identity.server_url);\n\n try {\n // Unread messages\n const messages = await client.checkMessages(identity.agent_id);\n\n if (jsonMode) {\n const result: Record<string, unknown> = { messages, count: messages.length };\n if (showHistory) {\n const history = await client.getMessageHistory(identity.agent_id, limit);\n result.history = history;\n result.history_count = history.length;\n }\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n if (messages.length > 0) {\n console.log(`New Messages (${messages.length})`);\n for (const msg of messages) {\n console.log('');\n console.log('---');\n console.log(`From: \\`${msg.sender_id}\\``);\n if (msg.summary) console.log(`Summary: ${msg.summary}`);\n console.log('');\n console.log(`> ${msg.content}`);\n }\n console.log('');\n console.log('Reply with `open-party send-message --recipient <id> --content \"reply\"` if needed.');\n } else {\n console.log('No new messages.');\n }\n\n // History when --history flag is passed\n if (showHistory) {\n const history = await client.getMessageHistory(identity.agent_id, limit);\n\n if (history.length === 0) {\n console.log('\\nNo message history yet.');\n return;\n }\n\n console.log(`\\nMessage History (last ${history.length})`);\n for (const entry of history) {\n console.log('');\n console.log('---');\n const isSent = entry.sender_id === identity.agent_id;\n const arrow = isSent ? '->' : '<-';\n const peer = isSent ? (entry.recipient_id as string) : (entry.sender_id as string);\n console.log(`${arrow} To: \\`${peer}\\``);\n console.log(`> ${entry.content}`);\n }\n }\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`Error: ${msg}`);\n process.exit(1);\n }\n}\n","/**\n * `open-party online` — register this agent with the Party Server.\n *\n * Reads identity from session store, registers with the server,\n * and marks the session as online.\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\nimport { resolveIdentity } from './identity.js';\nimport { updateOnlineStatus } from '../client/shared/session-store.js';\nimport { green, red, cyan, bold } from './tty-utils.js';\n\nfunction parseArgs(args: string[]): { name?: string } {\n const result: { name?: string } = {};\n for (let i = 0; i < args.length; i++) {\n if (args[i] === '--name' && args[i + 1]) {\n result.name = args[++i];\n }\n }\n return result;\n}\n\nexport async function onlineCommand(args: string[] = []): Promise<void> {\n const { name } = parseArgs(args);\n const identity = resolveIdentity();\n const displayName = name || identity.display_name;\n\n const client = new PartyHttpClient(identity.server_url);\n\n try {\n await client.health();\n } catch {\n console.log(`${red('Party Server is not running.')}`);\n console.log(\" Use 'open-party start' to start it.\");\n process.exit(1);\n }\n\n try {\n await client.register(identity.agent_id, displayName, { type: 'claude-code' });\n updateOnlineStatus(identity.agent_id, true);\n console.log(`${green(bold('Online'))} ${identity.agent_id} (${displayName})`);\n console.log(` Use ${cyan('open-party agents')} to see who else is online.`);\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`${red('Failed to go online:')} ${msg}`);\n process.exit(1);\n }\n}\n","/**\n * `open-party offline` — unregister this agent from the Party Server.\n */\n\nimport { PartyHttpClient } from '../client/shared/client.js';\nimport { resolveIdentity } from './identity.js';\nimport { updateOnlineStatus } from '../client/shared/session-store.js';\nimport { green, red, yellow, bold } from './tty-utils.js';\n\nexport async function offlineCommand(): Promise<void> {\n const identity = resolveIdentity();\n const client = new PartyHttpClient(identity.server_url);\n\n try {\n await client.health();\n } catch {\n // Server not running — agent is already effectively offline\n updateOnlineStatus(identity.agent_id, false);\n console.log(`${yellow('Party Server is not running.')} Marked as offline.`);\n return;\n }\n\n try {\n await client.remove(identity.agent_id);\n updateOnlineStatus(identity.agent_id, false);\n console.log(`${green(bold('Offline'))} ${identity.agent_id} (${identity.display_name})`);\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n console.error(`${red('Failed to go offline:')} ${msg}`);\n process.exit(1);\n }\n}\n","/**\n * Command registry for the Open Party CLI.\n *\n * Each command registers its metadata here so that help text,\n * per-command help, and validation can be generated from a single source.\n */\n\nexport interface CommandOption {\n flags: string;\n description: string;\n}\n\nexport interface CommandDef {\n name: string;\n alias?: string;\n scope: 'user' | 'agent';\n description: string;\n usage: string;\n options?: CommandOption[];\n examples?: string[];\n}\n\nexport const COMMANDS: CommandDef[] = [\n {\n name: 'setup',\n scope: 'user',\n description: 'Build & install plugin into Claude Code, then start server',\n usage: 'open-party setup',\n },\n {\n name: 'start',\n scope: 'user',\n description: 'Start the Party Server (default when no command given)',\n usage: 'open-party start [-d] [-p <port>]',\n options: [\n { flags: '-d, --daemon', description: 'Run in background (daemon mode)' },\n { flags: '-p, --port <port>', description: 'Override port (default: 8000, env: PARTY_PORT)' },\n ],\n examples: [\n 'open-party start',\n 'open-party start -d',\n 'open-party start -d -p 9000',\n ],\n },\n {\n name: 'stop',\n scope: 'user',\n description: 'Stop the Party Server',\n usage: 'open-party stop',\n },\n {\n name: 'status',\n scope: 'user',\n description: 'Show server status',\n usage: 'open-party status',\n },\n {\n name: 'login',\n scope: 'user',\n description: 'Login to Tailscale network',\n usage: 'open-party login',\n },\n {\n name: 'logout',\n scope: 'user',\n description: 'Log out of Tailscale network',\n usage: 'open-party logout',\n },\n {\n name: 'agents',\n alias: 'list-agents',\n scope: 'agent',\n description: 'List online agents (local + remote, with status)',\n usage: 'open-party agents [--json]',\n options: [\n { flags: '--json', description: 'Output raw JSON response' },\n ],\n examples: [\n 'open-party agents',\n 'open-party agents --json',\n ],\n },\n {\n name: 'peers',\n scope: 'agent',\n description: 'List discovered peer nodes',\n usage: 'open-party peers [--json]',\n options: [\n { flags: '--json', description: 'Output raw JSON response' },\n ],\n },\n {\n name: 'send-message',\n scope: 'agent',\n description: 'Send a message to an agent',\n usage: 'open-party send-message --recipient <id> --content <text> [options]',\n options: [\n { flags: '--recipient <id>', description: 'Target agent ID (required)' },\n { flags: '--content <text>', description: 'Message content (required)' },\n { flags: '--summary <text>', description: 'Optional one-line summary' },\n { flags: '--agent-id <id>', description: 'Override sender identity' },\n { flags: '--json', description: 'Output raw JSON response' },\n ],\n examples: [\n 'open-party send-message --recipient <id> --content \"hello\"',\n 'open-party send-message --recipient <id> --content \"hi\" --summary \"Greeting\"',\n ],\n },\n {\n name: 'online',\n scope: 'agent',\n description: 'Go online — register this agent with the Party Server',\n usage: 'open-party online [--name <name>]',\n options: [\n { flags: '--name <name>', description: 'Override display name' },\n ],\n examples: [\n 'open-party online',\n 'open-party online --name \"my-agent\"',\n ],\n },\n {\n name: 'offline',\n scope: 'agent',\n description: 'Go offline — unregister from the Party Server',\n usage: 'open-party offline',\n },\n {\n name: 'check-messages',\n scope: 'agent',\n description: 'Check for new messages (add --history to include history)',\n usage: 'open-party check-messages [--agent-id <id>] [--history] [--limit N] [--json]',\n options: [\n { flags: '--agent-id <id>', description: 'Override agent identity' },\n { flags: '--history', description: 'Also show message history' },\n { flags: '--limit N', description: 'Number of history messages (default: 10, max: 50)' },\n { flags: '--json', description: 'Output raw JSON response' },\n ],\n examples: [\n 'open-party check-messages',\n 'open-party check-messages --history',\n 'open-party check-messages --history --limit 20',\n ],\n },\n];\n\n/** Find a command definition by name or alias. */\nexport function findCommand(name: string): CommandDef | undefined {\n return COMMANDS.find(\n (c) => c.name === name || c.alias === name,\n );\n}\n","/**\n * Open Party CLI — decentralized Agent communication network.\n */\n\nimport { setupCommand } from './setup.js';\nimport { loginCommand } from './login.js';\nimport { logoutCommand } from './logout.js';\nimport { startServer } from './start-server.js';\nimport { stopServer } from './stop-server.js';\nimport { statusCommand } from './status.js';\nimport { showVersion } from './version.js';\nimport { listAgentsCommand } from './list-agents.js';\nimport { peersCommand } from './peers.js';\nimport { sendMessageCommand } from './send-message.js';\nimport { checkMessagesCommand } from './check-messages.js';\nimport { onlineCommand } from './online.js';\nimport { offlineCommand } from './offline.js';\nimport { COMMANDS, findCommand } from './registry.js';\n\nfunction showHelp(commandName?: string): void {\n if (commandName) {\n const cmd = findCommand(commandName);\n if (!cmd) {\n console.log(`Unknown command: ${commandName}\\n`);\n showHelp();\n return;\n }\n\n // Per-command help\n console.log(`Usage: ${cmd.usage}`);\n console.log('');\n console.log(cmd.description);\n if (cmd.alias) {\n console.log(`Alias: ${cmd.alias}`);\n }\n\n if (cmd.options && cmd.options.length > 0) {\n console.log('');\n console.log('Options:');\n for (const opt of cmd.options) {\n console.log(` ${opt.flags.padEnd(24)} ${opt.description}`);\n }\n }\n\n if (cmd.examples && cmd.examples.length > 0) {\n console.log('');\n console.log('Examples:');\n for (const ex of cmd.examples) {\n console.log(` ${ex}`);\n }\n }\n\n return;\n }\n\n // Top-level help\n const userCmds = COMMANDS.filter((c) => c.scope === 'user');\n const agentCmds = COMMANDS.filter((c) => c.scope === 'agent');\n\n const lines: string[] = ['Usage: open-party <command> [options]', '', 'Server & Network (user):'];\n for (const cmd of userCmds) {\n const label = cmd.alias ? `${cmd.name}, ${cmd.alias}` : cmd.name;\n lines.push(` ${label.padEnd(22)} ${cmd.description}`);\n }\n\n lines.push('', 'Agent Communication:');\n for (const cmd of agentCmds) {\n const label = cmd.alias ? `${cmd.name}, ${cmd.alias}` : cmd.name;\n lines.push(` ${label.padEnd(22)} ${cmd.description}`);\n }\n\n lines.push('');\n lines.push('Global options:');\n lines.push(' -v, --version Show version number');\n lines.push('');\n lines.push('Run \"open-party help <command>\" for details on a specific command.');\n\n console.log(lines.join('\\n'));\n}\n\nconst args = process.argv.slice(2);\nconst command = args[0] ?? 'start';\nconst commandArgs = args.slice(1);\n\nasync function main(): Promise<void> {\n // Handle global flags before command dispatch\n if (command === '--version' || command === '-v') {\n showVersion();\n process.exit(0);\n }\n\n // Per-command --help flag\n if (commandArgs.includes('--help') || commandArgs.includes('-h')) {\n showHelp(command);\n process.exit(0);\n }\n\n switch (command) {\n case 'setup':\n await setupCommand();\n break;\n case 'login':\n await loginCommand();\n break;\n case 'logout':\n await logoutCommand();\n break;\n case 'start':\n await startServer(commandArgs);\n break;\n case 'stop':\n await stopServer();\n break;\n case 'status':\n await statusCommand();\n break;\n case 'agents':\n case 'list-agents':\n await listAgentsCommand(commandArgs);\n break;\n case 'peers':\n await peersCommand(commandArgs);\n break;\n case 'send-message':\n await sendMessageCommand(commandArgs);\n break;\n case 'check-messages':\n await checkMessagesCommand(commandArgs);\n break;\n case 'online':\n await onlineCommand(commandArgs);\n break;\n case 'offline':\n await offlineCommand();\n break;\n case 'help':\n case '--help':\n case '-h':\n showHelp(args[1]);\n break;\n default:\n console.log(`Unknown command: ${command}\\n`);\n showHelp();\n process.exit(1);\n }\n}\n\nmain().catch((e) => {\n console.error('Fatal error:', e);\n process.exit(1);\n});\n"],"mappings":"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","names":["execSync","existsSync","join","raw","output","match","cacheKey","raw","args","init_constants","init_constants","args","app","init_router","init_router","init_router","init_router","init_router","Node","init_node","_Node","init_router","init_node","Node","init_router","Hono","Request","init_dist","resolve","existsSync","mkdirSync","readdirSync","unlinkSync","statSync","join","homedir","existsSync","readFileSync","writeFileSync","unlinkSync","mkdirSync","join","homedir","resolve","raw","registry","DEFAULT_CAPACITY","Hono","registry","messageQueue","discovery","Hono","discovery","mkdirSync","writeFileSync","unlinkSync","join","dirname","homedir","pidFilePath","resolve","init_dist","Hono","existsSync","readFileSync","writeFileSync","mkdirSync","join","dirname","resolve","homedir","execSync","resolve","output","match","args","resolve","resolve","execSync","existsSync","dirname","mkdirSync","readFileSync","writeFileSync","join","homedir","spawn","spawn","resolve","args","pid","stillUp","readFileSync","resolve","dirname","fileURLToPath","args","args","existsSync","readdirSync","readFileSync","statSync","join","existsSync","mkdirSync","readFileSync","readdirSync","unlinkSync","writeFileSync","join","homedir","join","existsSync","readFileSync","writeFileSync","existsSync","readdirSync","statSync","join","raw","readFileSync","args","args","args","main"]}