dorkos 0.1.0

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.
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../apps/server/src/index.ts", "../../../../apps/server/src/app.ts", "../../../../apps/server/src/routes/sessions.ts", "../../../../apps/server/src/services/agent-manager.ts", "../../../../apps/server/src/services/transcript-reader.ts", "../../../../apps/server/src/services/stream-adapter.ts", "../../../shared/src/schemas.ts", "../../../../apps/server/src/routes/commands.ts", "../../../../apps/server/src/services/command-registry.ts", "../../../../apps/server/src/routes/health.ts", "../../../../apps/server/src/services/tunnel-manager.ts", "../../../../apps/server/src/routes/directory.ts", "../../../../apps/server/src/routes/config.ts", "../../../../apps/server/src/routes/files.ts", "../../../../apps/server/src/services/file-lister.ts", "../../../../apps/server/src/routes/git.ts", "../../../../apps/server/src/services/git-status.ts", "../../../../apps/server/src/services/openapi-registry.ts", "../../../../apps/server/src/middleware/error-handler.ts", "../../../../node_modules/chokidar/esm/index.js", "../../../../node_modules/readdirp/esm/index.js", "../../../../node_modules/chokidar/esm/handler.js", "../../../../apps/server/src/services/session-broadcaster.ts"],
4
+ "sourcesContent": ["import dotenv from 'dotenv';\nimport path from 'path';\nimport { fileURLToPath } from 'url';\nimport { createApp } from './app.js';\nimport { agentManager } from './services/agent-manager.js';\nimport { tunnelManager } from './services/tunnel-manager.js';\nimport { SessionBroadcaster } from './services/session-broadcaster.js';\nimport { transcriptReader } from './services/transcript-reader.js';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\nif (!process.env.CLIENT_DIST_PATH) {\n dotenv.config({ path: path.join(__dirname, '../../../.env') });\n}\n\nconst PORT = parseInt(process.env.GATEWAY_PORT || '6942', 10);\n\n// Global reference for graceful shutdown\nlet sessionBroadcaster: SessionBroadcaster | null = null;\n\nasync function start() {\n const app = createApp();\n\n // Initialize SessionBroadcaster and attach to app.locals\n sessionBroadcaster = new SessionBroadcaster(transcriptReader);\n app.locals.sessionBroadcaster = sessionBroadcaster;\n\n const host = process.env.TUNNEL_ENABLED === 'true' ? '0.0.0.0' : 'localhost';\n app.listen(PORT, host, () => {\n console.log(`Gateway server running on http://localhost:${PORT}`);\n });\n\n // Run session health check every 5 minutes\n setInterval(() => {\n agentManager.checkSessionHealth();\n }, 5 * 60 * 1000);\n\n // Start ngrok tunnel if enabled\n if (process.env.TUNNEL_ENABLED === 'true') {\n const tunnelPort = parseInt(process.env.TUNNEL_PORT || String(PORT), 10);\n\n try {\n const url = await tunnelManager.start({\n port: tunnelPort,\n authtoken: process.env.NGROK_AUTHTOKEN,\n basicAuth: process.env.TUNNEL_AUTH,\n domain: process.env.TUNNEL_DOMAIN,\n });\n\n const hasAuth = !!process.env.TUNNEL_AUTH;\n const isDevPort = tunnelPort !== PORT;\n\n console.log('');\n console.log('\\u250c\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2510');\n console.log('\\u2502 ngrok tunnel active \\u2502');\n console.log('\\u2502 \\u2502');\n console.log(`\\u2502 URL: ${url.padEnd(40)} \\u2502`);\n console.log(`\\u2502 Port: ${String(tunnelPort).padEnd(40)} \\u2502`);\n console.log(`\\u2502 Auth: ${(hasAuth ? 'basic auth enabled' : 'none (open)').padEnd(40)} \\u2502`);\n if (isDevPort) {\n console.log(`\\u2502 Mode: ${('dev (Vite on :' + tunnelPort + ')').padEnd(40)} \\u2502`);\n }\n console.log('\\u2502 \\u2502');\n console.log('\\u2502 Free tier: 1GB/month bandwidth, session limits \\u2502');\n console.log('\\u2514\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2500\\u2518');\n console.log('');\n } catch (err) {\n console.warn('[Tunnel] Failed to start ngrok tunnel:', err instanceof Error ? err.message : err);\n console.warn('[Tunnel] Server continues without tunnel.');\n }\n }\n}\n\n// Graceful shutdown\nfunction shutdown() {\n console.log('\\nShutting down...');\n if (sessionBroadcaster) {\n sessionBroadcaster.shutdown();\n }\n tunnelManager.stop().finally(() => { process.exit(0); });\n}\n\nprocess.on('SIGINT', shutdown);\nprocess.on('SIGTERM', shutdown);\n\nstart();\n", "import express from 'express';\nimport cors from 'cors';\nimport path from 'path';\nimport { fileURLToPath } from 'url';\nimport { apiReference } from '@scalar/express-api-reference';\nimport sessionRoutes from './routes/sessions.js';\nimport commandRoutes from './routes/commands.js';\nimport healthRoutes from './routes/health.js';\nimport directoryRoutes from './routes/directory.js';\nimport configRoutes from './routes/config.js';\nimport fileRoutes from './routes/files.js';\nimport gitRoutes from './routes/git.js';\nimport { generateOpenAPISpec } from './services/openapi-registry.js';\nimport { errorHandler } from './middleware/error-handler.js';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\n\nexport function createApp() {\n const app = express();\n\n app.use(cors());\n app.use(express.json());\n\n // API routes\n app.use('/api/sessions', sessionRoutes);\n app.use('/api/commands', commandRoutes);\n app.use('/api/health', healthRoutes);\n app.use('/api/directory', directoryRoutes);\n app.use('/api/config', configRoutes);\n app.use('/api/files', fileRoutes);\n app.use('/api/git', gitRoutes);\n\n // OpenAPI spec + interactive docs\n const spec = generateOpenAPISpec();\n app.get('/api/openapi.json', (_req, res) => res.json(spec));\n app.use('/api/docs', apiReference({ content: spec }));\n\n // Error handler (must be after routes)\n app.use(errorHandler);\n\n // In production, serve the built React app\n if (process.env.NODE_ENV === 'production') {\n const distPath = process.env.CLIENT_DIST_PATH\n ?? path.join(__dirname, '../../client/dist');\n app.use(express.static(distPath));\n app.get('*', (_req, res) => {\n res.sendFile(path.join(distPath, 'index.html'));\n });\n }\n\n return app;\n}\n", "import path from 'path';\nimport { fileURLToPath } from 'url';\nimport { Router } from 'express';\nimport { agentManager } from '../services/agent-manager.js';\nimport { transcriptReader } from '../services/transcript-reader.js';\nimport { initSSEStream, sendSSEEvent, endSSEStream } from '../services/stream-adapter.js';\nimport {\n CreateSessionRequestSchema,\n UpdateSessionRequestSchema,\n SendMessageRequestSchema,\n ApprovalRequestSchema,\n SubmitAnswersRequestSchema,\n ListSessionsQuerySchema,\n} from '@dorkos/shared/schemas';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\nconst vaultRoot = path.resolve(__dirname, '../../../../');\n\nconst router = Router();\n\n// POST /api/sessions - Create new session\n// Sends an initial message to the SDK to generate the session JSONL file,\n// then returns the session metadata.\nrouter.post('/', async (req, res) => {\n const parsed = CreateSessionRequestSchema.safeParse(req.body);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid request', details: parsed.error.format() });\n }\n const { permissionMode = 'default', cwd } = parsed.data;\n\n // Use SDK's query() with a no-op prompt to establish the session.\n // The SDK will create the JSONL file and assign a session ID.\n // We need to send a real first message, so we'll just create an in-memory\n // session entry and let the first POST /messages call create the JSONL.\n const sessionId = crypto.randomUUID();\n agentManager.ensureSession(sessionId, { permissionMode, cwd });\n\n res.json({\n id: sessionId,\n title: `New Session`,\n createdAt: new Date().toISOString(),\n updatedAt: new Date().toISOString(),\n permissionMode,\n cwd,\n });\n});\n\n// GET /api/sessions - List all sessions from SDK transcripts\nrouter.get('/', async (req, res) => {\n const parsed = ListSessionsQuerySchema.safeParse(req.query);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid query', details: parsed.error.format() });\n }\n const { limit, cwd } = parsed.data;\n const projectDir = cwd || vaultRoot;\n const sessions = await transcriptReader.listSessions(projectDir);\n res.json(sessions.slice(0, limit));\n});\n\n// GET /api/sessions/:id - Get session details\nrouter.get('/:id', async (req, res) => {\n const cwd = (req.query.cwd as string) || vaultRoot;\n const session = await transcriptReader.getSession(cwd, req.params.id);\n if (!session) return res.status(404).json({ error: 'Session not found' });\n res.json(session);\n});\n\n// GET /api/sessions/:id/tasks - Get task state from SDK transcript\nrouter.get('/:id/tasks', async (req, res) => {\n const cwd = (req.query.cwd as string) || vaultRoot;\n\n const etag = await transcriptReader.getTranscriptETag(cwd, req.params.id);\n if (etag) {\n res.setHeader('ETag', etag);\n if (req.headers['if-none-match'] === etag) {\n return res.status(304).end();\n }\n }\n\n try {\n const tasks = await transcriptReader.readTasks(cwd, req.params.id);\n res.json({ tasks });\n } catch {\n res.status(404).json({ error: 'Session not found' });\n }\n});\n\n// GET /api/sessions/:id/messages - Get message history from SDK transcript\nrouter.get('/:id/messages', async (req, res) => {\n const cwd = (req.query.cwd as string) || vaultRoot;\n\n const etag = await transcriptReader.getTranscriptETag(cwd, req.params.id);\n if (etag) {\n res.setHeader('ETag', etag);\n if (req.headers['if-none-match'] === etag) {\n return res.status(304).end();\n }\n }\n\n const messages = await transcriptReader.readTranscript(cwd, req.params.id);\n res.json({ messages });\n});\n\n// PATCH /api/sessions/:id - Update session settings\nrouter.patch('/:id', async (req, res) => {\n const parsed = UpdateSessionRequestSchema.safeParse(req.body);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid request', details: parsed.error.format() });\n }\n const { permissionMode, model } = parsed.data;\n const updated = agentManager.updateSession(req.params.id, { permissionMode, model });\n if (!updated) return res.status(404).json({ error: 'Session not found' });\n\n const cwd = (req.query.cwd as string) || vaultRoot;\n const session = await transcriptReader.getSession(cwd, req.params.id);\n if (session) {\n session.permissionMode = permissionMode ?? session.permissionMode;\n session.model = model ?? session.model;\n }\n res.json(session ?? { id: req.params.id, permissionMode, model });\n});\n\n// POST /api/sessions/:id/messages - Send message (SSE stream response)\nrouter.post('/:id/messages', async (req, res) => {\n const parsed = SendMessageRequestSchema.safeParse(req.body);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid request', details: parsed.error.format() });\n }\n const { content, cwd } = parsed.data;\n\n const sessionId = req.params.id;\n\n // Read X-Client-Id header, or generate UUID if missing\n const clientId = (req.headers['x-client-id'] as string) || crypto.randomUUID();\n\n // Acquire lock before starting SSE stream\n const lockAcquired = agentManager.acquireLock(sessionId, clientId, res);\n if (!lockAcquired) {\n const lockInfo = agentManager.getLockInfo(sessionId);\n return res.status(409).json({\n error: 'Session locked',\n code: 'SESSION_LOCKED',\n lockedBy: lockInfo?.clientId ?? 'unknown',\n lockedAt: lockInfo ? new Date(lockInfo.acquiredAt).toISOString() : new Date().toISOString(),\n });\n }\n\n // Guarantee lock release if client disconnects before try block\n res.on('close', () => {\n agentManager.releaseLock(sessionId, clientId);\n });\n\n initSSEStream(res);\n\n try {\n for await (const event of agentManager.sendMessage(sessionId, content, { cwd })) {\n sendSSEEvent(res, event);\n\n // If SDK assigned a different session ID, track it\n if (event.type === 'done') {\n const actualSdkId = agentManager.getSdkSessionId(sessionId);\n if (actualSdkId && actualSdkId !== sessionId) {\n // Send a redirect hint so the client can update its session ID\n sendSSEEvent(res, {\n type: 'done',\n data: { sessionId: actualSdkId },\n });\n }\n }\n }\n } catch (err) {\n sendSSEEvent(res, {\n type: 'error',\n data: { message: err instanceof Error ? err.message : 'Unknown error' },\n });\n } finally {\n agentManager.releaseLock(sessionId, clientId);\n endSSEStream(res);\n }\n});\n\n// POST /api/sessions/:id/approve - Approve pending tool call\nrouter.post('/:id/approve', async (req, res) => {\n const parsed = ApprovalRequestSchema.safeParse(req.body);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid request', details: parsed.error.format() });\n }\n const { toolCallId } = parsed.data;\n const approved = agentManager.approveTool(req.params.id, toolCallId, true);\n if (!approved) return res.status(404).json({ error: 'No pending approval' });\n res.json({ ok: true });\n});\n\n// POST /api/sessions/:id/deny - Deny pending tool call\nrouter.post('/:id/deny', async (req, res) => {\n const parsed = ApprovalRequestSchema.safeParse(req.body);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid request', details: parsed.error.format() });\n }\n const { toolCallId } = parsed.data;\n const denied = agentManager.approveTool(req.params.id, toolCallId, false);\n if (!denied) return res.status(404).json({ error: 'No pending approval' });\n res.json({ ok: true });\n});\n\n// POST /api/sessions/:id/submit-answers - Submit answers for AskUserQuestion\nrouter.post('/:id/submit-answers', async (req, res) => {\n const parsed = SubmitAnswersRequestSchema.safeParse(req.body);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid request', details: parsed.error.format() });\n }\n const { toolCallId, answers } = parsed.data;\n const ok = agentManager.submitAnswers(req.params.id, toolCallId, answers);\n if (!ok) return res.status(404).json({ error: 'No pending question' });\n res.json({ ok: true });\n});\n\n// GET /api/sessions/:id/stream - Persistent SSE connection for session sync\nrouter.get('/:id/stream', (req, res) => {\n const sessionId = req.params.id;\n const cwd = (req.query.cwd as string) || vaultRoot;\n const sessionBroadcaster = req.app.locals.sessionBroadcaster;\n\n // Set SSE headers\n res.setHeader('Content-Type', 'text/event-stream');\n res.setHeader('Cache-Control', 'no-cache');\n res.setHeader('Connection', 'keep-alive');\n res.setHeader('X-Accel-Buffering', 'no'); // Disable nginx buffering\n res.flushHeaders();\n\n // Register with broadcaster\n sessionBroadcaster.registerClient(sessionId, cwd, res);\n\n // The broadcaster handles:\n // - Sending sync_connected event\n // - Auto-deregistering on disconnect (res.on('close'))\n // - Broadcasting sync_update events when JSONL changes\n});\n\nexport default router;\n", "import path from 'path';\nimport { fileURLToPath } from 'url';\nimport { execFileSync } from 'child_process';\nimport { existsSync } from 'fs';\nimport { query, type Options, type SDKMessage, type PermissionResult, type Query } from '@anthropic-ai/claude-agent-sdk';\nimport type { Response } from 'express';\nimport type { StreamEvent, PermissionMode, TaskUpdateEvent, TaskStatus } from '@dorkos/shared/types';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\n\nconst INTERACTION_TIMEOUT_MS = 10 * 60 * 1000; // 10 minutes\n\n/** Resolve the Claude Code CLI path for the SDK to spawn. */\nexport function resolveClaudeCliPath(): string | undefined {\n // 1. Try the SDK's bundled cli.js (works when running from source / node_modules)\n try {\n const sdkCli = require.resolve('@anthropic-ai/claude-agent-sdk/cli.js');\n if (existsSync(sdkCli)) return sdkCli;\n } catch { /* not resolvable in bundled context */ }\n\n // 2. Find the globally installed `claude` binary via PATH\n try {\n const bin = execFileSync('which', ['claude'], { encoding: 'utf-8' }).trim();\n if (bin && existsSync(bin)) return bin;\n } catch { /* not found on PATH */ }\n\n // 3. Let SDK use its default resolution (may fail in Electron)\n return undefined;\n}\n\ninterface SessionLock {\n clientId: string;\n acquiredAt: number;\n ttl: number;\n response: Response;\n}\n\ninterface PendingInteraction {\n type: 'question' | 'approval';\n toolCallId: string;\n resolve: (result: unknown) => void;\n reject: (reason: unknown) => void;\n timeout: ReturnType<typeof setTimeout>;\n}\n\ninterface AgentSession {\n sdkSessionId: string;\n lastActivity: number;\n permissionMode: PermissionMode;\n model?: string;\n cwd?: string;\n /** True once the first SDK query has been sent (JSONL file exists) */\n hasStarted: boolean;\n /** Active SDK query object \u2014 used for mid-stream control (setPermissionMode, setModel) */\n activeQuery?: Query;\n pendingInteractions: Map<string, PendingInteraction>;\n eventQueue: StreamEvent[];\n eventQueueNotify?: () => void;\n}\n\nfunction handleAskUserQuestion(\n session: AgentSession,\n toolUseId: string,\n input: Record<string, unknown>,\n): Promise<PermissionResult> {\n session.eventQueue.push({\n type: 'question_prompt',\n data: {\n toolCallId: toolUseId,\n questions: input.questions as import('@dorkos/shared/types').QuestionItem[],\n },\n });\n session.eventQueueNotify?.();\n\n return new Promise((resolve) => {\n const timeout = setTimeout(() => {\n session.pendingInteractions.delete(toolUseId);\n resolve({ behavior: 'deny', message: 'User did not respond within 10 minutes' });\n }, INTERACTION_TIMEOUT_MS);\n\n session.pendingInteractions.set(toolUseId, {\n type: 'question',\n toolCallId: toolUseId,\n resolve: (answers) => {\n clearTimeout(timeout);\n session.pendingInteractions.delete(toolUseId);\n resolve({\n behavior: 'allow',\n updatedInput: { ...input, answers },\n });\n },\n reject: () => {\n clearTimeout(timeout);\n session.pendingInteractions.delete(toolUseId);\n resolve({ behavior: 'deny', message: 'Interaction cancelled' });\n },\n timeout,\n });\n });\n}\n\nfunction handleToolApproval(\n session: AgentSession,\n toolUseId: string,\n toolName: string,\n input: Record<string, unknown>,\n): Promise<PermissionResult> {\n session.eventQueue.push({\n type: 'approval_required',\n data: {\n toolCallId: toolUseId,\n toolName,\n input: JSON.stringify(input),\n },\n });\n session.eventQueueNotify?.();\n\n return new Promise((resolve) => {\n const timeout = setTimeout(() => {\n session.pendingInteractions.delete(toolUseId);\n resolve({ behavior: 'deny', message: 'Tool approval timed out after 10 minutes' });\n }, INTERACTION_TIMEOUT_MS);\n\n session.pendingInteractions.set(toolUseId, {\n type: 'approval',\n toolCallId: toolUseId,\n resolve: (approved) => {\n clearTimeout(timeout);\n session.pendingInteractions.delete(toolUseId);\n resolve(\n approved\n ? { behavior: 'allow', updatedInput: input }\n : { behavior: 'deny', message: 'User denied tool execution' },\n );\n },\n reject: () => {\n clearTimeout(timeout);\n session.pendingInteractions.delete(toolUseId);\n resolve({ behavior: 'deny', message: 'Interaction cancelled' });\n },\n timeout,\n });\n });\n}\n\nconst TASK_TOOL_NAMES = new Set(['TaskCreate', 'TaskUpdate', 'TaskList', 'TaskGet']);\n\nexport function buildTaskEvent(toolName: string, input: Record<string, unknown>): TaskUpdateEvent | null {\n switch (toolName) {\n case 'TaskCreate':\n return {\n action: 'create',\n task: {\n id: '',\n subject: (input.subject as string) ?? '',\n description: input.description as string | undefined,\n activeForm: input.activeForm as string | undefined,\n status: 'pending',\n },\n };\n case 'TaskUpdate': {\n // Only include fields the SDK actually sent \u2014 the client's stripDefaults\n // strips empty strings during merge, so absent fields use '' sentinel.\n const task: TaskUpdateEvent['task'] = {\n id: (input.taskId as string) ?? '',\n subject: (input.subject as string) ?? '',\n status: (input.status as TaskStatus) ?? ('' as TaskStatus),\n };\n if (input.activeForm) task.activeForm = input.activeForm as string;\n if (input.description) task.description = input.description as string;\n if (input.addBlockedBy) task.blockedBy = input.addBlockedBy as string[];\n if (input.addBlocks) task.blocks = input.addBlocks as string[];\n if (input.owner) task.owner = input.owner as string;\n return { action: 'update', task };\n }\n default:\n return null;\n }\n}\n\nexport class AgentManager {\n private sessions = new Map<string, AgentSession>();\n private sessionLocks = new Map<string, SessionLock>();\n private readonly SESSION_TIMEOUT_MS = 30 * 60 * 1000; // 30 minutes\n private readonly LOCK_TTL_MS = 5 * 60 * 1000; // 5 minutes\n private readonly cwd: string;\n private readonly claudeCliPath: string | undefined;\n\n constructor(cwd?: string) {\n this.cwd = cwd ?? process.env.GATEWAY_CWD ?? path.resolve(__dirname, '../../../../');\n this.claudeCliPath = resolveClaudeCliPath();\n }\n\n /**\n * Start or resume an agent session.\n * For new sessions, sdkSessionId is assigned after the first query() init message.\n * For resumed sessions, the sessionId IS the sdkSessionId.\n */\n ensureSession(sessionId: string, opts: {\n permissionMode: PermissionMode;\n cwd?: string;\n hasStarted?: boolean;\n }): void {\n if (!this.sessions.has(sessionId)) {\n this.sessions.set(sessionId, {\n sdkSessionId: sessionId,\n lastActivity: Date.now(),\n permissionMode: opts.permissionMode,\n cwd: opts.cwd,\n hasStarted: opts.hasStarted ?? false,\n pendingInteractions: new Map(),\n eventQueue: [],\n });\n }\n }\n\n async *sendMessage(\n sessionId: string,\n content: string,\n opts?: { permissionMode?: PermissionMode; cwd?: string }\n ): AsyncGenerator<StreamEvent> {\n // Auto-create session if it doesn't exist (for resuming SDK sessions).\n // Sessions hitting this path already exist on disk (created by CLI or a\n // previous server run), so hasStarted must be true to trigger resume.\n if (!this.sessions.has(sessionId)) {\n this.ensureSession(sessionId, {\n permissionMode: opts?.permissionMode ?? 'default',\n cwd: opts?.cwd,\n hasStarted: true,\n });\n }\n\n const session = this.sessions.get(sessionId)!;\n session.lastActivity = Date.now();\n session.eventQueue = [];\n\n const sdkOptions: Options = {\n cwd: session.cwd ?? this.cwd,\n includePartialMessages: true,\n settingSources: ['project', 'user'],\n ...(this.claudeCliPath ? { pathToClaudeCodeExecutable: this.claudeCliPath } : {}),\n };\n\n // Only resume if the session has been started (JSONL exists)\n if (session.hasStarted) {\n sdkOptions.resume = session.sdkSessionId;\n }\n\n console.log(`[sendMessage] session=${sessionId} permissionMode=${session.permissionMode} hasStarted=${session.hasStarted} resume=${session.hasStarted ? session.sdkSessionId : 'N/A'}`);\n\n switch (session.permissionMode) {\n case 'bypassPermissions':\n sdkOptions.permissionMode = 'bypassPermissions';\n sdkOptions.allowDangerouslySkipPermissions = true;\n break;\n case 'plan':\n sdkOptions.permissionMode = 'plan';\n break;\n case 'acceptEdits':\n sdkOptions.permissionMode = 'acceptEdits';\n break;\n default:\n sdkOptions.permissionMode = 'default';\n }\n\n if (session.model) {\n (sdkOptions as Record<string, unknown>).model = session.model;\n }\n\n // Register canUseTool callback for interactive tools\n sdkOptions.canUseTool = async (\n toolName: string,\n input: Record<string, unknown>,\n context: {\n signal: AbortSignal;\n toolUseID: string;\n decisionReason?: string;\n suggestions?: unknown[];\n },\n ): Promise<PermissionResult> => {\n // AskUserQuestion: pause, collect answers, inject into input\n if (toolName === 'AskUserQuestion') {\n console.log(`[canUseTool] ${toolName} \u2192 routing to question handler (toolUseID=${context.toolUseID})`);\n return handleAskUserQuestion(session, context.toolUseID, input);\n }\n\n // Tool approval: pause when permissionMode is 'default'\n if (session.permissionMode === 'default') {\n console.log(`[canUseTool] ${toolName} \u2192 requesting approval (permissionMode=default, toolUseID=${context.toolUseID})`);\n return handleToolApproval(session, context.toolUseID, toolName, input);\n }\n\n // All other cases: allow immediately\n console.log(`[canUseTool] ${toolName} \u2192 auto-allow (permissionMode=${session.permissionMode}, toolUseID=${context.toolUseID})`);\n return { behavior: 'allow', updatedInput: input };\n };\n\n const agentQuery = query({ prompt: content, options: sdkOptions });\n session.activeQuery = agentQuery;\n\n let inTool = false;\n let currentToolName = '';\n let currentToolId = '';\n let emittedDone = false;\n let taskToolInput = '';\n\n const toolState = {\n get inTool() { return inTool; },\n get currentToolName() { return currentToolName; },\n get currentToolId() { return currentToolId; },\n get taskToolInput() { return taskToolInput; },\n appendTaskInput: (chunk: string) => { taskToolInput += chunk; },\n resetTaskInput: () => { taskToolInput = ''; },\n setToolState: (tool: boolean, name: string, id: string) => {\n inTool = tool;\n currentToolName = name;\n currentToolId = id;\n },\n };\n\n try {\n const sdkIterator = agentQuery[Symbol.asyncIterator]();\n // Cache the SDK promise so we never call .next() twice concurrently\n let pendingSdkPromise: Promise<{ sdk: true; result: IteratorResult<SDKMessage> }> | null = null;\n\n while (true) {\n // Drain any events pushed by canUseTool callbacks\n while (session.eventQueue.length > 0) {\n const queuedEvent = session.eventQueue.shift()!;\n if (queuedEvent.type === 'done') emittedDone = true;\n yield queuedEvent;\n }\n\n // Race between SDK yielding next message and queue getting a new event\n const queuePromise = new Promise<'queue'>(resolve => {\n session.eventQueueNotify = () => resolve('queue');\n });\n\n // Only call .next() if we don't already have a pending SDK promise\n if (!pendingSdkPromise) {\n pendingSdkPromise = sdkIterator.next().then(result => ({ sdk: true as const, result }));\n }\n\n const winner = await Promise.race([queuePromise, pendingSdkPromise]);\n\n if (winner === 'queue') {\n // Queue got new items from canUseTool, drain them on next iteration.\n // pendingSdkPromise stays cached \u2014 we'll race it again next time.\n continue;\n }\n\n // SDK yielded a message \u2014 consume the cached promise\n pendingSdkPromise = null;\n const { result } = winner;\n if (result.done) break;\n\n for await (const event of this.mapSdkMessage(result.value, session, sessionId, toolState)) {\n if (event.type === 'done') emittedDone = true;\n yield event;\n }\n }\n } catch (err) {\n yield {\n type: 'error',\n data: {\n message: err instanceof Error ? err.message : 'SDK error',\n },\n };\n } finally {\n session.activeQuery = undefined;\n }\n\n if (!emittedDone) {\n yield {\n type: 'done',\n data: { sessionId },\n };\n }\n }\n\n private async *mapSdkMessage(\n message: SDKMessage,\n session: AgentSession,\n sessionId: string,\n toolState: {\n inTool: boolean;\n currentToolName: string;\n currentToolId: string;\n taskToolInput: string;\n appendTaskInput: (chunk: string) => void;\n resetTaskInput: () => void;\n setToolState: (tool: boolean, name: string, id: string) => void;\n }\n ): AsyncGenerator<StreamEvent> {\n // Capture session ID from init (for new sessions where SDK assigns the ID)\n if (message.type === 'system' && 'subtype' in message && message.subtype === 'init') {\n session.sdkSessionId = message.session_id;\n session.hasStarted = true;\n // Forward model info from init\n const initModel = (message as Record<string, unknown>).model as string | undefined;\n if (initModel) {\n yield {\n type: 'session_status',\n data: {\n sessionId,\n model: initModel,\n },\n };\n }\n return;\n }\n\n if (message.type === 'stream_event') {\n const event = (message as { event: Record<string, unknown> }).event;\n const eventType = event.type as string;\n\n if (eventType === 'content_block_start') {\n const contentBlock = event.content_block as Record<string, unknown> | undefined;\n if (contentBlock?.type === 'tool_use') {\n toolState.resetTaskInput();\n toolState.setToolState(true, contentBlock.name as string, contentBlock.id as string);\n yield {\n type: 'tool_call_start',\n data: {\n toolCallId: contentBlock.id as string,\n toolName: contentBlock.name as string,\n status: 'running',\n },\n };\n }\n } else if (eventType === 'content_block_delta') {\n const delta = event.delta as Record<string, unknown> | undefined;\n if (delta?.type === 'text_delta' && !toolState.inTool) {\n yield { type: 'text_delta', data: { text: delta.text as string } };\n } else if (delta?.type === 'input_json_delta' && toolState.inTool) {\n if (TASK_TOOL_NAMES.has(toolState.currentToolName)) {\n toolState.appendTaskInput(delta.partial_json as string);\n }\n yield {\n type: 'tool_call_delta',\n data: {\n toolCallId: toolState.currentToolId,\n toolName: toolState.currentToolName,\n input: delta.partial_json as string,\n status: 'running',\n },\n };\n }\n } else if (eventType === 'content_block_stop') {\n if (toolState.inTool) {\n const wasTaskTool = TASK_TOOL_NAMES.has(toolState.currentToolName);\n const taskToolName = toolState.currentToolName;\n yield {\n type: 'tool_call_end',\n data: {\n toolCallId: toolState.currentToolId,\n toolName: toolState.currentToolName,\n status: 'complete',\n },\n };\n toolState.setToolState(false, '', '');\n if (wasTaskTool && toolState.taskToolInput) {\n try {\n const input = JSON.parse(toolState.taskToolInput);\n const taskEvent = buildTaskEvent(taskToolName, input);\n if (taskEvent) {\n yield { type: 'task_update', data: taskEvent };\n }\n } catch { /* malformed JSON, skip */ }\n toolState.resetTaskInput();\n }\n }\n }\n return;\n }\n\n if (message.type === 'tool_use_summary') {\n const summary = message as { summary: string; preceding_tool_use_ids: string[] };\n for (const toolUseId of summary.preceding_tool_use_ids) {\n yield {\n type: 'tool_result',\n data: {\n toolCallId: toolUseId,\n toolName: '',\n result: summary.summary,\n status: 'complete',\n },\n };\n }\n return;\n }\n\n if (message.type === 'result') {\n const result = message as Record<string, unknown>;\n const usage = result.usage as Record<string, unknown> | undefined;\n // modelUsage is Record<string, ModelUsage> \u2014 grab the first entry for contextWindow\n const modelUsageMap = result.modelUsage as Record<string, Record<string, unknown>> | undefined;\n const firstModelUsage = modelUsageMap\n ? Object.values(modelUsageMap)[0]\n : undefined;\n yield {\n type: 'session_status',\n data: {\n sessionId,\n model: result.model as string | undefined,\n costUsd: result.total_cost_usd as number | undefined,\n contextTokens: usage?.input_tokens as number | undefined,\n contextMaxTokens: firstModelUsage?.contextWindow as number | undefined,\n },\n };\n yield {\n type: 'done',\n data: { sessionId },\n };\n }\n }\n\n updateSession(sessionId: string, opts: { permissionMode?: PermissionMode; model?: string }): boolean {\n let session = this.findSession(sessionId);\n if (!session) {\n // Auto-create so settings are ready for the next sendMessage call\n this.ensureSession(sessionId, {\n permissionMode: opts.permissionMode ?? 'default',\n hasStarted: true,\n });\n session = this.sessions.get(sessionId)!;\n }\n if (opts.permissionMode) {\n console.log(`[updateSession] ${sessionId} permissionMode: ${session.permissionMode} \u2192 ${opts.permissionMode}`);\n session.permissionMode = opts.permissionMode;\n // Propagate to active SDK query for mid-stream changes\n if (session.activeQuery) {\n console.log(`[updateSession] ${sessionId} calling setPermissionMode(${opts.permissionMode}) on active query`);\n session.activeQuery.setPermissionMode(opts.permissionMode).catch((err) => {\n console.error(`[updateSession] setPermissionMode failed:`, err);\n });\n }\n }\n if (opts.model) {\n session.model = opts.model;\n }\n return true;\n }\n\n approveTool(sessionId: string, toolCallId: string, approved: boolean): boolean {\n const session = this.findSession(sessionId);\n const pending = session?.pendingInteractions.get(toolCallId);\n if (!pending || pending.type !== 'approval') {\n console.log(`[approveTool] ${sessionId} toolCallId=${toolCallId} approved=${approved} \u2192 NOT FOUND (session=${!!session}, pending=${!!pending}, type=${pending?.type})`);\n return false;\n }\n console.log(`[approveTool] ${sessionId} toolCallId=${toolCallId} approved=${approved} \u2192 resolving`);\n pending.resolve(approved);\n return true;\n }\n\n submitAnswers(sessionId: string, toolCallId: string, answers: Record<string, string>): boolean {\n const session = this.findSession(sessionId);\n const pending = session?.pendingInteractions.get(toolCallId);\n if (!pending || pending.type !== 'question') return false;\n pending.resolve(answers);\n return true;\n }\n\n checkSessionHealth(): void {\n const now = Date.now();\n for (const [id, session] of this.sessions) {\n if (now - session.lastActivity > this.SESSION_TIMEOUT_MS) {\n // Clean up any pending interactions\n for (const interaction of session.pendingInteractions.values()) {\n clearTimeout(interaction.timeout);\n }\n this.sessions.delete(id);\n this.sessionLocks.delete(id); // Clean up stale locks too\n }\n }\n // Clean up expired locks\n for (const [id, lock] of this.sessionLocks) {\n if (now - lock.acquiredAt > lock.ttl) {\n this.sessionLocks.delete(id);\n }\n }\n }\n\n /**\n * Find a session by its map key OR by its sdkSessionId.\n * After the SDK assigns a real session ID (on first message), the client\n * starts using the new ID while the map still stores it under the original key.\n */\n private findSession(sessionId: string): AgentSession | undefined {\n const direct = this.sessions.get(sessionId);\n if (direct) return direct;\n // Fallback: linear scan for sdkSessionId match\n for (const session of this.sessions.values()) {\n if (session.sdkSessionId === sessionId) return session;\n }\n return undefined;\n }\n\n hasSession(sessionId: string): boolean {\n return !!this.findSession(sessionId);\n }\n\n /**\n * Get the actual SDK session ID (may differ from input if SDK assigned a new one).\n */\n getSdkSessionId(sessionId: string): string | undefined {\n return this.findSession(sessionId)?.sdkSessionId;\n }\n\n /**\n * Attempt to acquire a lock on a session for a specific client.\n * Returns true if the lock was acquired, false if the session is locked by another client.\n */\n acquireLock(sessionId: string, clientId: string, res: Response): boolean {\n const existing = this.sessionLocks.get(sessionId);\n if (existing) {\n const expired = Date.now() - existing.acquiredAt > existing.ttl;\n if (expired) {\n this.sessionLocks.delete(sessionId);\n } else if (existing.clientId !== clientId) {\n return false;\n }\n }\n const lock: SessionLock = {\n clientId,\n acquiredAt: Date.now(),\n ttl: this.LOCK_TTL_MS,\n response: res,\n };\n this.sessionLocks.set(sessionId, lock);\n res.on('close', () => {\n const current = this.sessionLocks.get(sessionId);\n if (current === lock) {\n this.sessionLocks.delete(sessionId);\n }\n });\n return true;\n }\n\n /**\n * Release a lock on a session if it's held by the specified client.\n */\n releaseLock(sessionId: string, clientId: string): void {\n const lock = this.sessionLocks.get(sessionId);\n if (lock && lock.clientId === clientId) {\n this.sessionLocks.delete(sessionId);\n }\n }\n\n /**\n * Check if a session is locked.\n * If clientId is provided, returns false if the lock is held by that client (owns the lock).\n * Returns true if the session is locked by another client.\n */\n isLocked(sessionId: string, clientId?: string): boolean {\n const lock = this.sessionLocks.get(sessionId);\n if (!lock) return false;\n if (Date.now() - lock.acquiredAt > lock.ttl) {\n this.sessionLocks.delete(sessionId);\n return false;\n }\n if (clientId && lock.clientId === clientId) return false;\n return true;\n }\n\n /**\n * Get information about the current lock on a session.\n * Returns null if the session is not locked or the lock has expired.\n */\n getLockInfo(sessionId: string): { clientId: string; acquiredAt: number } | null {\n const lock = this.sessionLocks.get(sessionId);\n if (!lock) return null;\n if (Date.now() - lock.acquiredAt > lock.ttl) {\n this.sessionLocks.delete(sessionId);\n return null;\n }\n return { clientId: lock.clientId, acquiredAt: lock.acquiredAt };\n }\n}\n\nexport const agentManager = new AgentManager();\n", "import fs from 'fs/promises';\nimport path from 'path';\nimport os from 'os';\nimport type { Session, PermissionMode, HistoryMessage, HistoryToolCall, QuestionItem, TaskItem, TaskStatus, MessagePart, ToolCallPart } from '@dorkos/shared/types';\n\nexport type { HistoryMessage, HistoryToolCall };\n\ninterface TranscriptLine {\n type: string;\n uuid?: string;\n message?: {\n role: string;\n content: string | ContentBlock[];\n model?: string;\n usage?: {\n input_tokens?: number;\n cache_read_input_tokens?: number;\n cache_creation_input_tokens?: number;\n };\n };\n timestamp?: string;\n sessionId?: string;\n permissionMode?: string;\n subtype?: string;\n cwd?: string;\n /** SDK-provided structured answers for AskUserQuestion tool results */\n toolUseResult?: {\n questions?: QuestionItem[];\n answers?: Record<string, string>;\n commandName?: string;\n };\n}\n\ninterface ContentBlock {\n type: string;\n text?: string;\n // tool_use fields\n name?: string;\n id?: string;\n input?: Record<string, unknown>;\n // tool_result fields\n tool_use_id?: string;\n content?: string | ContentBlock[];\n}\n\nexport class TranscriptReader {\n private metaCache = new Map<string, { session: Session; mtimeMs: number }>();\n\n getProjectSlug(cwd: string): string {\n return cwd.replace(/[^a-zA-Z0-9-]/g, '-');\n }\n\n getTranscriptsDir(vaultRoot: string): string {\n const slug = this.getProjectSlug(vaultRoot);\n return path.join(os.homedir(), '.claude', 'projects', slug);\n }\n\n /**\n * List all sessions by scanning SDK JSONL transcript files.\n * Extracts metadata (title, timestamps, preview) from file content and stats.\n */\n async listSessions(vaultRoot: string): Promise<Session[]> {\n const transcriptsDir = this.getTranscriptsDir(vaultRoot);\n\n let files: string[];\n try {\n files = (await fs.readdir(transcriptsDir)).filter(f => f.endsWith('.jsonl'));\n } catch {\n return [];\n }\n\n const sessions: Session[] = [];\n\n for (const file of files) {\n const sessionId = file.replace('.jsonl', '');\n const filePath = path.join(transcriptsDir, file);\n\n try {\n const fileStat = await fs.stat(filePath);\n const cached = this.metaCache.get(sessionId);\n if (cached && cached.mtimeMs === fileStat.mtimeMs) {\n sessions.push(cached.session);\n continue;\n }\n const meta = await this.extractSessionMeta(filePath, sessionId, fileStat);\n this.metaCache.set(sessionId, { session: meta, mtimeMs: fileStat.mtimeMs });\n sessions.push(meta);\n } catch {\n // Skip unreadable files\n }\n }\n\n // Sort by updatedAt descending (most recent first)\n sessions.sort((a, b) => b.updatedAt.localeCompare(a.updatedAt));\n return sessions;\n }\n\n /**\n * Get metadata for a single session.\n * Reads both head (for title/timestamps) and tail (for latest model/context).\n */\n async getSession(vaultRoot: string, sessionId: string): Promise<Session | null> {\n const filePath = path.join(this.getTranscriptsDir(vaultRoot), `${sessionId}.jsonl`);\n try {\n const session = await this.extractSessionMeta(filePath, sessionId);\n // Enrich with latest status from file tail\n const tailStatus = await this.readTailStatus(filePath);\n if (tailStatus.model) session.model = tailStatus.model;\n if (tailStatus.permissionMode) session.permissionMode = tailStatus.permissionMode;\n if (tailStatus.contextTokens) session.contextTokens = tailStatus.contextTokens;\n return session;\n } catch {\n return null;\n }\n }\n\n /**\n * Read the tail of a JSONL file to get the most recent model, permissionMode, and context tokens.\n * Reads the last ~16KB which typically contains the final assistant messages.\n */\n private async readTailStatus(filePath: string): Promise<{\n model?: string;\n permissionMode?: PermissionMode;\n contextTokens?: number;\n }> {\n const TAIL_SIZE = 16384;\n try {\n const stat = await fs.stat(filePath);\n const fileHandle = await fs.open(filePath, 'r');\n try {\n const readOffset = Math.max(0, stat.size - TAIL_SIZE);\n const buffer = Buffer.alloc(Math.min(TAIL_SIZE, stat.size));\n const { bytesRead } = await fileHandle.read(buffer, 0, buffer.length, readOffset);\n const chunk = buffer.toString('utf-8', 0, bytesRead);\n const lines = chunk.split('\\n').filter(l => l.trim());\n\n let model: string | undefined;\n let permissionMode: PermissionMode | undefined;\n let contextTokens: number | undefined;\n\n // Iterate forward \u2014 last occurrence wins\n for (const line of lines) {\n let parsed: TranscriptLine;\n try {\n parsed = JSON.parse(line);\n } catch {\n continue;\n }\n if (parsed.type === 'assistant' && parsed.message?.model) {\n model = parsed.message.model;\n if (parsed.message.usage) {\n const u = parsed.message.usage;\n contextTokens =\n (u.input_tokens ?? 0) +\n (u.cache_read_input_tokens ?? 0) +\n (u.cache_creation_input_tokens ?? 0);\n }\n }\n if (parsed.type === 'user' && parsed.permissionMode) {\n const sdkMode = parsed.permissionMode;\n if (sdkMode === 'bypassPermissions' || sdkMode === 'dangerously-skip') {\n permissionMode = 'bypassPermissions';\n } else if (sdkMode === 'plan') {\n permissionMode = 'plan';\n } else if (sdkMode === 'acceptEdits') {\n permissionMode = 'acceptEdits';\n } else {\n permissionMode = 'default';\n }\n }\n }\n\n return { model, permissionMode, contextTokens };\n } finally {\n await fileHandle.close();\n }\n } catch {\n return {};\n }\n }\n\n /**\n * Extract session metadata from a JSONL file.\n * Reads only the first ~8KB for title/permissionMode, and uses file stat for timestamps.\n */\n private async extractSessionMeta(\n filePath: string,\n sessionId: string,\n fileStat?: Awaited<ReturnType<typeof fs.stat>>\n ): Promise<Session> {\n const stat = fileStat ?? await fs.stat(filePath);\n\n // Read only the head of the file (8KB) \u2014 metadata is always in the first few lines\n const fileHandle = await fs.open(filePath, 'r');\n let chunk: string;\n try {\n const buffer = Buffer.alloc(8192);\n const { bytesRead } = await fileHandle.read(buffer, 0, 8192, 0);\n chunk = buffer.toString('utf-8', 0, bytesRead);\n } finally {\n await fileHandle.close();\n }\n\n const lines = chunk.split('\\n').filter(l => l.trim());\n\n let firstUserMessage = '';\n let permissionMode: PermissionMode = 'default';\n let firstTimestamp = '';\n let model: string | undefined;\n let cwd: string | undefined;\n\n for (const line of lines) {\n let parsed: TranscriptLine;\n try {\n parsed = JSON.parse(line);\n } catch {\n continue;\n }\n\n // Extract permission mode from init message or user messages\n if (parsed.type === 'system' && parsed.subtype === 'init' && parsed.permissionMode) {\n const sdkMode = parsed.permissionMode as string;\n if (sdkMode === 'bypassPermissions' || sdkMode === 'dangerously-skip') {\n permissionMode = 'bypassPermissions';\n } else if (sdkMode === 'plan') {\n permissionMode = 'plan';\n } else if (sdkMode === 'acceptEdits') {\n permissionMode = 'acceptEdits';\n }\n }\n if (parsed.type === 'user' && parsed.permissionMode) {\n const sdkMode = parsed.permissionMode as string;\n if (sdkMode === 'bypassPermissions' || sdkMode === 'dangerously-skip') {\n permissionMode = 'bypassPermissions';\n } else if (sdkMode === 'plan') {\n permissionMode = 'plan';\n } else if (sdkMode === 'acceptEdits') {\n permissionMode = 'acceptEdits';\n } else {\n permissionMode = 'default';\n }\n }\n\n // Extract model from assistant messages\n if (!model && parsed.type === 'assistant' && parsed.message?.model) {\n model = parsed.message.model;\n }\n\n // Extract timestamps\n if (parsed.timestamp && !firstTimestamp) {\n firstTimestamp = parsed.timestamp;\n }\n\n // Extract cwd (before title extraction \u2014 the continue statements below skip the rest of the loop)\n if (!cwd && parsed.cwd) {\n cwd = parsed.cwd;\n }\n\n // Extract first user message for title\n if (!firstUserMessage && parsed.type === 'user' && parsed.message) {\n const text = this.extractTextContent(parsed.message.content);\n if (text.startsWith('<local-command') || text.startsWith('<command-name>') || text.startsWith('<command-message>') || text.startsWith('<task-notification>')) {\n continue;\n }\n if (text.startsWith('This session is being continued')) {\n continue;\n }\n const cleanText = this.stripSystemTags(text);\n if (!cleanText.trim()) continue;\n\n firstUserMessage = cleanText.trim();\n }\n\n // Once we have all head metadata, stop early\n if (firstUserMessage && firstTimestamp && model && cwd) break;\n }\n\n const title = firstUserMessage\n ? firstUserMessage.slice(0, 80) + (firstUserMessage.length > 80 ? '...' : '')\n : `Session ${sessionId.slice(0, 8)}`;\n\n return {\n id: sessionId,\n title,\n createdAt: firstTimestamp || stat.birthtime.toISOString(),\n updatedAt: stat.mtime.toISOString(),\n lastMessagePreview: undefined,\n permissionMode,\n model,\n cwd,\n };\n }\n\n /**\n * Read messages from an SDK session transcript.\n */\n async readTranscript(\n vaultRoot: string,\n sessionId: string\n ): Promise<HistoryMessage[]> {\n const transcriptsDir = this.getTranscriptsDir(vaultRoot);\n const filePath = path.join(transcriptsDir, `${sessionId}.jsonl`);\n\n let content: string;\n try {\n content = await fs.readFile(filePath, 'utf-8');\n } catch {\n return [];\n }\n\n const messages: HistoryMessage[] = [];\n const lines = content.split('\\n').filter(l => l.trim());\n // Track pending slash command metadata for correlating with expanded prompt\n let pendingCommand: { commandName: string; commandArgs: string } | null = null;\n // Track args from the most recent Skill tool_use (assistant message)\n let pendingSkillArgs: string | null = null;\n // Map tool_use_id \u2192 HistoryToolCall for correlating results\n const toolCallMap = new Map<string, HistoryToolCall>();\n // Map tool_use_id \u2192 ToolCallPart for correlating results into parts\n const toolCallPartMap = new Map<string, ToolCallPart>();\n\n for (const line of lines) {\n let parsed: TranscriptLine;\n try {\n parsed = JSON.parse(line);\n } catch {\n continue;\n }\n\n if (parsed.type === 'user' && parsed.message) {\n const msgContent = parsed.message.content;\n\n // Check for tool_result blocks in array content (auto-generated user messages)\n if (Array.isArray(msgContent)) {\n let hasToolResult = false;\n const textParts: string[] = [];\n\n // Extract structured answers from SDK's toolUseResult field (if present)\n const sdkAnswers = parsed.toolUseResult?.answers;\n\n for (const block of msgContent) {\n if (block.type === 'tool_result' && block.tool_use_id) {\n hasToolResult = true;\n const resultText = this.extractToolResultContent(block.content);\n const tc = toolCallMap.get(block.tool_use_id);\n if (tc) {\n tc.result = resultText;\n // AskUserQuestion: extract answers from SDK metadata or parse from result text\n if (tc.toolName === 'AskUserQuestion' && tc.questions && !tc.answers) {\n tc.answers = sdkAnswers\n ? this.mapSdkAnswersToIndices(sdkAnswers, tc.questions)\n : this.parseQuestionAnswers(resultText, tc.questions);\n }\n }\n const tcPart = toolCallPartMap.get(block.tool_use_id);\n if (tcPart) {\n tcPart.result = resultText;\n if (tcPart.toolName === 'AskUserQuestion' && tcPart.questions && !tcPart.answers) {\n tcPart.answers = sdkAnswers\n ? this.mapSdkAnswersToIndices(sdkAnswers, tcPart.questions as QuestionItem[])\n : this.parseQuestionAnswers(resultText, tcPart.questions as QuestionItem[]);\n }\n }\n } else if (block.type === 'text' && block.text) {\n textParts.push(block.text);\n }\n }\n\n // If this user message is purely tool results, skip it as a visible message\n // But first check if it's a Skill tool invocation (toolUseResult.commandName)\n if (hasToolResult && textParts.length === 0) {\n if (parsed.toolUseResult?.commandName) {\n const cmdName = '/' + parsed.toolUseResult.commandName.replace(/^\\//, '');\n pendingCommand = { commandName: cmdName, commandArgs: pendingSkillArgs || '' };\n pendingSkillArgs = null;\n }\n continue;\n }\n\n // If there's a pending command, this array-content message is the expanded skill prompt\n if (pendingCommand) {\n const { commandName, commandArgs } = pendingCommand;\n pendingCommand = null;\n const displayContent = commandArgs\n ? `${commandName} ${commandArgs}`\n : commandName;\n messages.push({\n id: parsed.uuid || crypto.randomUUID(),\n role: 'user',\n content: displayContent,\n messageType: 'command',\n commandName,\n commandArgs: commandArgs || undefined,\n });\n continue;\n }\n\n // Otherwise it has human text alongside tool results\n if (textParts.length > 0) {\n const cleanText = this.stripSystemTags(textParts.join('\\n'));\n if (cleanText.trim()) {\n messages.push({\n id: parsed.uuid || crypto.randomUUID(),\n role: 'user',\n content: cleanText,\n });\n }\n }\n continue;\n }\n\n // Plain string content (normal user message)\n const text = typeof msgContent === 'string' ? msgContent : '';\n\n // Skip task notifications entirely\n if (text.startsWith('<task-notification>')) {\n continue;\n }\n\n // Detect command metadata messages (set pendingCommand for next message)\n if (text.startsWith('<command-message>') || text.startsWith('<command-name>')) {\n const meta = this.extractCommandMeta(text);\n if (meta) {\n pendingCommand = meta;\n }\n continue;\n }\n\n // Local command messages (like /compact stdout) \u2014 skip and clear pending\n if (text.startsWith('<local-command')) {\n pendingCommand = null;\n continue;\n }\n\n // If there's a pending command, this message is the expanded skill prompt\n if (pendingCommand) {\n const { commandName, commandArgs } = pendingCommand;\n pendingCommand = null;\n const displayContent = commandArgs\n ? `${commandName} ${commandArgs}`\n : commandName;\n messages.push({\n id: parsed.uuid || crypto.randomUUID(),\n role: 'user',\n content: displayContent,\n messageType: 'command',\n commandName,\n commandArgs: commandArgs || undefined,\n });\n continue;\n }\n\n // Detect compaction summaries\n if (text.startsWith('This session is being continued')) {\n messages.push({\n id: parsed.uuid || crypto.randomUUID(),\n role: 'user',\n content: text,\n messageType: 'compaction',\n });\n continue;\n }\n\n const cleanText = this.stripSystemTags(text);\n if (!cleanText.trim()) continue;\n\n messages.push({\n id: parsed.uuid || crypto.randomUUID(),\n role: 'user',\n content: cleanText,\n });\n } else if (parsed.type === 'assistant' && parsed.message) {\n const contentBlocks = parsed.message.content;\n if (!Array.isArray(contentBlocks)) continue;\n\n const parts: MessagePart[] = [];\n const toolCalls: HistoryToolCall[] = [];\n\n for (const block of contentBlocks) {\n if (block.type === 'text' && block.text) {\n // Merge adjacent text parts\n const lastPart = parts[parts.length - 1];\n if (lastPart && lastPart.type === 'text') {\n lastPart.text += '\\n' + block.text;\n } else {\n parts.push({ type: 'text', text: block.text });\n }\n } else if (block.type === 'tool_use' && block.name && block.id) {\n const tc: HistoryToolCall = {\n toolCallId: block.id,\n toolName: block.name,\n input: block.input ? JSON.stringify(block.input) : undefined,\n status: 'complete',\n };\n // Preserve question/answer data for AskUserQuestion tool calls\n if (block.name === 'AskUserQuestion' && block.input) {\n if (Array.isArray(block.input.questions)) {\n tc.questions = block.input.questions as QuestionItem[];\n }\n if (block.input.answers && typeof block.input.answers === 'object') {\n tc.answers = block.input.answers as Record<string, string>;\n }\n }\n // Track Skill tool args for correlating with expanded prompt\n if (block.name === 'Skill' && block.input) {\n const input = block.input as Record<string, unknown>;\n pendingSkillArgs = (input.args as string) || null;\n }\n toolCalls.push(tc);\n toolCallMap.set(block.id, tc);\n\n // Add tool call part inline to preserve ordering\n const toolCallPart: ToolCallPart = {\n type: 'tool_call',\n toolCallId: block.id,\n toolName: block.name,\n input: block.input ? JSON.stringify(block.input) : undefined,\n status: 'complete',\n ...(tc.questions ? {\n interactiveType: 'question' as const,\n questions: tc.questions,\n answers: tc.answers,\n } : {}),\n };\n parts.push(toolCallPart);\n toolCallPartMap.set(block.id, toolCallPart);\n }\n }\n\n if (parts.length === 0) continue;\n\n // Derive flat content from text parts\n const text = parts\n .filter((p): p is { type: 'text'; text: string } => p.type === 'text')\n .map(p => p.text)\n .join('\\n')\n .trim();\n\n messages.push({\n id: parsed.uuid || crypto.randomUUID(),\n role: 'assistant',\n content: text,\n toolCalls: toolCalls.length > 0 ? toolCalls : undefined,\n parts,\n timestamp: parsed.timestamp,\n });\n }\n }\n\n return messages;\n }\n\n /**\n * List available SDK session transcript IDs.\n */\n async listTranscripts(vaultRoot: string): Promise<string[]> {\n const transcriptsDir = this.getTranscriptsDir(vaultRoot);\n try {\n const files = await fs.readdir(transcriptsDir);\n return files\n .filter(f => f.endsWith('.jsonl'))\n .map(f => f.replace('.jsonl', ''));\n } catch {\n return [];\n }\n }\n\n /**\n * Read task state from an SDK session transcript.\n * Parses TaskCreate/TaskUpdate tool_use blocks and reconstructs final state.\n */\n async getTranscriptETag(vaultRoot: string, sessionId: string): Promise<string | null> {\n const filePath = path.join(this.getTranscriptsDir(vaultRoot), `${sessionId}.jsonl`);\n try {\n const stat = await fs.stat(filePath);\n return `\"${stat.mtimeMs}-${stat.size}\"`;\n } catch {\n return null;\n }\n }\n\n async readTasks(vaultRoot: string, sessionId: string): Promise<TaskItem[]> {\n const transcriptsDir = this.getTranscriptsDir(vaultRoot);\n const filePath = path.join(transcriptsDir, `${sessionId}.jsonl`);\n\n let content: string;\n try {\n content = await fs.readFile(filePath, 'utf-8');\n } catch {\n return [];\n }\n\n const lines = content.split('\\n').filter(l => l.trim());\n const tasks = new Map<string, TaskItem>();\n let nextId = 1;\n\n for (const line of lines) {\n let parsed: TranscriptLine;\n try {\n parsed = JSON.parse(line);\n } catch {\n continue;\n }\n\n if (parsed.type !== 'assistant') continue;\n const message = parsed.message;\n if (!message?.content || !Array.isArray(message.content)) continue;\n\n for (const block of message.content) {\n if (block.type !== 'tool_use') continue;\n if (!block.name || !['TaskCreate', 'TaskUpdate'].includes(block.name)) continue;\n const input = block.input;\n if (!input) continue;\n\n if (block.name === 'TaskCreate') {\n const id = String(nextId++);\n tasks.set(id, {\n id,\n subject: (input.subject as string) ?? '',\n description: input.description as string | undefined,\n activeForm: input.activeForm as string | undefined,\n status: 'pending',\n });\n } else if (block.name === 'TaskUpdate' && input.taskId) {\n const existing = tasks.get(input.taskId as string);\n if (existing) {\n if (input.status) existing.status = input.status as TaskStatus;\n if (input.subject) existing.subject = input.subject as string;\n if (input.activeForm) existing.activeForm = input.activeForm as string;\n if (input.description) existing.description = input.description as string;\n if (input.addBlockedBy) existing.blockedBy = [...(existing.blockedBy ?? []), ...(input.addBlockedBy as string[])];\n if (input.addBlocks) existing.blocks = [...(existing.blocks ?? []), ...(input.addBlocks as string[])];\n if (input.owner) existing.owner = input.owner as string;\n }\n }\n }\n }\n\n return Array.from(tasks.values());\n }\n\n /**\n * Read new content from a transcript file starting from a byte offset.\n * Returns the new content and the updated file size (new offset).\n */\n async readFromOffset(\n vaultRoot: string,\n sessionId: string,\n fromOffset: number,\n ): Promise<{ content: string; newOffset: number }> {\n const filePath = path.join(this.getTranscriptsDir(vaultRoot), `${sessionId}.jsonl`);\n const stat = await fs.stat(filePath);\n\n if (stat.size <= fromOffset) {\n return { content: '', newOffset: fromOffset };\n }\n\n const fileHandle = await fs.open(filePath, 'r');\n try {\n const newBytes = stat.size - fromOffset;\n const buffer = Buffer.alloc(newBytes);\n await fileHandle.read(buffer, 0, newBytes, fromOffset);\n return {\n content: buffer.toString('utf-8'),\n newOffset: stat.size,\n };\n } finally {\n await fileHandle.close();\n }\n }\n\n private extractToolResultContent(content: string | ContentBlock[] | undefined): string {\n if (!content) return '';\n if (typeof content === 'string') return content;\n if (!Array.isArray(content)) return '';\n return content\n .filter(b => b.type === 'text' && b.text)\n .map(b => b.text!)\n .join('\\n');\n }\n\n private extractTextContent(content: string | ContentBlock[]): string {\n if (typeof content === 'string') return content;\n if (!Array.isArray(content)) return '';\n return content\n .filter(b => b.type === 'text' && b.text)\n .map(b => b.text!)\n .join('\\n');\n }\n\n private extractCommandMeta(text: string): { commandName: string; commandArgs: string } | null {\n const nameMatch = text.match(/<command-name>\\/?([^<]+)<\\/command-name>/);\n if (!nameMatch) return null;\n const commandName = '/' + nameMatch[1].replace(/^\\//, '');\n const argsMatch = text.match(/<command-args>([\\s\\S]*?)<\\/command-args>/);\n const commandArgs = argsMatch ? argsMatch[1].trim() : '';\n return { commandName, commandArgs };\n }\n\n private stripSystemTags(text: string): string {\n return text.replace(/<system-reminder>[\\s\\S]*?<\\/system-reminder>/g, '').trim();\n }\n\n /**\n * Map SDK's toolUseResult.answers (keyed by question text) to index-keyed record.\n * SDK stores answers as { \"Question text\": \"Answer value\" }.\n * Client expects { \"0\": \"Answer value\", \"1\": \"...\" }.\n */\n private mapSdkAnswersToIndices(sdkAnswers: Record<string, string>, questions: QuestionItem[]): Record<string, string> {\n const answers: Record<string, string> = {};\n for (const [questionText, answerText] of Object.entries(sdkAnswers)) {\n const qIdx = questions.findIndex(q => q.question === questionText);\n if (qIdx !== -1) {\n answers[String(qIdx)] = answerText;\n }\n }\n // If SDK answer keys are already indices (our gateway format), use directly\n if (Object.keys(answers).length === 0) {\n for (const [key, value] of Object.entries(sdkAnswers)) {\n if (/^\\d+$/.test(key)) {\n answers[key] = value;\n }\n }\n }\n return answers;\n }\n\n /**\n * Parse answers from AskUserQuestion tool_result text (fallback).\n * Format: `...\"Question text\"=\"Answer text\", \"Q2\"=\"A2\". You can now...`\n * Falls back to empty record (truthy signal) if parsing fails.\n */\n private parseQuestionAnswers(resultText: string, questions: QuestionItem[]): Record<string, string> {\n const answers: Record<string, string> = {};\n // Match \"question\"=\"answer\" pairs in the result text\n const pairRegex = /\"([^\"]+?)\"\\s*=\\s*\"([^\"]+?)\"/g;\n let match;\n while ((match = pairRegex.exec(resultText)) !== null) {\n const [, questionText, answerText] = match;\n const qIdx = questions.findIndex(q => q.question === questionText);\n if (qIdx !== -1) {\n answers[String(qIdx)] = answerText;\n }\n }\n return answers;\n }\n}\n\nexport const transcriptReader = new TranscriptReader();\n", "import type { Response } from 'express';\nimport type { StreamEvent } from '@dorkos/shared/types';\n\nexport function initSSEStream(res: Response): void {\n res.writeHead(200, {\n 'Content-Type': 'text/event-stream',\n 'Cache-Control': 'no-cache',\n Connection: 'keep-alive',\n 'X-Accel-Buffering': 'no',\n });\n}\n\nexport function sendSSEEvent(res: Response, event: StreamEvent): void {\n res.write(`event: ${event.type}\\n`);\n res.write(`data: ${JSON.stringify(event.data)}\\n\\n`);\n}\n\nexport function endSSEStream(res: Response): void {\n res.end();\n}\n", "import { z } from 'zod';\nimport { extendZodWithOpenApi } from '@asteasolutions/zod-to-openapi';\n\nextendZodWithOpenApi(z);\n\n// === Enums ===\n\nexport const PermissionModeSchema = z\n .enum(['default', 'plan', 'acceptEdits', 'bypassPermissions'])\n .openapi('PermissionMode');\n\nexport type PermissionMode = z.infer<typeof PermissionModeSchema>;\n\nexport const TaskStatusSchema = z\n .enum(['pending', 'in_progress', 'completed'])\n .openapi('TaskStatus');\n\nexport type TaskStatus = z.infer<typeof TaskStatusSchema>;\n\nexport const StreamEventTypeSchema = z\n .enum([\n 'text_delta',\n 'tool_call_start',\n 'tool_call_delta',\n 'tool_call_end',\n 'tool_result',\n 'approval_required',\n 'question_prompt',\n 'error',\n 'done',\n 'session_status',\n 'task_update',\n 'sync_update',\n 'sync_connected',\n ])\n .openapi('StreamEventType');\n\nexport type StreamEventType = z.infer<typeof StreamEventTypeSchema>;\n\n// === Question / Option Types ===\n\nexport const QuestionOptionSchema = z\n .object({\n label: z.string(),\n description: z.string().optional(),\n })\n .openapi('QuestionOption');\n\nexport type QuestionOption = z.infer<typeof QuestionOptionSchema>;\n\nexport const QuestionItemSchema = z\n .object({\n header: z.string(),\n question: z.string(),\n options: z.array(QuestionOptionSchema),\n multiSelect: z.boolean(),\n })\n .openapi('QuestionItem');\n\nexport type QuestionItem = z.infer<typeof QuestionItemSchema>;\n\n// === Session Types ===\n\nexport const SessionSchema = z\n .object({\n id: z.string().uuid(),\n title: z.string(),\n createdAt: z.string().datetime(),\n updatedAt: z.string().datetime(),\n lastMessagePreview: z.string().optional(),\n permissionMode: PermissionModeSchema,\n model: z.string().optional(),\n contextTokens: z.number().int().optional(),\n cwd: z.string().optional(),\n })\n .openapi('Session');\n\nexport type Session = z.infer<typeof SessionSchema>;\n\nexport const CreateSessionRequestSchema = z\n .object({\n permissionMode: PermissionModeSchema.optional(),\n cwd: z.string().optional(),\n })\n .openapi('CreateSessionRequest');\n\nexport type CreateSessionRequest = z.infer<typeof CreateSessionRequestSchema>;\n\nexport const UpdateSessionRequestSchema = z\n .object({\n permissionMode: PermissionModeSchema.optional(),\n model: z.string().optional(),\n })\n .openapi('UpdateSessionRequest');\n\nexport type UpdateSessionRequest = z.infer<typeof UpdateSessionRequestSchema>;\n\nexport const SendMessageRequestSchema = z\n .object({\n content: z.string().min(1, 'content is required'),\n cwd: z.string().optional(),\n })\n .openapi('SendMessageRequest');\n\nexport type SendMessageRequest = z.infer<typeof SendMessageRequestSchema>;\n\nexport const ApprovalRequestSchema = z\n .object({\n toolCallId: z.string(),\n })\n .openapi('ApprovalRequest');\n\nexport type ApprovalRequest = z.infer<typeof ApprovalRequestSchema>;\n\nexport const SubmitAnswersRequestSchema = z\n .object({\n toolCallId: z.string(),\n answers: z.record(z.string(), z.string()),\n })\n .openapi('SubmitAnswersRequest');\n\nexport type SubmitAnswersRequest = z.infer<typeof SubmitAnswersRequestSchema>;\n\nexport const ListSessionsQuerySchema = z\n .object({\n limit: z.coerce.number().int().min(1).max(500).optional().default(200),\n cwd: z.string().optional(),\n })\n .openapi('ListSessionsQuery');\n\nexport type ListSessionsQuery = z.infer<typeof ListSessionsQuerySchema>;\n\nexport const CommandsQuerySchema = z\n .object({\n refresh: z.enum(['true', 'false']).optional(),\n cwd: z.string().optional(),\n })\n .openapi('CommandsQuery');\n\nexport type CommandsQuery = z.infer<typeof CommandsQuerySchema>;\n\n// === SSE Event Types ===\n\nexport const TextDeltaSchema = z\n .object({\n text: z.string(),\n })\n .openapi('TextDelta');\n\nexport type TextDelta = z.infer<typeof TextDeltaSchema>;\n\nconst ToolCallStatusSchema = z.enum(['pending', 'running', 'complete', 'error']);\n\nexport const ToolCallEventSchema = z\n .object({\n toolCallId: z.string(),\n toolName: z.string(),\n input: z.string().optional(),\n result: z.string().optional(),\n status: ToolCallStatusSchema,\n })\n .openapi('ToolCallEvent');\n\nexport type ToolCallEvent = z.infer<typeof ToolCallEventSchema>;\n\nexport const ApprovalEventSchema = z\n .object({\n toolCallId: z.string(),\n toolName: z.string(),\n input: z.string(),\n })\n .openapi('ApprovalEvent');\n\nexport type ApprovalEvent = z.infer<typeof ApprovalEventSchema>;\n\nexport const QuestionPromptEventSchema = z\n .object({\n toolCallId: z.string(),\n questions: z.array(QuestionItemSchema),\n })\n .openapi('QuestionPromptEvent');\n\nexport type QuestionPromptEvent = z.infer<typeof QuestionPromptEventSchema>;\n\nexport const ErrorEventSchema = z\n .object({\n message: z.string(),\n code: z.string().optional(),\n })\n .openapi('ErrorEvent');\n\nexport type ErrorEvent = z.infer<typeof ErrorEventSchema>;\n\nexport const DoneEventSchema = z\n .object({\n sessionId: z.string(),\n })\n .openapi('DoneEvent');\n\nexport type DoneEvent = z.infer<typeof DoneEventSchema>;\n\nexport const SessionStatusEventSchema = z\n .object({\n sessionId: z.string(),\n model: z.string().optional(),\n costUsd: z.number().optional(),\n contextTokens: z.number().int().optional(),\n contextMaxTokens: z.number().int().optional(),\n })\n .openapi('SessionStatusEvent');\n\nexport type SessionStatusEvent = z.infer<typeof SessionStatusEventSchema>;\n\nexport const TaskItemSchema = z\n .object({\n id: z.string(),\n subject: z.string(),\n description: z.string().optional(),\n activeForm: z.string().optional(),\n status: TaskStatusSchema,\n blockedBy: z.array(z.string()).optional(),\n blocks: z.array(z.string()).optional(),\n owner: z.string().optional(),\n })\n .openapi('TaskItem');\n\nexport type TaskItem = z.infer<typeof TaskItemSchema>;\n\nexport const TaskUpdateEventSchema = z\n .object({\n action: z.enum(['create', 'update', 'snapshot']),\n task: TaskItemSchema,\n })\n .openapi('TaskUpdateEvent');\n\nexport type TaskUpdateEvent = z.infer<typeof TaskUpdateEventSchema>;\n\nexport const SyncUpdateEventSchema = z\n .object({\n sessionId: z.string(),\n timestamp: z.string(),\n })\n .openapi('SyncUpdateEvent');\n\nexport type SyncUpdateEvent = z.infer<typeof SyncUpdateEventSchema>;\n\nexport const SyncConnectedEventSchema = z\n .object({\n sessionId: z.string(),\n })\n .openapi('SyncConnectedEvent');\n\nexport type SyncConnectedEvent = z.infer<typeof SyncConnectedEventSchema>;\n\nexport const StreamEventSchema = z\n .object({\n type: StreamEventTypeSchema,\n data: z.union([\n TextDeltaSchema,\n ToolCallEventSchema,\n ApprovalEventSchema,\n QuestionPromptEventSchema,\n ErrorEventSchema,\n DoneEventSchema,\n SessionStatusEventSchema,\n TaskUpdateEventSchema,\n SyncUpdateEventSchema,\n SyncConnectedEventSchema,\n ]),\n })\n .openapi('StreamEvent');\n\nexport type StreamEvent = z.infer<typeof StreamEventSchema>;\n\n// === Message Part Types ===\n\nexport const TextPartSchema = z\n .object({\n type: z.literal('text'),\n text: z.string(),\n })\n .openapi('TextPart');\n\nexport type TextPart = z.infer<typeof TextPartSchema>;\n\nexport const ToolCallPartSchema = z\n .object({\n type: z.literal('tool_call'),\n toolCallId: z.string(),\n toolName: z.string(),\n input: z.string().optional(),\n result: z.string().optional(),\n status: ToolCallStatusSchema,\n interactiveType: z.enum(['approval', 'question']).optional(),\n questions: z.array(QuestionItemSchema).optional(),\n answers: z.record(z.string(), z.string()).optional(),\n })\n .openapi('ToolCallPart');\n\nexport type ToolCallPart = z.infer<typeof ToolCallPartSchema>;\n\nexport const MessagePartSchema = z.discriminatedUnion('type', [\n TextPartSchema,\n ToolCallPartSchema,\n]);\n\nexport type MessagePart = z.infer<typeof MessagePartSchema>;\n\n// === Message Type ===\n\nexport const MessageTypeSchema = z\n .enum(['command', 'compaction'])\n .openapi('MessageType');\n\nexport type MessageType = z.infer<typeof MessageTypeSchema>;\n\n// === Chat History Types ===\n\nexport const HistoryToolCallSchema = z\n .object({\n toolCallId: z.string(),\n toolName: z.string(),\n input: z.string().optional(),\n result: z.string().optional(),\n status: z.literal('complete'),\n questions: z.array(QuestionItemSchema).optional(),\n answers: z.record(z.string(), z.string()).optional(),\n })\n .openapi('HistoryToolCall');\n\nexport type HistoryToolCall = z.infer<typeof HistoryToolCallSchema>;\n\nexport const HistoryMessageSchema = z\n .object({\n id: z.string(),\n role: z.enum(['user', 'assistant']),\n content: z.string(),\n toolCalls: z.array(HistoryToolCallSchema).optional(),\n parts: z.array(MessagePartSchema).optional(),\n timestamp: z.string().optional(),\n messageType: MessageTypeSchema.optional(),\n commandName: z.string().optional(),\n commandArgs: z.string().optional(),\n })\n .openapi('HistoryMessage');\n\nexport type HistoryMessage = z.infer<typeof HistoryMessageSchema>;\n\n// === Command Types ===\n\nexport const CommandEntrySchema = z\n .object({\n namespace: z.string(),\n command: z.string(),\n fullCommand: z.string(),\n description: z.string(),\n argumentHint: z.string().optional(),\n allowedTools: z.array(z.string()).optional(),\n filePath: z.string(),\n })\n .openapi('CommandEntry');\n\nexport type CommandEntry = z.infer<typeof CommandEntrySchema>;\n\nexport const CommandRegistrySchema = z\n .object({\n commands: z.array(CommandEntrySchema),\n lastScanned: z.string(),\n })\n .openapi('CommandRegistry');\n\nexport type CommandRegistry = z.infer<typeof CommandRegistrySchema>;\n\n// === File Listing Types ===\n\nexport const FileListQuerySchema = z\n .object({\n cwd: z.string().min(1),\n })\n .openapi('FileListQuery');\n\nexport type FileListQuery = z.infer<typeof FileListQuerySchema>;\n\nexport const FileListResponseSchema = z\n .object({\n files: z.array(z.string()),\n truncated: z.boolean(),\n total: z.number().int(),\n })\n .openapi('FileListResponse');\n\nexport type FileListResponse = z.infer<typeof FileListResponseSchema>;\n\n// === Directory Browsing Types ===\n\nexport const BrowseDirectoryQuerySchema = z\n .object({\n path: z.string().min(1).optional(),\n showHidden: z.coerce.boolean().optional().default(false),\n })\n .openapi('BrowseDirectoryQuery');\n\nexport type BrowseDirectoryQuery = z.infer<typeof BrowseDirectoryQuerySchema>;\n\nexport const DirectoryEntrySchema = z\n .object({\n name: z.string(),\n path: z.string(),\n isDirectory: z.boolean(),\n })\n .openapi('DirectoryEntry');\n\nexport type DirectoryEntry = z.infer<typeof DirectoryEntrySchema>;\n\nexport const BrowseDirectoryResponseSchema = z\n .object({\n path: z.string(),\n entries: z.array(DirectoryEntrySchema),\n parent: z.string().nullable(),\n })\n .openapi('BrowseDirectoryResponse');\n\nexport type BrowseDirectoryResponse = z.infer<typeof BrowseDirectoryResponseSchema>;\n\n// === Tunnel Status ===\n\nexport const TunnelStatusSchema = z\n .object({\n connected: z.boolean(),\n url: z.string().nullable(),\n port: z.number().int().nullable(),\n startedAt: z.string().nullable(),\n })\n .openapi('TunnelStatus');\n\nexport type TunnelStatus = z.infer<typeof TunnelStatusSchema>;\n\n// === Health Response ===\n\nexport const HealthResponseSchema = z\n .object({\n status: z.string(),\n version: z.string(),\n uptime: z.number(),\n tunnel: TunnelStatusSchema.optional(),\n })\n .openapi('HealthResponse');\n\nexport type HealthResponse = z.infer<typeof HealthResponseSchema>;\n\n// === Server Config ===\n\nexport const ServerConfigSchema = z\n .object({\n version: z.string(),\n port: z.number().int(),\n uptime: z.number(),\n workingDirectory: z.string(),\n nodeVersion: z.string(),\n claudeCliPath: z.string().nullable(),\n tunnel: z.object({\n enabled: z.boolean(),\n connected: z.boolean(),\n url: z.string().nullable(),\n authEnabled: z.boolean(),\n tokenConfigured: z.boolean(),\n }),\n })\n .openapi('ServerConfig');\n\nexport type ServerConfig = z.infer<typeof ServerConfigSchema>;\n\n// === Git Status ===\n\nexport const GitStatusResponseSchema = z\n .object({\n branch: z.string().describe('Current branch name or HEAD SHA if detached'),\n ahead: z.number().int().describe('Commits ahead of remote tracking branch'),\n behind: z.number().int().describe('Commits behind remote tracking branch'),\n modified: z.number().int().describe('Count of modified files (staged + unstaged)'),\n staged: z.number().int().describe('Count of staged files'),\n untracked: z.number().int().describe('Count of untracked files'),\n conflicted: z.number().int().describe('Count of files with merge conflicts'),\n clean: z.boolean().describe('True if working directory is clean'),\n detached: z.boolean().describe('True if HEAD is detached'),\n tracking: z.string().nullable().describe('Remote tracking branch name'),\n })\n .openapi('GitStatusResponse');\n\nexport type GitStatusResponse = z.infer<typeof GitStatusResponseSchema>;\n\nexport const GitStatusErrorSchema = z\n .object({\n error: z.literal('not_git_repo'),\n })\n .openapi('GitStatusError');\n\nexport type GitStatusError = z.infer<typeof GitStatusErrorSchema>;\n\n// === Error Response ===\n\nexport const ErrorResponseSchema = z\n .object({\n error: z.string(),\n details: z.any().optional(),\n })\n .openapi('ErrorResponse');\n\nexport type ErrorResponse = z.infer<typeof ErrorResponseSchema>;\n\nexport const SessionLockedErrorSchema = z\n .object({\n error: z.literal('Session locked'),\n code: z.literal('SESSION_LOCKED'),\n lockedBy: z.string(),\n lockedAt: z.string(),\n })\n .openapi('SessionLockedError');\n\nexport type SessionLockedError = z.infer<typeof SessionLockedErrorSchema>;\n", "import { Router } from 'express';\nimport { CommandRegistryService } from '../services/command-registry.js';\nimport { CommandsQuerySchema } from '@dorkos/shared/schemas';\nimport path from 'path';\nimport { fileURLToPath } from 'url';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\nconst defaultRoot = process.env.GATEWAY_CWD ?? path.resolve(__dirname, '../../../../');\nconst registryCache = new Map<string, CommandRegistryService>();\n\nfunction getRegistry(cwd?: string): CommandRegistryService {\n const root = cwd || defaultRoot;\n let registry = registryCache.get(root);\n if (!registry) {\n registry = new CommandRegistryService(root);\n registryCache.set(root, registry);\n }\n return registry;\n}\n\nconst router = Router();\n\n// GET /api/commands - List all commands (with optional refresh and cwd)\nrouter.get('/', async (req, res) => {\n const parsed = CommandsQuerySchema.safeParse(req.query);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid query', details: parsed.error.format() });\n }\n const refresh = parsed.data.refresh === 'true';\n const registry = getRegistry(parsed.data.cwd);\n const commands = await registry.getCommands(refresh);\n res.json(commands);\n});\n\nexport default router;\n", "import fs from 'fs/promises';\nimport path from 'path';\nimport matter from 'gray-matter';\nimport type { CommandEntry, CommandRegistry } from '@dorkos/shared/types';\n\n/**\n * Fallback frontmatter parser for when gray-matter's YAML parser fails\n * (e.g. unquoted values with brackets, colons, pipes).\n * Extracts simple key: value pairs from the frontmatter block.\n */\nfunction parseFrontmatterFallback(content: string): Record<string, string> {\n const match = content.match(/^---\\n([\\s\\S]*?)\\n---/);\n if (!match) return {};\n\n const result: Record<string, string> = {};\n for (const line of match[1].split('\\n')) {\n const colonIdx = line.indexOf(':');\n if (colonIdx === -1) continue;\n const key = line.slice(0, colonIdx).trim();\n const val = line.slice(colonIdx + 1).trim();\n if (key && val) result[key] = val;\n }\n return result;\n}\n\nclass CommandRegistryService {\n private cache: CommandRegistry | null = null;\n private readonly commandsDir: string;\n\n constructor(vaultRoot: string) {\n this.commandsDir = path.join(vaultRoot, '.claude', 'commands');\n }\n\n async getCommands(forceRefresh = false): Promise<CommandRegistry> {\n if (this.cache && !forceRefresh) return this.cache;\n\n const commands: CommandEntry[] = [];\n\n try {\n const entries = await fs.readdir(this.commandsDir, {\n withFileTypes: true,\n });\n\n for (const entry of entries) {\n if (!entry.isDirectory()) continue;\n\n const nsPath = path.join(this.commandsDir, entry.name);\n const files = await fs.readdir(nsPath);\n\n for (const file of files) {\n if (!file.endsWith('.md')) continue;\n\n const filePath = path.join(nsPath, file);\n try {\n const content = await fs.readFile(filePath, 'utf-8');\n\n let frontmatter: Record<string, any>;\n try {\n frontmatter = matter(content).data;\n } catch {\n // YAML parse failed (e.g. unquoted brackets/colons) \u2014 use simple fallback\n frontmatter = parseFrontmatterFallback(content);\n }\n\n const commandName = file.replace('.md', '');\n const allowedToolsRaw = frontmatter['allowed-tools'];\n commands.push({\n namespace: entry.name,\n command: commandName,\n fullCommand: `/${entry.name}:${commandName}`,\n description: frontmatter.description || '',\n argumentHint: frontmatter['argument-hint'],\n allowedTools: typeof allowedToolsRaw === 'string'\n ? allowedToolsRaw.split(',').map((t: string) => t.trim())\n : allowedToolsRaw,\n filePath: path.relative(process.cwd(), filePath),\n });\n } catch (fileErr) {\n console.warn(`[CommandRegistry] Skipping ${entry.name}/${file}: ${(fileErr as Error).message}`);\n }\n }\n }\n } catch (err) {\n // Commands directory might not exist\n console.warn('[CommandRegistry] Could not read commands directory:', (err as Error).message);\n }\n\n commands.sort((a, b) => a.fullCommand.localeCompare(b.fullCommand));\n\n this.cache = { commands, lastScanned: new Date().toISOString() };\n return this.cache;\n }\n\n invalidateCache(): void {\n this.cache = null;\n }\n}\n\nexport { CommandRegistryService };\n", "import { Router } from 'express';\nimport { tunnelManager } from '../services/tunnel-manager.js';\n\nconst router = Router();\n\nrouter.get('/', (_req, res) => {\n const response: Record<string, unknown> = {\n status: 'ok',\n version: '1.0.0',\n uptime: process.uptime(),\n };\n\n const tunnelStatus = tunnelManager.status;\n if (tunnelStatus.enabled) {\n response.tunnel = {\n connected: tunnelStatus.connected,\n url: tunnelStatus.url,\n port: tunnelStatus.port,\n startedAt: tunnelStatus.startedAt,\n };\n }\n\n res.json(response);\n});\n\nexport default router;\n", "export interface TunnelConfig {\n port: number;\n authtoken?: string;\n basicAuth?: string;\n domain?: string;\n}\n\nexport interface TunnelStatus {\n enabled: boolean;\n connected: boolean;\n url: string | null;\n port: number | null;\n startedAt: string | null;\n}\n\nexport class TunnelManager {\n private listener: { close(): Promise<void>; url(): string | null } | null = null;\n private _status: TunnelStatus = {\n enabled: false, connected: false, url: null, port: null, startedAt: null,\n };\n\n get status(): TunnelStatus { return { ...this._status }; }\n\n async start(config: TunnelConfig): Promise<string> {\n if (this.listener) throw new Error('Tunnel is already running');\n\n const ngrok = await import('@ngrok/ngrok');\n\n const forwardOpts: Record<string, unknown> = {\n addr: config.port,\n authtoken_from_env: true,\n };\n\n if (config.authtoken) {\n forwardOpts.authtoken = config.authtoken;\n delete forwardOpts.authtoken_from_env;\n }\n if (config.basicAuth) forwardOpts.basic_auth = [config.basicAuth];\n if (config.domain) forwardOpts.domain = config.domain;\n\n this.listener = await ngrok.forward(forwardOpts);\n const url = this.listener.url() ?? '';\n\n this._status = {\n enabled: true, connected: true, url, port: config.port,\n startedAt: new Date().toISOString(),\n };\n return url;\n }\n\n async stop(): Promise<void> {\n if (this.listener) {\n await this.listener.close();\n this.listener = null;\n }\n this._status = {\n enabled: this._status.enabled, connected: false, url: null,\n port: this._status.port, startedAt: this._status.startedAt,\n };\n }\n}\n\nexport const tunnelManager = new TunnelManager();\n", "import { Router } from 'express';\nimport fs from 'fs/promises';\nimport path from 'path';\nimport os from 'os';\nimport { BrowseDirectoryQuerySchema } from '@dorkos/shared/schemas';\n\nconst router = Router();\nconst HOME = os.homedir();\n\n// GET /api/directory - Browse directories (restricted to home directory)\nrouter.get('/', async (req, res) => {\n const parsed = BrowseDirectoryQuerySchema.safeParse(req.query);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid query', details: parsed.error.format() });\n }\n const { path: userPath, showHidden } = parsed.data;\n\n const targetPath = userPath || HOME;\n\n // Reject null bytes\n if (targetPath.includes('\\0')) {\n return res.status(400).json({ error: 'Invalid path' });\n }\n\n let resolved: string;\n try {\n resolved = await fs.realpath(targetPath);\n } catch (err: unknown) {\n const code = (err as NodeJS.ErrnoException).code;\n if (code === 'ENOENT') return res.status(404).json({ error: 'Directory not found' });\n if (code === 'EACCES') return res.status(403).json({ error: 'Permission denied' });\n throw err;\n }\n\n // Security: restrict to home directory\n if (!resolved.startsWith(HOME)) {\n return res.status(403).json({ error: 'Access denied: path outside home directory' });\n }\n\n // Read directory entries (directories only)\n let dirents: import('fs').Dirent[];\n try {\n dirents = await fs.readdir(resolved, { withFileTypes: true }) as import('fs').Dirent[];\n } catch (err: unknown) {\n const code = (err as NodeJS.ErrnoException).code;\n if (code === 'EACCES') return res.status(403).json({ error: 'Permission denied' });\n if (code === 'ENOTDIR') return res.status(400).json({ error: 'Not a directory' });\n throw err;\n }\n\n const entries = dirents\n .filter(d => d.isDirectory())\n .filter(d => showHidden || !d.name.startsWith('.'))\n .map(d => ({\n name: d.name,\n path: path.join(resolved, d.name),\n isDirectory: true,\n }))\n .sort((a, b) => a.name.localeCompare(b.name));\n\n const parent = path.dirname(resolved);\n const hasParent = parent !== resolved && parent.startsWith(HOME);\n\n res.json({\n path: resolved,\n entries,\n parent: hasParent ? parent : null,\n });\n});\n\n// GET /api/directory/default - Get the server's default working directory\nrouter.get('/default', (_req, res) => {\n res.json({ path: process.cwd() });\n});\n\nexport default router;\n", "import { Router } from 'express';\nimport { tunnelManager } from '../services/tunnel-manager.js';\nimport { resolveClaudeCliPath } from '../services/agent-manager.js';\n\nconst router = Router();\n\nrouter.get('/', (_req, res) => {\n let claudeCliPath: string | null = null;\n try {\n claudeCliPath = resolveClaudeCliPath() ?? null;\n } catch {}\n\n const tunnel = tunnelManager.status;\n\n res.json({\n version: '1.0.0',\n port: parseInt(process.env.GATEWAY_PORT || '6942', 10),\n uptime: process.uptime(),\n workingDirectory: process.cwd(),\n nodeVersion: process.version,\n claudeCliPath,\n tunnel: {\n enabled: tunnel.enabled,\n connected: tunnel.connected,\n url: tunnel.url,\n authEnabled: !!process.env.TUNNEL_AUTH,\n tokenConfigured: !!process.env.NGROK_AUTHTOKEN,\n },\n });\n});\n\nexport default router;\n", "import { Router } from 'express';\nimport { fileLister } from '../services/file-lister.js';\nimport { FileListQuerySchema } from '@dorkos/shared/schemas';\n\nconst router = Router();\n\nrouter.get('/', async (req, res) => {\n const parsed = FileListQuerySchema.safeParse(req.query);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid query', details: parsed.error.format() });\n }\n const result = await fileLister.listFiles(parsed.data.cwd);\n res.json(result);\n});\n\nexport default router;\n", "import { execFile } from 'child_process';\nimport { promisify } from 'util';\nimport fs from 'fs/promises';\nimport path from 'path';\n\nconst execFileAsync = promisify(execFile);\n\nconst EXCLUDED_DIRS = new Set([\n 'node_modules', '.git', 'dist', 'build', '.next', 'coverage', '__pycache__', '.cache',\n]);\nconst MAX_FILES = 10_000;\nconst CACHE_TTL = 5 * 60 * 1000;\n\nclass FileListService {\n private cache = new Map<string, { files: string[]; timestamp: number }>();\n\n async listFiles(cwd: string): Promise<{ files: string[]; truncated: boolean; total: number }> {\n const cached = this.cache.get(cwd);\n if (cached && Date.now() - cached.timestamp < CACHE_TTL) {\n return { files: cached.files, truncated: cached.files.length >= MAX_FILES, total: cached.files.length };\n }\n\n let files: string[];\n try {\n files = await this.listViaGit(cwd);\n } catch {\n files = await this.listViaReaddir(cwd);\n }\n\n const truncated = files.length > MAX_FILES;\n if (truncated) files = files.slice(0, MAX_FILES);\n\n this.cache.set(cwd, { files, timestamp: Date.now() });\n return { files, truncated, total: files.length };\n }\n\n private async listViaGit(cwd: string): Promise<string[]> {\n const { stdout } = await execFileAsync('git', ['ls-files', '--cached', '--others', '--exclude-standard'], {\n cwd,\n maxBuffer: 10 * 1024 * 1024,\n });\n return stdout.split('\\n').filter(Boolean);\n }\n\n private async listViaReaddir(cwd: string, prefix = '', depth = 0): Promise<string[]> {\n if (depth > 8) return [];\n const results: string[] = [];\n const entries = await fs.readdir(path.join(cwd, prefix), { withFileTypes: true });\n for (const entry of entries) {\n if (entry.name.startsWith('.') && entry.name !== '.') continue;\n const rel = prefix ? `${prefix}/${entry.name}` : entry.name;\n if (entry.isDirectory()) {\n if (EXCLUDED_DIRS.has(entry.name)) continue;\n results.push(...await this.listViaReaddir(cwd, rel, depth + 1));\n } else {\n results.push(rel);\n }\n if (results.length >= MAX_FILES) break;\n }\n return results;\n }\n\n invalidateCache(cwd?: string): void {\n if (cwd) this.cache.delete(cwd);\n else this.cache.clear();\n }\n}\n\nexport const fileLister = new FileListService();\n", "import { Router } from 'express';\nimport { z } from 'zod';\nimport { getGitStatus } from '../services/git-status.js';\n\nconst router = Router();\n\nconst GitStatusQuerySchema = z.object({\n dir: z.string().optional(),\n});\n\nrouter.get('/status', async (req, res) => {\n const parsed = GitStatusQuerySchema.safeParse(req.query);\n if (!parsed.success) {\n return res.status(400).json({ error: 'Invalid query', details: parsed.error.format() });\n }\n const cwd = parsed.data.dir || process.cwd();\n const result = await getGitStatus(cwd);\n res.json(result);\n});\n\nexport default router;\n", "import { execFile } from 'node:child_process';\nimport { promisify } from 'node:util';\nimport type { GitStatusResponse, GitStatusError } from '@dorkos/shared/types';\n\nconst execFileAsync = promisify(execFile);\n\nexport async function getGitStatus(cwd: string): Promise<GitStatusResponse | GitStatusError> {\n try {\n const { stdout } = await execFileAsync('git', ['status', '--porcelain=v1', '--branch'], {\n cwd,\n timeout: 5000,\n });\n return parsePorcelainOutput(stdout);\n } catch {\n return { error: 'not_git_repo' as const };\n }\n}\n\nconst CONFLICT_CODES = new Set(['UU', 'AA', 'DD', 'AU', 'UA', 'DU', 'UD']);\nconst STAGED_CODES = new Set(['M', 'A', 'D', 'R', 'C']);\n\nexport function parsePorcelainOutput(stdout: string): GitStatusResponse {\n const lines = stdout.split('\\n').filter(Boolean);\n\n let branch = '';\n let tracking: string | null = null;\n let ahead = 0;\n let behind = 0;\n let detached = false;\n\n let modified = 0;\n let staged = 0;\n let untracked = 0;\n let conflicted = 0;\n\n for (const line of lines) {\n if (line.startsWith('## ')) {\n const branchLine = line.slice(3);\n\n // Detached HEAD\n if (branchLine.startsWith('HEAD (no branch)')) {\n detached = true;\n branch = 'HEAD';\n continue;\n }\n\n // Extract ahead/behind from bracket notation\n const bracketMatch = branchLine.match(/\\[(.+)\\]/);\n if (bracketMatch) {\n const info = bracketMatch[1];\n const aheadMatch = info.match(/ahead (\\d+)/);\n const behindMatch = info.match(/behind (\\d+)/);\n if (aheadMatch) ahead = parseInt(aheadMatch[1], 10);\n if (behindMatch) behind = parseInt(behindMatch[1], 10);\n }\n\n // Extract branch and tracking\n const branchPart = branchLine.replace(/\\s*\\[.*\\]/, '');\n const dotIndex = branchPart.indexOf('...');\n if (dotIndex !== -1) {\n branch = branchPart.slice(0, dotIndex);\n tracking = branchPart.slice(dotIndex + 3);\n } else {\n branch = branchPart;\n }\n\n continue;\n }\n\n // File status lines: XY filename\n const x = line[0];\n const y = line[1];\n const code = `${x}${y}`;\n\n if (code === '??') {\n untracked++;\n } else if (CONFLICT_CODES.has(code)) {\n conflicted++;\n } else {\n if (STAGED_CODES.has(x)) staged++;\n if (y === 'M' || y === 'D') modified++;\n }\n }\n\n const clean = modified === 0 && staged === 0 && untracked === 0 && conflicted === 0;\n\n return { branch, ahead, behind, modified, staged, untracked, conflicted, clean, detached, tracking };\n}\n", "import {\n OpenAPIRegistry,\n OpenApiGeneratorV31,\n} from '@asteasolutions/zod-to-openapi';\nimport {\n SessionSchema,\n CreateSessionRequestSchema,\n UpdateSessionRequestSchema,\n SendMessageRequestSchema,\n ApprovalRequestSchema,\n SubmitAnswersRequestSchema,\n ListSessionsQuerySchema,\n BrowseDirectoryQuerySchema,\n BrowseDirectoryResponseSchema,\n CommandsQuerySchema,\n CommandRegistrySchema,\n HealthResponseSchema,\n ErrorResponseSchema,\n HistoryMessageSchema,\n TaskItemSchema,\n} from '@dorkos/shared/schemas';\nimport { z } from 'zod';\n\nconst registry = new OpenAPIRegistry();\n\n// --- Health ---\n\nregistry.registerPath({\n method: 'get',\n path: '/api/health',\n tags: ['Health'],\n summary: 'Health check',\n responses: {\n 200: {\n description: 'Server is healthy',\n content: { 'application/json': { schema: HealthResponseSchema } },\n },\n },\n});\n\n// --- Sessions ---\n\nregistry.registerPath({\n method: 'post',\n path: '/api/sessions',\n tags: ['Sessions'],\n summary: 'Create a new session',\n request: {\n body: {\n content: { 'application/json': { schema: CreateSessionRequestSchema } },\n },\n },\n responses: {\n 200: {\n description: 'Created session',\n content: { 'application/json': { schema: SessionSchema } },\n },\n 400: {\n description: 'Validation error',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'get',\n path: '/api/sessions',\n tags: ['Sessions'],\n summary: 'List all sessions',\n request: {\n query: ListSessionsQuerySchema,\n },\n responses: {\n 200: {\n description: 'Array of sessions',\n content: {\n 'application/json': { schema: z.array(SessionSchema) },\n },\n },\n 400: {\n description: 'Validation error',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'get',\n path: '/api/sessions/{id}',\n tags: ['Sessions'],\n summary: 'Get session details',\n request: {\n params: z.object({ id: z.string().uuid() }),\n },\n responses: {\n 200: {\n description: 'Session details',\n content: { 'application/json': { schema: SessionSchema } },\n },\n 404: {\n description: 'Session not found',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'get',\n path: '/api/sessions/{id}/messages',\n tags: ['Sessions'],\n summary: 'Get message history',\n request: {\n params: z.object({ id: z.string().uuid() }),\n },\n responses: {\n 200: {\n description: 'Message history',\n content: {\n 'application/json': {\n schema: z.object({ messages: z.array(HistoryMessageSchema) }),\n },\n },\n },\n },\n});\n\nregistry.registerPath({\n method: 'get',\n path: '/api/sessions/{id}/tasks',\n tags: ['Sessions'],\n summary: 'Get task state from session transcript',\n request: {\n params: z.object({ id: z.string().uuid() }),\n },\n responses: {\n 200: {\n description: 'Task list',\n content: {\n 'application/json': {\n schema: z.object({ tasks: z.array(TaskItemSchema) }),\n },\n },\n },\n 404: {\n description: 'Session not found',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'patch',\n path: '/api/sessions/{id}',\n tags: ['Sessions'],\n summary: 'Update session settings',\n request: {\n params: z.object({ id: z.string().uuid() }),\n body: {\n content: { 'application/json': { schema: UpdateSessionRequestSchema } },\n },\n },\n responses: {\n 200: {\n description: 'Updated session',\n content: { 'application/json': { schema: SessionSchema } },\n },\n 400: {\n description: 'Validation error',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n 404: {\n description: 'Session not found',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'post',\n path: '/api/sessions/{id}/messages',\n tags: ['Sessions'],\n summary: 'Send message (SSE stream response)',\n description:\n 'Sends a message to the Claude agent and streams the response as Server-Sent Events. ' +\n 'Event types: text_delta, tool_call_start, tool_call_delta, tool_call_end, tool_result, ' +\n 'approval_required, question_prompt, error, done, session_status, task_update. ' +\n 'Each SSE message has the format: `event: message\\\\ndata: {\"type\":\"<type>\",\"data\":{...}}\\\\n\\\\n`',\n request: {\n params: z.object({ id: z.string().uuid() }),\n body: {\n content: { 'application/json': { schema: SendMessageRequestSchema } },\n },\n },\n responses: {\n 200: {\n description: 'SSE stream of StreamEvent objects',\n content: {\n 'text/event-stream': {\n schema: z.string().openapi({ description: 'Server-Sent Events stream' }),\n },\n },\n },\n 400: {\n description: 'Validation error',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'post',\n path: '/api/sessions/{id}/approve',\n tags: ['Sessions'],\n summary: 'Approve pending tool call',\n request: {\n params: z.object({ id: z.string().uuid() }),\n body: {\n content: { 'application/json': { schema: ApprovalRequestSchema } },\n },\n },\n responses: {\n 200: {\n description: 'Approved',\n content: {\n 'application/json': { schema: z.object({ ok: z.boolean() }) },\n },\n },\n 400: {\n description: 'Validation error',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n 404: {\n description: 'No pending approval',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'post',\n path: '/api/sessions/{id}/deny',\n tags: ['Sessions'],\n summary: 'Deny pending tool call',\n request: {\n params: z.object({ id: z.string().uuid() }),\n body: {\n content: { 'application/json': { schema: ApprovalRequestSchema } },\n },\n },\n responses: {\n 200: {\n description: 'Denied',\n content: {\n 'application/json': { schema: z.object({ ok: z.boolean() }) },\n },\n },\n 400: {\n description: 'Validation error',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n 404: {\n description: 'No pending approval',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'post',\n path: '/api/sessions/{id}/submit-answers',\n tags: ['Sessions'],\n summary: 'Submit answers for AskUserQuestion',\n request: {\n params: z.object({ id: z.string().uuid() }),\n body: {\n content: { 'application/json': { schema: SubmitAnswersRequestSchema } },\n },\n },\n responses: {\n 200: {\n description: 'Answers submitted',\n content: {\n 'application/json': { schema: z.object({ ok: z.boolean() }) },\n },\n },\n 400: {\n description: 'Validation error',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n 404: {\n description: 'No pending question',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\n// --- Directory ---\n\nregistry.registerPath({\n method: 'get',\n path: '/api/directory',\n tags: ['Directory'],\n summary: 'Browse directories',\n description: 'Browse directories on the server filesystem. Restricted to the home directory for security.',\n request: {\n query: BrowseDirectoryQuerySchema,\n },\n responses: {\n 200: {\n description: 'Directory listing',\n content: { 'application/json': { schema: BrowseDirectoryResponseSchema } },\n },\n 400: {\n description: 'Invalid path',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n 403: {\n description: 'Access denied (path outside home directory)',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n 404: {\n description: 'Directory not found',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\nregistry.registerPath({\n method: 'get',\n path: '/api/directory/default',\n tags: ['Directory'],\n summary: 'Get default working directory',\n description: 'Returns the server\\'s default working directory (process.cwd()).',\n responses: {\n 200: {\n description: 'Default directory path',\n content: {\n 'application/json': {\n schema: z.object({ path: z.string() }),\n },\n },\n },\n },\n});\n\n// --- Commands ---\n\nregistry.registerPath({\n method: 'get',\n path: '/api/commands',\n tags: ['Commands'],\n summary: 'List all slash commands',\n request: {\n query: CommandsQuerySchema,\n },\n responses: {\n 200: {\n description: 'Command registry',\n content: { 'application/json': { schema: CommandRegistrySchema } },\n },\n 400: {\n description: 'Validation error',\n content: { 'application/json': { schema: ErrorResponseSchema } },\n },\n },\n});\n\n// --- Generator ---\n\nexport function generateOpenAPISpec() {\n const generator = new OpenApiGeneratorV31(registry.definitions);\n return generator.generateDocument({\n openapi: '3.1.0',\n info: {\n title: 'DorkOS API',\n version: '0.1.0',\n description:\n 'REST/SSE API for Claude Code sessions, built with the Claude Agent SDK.',\n },\n servers: [{ url: 'http://localhost:6942' }],\n });\n}\n", "import type { Request, Response, NextFunction } from 'express';\n\nexport function errorHandler(\n err: Error,\n _req: Request,\n res: Response,\n _next: NextFunction\n): void {\n console.error('[Gateway Error]', err.message, err.stack);\n res.status(500).json({\n error: err.message || 'Internal Server Error',\n code: 'INTERNAL_ERROR',\n });\n}\n", "/*! chokidar - MIT License (c) 2012 Paul Miller (paulmillr.com) */\nimport { stat as statcb } from 'fs';\nimport { stat, readdir } from 'fs/promises';\nimport { EventEmitter } from 'events';\nimport * as sysPath from 'path';\nimport { readdirp } from 'readdirp';\nimport { NodeFsHandler, EVENTS as EV, isWindows, isIBMi, EMPTY_FN, STR_CLOSE, STR_END, } from './handler.js';\nconst SLASH = '/';\nconst SLASH_SLASH = '//';\nconst ONE_DOT = '.';\nconst TWO_DOTS = '..';\nconst STRING_TYPE = 'string';\nconst BACK_SLASH_RE = /\\\\/g;\nconst DOUBLE_SLASH_RE = /\\/\\//;\nconst DOT_RE = /\\..*\\.(sw[px])$|~$|\\.subl.*\\.tmp/;\nconst REPLACER_RE = /^\\.[/\\\\]/;\nfunction arrify(item) {\n return Array.isArray(item) ? item : [item];\n}\nconst isMatcherObject = (matcher) => typeof matcher === 'object' && matcher !== null && !(matcher instanceof RegExp);\nfunction createPattern(matcher) {\n if (typeof matcher === 'function')\n return matcher;\n if (typeof matcher === 'string')\n return (string) => matcher === string;\n if (matcher instanceof RegExp)\n return (string) => matcher.test(string);\n if (typeof matcher === 'object' && matcher !== null) {\n return (string) => {\n if (matcher.path === string)\n return true;\n if (matcher.recursive) {\n const relative = sysPath.relative(matcher.path, string);\n if (!relative) {\n return false;\n }\n return !relative.startsWith('..') && !sysPath.isAbsolute(relative);\n }\n return false;\n };\n }\n return () => false;\n}\nfunction normalizePath(path) {\n if (typeof path !== 'string')\n throw new Error('string expected');\n path = sysPath.normalize(path);\n path = path.replace(/\\\\/g, '/');\n let prepend = false;\n if (path.startsWith('//'))\n prepend = true;\n const DOUBLE_SLASH_RE = /\\/\\//;\n while (path.match(DOUBLE_SLASH_RE))\n path = path.replace(DOUBLE_SLASH_RE, '/');\n if (prepend)\n path = '/' + path;\n return path;\n}\nfunction matchPatterns(patterns, testString, stats) {\n const path = normalizePath(testString);\n for (let index = 0; index < patterns.length; index++) {\n const pattern = patterns[index];\n if (pattern(path, stats)) {\n return true;\n }\n }\n return false;\n}\nfunction anymatch(matchers, testString) {\n if (matchers == null) {\n throw new TypeError('anymatch: specify first argument');\n }\n // Early cache for matchers.\n const matchersArray = arrify(matchers);\n const patterns = matchersArray.map((matcher) => createPattern(matcher));\n if (testString == null) {\n return (testString, stats) => {\n return matchPatterns(patterns, testString, stats);\n };\n }\n return matchPatterns(patterns, testString);\n}\nconst unifyPaths = (paths_) => {\n const paths = arrify(paths_).flat();\n if (!paths.every((p) => typeof p === STRING_TYPE)) {\n throw new TypeError(`Non-string provided as watch path: ${paths}`);\n }\n return paths.map(normalizePathToUnix);\n};\n// If SLASH_SLASH occurs at the beginning of path, it is not replaced\n// because \"//StoragePC/DrivePool/Movies\" is a valid network path\nconst toUnix = (string) => {\n let str = string.replace(BACK_SLASH_RE, SLASH);\n let prepend = false;\n if (str.startsWith(SLASH_SLASH)) {\n prepend = true;\n }\n while (str.match(DOUBLE_SLASH_RE)) {\n str = str.replace(DOUBLE_SLASH_RE, SLASH);\n }\n if (prepend) {\n str = SLASH + str;\n }\n return str;\n};\n// Our version of upath.normalize\n// TODO: this is not equal to path-normalize module - investigate why\nconst normalizePathToUnix = (path) => toUnix(sysPath.normalize(toUnix(path)));\n// TODO: refactor\nconst normalizeIgnored = (cwd = '') => (path) => {\n if (typeof path === 'string') {\n return normalizePathToUnix(sysPath.isAbsolute(path) ? path : sysPath.join(cwd, path));\n }\n else {\n return path;\n }\n};\nconst getAbsolutePath = (path, cwd) => {\n if (sysPath.isAbsolute(path)) {\n return path;\n }\n return sysPath.join(cwd, path);\n};\nconst EMPTY_SET = Object.freeze(new Set());\n/**\n * Directory entry.\n */\nclass DirEntry {\n constructor(dir, removeWatcher) {\n this.path = dir;\n this._removeWatcher = removeWatcher;\n this.items = new Set();\n }\n add(item) {\n const { items } = this;\n if (!items)\n return;\n if (item !== ONE_DOT && item !== TWO_DOTS)\n items.add(item);\n }\n async remove(item) {\n const { items } = this;\n if (!items)\n return;\n items.delete(item);\n if (items.size > 0)\n return;\n const dir = this.path;\n try {\n await readdir(dir);\n }\n catch (err) {\n if (this._removeWatcher) {\n this._removeWatcher(sysPath.dirname(dir), sysPath.basename(dir));\n }\n }\n }\n has(item) {\n const { items } = this;\n if (!items)\n return;\n return items.has(item);\n }\n getChildren() {\n const { items } = this;\n if (!items)\n return [];\n return [...items.values()];\n }\n dispose() {\n this.items.clear();\n this.path = '';\n this._removeWatcher = EMPTY_FN;\n this.items = EMPTY_SET;\n Object.freeze(this);\n }\n}\nconst STAT_METHOD_F = 'stat';\nconst STAT_METHOD_L = 'lstat';\nexport class WatchHelper {\n constructor(path, follow, fsw) {\n this.fsw = fsw;\n const watchPath = path;\n this.path = path = path.replace(REPLACER_RE, '');\n this.watchPath = watchPath;\n this.fullWatchPath = sysPath.resolve(watchPath);\n this.dirParts = [];\n this.dirParts.forEach((parts) => {\n if (parts.length > 1)\n parts.pop();\n });\n this.followSymlinks = follow;\n this.statMethod = follow ? STAT_METHOD_F : STAT_METHOD_L;\n }\n entryPath(entry) {\n return sysPath.join(this.watchPath, sysPath.relative(this.watchPath, entry.fullPath));\n }\n filterPath(entry) {\n const { stats } = entry;\n if (stats && stats.isSymbolicLink())\n return this.filterDir(entry);\n const resolvedPath = this.entryPath(entry);\n // TODO: what if stats is undefined? remove !\n return this.fsw._isntIgnored(resolvedPath, stats) && this.fsw._hasReadPermissions(stats);\n }\n filterDir(entry) {\n return this.fsw._isntIgnored(this.entryPath(entry), entry.stats);\n }\n}\n/**\n * Watches files & directories for changes. Emitted events:\n * `add`, `addDir`, `change`, `unlink`, `unlinkDir`, `all`, `error`\n *\n * new FSWatcher()\n * .add(directories)\n * .on('add', path => log('File', path, 'was added'))\n */\nexport class FSWatcher extends EventEmitter {\n // Not indenting methods for history sake; for now.\n constructor(_opts = {}) {\n super();\n this.closed = false;\n this._closers = new Map();\n this._ignoredPaths = new Set();\n this._throttled = new Map();\n this._streams = new Set();\n this._symlinkPaths = new Map();\n this._watched = new Map();\n this._pendingWrites = new Map();\n this._pendingUnlinks = new Map();\n this._readyCount = 0;\n this._readyEmitted = false;\n const awf = _opts.awaitWriteFinish;\n const DEF_AWF = { stabilityThreshold: 2000, pollInterval: 100 };\n const opts = {\n // Defaults\n persistent: true,\n ignoreInitial: false,\n ignorePermissionErrors: false,\n interval: 100,\n binaryInterval: 300,\n followSymlinks: true,\n usePolling: false,\n // useAsync: false,\n atomic: true, // NOTE: overwritten later (depends on usePolling)\n ..._opts,\n // Change format\n ignored: _opts.ignored ? arrify(_opts.ignored) : arrify([]),\n awaitWriteFinish: awf === true ? DEF_AWF : typeof awf === 'object' ? { ...DEF_AWF, ...awf } : false,\n };\n // Always default to polling on IBM i because fs.watch() is not available on IBM i.\n if (isIBMi)\n opts.usePolling = true;\n // Editor atomic write normalization enabled by default with fs.watch\n if (opts.atomic === undefined)\n opts.atomic = !opts.usePolling;\n // opts.atomic = typeof _opts.atomic === 'number' ? _opts.atomic : 100;\n // Global override. Useful for developers, who need to force polling for all\n // instances of chokidar, regardless of usage / dependency depth\n const envPoll = process.env.CHOKIDAR_USEPOLLING;\n if (envPoll !== undefined) {\n const envLower = envPoll.toLowerCase();\n if (envLower === 'false' || envLower === '0')\n opts.usePolling = false;\n else if (envLower === 'true' || envLower === '1')\n opts.usePolling = true;\n else\n opts.usePolling = !!envLower;\n }\n const envInterval = process.env.CHOKIDAR_INTERVAL;\n if (envInterval)\n opts.interval = Number.parseInt(envInterval, 10);\n // This is done to emit ready only once, but each 'add' will increase that?\n let readyCalls = 0;\n this._emitReady = () => {\n readyCalls++;\n if (readyCalls >= this._readyCount) {\n this._emitReady = EMPTY_FN;\n this._readyEmitted = true;\n // use process.nextTick to allow time for listener to be bound\n process.nextTick(() => this.emit(EV.READY));\n }\n };\n this._emitRaw = (...args) => this.emit(EV.RAW, ...args);\n this._boundRemove = this._remove.bind(this);\n this.options = opts;\n this._nodeFsHandler = new NodeFsHandler(this);\n // You\u2019re frozen when your heart\u2019s not open.\n Object.freeze(opts);\n }\n _addIgnoredPath(matcher) {\n if (isMatcherObject(matcher)) {\n // return early if we already have a deeply equal matcher object\n for (const ignored of this._ignoredPaths) {\n if (isMatcherObject(ignored) &&\n ignored.path === matcher.path &&\n ignored.recursive === matcher.recursive) {\n return;\n }\n }\n }\n this._ignoredPaths.add(matcher);\n }\n _removeIgnoredPath(matcher) {\n this._ignoredPaths.delete(matcher);\n // now find any matcher objects with the matcher as path\n if (typeof matcher === 'string') {\n for (const ignored of this._ignoredPaths) {\n // TODO (43081j): make this more efficient.\n // probably just make a `this._ignoredDirectories` or some\n // such thing.\n if (isMatcherObject(ignored) && ignored.path === matcher) {\n this._ignoredPaths.delete(ignored);\n }\n }\n }\n }\n // Public methods\n /**\n * Adds paths to be watched on an existing FSWatcher instance.\n * @param paths_ file or file list. Other arguments are unused\n */\n add(paths_, _origAdd, _internal) {\n const { cwd } = this.options;\n this.closed = false;\n this._closePromise = undefined;\n let paths = unifyPaths(paths_);\n if (cwd) {\n paths = paths.map((path) => {\n const absPath = getAbsolutePath(path, cwd);\n // Check `path` instead of `absPath` because the cwd portion can't be a glob\n return absPath;\n });\n }\n paths.forEach((path) => {\n this._removeIgnoredPath(path);\n });\n this._userIgnored = undefined;\n if (!this._readyCount)\n this._readyCount = 0;\n this._readyCount += paths.length;\n Promise.all(paths.map(async (path) => {\n const res = await this._nodeFsHandler._addToNodeFs(path, !_internal, undefined, 0, _origAdd);\n if (res)\n this._emitReady();\n return res;\n })).then((results) => {\n if (this.closed)\n return;\n results.forEach((item) => {\n if (item)\n this.add(sysPath.dirname(item), sysPath.basename(_origAdd || item));\n });\n });\n return this;\n }\n /**\n * Close watchers or start ignoring events from specified paths.\n */\n unwatch(paths_) {\n if (this.closed)\n return this;\n const paths = unifyPaths(paths_);\n const { cwd } = this.options;\n paths.forEach((path) => {\n // convert to absolute path unless relative path already matches\n if (!sysPath.isAbsolute(path) && !this._closers.has(path)) {\n if (cwd)\n path = sysPath.join(cwd, path);\n path = sysPath.resolve(path);\n }\n this._closePath(path);\n this._addIgnoredPath(path);\n if (this._watched.has(path)) {\n this._addIgnoredPath({\n path,\n recursive: true,\n });\n }\n // reset the cached userIgnored anymatch fn\n // to make ignoredPaths changes effective\n this._userIgnored = undefined;\n });\n return this;\n }\n /**\n * Close watchers and remove all listeners from watched paths.\n */\n close() {\n if (this._closePromise) {\n return this._closePromise;\n }\n this.closed = true;\n // Memory management.\n this.removeAllListeners();\n const closers = [];\n this._closers.forEach((closerList) => closerList.forEach((closer) => {\n const promise = closer();\n if (promise instanceof Promise)\n closers.push(promise);\n }));\n this._streams.forEach((stream) => stream.destroy());\n this._userIgnored = undefined;\n this._readyCount = 0;\n this._readyEmitted = false;\n this._watched.forEach((dirent) => dirent.dispose());\n this._closers.clear();\n this._watched.clear();\n this._streams.clear();\n this._symlinkPaths.clear();\n this._throttled.clear();\n this._closePromise = closers.length\n ? Promise.all(closers).then(() => undefined)\n : Promise.resolve();\n return this._closePromise;\n }\n /**\n * Expose list of watched paths\n * @returns for chaining\n */\n getWatched() {\n const watchList = {};\n this._watched.forEach((entry, dir) => {\n const key = this.options.cwd ? sysPath.relative(this.options.cwd, dir) : dir;\n const index = key || ONE_DOT;\n watchList[index] = entry.getChildren().sort();\n });\n return watchList;\n }\n emitWithAll(event, args) {\n this.emit(event, ...args);\n if (event !== EV.ERROR)\n this.emit(EV.ALL, event, ...args);\n }\n // Common helpers\n // --------------\n /**\n * Normalize and emit events.\n * Calling _emit DOES NOT MEAN emit() would be called!\n * @param event Type of event\n * @param path File or directory path\n * @param stats arguments to be passed with event\n * @returns the error if defined, otherwise the value of the FSWatcher instance's `closed` flag\n */\n async _emit(event, path, stats) {\n if (this.closed)\n return;\n const opts = this.options;\n if (isWindows)\n path = sysPath.normalize(path);\n if (opts.cwd)\n path = sysPath.relative(opts.cwd, path);\n const args = [path];\n if (stats != null)\n args.push(stats);\n const awf = opts.awaitWriteFinish;\n let pw;\n if (awf && (pw = this._pendingWrites.get(path))) {\n pw.lastChange = new Date();\n return this;\n }\n if (opts.atomic) {\n if (event === EV.UNLINK) {\n this._pendingUnlinks.set(path, [event, ...args]);\n setTimeout(() => {\n this._pendingUnlinks.forEach((entry, path) => {\n this.emit(...entry);\n this.emit(EV.ALL, ...entry);\n this._pendingUnlinks.delete(path);\n });\n }, typeof opts.atomic === 'number' ? opts.atomic : 100);\n return this;\n }\n if (event === EV.ADD && this._pendingUnlinks.has(path)) {\n event = EV.CHANGE;\n this._pendingUnlinks.delete(path);\n }\n }\n if (awf && (event === EV.ADD || event === EV.CHANGE) && this._readyEmitted) {\n const awfEmit = (err, stats) => {\n if (err) {\n event = EV.ERROR;\n args[0] = err;\n this.emitWithAll(event, args);\n }\n else if (stats) {\n // if stats doesn't exist the file must have been deleted\n if (args.length > 1) {\n args[1] = stats;\n }\n else {\n args.push(stats);\n }\n this.emitWithAll(event, args);\n }\n };\n this._awaitWriteFinish(path, awf.stabilityThreshold, event, awfEmit);\n return this;\n }\n if (event === EV.CHANGE) {\n const isThrottled = !this._throttle(EV.CHANGE, path, 50);\n if (isThrottled)\n return this;\n }\n if (opts.alwaysStat &&\n stats === undefined &&\n (event === EV.ADD || event === EV.ADD_DIR || event === EV.CHANGE)) {\n const fullPath = opts.cwd ? sysPath.join(opts.cwd, path) : path;\n let stats;\n try {\n stats = await stat(fullPath);\n }\n catch (err) {\n // do nothing\n }\n // Suppress event when fs_stat fails, to avoid sending undefined 'stat'\n if (!stats || this.closed)\n return;\n args.push(stats);\n }\n this.emitWithAll(event, args);\n return this;\n }\n /**\n * Common handler for errors\n * @returns The error if defined, otherwise the value of the FSWatcher instance's `closed` flag\n */\n _handleError(error) {\n const code = error && error.code;\n if (error &&\n code !== 'ENOENT' &&\n code !== 'ENOTDIR' &&\n (!this.options.ignorePermissionErrors || (code !== 'EPERM' && code !== 'EACCES'))) {\n this.emit(EV.ERROR, error);\n }\n return error || this.closed;\n }\n /**\n * Helper utility for throttling\n * @param actionType type being throttled\n * @param path being acted upon\n * @param timeout duration of time to suppress duplicate actions\n * @returns tracking object or false if action should be suppressed\n */\n _throttle(actionType, path, timeout) {\n if (!this._throttled.has(actionType)) {\n this._throttled.set(actionType, new Map());\n }\n const action = this._throttled.get(actionType);\n if (!action)\n throw new Error('invalid throttle');\n const actionPath = action.get(path);\n if (actionPath) {\n actionPath.count++;\n return false;\n }\n // eslint-disable-next-line prefer-const\n let timeoutObject;\n const clear = () => {\n const item = action.get(path);\n const count = item ? item.count : 0;\n action.delete(path);\n clearTimeout(timeoutObject);\n if (item)\n clearTimeout(item.timeoutObject);\n return count;\n };\n timeoutObject = setTimeout(clear, timeout);\n const thr = { timeoutObject, clear, count: 0 };\n action.set(path, thr);\n return thr;\n }\n _incrReadyCount() {\n return this._readyCount++;\n }\n /**\n * Awaits write operation to finish.\n * Polls a newly created file for size variations. When files size does not change for 'threshold' milliseconds calls callback.\n * @param path being acted upon\n * @param threshold Time in milliseconds a file size must be fixed before acknowledging write OP is finished\n * @param event\n * @param awfEmit Callback to be called when ready for event to be emitted.\n */\n _awaitWriteFinish(path, threshold, event, awfEmit) {\n const awf = this.options.awaitWriteFinish;\n if (typeof awf !== 'object')\n return;\n const pollInterval = awf.pollInterval;\n let timeoutHandler;\n let fullPath = path;\n if (this.options.cwd && !sysPath.isAbsolute(path)) {\n fullPath = sysPath.join(this.options.cwd, path);\n }\n const now = new Date();\n const writes = this._pendingWrites;\n function awaitWriteFinishFn(prevStat) {\n statcb(fullPath, (err, curStat) => {\n if (err || !writes.has(path)) {\n if (err && err.code !== 'ENOENT')\n awfEmit(err);\n return;\n }\n const now = Number(new Date());\n if (prevStat && curStat.size !== prevStat.size) {\n writes.get(path).lastChange = now;\n }\n const pw = writes.get(path);\n const df = now - pw.lastChange;\n if (df >= threshold) {\n writes.delete(path);\n awfEmit(undefined, curStat);\n }\n else {\n timeoutHandler = setTimeout(awaitWriteFinishFn, pollInterval, curStat);\n }\n });\n }\n if (!writes.has(path)) {\n writes.set(path, {\n lastChange: now,\n cancelWait: () => {\n writes.delete(path);\n clearTimeout(timeoutHandler);\n return event;\n },\n });\n timeoutHandler = setTimeout(awaitWriteFinishFn, pollInterval);\n }\n }\n /**\n * Determines whether user has asked to ignore this path.\n */\n _isIgnored(path, stats) {\n if (this.options.atomic && DOT_RE.test(path))\n return true;\n if (!this._userIgnored) {\n const { cwd } = this.options;\n const ign = this.options.ignored;\n const ignored = (ign || []).map(normalizeIgnored(cwd));\n const ignoredPaths = [...this._ignoredPaths];\n const list = [...ignoredPaths.map(normalizeIgnored(cwd)), ...ignored];\n this._userIgnored = anymatch(list, undefined);\n }\n return this._userIgnored(path, stats);\n }\n _isntIgnored(path, stat) {\n return !this._isIgnored(path, stat);\n }\n /**\n * Provides a set of common helpers and properties relating to symlink handling.\n * @param path file or directory pattern being watched\n */\n _getWatchHelpers(path) {\n return new WatchHelper(path, this.options.followSymlinks, this);\n }\n // Directory helpers\n // -----------------\n /**\n * Provides directory tracking objects\n * @param directory path of the directory\n */\n _getWatchedDir(directory) {\n const dir = sysPath.resolve(directory);\n if (!this._watched.has(dir))\n this._watched.set(dir, new DirEntry(dir, this._boundRemove));\n return this._watched.get(dir);\n }\n // File helpers\n // ------------\n /**\n * Check for read permissions: https://stackoverflow.com/a/11781404/1358405\n */\n _hasReadPermissions(stats) {\n if (this.options.ignorePermissionErrors)\n return true;\n return Boolean(Number(stats.mode) & 0o400);\n }\n /**\n * Handles emitting unlink events for\n * files and directories, and via recursion, for\n * files and directories within directories that are unlinked\n * @param directory within which the following item is located\n * @param item base path of item/directory\n */\n _remove(directory, item, isDirectory) {\n // if what is being deleted is a directory, get that directory's paths\n // for recursive deleting and cleaning of watched object\n // if it is not a directory, nestedDirectoryChildren will be empty array\n const path = sysPath.join(directory, item);\n const fullPath = sysPath.resolve(path);\n isDirectory =\n isDirectory != null ? isDirectory : this._watched.has(path) || this._watched.has(fullPath);\n // prevent duplicate handling in case of arriving here nearly simultaneously\n // via multiple paths (such as _handleFile and _handleDir)\n if (!this._throttle('remove', path, 100))\n return;\n // if the only watched file is removed, watch for its return\n if (!isDirectory && this._watched.size === 1) {\n this.add(directory, item, true);\n }\n // This will create a new entry in the watched object in either case\n // so we got to do the directory check beforehand\n const wp = this._getWatchedDir(path);\n const nestedDirectoryChildren = wp.getChildren();\n // Recursively remove children directories / files.\n nestedDirectoryChildren.forEach((nested) => this._remove(path, nested));\n // Check if item was on the watched list and remove it\n const parent = this._getWatchedDir(directory);\n const wasTracked = parent.has(item);\n parent.remove(item);\n // Fixes issue #1042 -> Relative paths were detected and added as symlinks\n // (https://github.com/paulmillr/chokidar/blob/e1753ddbc9571bdc33b4a4af172d52cb6e611c10/lib/nodefs-handler.js#L612),\n // but never removed from the map in case the path was deleted.\n // This leads to an incorrect state if the path was recreated:\n // https://github.com/paulmillr/chokidar/blob/e1753ddbc9571bdc33b4a4af172d52cb6e611c10/lib/nodefs-handler.js#L553\n if (this._symlinkPaths.has(fullPath)) {\n this._symlinkPaths.delete(fullPath);\n }\n // If we wait for this file to be fully written, cancel the wait.\n let relPath = path;\n if (this.options.cwd)\n relPath = sysPath.relative(this.options.cwd, path);\n if (this.options.awaitWriteFinish && this._pendingWrites.has(relPath)) {\n const event = this._pendingWrites.get(relPath).cancelWait();\n if (event === EV.ADD)\n return;\n }\n // The Entry will either be a directory that just got removed\n // or a bogus entry to a file, in either case we have to remove it\n this._watched.delete(path);\n this._watched.delete(fullPath);\n const eventName = isDirectory ? EV.UNLINK_DIR : EV.UNLINK;\n if (wasTracked && !this._isIgnored(path))\n this._emit(eventName, path);\n // Avoid conflicts if we later create another file with the same name\n this._closePath(path);\n }\n /**\n * Closes all watchers for a path\n */\n _closePath(path) {\n this._closeFile(path);\n const dir = sysPath.dirname(path);\n this._getWatchedDir(dir).remove(sysPath.basename(path));\n }\n /**\n * Closes only file-specific watchers\n */\n _closeFile(path) {\n const closers = this._closers.get(path);\n if (!closers)\n return;\n closers.forEach((closer) => closer());\n this._closers.delete(path);\n }\n _addPathCloser(path, closer) {\n if (!closer)\n return;\n let list = this._closers.get(path);\n if (!list) {\n list = [];\n this._closers.set(path, list);\n }\n list.push(closer);\n }\n _readdirp(root, opts) {\n if (this.closed)\n return;\n const options = { type: EV.ALL, alwaysStat: true, lstat: true, ...opts, depth: 0 };\n let stream = readdirp(root, options);\n this._streams.add(stream);\n stream.once(STR_CLOSE, () => {\n stream = undefined;\n });\n stream.once(STR_END, () => {\n if (stream) {\n this._streams.delete(stream);\n stream = undefined;\n }\n });\n return stream;\n }\n}\n/**\n * Instantiates watcher with paths to be tracked.\n * @param paths file / directory paths\n * @param options opts, such as `atomic`, `awaitWriteFinish`, `ignored`, and others\n * @returns an instance of FSWatcher for chaining.\n * @example\n * const watcher = watch('.').on('all', (event, path) => { console.log(event, path); });\n * watch('.', { atomic: true, awaitWriteFinish: true, ignored: (f, stats) => stats?.isFile() && !f.endsWith('.js') })\n */\nexport function watch(paths, options = {}) {\n const watcher = new FSWatcher(options);\n watcher.add(paths);\n return watcher;\n}\nexport default { watch, FSWatcher };\n", "import { stat, lstat, readdir, realpath } from 'node:fs/promises';\nimport { Readable } from 'node:stream';\nimport { resolve as presolve, relative as prelative, join as pjoin, sep as psep } from 'node:path';\nexport const EntryTypes = {\n FILE_TYPE: 'files',\n DIR_TYPE: 'directories',\n FILE_DIR_TYPE: 'files_directories',\n EVERYTHING_TYPE: 'all',\n};\nconst defaultOptions = {\n root: '.',\n fileFilter: (_entryInfo) => true,\n directoryFilter: (_entryInfo) => true,\n type: EntryTypes.FILE_TYPE,\n lstat: false,\n depth: 2147483648,\n alwaysStat: false,\n highWaterMark: 4096,\n};\nObject.freeze(defaultOptions);\nconst RECURSIVE_ERROR_CODE = 'READDIRP_RECURSIVE_ERROR';\nconst NORMAL_FLOW_ERRORS = new Set(['ENOENT', 'EPERM', 'EACCES', 'ELOOP', RECURSIVE_ERROR_CODE]);\nconst ALL_TYPES = [\n EntryTypes.DIR_TYPE,\n EntryTypes.EVERYTHING_TYPE,\n EntryTypes.FILE_DIR_TYPE,\n EntryTypes.FILE_TYPE,\n];\nconst DIR_TYPES = new Set([\n EntryTypes.DIR_TYPE,\n EntryTypes.EVERYTHING_TYPE,\n EntryTypes.FILE_DIR_TYPE,\n]);\nconst FILE_TYPES = new Set([\n EntryTypes.EVERYTHING_TYPE,\n EntryTypes.FILE_DIR_TYPE,\n EntryTypes.FILE_TYPE,\n]);\nconst isNormalFlowError = (error) => NORMAL_FLOW_ERRORS.has(error.code);\nconst wantBigintFsStats = process.platform === 'win32';\nconst emptyFn = (_entryInfo) => true;\nconst normalizeFilter = (filter) => {\n if (filter === undefined)\n return emptyFn;\n if (typeof filter === 'function')\n return filter;\n if (typeof filter === 'string') {\n const fl = filter.trim();\n return (entry) => entry.basename === fl;\n }\n if (Array.isArray(filter)) {\n const trItems = filter.map((item) => item.trim());\n return (entry) => trItems.some((f) => entry.basename === f);\n }\n return emptyFn;\n};\n/** Readable readdir stream, emitting new files as they're being listed. */\nexport class ReaddirpStream extends Readable {\n constructor(options = {}) {\n super({\n objectMode: true,\n autoDestroy: true,\n highWaterMark: options.highWaterMark,\n });\n const opts = { ...defaultOptions, ...options };\n const { root, type } = opts;\n this._fileFilter = normalizeFilter(opts.fileFilter);\n this._directoryFilter = normalizeFilter(opts.directoryFilter);\n const statMethod = opts.lstat ? lstat : stat;\n // Use bigint stats if it's windows and stat() supports options (node 10+).\n if (wantBigintFsStats) {\n this._stat = (path) => statMethod(path, { bigint: true });\n }\n else {\n this._stat = statMethod;\n }\n this._maxDepth = opts.depth ?? defaultOptions.depth;\n this._wantsDir = type ? DIR_TYPES.has(type) : false;\n this._wantsFile = type ? FILE_TYPES.has(type) : false;\n this._wantsEverything = type === EntryTypes.EVERYTHING_TYPE;\n this._root = presolve(root);\n this._isDirent = !opts.alwaysStat;\n this._statsProp = this._isDirent ? 'dirent' : 'stats';\n this._rdOptions = { encoding: 'utf8', withFileTypes: this._isDirent };\n // Launch stream with one parent, the root dir.\n this.parents = [this._exploreDir(root, 1)];\n this.reading = false;\n this.parent = undefined;\n }\n async _read(batch) {\n if (this.reading)\n return;\n this.reading = true;\n try {\n while (!this.destroyed && batch > 0) {\n const par = this.parent;\n const fil = par && par.files;\n if (fil && fil.length > 0) {\n const { path, depth } = par;\n const slice = fil.splice(0, batch).map((dirent) => this._formatEntry(dirent, path));\n const awaited = await Promise.all(slice);\n for (const entry of awaited) {\n if (!entry)\n continue;\n if (this.destroyed)\n return;\n const entryType = await this._getEntryType(entry);\n if (entryType === 'directory' && this._directoryFilter(entry)) {\n if (depth <= this._maxDepth) {\n this.parents.push(this._exploreDir(entry.fullPath, depth + 1));\n }\n if (this._wantsDir) {\n this.push(entry);\n batch--;\n }\n }\n else if ((entryType === 'file' || this._includeAsFile(entry)) &&\n this._fileFilter(entry)) {\n if (this._wantsFile) {\n this.push(entry);\n batch--;\n }\n }\n }\n }\n else {\n const parent = this.parents.pop();\n if (!parent) {\n this.push(null);\n break;\n }\n this.parent = await parent;\n if (this.destroyed)\n return;\n }\n }\n }\n catch (error) {\n this.destroy(error);\n }\n finally {\n this.reading = false;\n }\n }\n async _exploreDir(path, depth) {\n let files;\n try {\n files = await readdir(path, this._rdOptions);\n }\n catch (error) {\n this._onError(error);\n }\n return { files, depth, path };\n }\n async _formatEntry(dirent, path) {\n let entry;\n const basename = this._isDirent ? dirent.name : dirent;\n try {\n const fullPath = presolve(pjoin(path, basename));\n entry = { path: prelative(this._root, fullPath), fullPath, basename };\n entry[this._statsProp] = this._isDirent ? dirent : await this._stat(fullPath);\n }\n catch (err) {\n this._onError(err);\n return;\n }\n return entry;\n }\n _onError(err) {\n if (isNormalFlowError(err) && !this.destroyed) {\n this.emit('warn', err);\n }\n else {\n this.destroy(err);\n }\n }\n async _getEntryType(entry) {\n // entry may be undefined, because a warning or an error were emitted\n // and the statsProp is undefined\n if (!entry && this._statsProp in entry) {\n return '';\n }\n const stats = entry[this._statsProp];\n if (stats.isFile())\n return 'file';\n if (stats.isDirectory())\n return 'directory';\n if (stats && stats.isSymbolicLink()) {\n const full = entry.fullPath;\n try {\n const entryRealPath = await realpath(full);\n const entryRealPathStats = await lstat(entryRealPath);\n if (entryRealPathStats.isFile()) {\n return 'file';\n }\n if (entryRealPathStats.isDirectory()) {\n const len = entryRealPath.length;\n if (full.startsWith(entryRealPath) && full.substr(len, 1) === psep) {\n const recursiveError = new Error(`Circular symlink detected: \"${full}\" points to \"${entryRealPath}\"`);\n // @ts-ignore\n recursiveError.code = RECURSIVE_ERROR_CODE;\n return this._onError(recursiveError);\n }\n return 'directory';\n }\n }\n catch (error) {\n this._onError(error);\n return '';\n }\n }\n }\n _includeAsFile(entry) {\n const stats = entry && entry[this._statsProp];\n return stats && this._wantsEverything && !stats.isDirectory();\n }\n}\n/**\n * Streaming version: Reads all files and directories in given root recursively.\n * Consumes ~constant small amount of RAM.\n * @param root Root directory\n * @param options Options to specify root (start directory), filters and recursion depth\n */\nexport function readdirp(root, options = {}) {\n // @ts-ignore\n let type = options.entryType || options.type;\n if (type === 'both')\n type = EntryTypes.FILE_DIR_TYPE; // backwards-compatibility\n if (type)\n options.type = type;\n if (!root) {\n throw new Error('readdirp: root argument is required. Usage: readdirp(root, options)');\n }\n else if (typeof root !== 'string') {\n throw new TypeError('readdirp: root argument must be a string. Usage: readdirp(root, options)');\n }\n else if (type && !ALL_TYPES.includes(type)) {\n throw new Error(`readdirp: Invalid type passed. Use one of ${ALL_TYPES.join(', ')}`);\n }\n options.root = root;\n return new ReaddirpStream(options);\n}\n/**\n * Promise version: Reads all files and directories in given root recursively.\n * Compared to streaming version, will consume a lot of RAM e.g. when 1 million files are listed.\n * @returns array of paths and their entry infos\n */\nexport function readdirpPromise(root, options = {}) {\n return new Promise((resolve, reject) => {\n const files = [];\n readdirp(root, options)\n .on('data', (entry) => files.push(entry))\n .on('end', () => resolve(files))\n .on('error', (error) => reject(error));\n });\n}\nexport default readdirp;\n", "import { watchFile, unwatchFile, watch as fs_watch } from 'fs';\nimport { open, stat, lstat, realpath as fsrealpath } from 'fs/promises';\nimport * as sysPath from 'path';\nimport { type as osType } from 'os';\nexport const STR_DATA = 'data';\nexport const STR_END = 'end';\nexport const STR_CLOSE = 'close';\nexport const EMPTY_FN = () => { };\nexport const IDENTITY_FN = (val) => val;\nconst pl = process.platform;\nexport const isWindows = pl === 'win32';\nexport const isMacos = pl === 'darwin';\nexport const isLinux = pl === 'linux';\nexport const isFreeBSD = pl === 'freebsd';\nexport const isIBMi = osType() === 'OS400';\nexport const EVENTS = {\n ALL: 'all',\n READY: 'ready',\n ADD: 'add',\n CHANGE: 'change',\n ADD_DIR: 'addDir',\n UNLINK: 'unlink',\n UNLINK_DIR: 'unlinkDir',\n RAW: 'raw',\n ERROR: 'error',\n};\nconst EV = EVENTS;\nconst THROTTLE_MODE_WATCH = 'watch';\nconst statMethods = { lstat, stat };\nconst KEY_LISTENERS = 'listeners';\nconst KEY_ERR = 'errHandlers';\nconst KEY_RAW = 'rawEmitters';\nconst HANDLER_KEYS = [KEY_LISTENERS, KEY_ERR, KEY_RAW];\n// prettier-ignore\nconst binaryExtensions = new Set([\n '3dm', '3ds', '3g2', '3gp', '7z', 'a', 'aac', 'adp', 'afdesign', 'afphoto', 'afpub', 'ai',\n 'aif', 'aiff', 'alz', 'ape', 'apk', 'appimage', 'ar', 'arj', 'asf', 'au', 'avi',\n 'bak', 'baml', 'bh', 'bin', 'bk', 'bmp', 'btif', 'bz2', 'bzip2',\n 'cab', 'caf', 'cgm', 'class', 'cmx', 'cpio', 'cr2', 'cur', 'dat', 'dcm', 'deb', 'dex', 'djvu',\n 'dll', 'dmg', 'dng', 'doc', 'docm', 'docx', 'dot', 'dotm', 'dra', 'DS_Store', 'dsk', 'dts',\n 'dtshd', 'dvb', 'dwg', 'dxf',\n 'ecelp4800', 'ecelp7470', 'ecelp9600', 'egg', 'eol', 'eot', 'epub', 'exe',\n 'f4v', 'fbs', 'fh', 'fla', 'flac', 'flatpak', 'fli', 'flv', 'fpx', 'fst', 'fvt',\n 'g3', 'gh', 'gif', 'graffle', 'gz', 'gzip',\n 'h261', 'h263', 'h264', 'icns', 'ico', 'ief', 'img', 'ipa', 'iso',\n 'jar', 'jpeg', 'jpg', 'jpgv', 'jpm', 'jxr', 'key', 'ktx',\n 'lha', 'lib', 'lvp', 'lz', 'lzh', 'lzma', 'lzo',\n 'm3u', 'm4a', 'm4v', 'mar', 'mdi', 'mht', 'mid', 'midi', 'mj2', 'mka', 'mkv', 'mmr', 'mng',\n 'mobi', 'mov', 'movie', 'mp3',\n 'mp4', 'mp4a', 'mpeg', 'mpg', 'mpga', 'mxu',\n 'nef', 'npx', 'numbers', 'nupkg',\n 'o', 'odp', 'ods', 'odt', 'oga', 'ogg', 'ogv', 'otf', 'ott',\n 'pages', 'pbm', 'pcx', 'pdb', 'pdf', 'pea', 'pgm', 'pic', 'png', 'pnm', 'pot', 'potm',\n 'potx', 'ppa', 'ppam',\n 'ppm', 'pps', 'ppsm', 'ppsx', 'ppt', 'pptm', 'pptx', 'psd', 'pya', 'pyc', 'pyo', 'pyv',\n 'qt',\n 'rar', 'ras', 'raw', 'resources', 'rgb', 'rip', 'rlc', 'rmf', 'rmvb', 'rpm', 'rtf', 'rz',\n 's3m', 's7z', 'scpt', 'sgi', 'shar', 'snap', 'sil', 'sketch', 'slk', 'smv', 'snk', 'so',\n 'stl', 'suo', 'sub', 'swf',\n 'tar', 'tbz', 'tbz2', 'tga', 'tgz', 'thmx', 'tif', 'tiff', 'tlz', 'ttc', 'ttf', 'txz',\n 'udf', 'uvh', 'uvi', 'uvm', 'uvp', 'uvs', 'uvu',\n 'viv', 'vob',\n 'war', 'wav', 'wax', 'wbmp', 'wdp', 'weba', 'webm', 'webp', 'whl', 'wim', 'wm', 'wma',\n 'wmv', 'wmx', 'woff', 'woff2', 'wrm', 'wvx',\n 'xbm', 'xif', 'xla', 'xlam', 'xls', 'xlsb', 'xlsm', 'xlsx', 'xlt', 'xltm', 'xltx', 'xm',\n 'xmind', 'xpi', 'xpm', 'xwd', 'xz',\n 'z', 'zip', 'zipx',\n]);\nconst isBinaryPath = (filePath) => binaryExtensions.has(sysPath.extname(filePath).slice(1).toLowerCase());\n// TODO: emit errors properly. Example: EMFILE on Macos.\nconst foreach = (val, fn) => {\n if (val instanceof Set) {\n val.forEach(fn);\n }\n else {\n fn(val);\n }\n};\nconst addAndConvert = (main, prop, item) => {\n let container = main[prop];\n if (!(container instanceof Set)) {\n main[prop] = container = new Set([container]);\n }\n container.add(item);\n};\nconst clearItem = (cont) => (key) => {\n const set = cont[key];\n if (set instanceof Set) {\n set.clear();\n }\n else {\n delete cont[key];\n }\n};\nconst delFromSet = (main, prop, item) => {\n const container = main[prop];\n if (container instanceof Set) {\n container.delete(item);\n }\n else if (container === item) {\n delete main[prop];\n }\n};\nconst isEmptySet = (val) => (val instanceof Set ? val.size === 0 : !val);\nconst FsWatchInstances = new Map();\n/**\n * Instantiates the fs_watch interface\n * @param path to be watched\n * @param options to be passed to fs_watch\n * @param listener main event handler\n * @param errHandler emits info about errors\n * @param emitRaw emits raw event data\n * @returns {NativeFsWatcher}\n */\nfunction createFsWatchInstance(path, options, listener, errHandler, emitRaw) {\n const handleEvent = (rawEvent, evPath) => {\n listener(path);\n emitRaw(rawEvent, evPath, { watchedPath: path });\n // emit based on events occurring for files from a directory's watcher in\n // case the file's watcher misses it (and rely on throttling to de-dupe)\n if (evPath && path !== evPath) {\n fsWatchBroadcast(sysPath.resolve(path, evPath), KEY_LISTENERS, sysPath.join(path, evPath));\n }\n };\n try {\n return fs_watch(path, {\n persistent: options.persistent,\n }, handleEvent);\n }\n catch (error) {\n errHandler(error);\n return undefined;\n }\n}\n/**\n * Helper for passing fs_watch event data to a collection of listeners\n * @param fullPath absolute path bound to fs_watch instance\n */\nconst fsWatchBroadcast = (fullPath, listenerType, val1, val2, val3) => {\n const cont = FsWatchInstances.get(fullPath);\n if (!cont)\n return;\n foreach(cont[listenerType], (listener) => {\n listener(val1, val2, val3);\n });\n};\n/**\n * Instantiates the fs_watch interface or binds listeners\n * to an existing one covering the same file system entry\n * @param path\n * @param fullPath absolute path\n * @param options to be passed to fs_watch\n * @param handlers container for event listener functions\n */\nconst setFsWatchListener = (path, fullPath, options, handlers) => {\n const { listener, errHandler, rawEmitter } = handlers;\n let cont = FsWatchInstances.get(fullPath);\n let watcher;\n if (!options.persistent) {\n watcher = createFsWatchInstance(path, options, listener, errHandler, rawEmitter);\n if (!watcher)\n return;\n return watcher.close.bind(watcher);\n }\n if (cont) {\n addAndConvert(cont, KEY_LISTENERS, listener);\n addAndConvert(cont, KEY_ERR, errHandler);\n addAndConvert(cont, KEY_RAW, rawEmitter);\n }\n else {\n watcher = createFsWatchInstance(path, options, fsWatchBroadcast.bind(null, fullPath, KEY_LISTENERS), errHandler, // no need to use broadcast here\n fsWatchBroadcast.bind(null, fullPath, KEY_RAW));\n if (!watcher)\n return;\n watcher.on(EV.ERROR, async (error) => {\n const broadcastErr = fsWatchBroadcast.bind(null, fullPath, KEY_ERR);\n if (cont)\n cont.watcherUnusable = true; // documented since Node 10.4.1\n // Workaround for https://github.com/joyent/node/issues/4337\n if (isWindows && error.code === 'EPERM') {\n try {\n const fd = await open(path, 'r');\n await fd.close();\n broadcastErr(error);\n }\n catch (err) {\n // do nothing\n }\n }\n else {\n broadcastErr(error);\n }\n });\n cont = {\n listeners: listener,\n errHandlers: errHandler,\n rawEmitters: rawEmitter,\n watcher,\n };\n FsWatchInstances.set(fullPath, cont);\n }\n // const index = cont.listeners.indexOf(listener);\n // removes this instance's listeners and closes the underlying fs_watch\n // instance if there are no more listeners left\n return () => {\n delFromSet(cont, KEY_LISTENERS, listener);\n delFromSet(cont, KEY_ERR, errHandler);\n delFromSet(cont, KEY_RAW, rawEmitter);\n if (isEmptySet(cont.listeners)) {\n // Check to protect against issue gh-730.\n // if (cont.watcherUnusable) {\n cont.watcher.close();\n // }\n FsWatchInstances.delete(fullPath);\n HANDLER_KEYS.forEach(clearItem(cont));\n // @ts-ignore\n cont.watcher = undefined;\n Object.freeze(cont);\n }\n };\n};\n// fs_watchFile helpers\n// object to hold per-process fs_watchFile instances\n// (may be shared across chokidar FSWatcher instances)\nconst FsWatchFileInstances = new Map();\n/**\n * Instantiates the fs_watchFile interface or binds listeners\n * to an existing one covering the same file system entry\n * @param path to be watched\n * @param fullPath absolute path\n * @param options options to be passed to fs_watchFile\n * @param handlers container for event listener functions\n * @returns closer\n */\nconst setFsWatchFileListener = (path, fullPath, options, handlers) => {\n const { listener, rawEmitter } = handlers;\n let cont = FsWatchFileInstances.get(fullPath);\n // let listeners = new Set();\n // let rawEmitters = new Set();\n const copts = cont && cont.options;\n if (copts && (copts.persistent < options.persistent || copts.interval > options.interval)) {\n // \"Upgrade\" the watcher to persistence or a quicker interval.\n // This creates some unlikely edge case issues if the user mixes\n // settings in a very weird way, but solving for those cases\n // doesn't seem worthwhile for the added complexity.\n // listeners = cont.listeners;\n // rawEmitters = cont.rawEmitters;\n unwatchFile(fullPath);\n cont = undefined;\n }\n if (cont) {\n addAndConvert(cont, KEY_LISTENERS, listener);\n addAndConvert(cont, KEY_RAW, rawEmitter);\n }\n else {\n // TODO\n // listeners.add(listener);\n // rawEmitters.add(rawEmitter);\n cont = {\n listeners: listener,\n rawEmitters: rawEmitter,\n options,\n watcher: watchFile(fullPath, options, (curr, prev) => {\n foreach(cont.rawEmitters, (rawEmitter) => {\n rawEmitter(EV.CHANGE, fullPath, { curr, prev });\n });\n const currmtime = curr.mtimeMs;\n if (curr.size !== prev.size || currmtime > prev.mtimeMs || currmtime === 0) {\n foreach(cont.listeners, (listener) => listener(path, curr));\n }\n }),\n };\n FsWatchFileInstances.set(fullPath, cont);\n }\n // const index = cont.listeners.indexOf(listener);\n // Removes this instance's listeners and closes the underlying fs_watchFile\n // instance if there are no more listeners left.\n return () => {\n delFromSet(cont, KEY_LISTENERS, listener);\n delFromSet(cont, KEY_RAW, rawEmitter);\n if (isEmptySet(cont.listeners)) {\n FsWatchFileInstances.delete(fullPath);\n unwatchFile(fullPath);\n cont.options = cont.watcher = undefined;\n Object.freeze(cont);\n }\n };\n};\n/**\n * @mixin\n */\nexport class NodeFsHandler {\n constructor(fsW) {\n this.fsw = fsW;\n this._boundHandleError = (error) => fsW._handleError(error);\n }\n /**\n * Watch file for changes with fs_watchFile or fs_watch.\n * @param path to file or dir\n * @param listener on fs change\n * @returns closer for the watcher instance\n */\n _watchWithNodeFs(path, listener) {\n const opts = this.fsw.options;\n const directory = sysPath.dirname(path);\n const basename = sysPath.basename(path);\n const parent = this.fsw._getWatchedDir(directory);\n parent.add(basename);\n const absolutePath = sysPath.resolve(path);\n const options = {\n persistent: opts.persistent,\n };\n if (!listener)\n listener = EMPTY_FN;\n let closer;\n if (opts.usePolling) {\n const enableBin = opts.interval !== opts.binaryInterval;\n options.interval = enableBin && isBinaryPath(basename) ? opts.binaryInterval : opts.interval;\n closer = setFsWatchFileListener(path, absolutePath, options, {\n listener,\n rawEmitter: this.fsw._emitRaw,\n });\n }\n else {\n closer = setFsWatchListener(path, absolutePath, options, {\n listener,\n errHandler: this._boundHandleError,\n rawEmitter: this.fsw._emitRaw,\n });\n }\n return closer;\n }\n /**\n * Watch a file and emit add event if warranted.\n * @returns closer for the watcher instance\n */\n _handleFile(file, stats, initialAdd) {\n if (this.fsw.closed) {\n return;\n }\n const dirname = sysPath.dirname(file);\n const basename = sysPath.basename(file);\n const parent = this.fsw._getWatchedDir(dirname);\n // stats is always present\n let prevStats = stats;\n // if the file is already being watched, do nothing\n if (parent.has(basename))\n return;\n const listener = async (path, newStats) => {\n if (!this.fsw._throttle(THROTTLE_MODE_WATCH, file, 5))\n return;\n if (!newStats || newStats.mtimeMs === 0) {\n try {\n const newStats = await stat(file);\n if (this.fsw.closed)\n return;\n // Check that change event was not fired because of changed only accessTime.\n const at = newStats.atimeMs;\n const mt = newStats.mtimeMs;\n if (!at || at <= mt || mt !== prevStats.mtimeMs) {\n this.fsw._emit(EV.CHANGE, file, newStats);\n }\n if ((isMacos || isLinux || isFreeBSD) && prevStats.ino !== newStats.ino) {\n this.fsw._closeFile(path);\n prevStats = newStats;\n const closer = this._watchWithNodeFs(file, listener);\n if (closer)\n this.fsw._addPathCloser(path, closer);\n }\n else {\n prevStats = newStats;\n }\n }\n catch (error) {\n // Fix issues where mtime is null but file is still present\n this.fsw._remove(dirname, basename);\n }\n // add is about to be emitted if file not already tracked in parent\n }\n else if (parent.has(basename)) {\n // Check that change event was not fired because of changed only accessTime.\n const at = newStats.atimeMs;\n const mt = newStats.mtimeMs;\n if (!at || at <= mt || mt !== prevStats.mtimeMs) {\n this.fsw._emit(EV.CHANGE, file, newStats);\n }\n prevStats = newStats;\n }\n };\n // kick off the watcher\n const closer = this._watchWithNodeFs(file, listener);\n // emit an add event if we're supposed to\n if (!(initialAdd && this.fsw.options.ignoreInitial) && this.fsw._isntIgnored(file)) {\n if (!this.fsw._throttle(EV.ADD, file, 0))\n return;\n this.fsw._emit(EV.ADD, file, stats);\n }\n return closer;\n }\n /**\n * Handle symlinks encountered while reading a dir.\n * @param entry returned by readdirp\n * @param directory path of dir being read\n * @param path of this item\n * @param item basename of this item\n * @returns true if no more processing is needed for this entry.\n */\n async _handleSymlink(entry, directory, path, item) {\n if (this.fsw.closed) {\n return;\n }\n const full = entry.fullPath;\n const dir = this.fsw._getWatchedDir(directory);\n if (!this.fsw.options.followSymlinks) {\n // watch symlink directly (don't follow) and detect changes\n this.fsw._incrReadyCount();\n let linkPath;\n try {\n linkPath = await fsrealpath(path);\n }\n catch (e) {\n this.fsw._emitReady();\n return true;\n }\n if (this.fsw.closed)\n return;\n if (dir.has(item)) {\n if (this.fsw._symlinkPaths.get(full) !== linkPath) {\n this.fsw._symlinkPaths.set(full, linkPath);\n this.fsw._emit(EV.CHANGE, path, entry.stats);\n }\n }\n else {\n dir.add(item);\n this.fsw._symlinkPaths.set(full, linkPath);\n this.fsw._emit(EV.ADD, path, entry.stats);\n }\n this.fsw._emitReady();\n return true;\n }\n // don't follow the same symlink more than once\n if (this.fsw._symlinkPaths.has(full)) {\n return true;\n }\n this.fsw._symlinkPaths.set(full, true);\n }\n _handleRead(directory, initialAdd, wh, target, dir, depth, throttler) {\n // Normalize the directory name on Windows\n directory = sysPath.join(directory, '');\n throttler = this.fsw._throttle('readdir', directory, 1000);\n if (!throttler)\n return;\n const previous = this.fsw._getWatchedDir(wh.path);\n const current = new Set();\n let stream = this.fsw._readdirp(directory, {\n fileFilter: (entry) => wh.filterPath(entry),\n directoryFilter: (entry) => wh.filterDir(entry),\n });\n if (!stream)\n return;\n stream\n .on(STR_DATA, async (entry) => {\n if (this.fsw.closed) {\n stream = undefined;\n return;\n }\n const item = entry.path;\n let path = sysPath.join(directory, item);\n current.add(item);\n if (entry.stats.isSymbolicLink() &&\n (await this._handleSymlink(entry, directory, path, item))) {\n return;\n }\n if (this.fsw.closed) {\n stream = undefined;\n return;\n }\n // Files that present in current directory snapshot\n // but absent in previous are added to watch list and\n // emit `add` event.\n if (item === target || (!target && !previous.has(item))) {\n this.fsw._incrReadyCount();\n // ensure relativeness of path is preserved in case of watcher reuse\n path = sysPath.join(dir, sysPath.relative(dir, path));\n this._addToNodeFs(path, initialAdd, wh, depth + 1);\n }\n })\n .on(EV.ERROR, this._boundHandleError);\n return new Promise((resolve, reject) => {\n if (!stream)\n return reject();\n stream.once(STR_END, () => {\n if (this.fsw.closed) {\n stream = undefined;\n return;\n }\n const wasThrottled = throttler ? throttler.clear() : false;\n resolve(undefined);\n // Files that absent in current directory snapshot\n // but present in previous emit `remove` event\n // and are removed from @watched[directory].\n previous\n .getChildren()\n .filter((item) => {\n return item !== directory && !current.has(item);\n })\n .forEach((item) => {\n this.fsw._remove(directory, item);\n });\n stream = undefined;\n // one more time for any missed in case changes came in extremely quickly\n if (wasThrottled)\n this._handleRead(directory, false, wh, target, dir, depth, throttler);\n });\n });\n }\n /**\n * Read directory to add / remove files from `@watched` list and re-read it on change.\n * @param dir fs path\n * @param stats\n * @param initialAdd\n * @param depth relative to user-supplied path\n * @param target child path targeted for watch\n * @param wh Common watch helpers for this path\n * @param realpath\n * @returns closer for the watcher instance.\n */\n async _handleDir(dir, stats, initialAdd, depth, target, wh, realpath) {\n const parentDir = this.fsw._getWatchedDir(sysPath.dirname(dir));\n const tracked = parentDir.has(sysPath.basename(dir));\n if (!(initialAdd && this.fsw.options.ignoreInitial) && !target && !tracked) {\n this.fsw._emit(EV.ADD_DIR, dir, stats);\n }\n // ensure dir is tracked (harmless if redundant)\n parentDir.add(sysPath.basename(dir));\n this.fsw._getWatchedDir(dir);\n let throttler;\n let closer;\n const oDepth = this.fsw.options.depth;\n if ((oDepth == null || depth <= oDepth) && !this.fsw._symlinkPaths.has(realpath)) {\n if (!target) {\n await this._handleRead(dir, initialAdd, wh, target, dir, depth, throttler);\n if (this.fsw.closed)\n return;\n }\n closer = this._watchWithNodeFs(dir, (dirPath, stats) => {\n // if current directory is removed, do nothing\n if (stats && stats.mtimeMs === 0)\n return;\n this._handleRead(dirPath, false, wh, target, dir, depth, throttler);\n });\n }\n return closer;\n }\n /**\n * Handle added file, directory, or glob pattern.\n * Delegates call to _handleFile / _handleDir after checks.\n * @param path to file or ir\n * @param initialAdd was the file added at watch instantiation?\n * @param priorWh depth relative to user-supplied path\n * @param depth Child path actually targeted for watch\n * @param target Child path actually targeted for watch\n */\n async _addToNodeFs(path, initialAdd, priorWh, depth, target) {\n const ready = this.fsw._emitReady;\n if (this.fsw._isIgnored(path) || this.fsw.closed) {\n ready();\n return false;\n }\n const wh = this.fsw._getWatchHelpers(path);\n if (priorWh) {\n wh.filterPath = (entry) => priorWh.filterPath(entry);\n wh.filterDir = (entry) => priorWh.filterDir(entry);\n }\n // evaluate what is at the path we're being asked to watch\n try {\n const stats = await statMethods[wh.statMethod](wh.watchPath);\n if (this.fsw.closed)\n return;\n if (this.fsw._isIgnored(wh.watchPath, stats)) {\n ready();\n return false;\n }\n const follow = this.fsw.options.followSymlinks;\n let closer;\n if (stats.isDirectory()) {\n const absPath = sysPath.resolve(path);\n const targetPath = follow ? await fsrealpath(path) : path;\n if (this.fsw.closed)\n return;\n closer = await this._handleDir(wh.watchPath, stats, initialAdd, depth, target, wh, targetPath);\n if (this.fsw.closed)\n return;\n // preserve this symlink's target path\n if (absPath !== targetPath && targetPath !== undefined) {\n this.fsw._symlinkPaths.set(absPath, targetPath);\n }\n }\n else if (stats.isSymbolicLink()) {\n const targetPath = follow ? await fsrealpath(path) : path;\n if (this.fsw.closed)\n return;\n const parent = sysPath.dirname(wh.watchPath);\n this.fsw._getWatchedDir(parent).add(wh.watchPath);\n this.fsw._emit(EV.ADD, wh.watchPath, stats);\n closer = await this._handleDir(parent, stats, initialAdd, depth, path, wh, targetPath);\n if (this.fsw.closed)\n return;\n // preserve this symlink's target path\n if (targetPath !== undefined) {\n this.fsw._symlinkPaths.set(sysPath.resolve(path), targetPath);\n }\n }\n else {\n closer = this._handleFile(wh.watchPath, stats, initialAdd);\n }\n ready();\n if (closer)\n this.fsw._addPathCloser(path, closer);\n return false;\n }\n catch (error) {\n if (this.fsw._handleError(error)) {\n ready();\n return path;\n }\n }\n }\n}\n", "import chokidar, { type FSWatcher } from 'chokidar';\nimport { join } from 'path';\nimport type { Response } from 'express';\nimport type { TranscriptReader } from './transcript-reader.js';\n\n/**\n * SessionBroadcaster manages file watching and SSE broadcasting for cross-client session sync.\n *\n * Watches SDK JSONL transcript files and broadcasts updates to connected SSE clients when\n * file changes are detected. Supports multiple clients per session with automatic cleanup.\n *\n * Usage:\n * ```typescript\n * const broadcaster = new SessionBroadcaster(transcriptReader);\n *\n * // Register SSE client for a session\n * app.get('/api/sessions/:id/sync', (req, res) => {\n * res.setHeader('Content-Type', 'text/event-stream');\n * broadcaster.registerClient(req.params.id, vaultRoot, res);\n * });\n *\n * // Cleanup on shutdown\n * process.on('SIGTERM', () => broadcaster.shutdown());\n * ```\n */\nexport class SessionBroadcaster {\n private clients = new Map<string, Set<Response>>();\n private watchers = new Map<string, FSWatcher>();\n private offsets = new Map<string, number>();\n private debounceTimers = new Map<string, NodeJS.Timeout>();\n\n constructor(private transcriptReader: TranscriptReader) {}\n\n /**\n * Register an SSE client for a session.\n *\n * - Adds the response to the set of connected clients\n * - Starts a file watcher if none exists for this session\n * - Initializes offset to current file size (only broadcast new content)\n * - Sends sync_connected event to the client\n * - Auto-deregisters on response close\n *\n * @param sessionId - Session UUID\n * @param vaultRoot - Vault root path for resolving transcript directory\n * @param res - Express Response object configured for SSE\n */\n registerClient(sessionId: string, vaultRoot: string, res: Response): void {\n // Add client to set\n if (!this.clients.has(sessionId)) {\n this.clients.set(sessionId, new Set());\n }\n this.clients.get(sessionId)!.add(res);\n\n // Start watcher if this is the first client for this session\n if (!this.watchers.has(sessionId)) {\n this.startWatcher(sessionId, vaultRoot);\n }\n\n // Send sync_connected event\n res.write(`event: sync_connected\\ndata: ${JSON.stringify({ sessionId })}\\n\\n`);\n\n // Auto-deregister on close\n res.on('close', () => {\n this.deregisterClient(sessionId, res);\n });\n }\n\n /**\n * Deregister an SSE client from a session.\n *\n * - Removes the response from the client set\n * - Stops the file watcher if no clients remain for this session\n * - Cleans up offsets and timers\n *\n * @param sessionId - Session UUID\n * @param res - Express Response object to remove\n */\n deregisterClient(sessionId: string, res: Response): void {\n const clientSet = this.clients.get(sessionId);\n if (!clientSet) return;\n\n clientSet.delete(res);\n\n // Clean up if no clients remain\n if (clientSet.size === 0) {\n this.clients.delete(sessionId);\n\n // Stop watcher\n const watcher = this.watchers.get(sessionId);\n if (watcher) {\n watcher.close();\n this.watchers.delete(sessionId);\n }\n\n // Clean up state\n this.offsets.delete(sessionId);\n\n const timer = this.debounceTimers.get(sessionId);\n if (timer) {\n clearTimeout(timer);\n this.debounceTimers.delete(sessionId);\n }\n }\n }\n\n /**\n * Start a chokidar file watcher for a session's JSONL transcript.\n *\n * Watches the SDK transcript file and broadcasts updates on change events.\n * Changes are debounced (100ms) to batch rapid writes during streaming.\n *\n * @param sessionId - Session UUID\n * @param vaultRoot - Vault root path for resolving transcript directory\n */\n private startWatcher(sessionId: string, vaultRoot: string): void {\n const transcriptsDir = this.transcriptReader.getTranscriptsDir(vaultRoot);\n const filePath = join(transcriptsDir, `${sessionId}.jsonl`);\n\n // Initialize offset to current file size (only new content)\n this.initializeOffset(vaultRoot, sessionId);\n\n // Create watcher\n const watcher = chokidar.watch(filePath, {\n persistent: true,\n ignoreInitial: true, // Don't fire for initial file scan\n awaitWriteFinish: {\n stabilityThreshold: 50,\n pollInterval: 25,\n },\n });\n\n watcher.on('change', () => {\n // Debounce rapid changes\n const existingTimer = this.debounceTimers.get(sessionId);\n if (existingTimer) {\n clearTimeout(existingTimer);\n }\n\n const timer = setTimeout(() => {\n this.debounceTimers.delete(sessionId);\n this.broadcastUpdate(sessionId, vaultRoot).catch((err) => {\n console.error(`[SessionBroadcaster] Failed to broadcast update for session ${sessionId}:`, err);\n });\n }, 100);\n\n this.debounceTimers.set(sessionId, timer);\n });\n\n this.watchers.set(sessionId, watcher);\n }\n\n /**\n * Initialize the byte offset for a session to the current file size.\n * This ensures we only broadcast new content, not existing history.\n *\n * @param vaultRoot - Vault root path\n * @param sessionId - Session UUID\n */\n private async initializeOffset(vaultRoot: string, sessionId: string): Promise<void> {\n try {\n const { newOffset } = await this.transcriptReader.readFromOffset(vaultRoot, sessionId, 0);\n this.offsets.set(sessionId, newOffset);\n } catch (err) {\n // File may not exist yet, start at 0\n this.offsets.set(sessionId, 0);\n }\n }\n\n /**\n * Broadcast a sync_update event to all connected clients for a session.\n *\n * Reads new content from the transcript file since the last offset and\n * sends a sync_update SSE event if new content exists.\n *\n * @param sessionId - Session UUID\n * @param vaultRoot - Vault root path\n */\n private async broadcastUpdate(sessionId: string, vaultRoot: string): Promise<void> {\n const currentOffset = this.offsets.get(sessionId) ?? 0;\n\n try {\n const { content, newOffset } = await this.transcriptReader.readFromOffset(\n vaultRoot,\n sessionId,\n currentOffset\n );\n\n // Update offset\n this.offsets.set(sessionId, newOffset);\n\n // Only broadcast if there's new content\n if (content.length === 0) {\n return;\n }\n\n // Send to all connected clients\n const clientSet = this.clients.get(sessionId);\n if (!clientSet || clientSet.size === 0) {\n return;\n }\n\n const event = {\n sessionId,\n timestamp: new Date().toISOString(),\n };\n\n const eventData = `event: sync_update\\ndata: ${JSON.stringify(event)}\\n\\n`;\n\n for (const client of Array.from(clientSet)) {\n try {\n client.write(eventData);\n } catch (err) {\n // Client may have disconnected, will be cleaned up on 'close' event\n console.error(`[SessionBroadcaster] Failed to write to client for session ${sessionId}:`, err);\n }\n }\n } catch (err) {\n console.error(`[SessionBroadcaster] Failed to read offset for session ${sessionId}:`, err);\n }\n }\n\n /**\n * Shutdown the broadcaster, closing all watchers and client connections.\n * Should be called on server shutdown.\n */\n shutdown(): void {\n // Clear all timers\n Array.from(this.debounceTimers.values()).forEach(timer => {\n clearTimeout(timer);\n });\n this.debounceTimers.clear();\n\n // Close all watchers\n Array.from(this.watchers.values()).forEach(watcher => {\n watcher.close();\n });\n this.watchers.clear();\n\n // End all client responses\n Array.from(this.clients.values()).forEach(clientSet => {\n Array.from(clientSet).forEach(client => {\n try {\n client.end();\n } catch {\n // Ignore errors on close\n }\n });\n });\n this.clients.clear();\n\n // Clear offsets\n this.offsets.clear();\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["path", "fileURLToPath", "path", "fileURLToPath", "path", "fileURLToPath", "resolve", "result", "path", "vaultRoot", "stat", "cleanText", "__dirname", "path", "fileURLToPath", "sessionBroadcaster", "Router", "fs", "path", "vaultRoot", "path", "fileURLToPath", "__dirname", "registry", "router", "Router", "Router", "router", "Router", "Router", "fs", "path", "os", "router", "Router", "os", "fs", "path", "Router", "router", "Router", "Router", "fs", "path", "router", "Router", "Router", "z", "execFile", "promisify", "execFileAsync", "router", "Router", "z", "z", "__dirname", "path", "fileURLToPath", "stat", "readdir", "sysPath", "path", "basename", "stat", "lstat", "lstat", "stat", "path", "rawEmitter", "listener", "basename", "dirname", "newStats", "closer", "resolve", "realpath", "stats", "relative", "path", "DOUBLE_SLASH_RE", "testString", "readdir", "stats", "stat", "now", "join", "transcriptReader", "vaultRoot", "__dirname", "path", "fileURLToPath"]
7
+ }