whale-code 6.5.8 → 6.5.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (99) hide show
  1. package/dist/cli/services/agent-loop.js +26 -2
  2. package/dist/cli/services/agent-loop.js.map +1 -1
  3. package/dist/cli/services/hooks.js +2 -1
  4. package/dist/cli/services/hooks.js.map +1 -1
  5. package/dist/cli/services/telemetry-spans.js +1 -0
  6. package/dist/cli/services/telemetry-spans.js.map +1 -1
  7. package/dist/cli/services/telemetry.d.ts +23 -0
  8. package/dist/cli/services/telemetry.js +45 -1
  9. package/dist/cli/services/telemetry.js.map +1 -1
  10. package/dist/server/handlers/__test-utils__/test-db.d.ts +17 -3
  11. package/dist/server/handlers/__test-utils__/test-db.js +113 -14
  12. package/dist/server/handlers/__test-utils__/test-db.js.map +1 -1
  13. package/dist/server/handlers/affiliates.d.ts +9 -0
  14. package/dist/server/handlers/affiliates.js +197 -0
  15. package/dist/server/handlers/affiliates.js.map +1 -0
  16. package/dist/server/handlers/api-docs.d.ts +4 -2
  17. package/dist/server/handlers/api-docs.js +204 -1681
  18. package/dist/server/handlers/api-docs.js.map +1 -1
  19. package/dist/server/handlers/campaigns.d.ts +9 -0
  20. package/dist/server/handlers/campaigns.js +237 -0
  21. package/dist/server/handlers/campaigns.js.map +1 -0
  22. package/dist/server/handlers/catalog-schemas.js +9 -9
  23. package/dist/server/handlers/catalog-schemas.js.map +1 -1
  24. package/dist/server/handlers/catalog.js +1 -1
  25. package/dist/server/handlers/catalog.js.map +1 -1
  26. package/dist/server/handlers/comms-documents.js +28 -2
  27. package/dist/server/handlers/comms-documents.js.map +1 -1
  28. package/dist/server/handlers/comms-pdf-generation.js +25 -3
  29. package/dist/server/handlers/comms-pdf-generation.js.map +1 -1
  30. package/dist/server/handlers/comms-pdf-helpers.js +4 -4
  31. package/dist/server/handlers/comms-pdf-helpers.js.map +1 -1
  32. package/dist/server/handlers/comms.d.ts +100 -0
  33. package/dist/server/handlers/comms.js +146 -12
  34. package/dist/server/handlers/comms.js.map +1 -1
  35. package/dist/server/handlers/coupons.d.ts +9 -0
  36. package/dist/server/handlers/coupons.js +220 -0
  37. package/dist/server/handlers/coupons.js.map +1 -0
  38. package/dist/server/handlers/embeddings.js +1 -1
  39. package/dist/server/handlers/embeddings.js.map +1 -1
  40. package/dist/server/handlers/enrichment.js +2 -622
  41. package/dist/server/handlers/enrichment.js.map +1 -1
  42. package/dist/server/handlers/fulfillment.d.ts +9 -0
  43. package/dist/server/handlers/fulfillment.js +209 -0
  44. package/dist/server/handlers/fulfillment.js.map +1 -0
  45. package/dist/server/handlers/google-ads.d.ts +24 -0
  46. package/dist/server/handlers/google-ads.js +2199 -0
  47. package/dist/server/handlers/google-ads.js.map +1 -0
  48. package/dist/server/handlers/invoices.d.ts +9 -0
  49. package/dist/server/handlers/invoices.js +252 -0
  50. package/dist/server/handlers/invoices.js.map +1 -0
  51. package/dist/server/handlers/loyalty.d.ts +9 -0
  52. package/dist/server/handlers/loyalty.js +197 -0
  53. package/dist/server/handlers/loyalty.js.map +1 -0
  54. package/dist/server/handlers/meta-ads-graph-api.js +18 -3
  55. package/dist/server/handlers/meta-ads-graph-api.js.map +1 -1
  56. package/dist/server/handlers/phone.d.ts +9 -0
  57. package/dist/server/handlers/phone.js +197 -0
  58. package/dist/server/handlers/phone.js.map +1 -0
  59. package/dist/server/handlers/pipeline.d.ts +9 -0
  60. package/dist/server/handlers/pipeline.js +277 -0
  61. package/dist/server/handlers/pipeline.js.map +1 -0
  62. package/dist/server/handlers/qr-codes.d.ts +9 -0
  63. package/dist/server/handlers/qr-codes.js +198 -0
  64. package/dist/server/handlers/qr-codes.js.map +1 -0
  65. package/dist/server/handlers/reviews.d.ts +9 -0
  66. package/dist/server/handlers/reviews.js +171 -0
  67. package/dist/server/handlers/reviews.js.map +1 -0
  68. package/dist/server/handlers/segments.d.ts +9 -0
  69. package/dist/server/handlers/segments.js +229 -0
  70. package/dist/server/handlers/segments.js.map +1 -0
  71. package/dist/server/handlers/social.d.ts +9 -0
  72. package/dist/server/handlers/social.js +81 -0
  73. package/dist/server/handlers/social.js.map +1 -0
  74. package/dist/server/handlers/tax.d.ts +9 -0
  75. package/dist/server/handlers/tax.js +182 -0
  76. package/dist/server/handlers/tax.js.map +1 -0
  77. package/dist/server/handlers/wallet.d.ts +9 -0
  78. package/dist/server/handlers/wallet.js +203 -0
  79. package/dist/server/handlers/wallet.js.map +1 -0
  80. package/dist/server/handlers/webhooks-mgmt.d.ts +9 -0
  81. package/dist/server/handlers/webhooks-mgmt.js +181 -0
  82. package/dist/server/handlers/webhooks-mgmt.js.map +1 -0
  83. package/dist/server/handlers/wholesale.d.ts +9 -0
  84. package/dist/server/handlers/wholesale.js +219 -0
  85. package/dist/server/handlers/wholesale.js.map +1 -0
  86. package/dist/server/index.js +20 -9
  87. package/dist/server/index.js.map +1 -1
  88. package/dist/server/lib/clickhouse-buffer.js +1 -0
  89. package/dist/server/lib/clickhouse-buffer.js.map +1 -1
  90. package/dist/server/lib/coa-renderer.d.ts +1 -1
  91. package/dist/server/lib/coa-renderer.js +32 -10
  92. package/dist/server/lib/coa-renderer.js.map +1 -1
  93. package/dist/server/server-worker.d.ts +1 -0
  94. package/dist/server/server-worker.js +464 -3
  95. package/dist/server/server-worker.js.map +1 -1
  96. package/dist/server/tool-router.js +118 -4
  97. package/dist/server/tool-router.js.map +1 -1
  98. package/package.json +26 -3
  99. package/vendor/ink/package.json +0 -2
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["http","randomUUID","Anthropic","createLogger","log","sanitizeError","handleProxy","handleNodeRoutes","setNodeAgentInvoker","handleTranscribe","handleBillingRoutes","incrementUsage","checkPlanLimits","handleSessionRoutes","generateCompaction","initLocalAgentGateway","shutdownGateway","shutdownAgentGateway","getGatewayStats","initSupabase","getServiceClient","loadCheckpoint","markOrphaned","rateLimiter","sanitizeAndLog","generateOpenApiSpec","processWorkflowSteps","handleWebhookIngestion","executeInlineChain","initWorkerPool","getPoolStats","shutdownPool","verifyGuestApprovalSignature","loadUserTools","executeTool","flushSpans","queueSpan","auditRowToSpan","safeCompare","getCorsHeaders","jsonResponse","readBody","sendIpRateLimit","resolveAndValidateStoreId","getSseClients","safeSseWrite","sendWorkflowSSE","getTotalSseClients","sseCleanupInterval","MAX_SSE_CLIENTS_PER_RUN","MAX_SSE_TOTAL_CLIENTS","setupPgListen","closePgClient","pgListenReady","handleAgentChat","wireToolExecutor","wireAgentExecutor","wireBroadcasters","invokeAgentForChannel","startWorkerLoop","stopWorkerLoop","getCircuitBreakerStats","process","on","reason","_promise","error","err","fatal","exit","PORT","parseInt","env","SUPABASE_URL","SUPABASE_SERVICE_ROLE_KEY","SERVICE_ROLE_JWT","ANTHROPIC_API_KEY","FLY_INTERNAL_SECRET","console","warn","workerPoolReady","isReady","webchatAgentInvoker","activeRequests","server","createServer","req","res","origin","headers","corsHeaders","method","url","ready","status","agentStats","cbStats","version","npm_package_version","uptime","Math","floor","pg_listen","worker_pool","local_agents","total_agents","circuit_breakers","spec","writeHead","end","JSON","stringify","URL","host","pathname","match","runId","split","authHeader","authorization","token","startsWith","substring","isInternal","sb","data","user","authUser","authError","auth","getUser","sseRun","from","select","eq","single","membership","store_id","id","sseClients","existingClients","get","size","Connection","run","stepRuns","order","ascending","type","steps","has","set","Set","add","cleanup","clearInterval","heartbeat","clients","delete","setInterval","guestApprovalMatch","clientIp","toString","trim","socket","remoteAddress","stepRunId","urlParams","searchParams","action","expires","sig","Date","guestSupabase","approval","limit","length","isApprove","guestResult","guestErr","rpc","p_approval_id","p_store_id","p_response","p_response_data","guest","p_responded_by","success","message","run_id","webchatCors","webchatMsgMatch","rawBody","channelId","wcBody","parse","content","supabase","channel","planCheck","allowed","senderId","sender_id","conversationId","conversation_id","thirtyMinAgo","now","toISOString","recent","gt","not","msgErr","insert","channel_id","direction","sender_name","content_type","metadata","source","ip","widget_version","agent_id","messages_in","catch","p_channel_id","agentResponse","result","response","outMsg","auto_response","messages_out","agent_invocations","agent_response","webchatHistoryMatch","params","reqConvId","wcChannel","query","test","in","messages","histErr","fs","path","possiblePaths","join","import","meta","dirname","__dirname","cwd","widgetJs","p","readFileSync","resume","billingBody","billingUserId","payload","Buffer","sub","userId","isServiceRole","body","nodeBody","rawToken","handled","resumeMatch","convId","checkpoint","parsedMessages","turn","tokens_used","cost_so_far","tools_used","checkpointed_at","created_at","approvalMatch","approvalId","approvalMembership","response_data","responded_by","waitpointMatch","authToken","wp","expires_at","update","completion_data","completed_at","input","waitpoint_completed","waitpoint_data","step_run_id","webhookMatch","whClientIp","slug","k","v","Object","entries","event_type","idempotency_key","existing","event_id","deduplicated","eventId","fireErr","p_event_type","p_event_payload","p_source","batch_size","workflow_id","wfOwner","wfOwnerErr","p_workflow_id","p_trigger_type","trigger_type","p_trigger_payload","trigger_payload","p_idempotency_key","wf","published_version_id","version_id","info","contentLength","authErr","tier","rateLimitKey","memResult","checkRequest","String","ceil","retryAfterMs","bucket","parseErr","errMsg","Error","bodyLen","tail","slice","detail","body_length","mode","audio_base64","media_type","sid","storeId","compactMessages","system_prompt","Array","isArray","anthropic","apiKey","sanitizedCompactPrompt","compactionResult","systemPrompt","compaction_content","tool_name","args","trace_id","resolvedToolStoreId","validToolStoreId","toolUserId","toolLimit","checkToolLimit","utRows","rows","undefined","email","userEmail","resolvedStreamStoreId","validStreamStoreId","streamToolUserId","streamToolLimit","onToolProgress","_name","progress","write","spans","batch","queued","raw","resolvedStoreId","user_id","user_email","convStoreId","upsert","title","conversation_title","hostname","onConflict","headersSent","listen","port","supabaseUrl","runtime","stats","workers","total","serverBootTime","then","count","gracefulShutdown","signal","close","clear","shutdown","drainStart","drainInterval","setTimeout","unref"],"sources":["../../src/server/index.ts"],"sourcesContent":["// server/index.ts — Unified Node.js agent server for Fly.io\n// All CLI optimizations: prompt caching, retry, loop detection, parallel tools,\n// model-aware context management, cost tracking, compaction block handling\n//\n// Shares agent-core with CLI via src/shared/agent-core.ts\n\nimport http from \"node:http\";\nimport { randomUUID } from \"node:crypto\";\nimport { type SupabaseClient } from \"@supabase/supabase-js\";\nimport Anthropic from \"@anthropic-ai/sdk\";\nimport { createLogger } from \"./lib/logger.js\";\n\nconst log = createLogger(\"server\");\n\nimport {\n sanitizeError,\n} from \"../shared/agent-core.js\";\nimport { handleProxy } from \"./proxy-handlers.js\";\nimport { handleNodeRoutes, setNodeAgentInvoker, type SenderContext } from \"./handlers/nodes.js\";\nimport { handleTranscribe } from \"./handlers/transcription.js\";\nimport { handleBillingRoutes, incrementUsage, checkPlanLimits } from \"./handlers/billing.js\";\nimport { handleSessionRoutes } from \"./handlers/sessions-handlers.js\";\nimport { generateCompaction } from \"./lib/compaction-service.js\";\nimport { initLocalAgentGateway, shutdownGateway as shutdownAgentGateway, getGatewayStats } from \"./local-agent-gateway.js\";\nimport { initSupabase, getServiceClient } from \"./lib/supabase-client.js\";\nimport { loadCheckpoint, markOrphaned } from \"./lib/session-checkpoint.js\";\nimport { rateLimiter } from \"./lib/rate-limiter.js\";\nimport { sanitizeAndLog } from \"./lib/prompt-sanitizer.js\";\nimport { generateOpenApiSpec } from \"./handlers/api-docs.js\";\n\nimport { processWorkflowSteps, handleWebhookIngestion, executeInlineChain, initWorkerPool, getPoolStats, shutdownPool, verifyGuestApprovalSignature } from \"./handlers/workflows.js\";\nimport {\n loadUserTools,\n executeTool,\n type UserToolRow,\n flushSpans,\n} from \"./tool-router.js\";\nimport { queueSpan, auditRowToSpan } from \"./lib/clickhouse-buffer.js\";\n\n// Extracted modules — single source of truth (no inline duplicates)\nimport { safeCompare, getCorsHeaders, jsonResponse, readBody } from \"./server-helpers.js\";\nimport { sendIpRateLimit } from \"./server-rate-limit.js\";\nimport { resolveAndValidateStoreId } from \"./server-store.js\";\nimport { getSseClients, safeSseWrite, sendWorkflowSSE, getTotalSseClients, sseCleanupInterval, MAX_SSE_CLIENTS_PER_RUN, MAX_SSE_TOTAL_CLIENTS, setupPgListen, closePgClient, pgListenReady } from \"./server-sse.js\";\nimport { handleAgentChat } from \"./server-chat.js\";\nimport { wireToolExecutor, wireAgentExecutor, wireBroadcasters, invokeAgentForChannel } from \"./server-executors.js\";\nimport { startWorkerLoop, stopWorkerLoop } from \"./server-worker.js\";\nimport { getCircuitBreakerStats } from \"./server-store-circuit-breaker.js\";\n\n// ============================================================================\n// PROCESS ERROR HANDLERS\n// ============================================================================\n\nprocess.on(\"unhandledRejection\", (reason, _promise) => {\n log.error({ err: reason }, \"unhandled rejection\");\n});\n\nprocess.on(\"uncaughtException\", (err) => {\n log.fatal({ err }, \"uncaught exception\");\n process.exit(1);\n});\n\n// ============================================================================\n// ENV CONFIG\n// ============================================================================\n\nconst PORT = parseInt(process.env.PORT || \"8080\", 10);\nconst SUPABASE_URL = process.env.SUPABASE_URL!;\nconst SUPABASE_SERVICE_ROLE_KEY = process.env.SUPABASE_SERVICE_ROLE_KEY!;\nconst SERVICE_ROLE_JWT = process.env.SERVICE_ROLE_JWT || \"\";\nconst ANTHROPIC_API_KEY = process.env.ANTHROPIC_API_KEY!;\nconst FLY_INTERNAL_SECRET = process.env.FLY_INTERNAL_SECRET || \"\";\nif (!FLY_INTERNAL_SECRET) {\n console.warn(\"[SECURITY] FLY_INTERNAL_SECRET is not set — internal endpoints are unprotected\");\n}\n\n// ============================================================================\n// READINESS STATE\n// ============================================================================\n\nlet workerPoolReady = false;\n\nfunction isReady(): boolean {\n return workerPoolReady; // PG listen is optional (SSE only)\n}\n\n// Webchat agent invoker — set later to avoid circular deps (same as node agent invoker)\nlet webchatAgentInvoker: ((\n supabase: SupabaseClient,\n agentId: string,\n message: string,\n storeId: string,\n conversationId: string,\n senderContext?: SenderContext,\n) => Promise<{ success: boolean; response?: string; error?: string }>) | null = null;\n\n// ============================================================================\n// HTTP SERVER\n// ============================================================================\n\n// Connection tracking for graceful shutdown draining\nlet activeRequests = 0;\n\nconst server = http.createServer(async (req, res) => {\n activeRequests++;\n res.on(\"close\", () => { activeRequests--; });\n\n const origin = req.headers.origin || \"\";\n const corsHeaders = getCorsHeaders(origin);\n\n // Health check — readiness-aware for Fly.io\n if (req.method === \"GET\" && (req.url === \"/\" || req.url === \"/health\")) {\n const ready = isReady();\n const status = ready ? 200 : 503;\n const agentStats = getGatewayStats();\n const cbStats = getCircuitBreakerStats();\n jsonResponse(res, status, {\n status: ready ? \"ok\" : \"starting\",\n version: process.env.npm_package_version || \"6.4.0\",\n uptime: Math.floor(process.uptime()),\n pg_listen: pgListenReady,\n worker_pool: workerPoolReady,\n local_agents: agentStats.total_agents,\n circuit_breakers: cbStats,\n }, corsHeaders);\n return;\n }\n\n // OpenAPI spec — public, no auth required (for Scalar docs viewer)\n if (req.method === \"GET\" && req.url === \"/openapi.json\") {\n const spec = generateOpenApiSpec();\n res.writeHead(200, { ...corsHeaders, \"Content-Type\": \"application/json\", \"Cache-Control\": \"public, max-age=3600\" });\n res.end(JSON.stringify(spec));\n return;\n }\n\n // CORS preflight\n if (req.method === \"OPTIONS\") {\n res.writeHead(204, corsHeaders);\n res.end();\n return;\n }\n\n const url = new URL(req.url || \"/\", `http://${req.headers.host || \"localhost\"}`);\n const pathname = url.pathname;\n\n // ================================================================\n // Phase 3: SSE stream for workflow run progress\n // GET /workflows/runs/:id/stream\n // ================================================================\n if (req.method === \"GET\" && pathname.match(/^\\/workflows\\/runs\\/[a-f0-9-]+\\/stream$/)) {\n const runId = pathname.split(\"/\")[3];\n\n // Auth check\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n if (!isInternal) {\n const sb = getServiceClient();\n const { data: { user: authUser }, error: authError } = await sb.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n // P1 FIX: Verify user belongs to the run's store (prevent cross-store SSE snooping)\n const { data: sseRun } = await sb.from(\"workflow_runs\")\n .select(\"store_id\").eq(\"id\", runId).single();\n if (sseRun) {\n const { data: membership } = await sb.from(\"store_members\")\n .select(\"id\").eq(\"store_id\", sseRun.store_id).eq(\"user_id\", authUser.id).single();\n if (!membership) {\n jsonResponse(res, 403, { error: \"Not authorized to view this run\" }, corsHeaders);\n return;\n }\n }\n }\n\n // H6 FIX: Enforce per-run and total client limits\n const sseClients = getSseClients();\n const existingClients = sseClients.get(runId)?.size || 0;\n if (existingClients >= MAX_SSE_CLIENTS_PER_RUN) {\n jsonResponse(res, 429, { error: \"Too many SSE clients for this run\" }, corsHeaders);\n return;\n }\n if (getTotalSseClients() >= MAX_SSE_TOTAL_CLIENTS) {\n jsonResponse(res, 429, { error: \"Too many total SSE connections\" }, corsHeaders);\n return;\n }\n\n // Start SSE stream\n res.writeHead(200, {\n \"Content-Type\": \"text/event-stream\",\n \"Cache-Control\": \"no-cache\",\n Connection: \"keep-alive\",\n ...corsHeaders,\n });\n\n // Send snapshot\n const sb = getServiceClient();\n const { data: run } = await sb.from(\"workflow_runs\")\n .select(\"id, workflow_id, status, trigger_type, current_step_key, error_message, error_step_key, started_at, completed_at, duration_ms\")\n .eq(\"id\", runId).single();\n const { data: stepRuns } = await sb.from(\"workflow_step_runs\")\n .select(\"id, step_key, step_type, status, error_message, duration_ms, started_at, completed_at\")\n .eq(\"run_id\", runId).order(\"created_at\", { ascending: true });\n\n sendWorkflowSSE(res, { type: \"snapshot\", run, steps: stepRuns || [] });\n\n // Register client\n if (!sseClients.has(runId)) sseClients.set(runId, new Set());\n sseClients.get(runId)!.add(res);\n\n // Cleanup on disconnect\n const cleanup = () => {\n clearInterval(heartbeat);\n const clients = sseClients.get(runId);\n if (clients) {\n clients.delete(res);\n if (clients.size === 0) sseClients.delete(runId);\n }\n };\n\n // Heartbeat — uses safeSseWrite so dead connections are cleaned up immediately\n const heartbeat = setInterval(() => {\n if (!safeSseWrite(res, `: heartbeat\\n\\n`, cleanup)) {\n clearInterval(heartbeat);\n }\n }, 15_000);\n\n req.on(\"close\", cleanup);\n req.on(\"error\", cleanup);\n return;\n }\n\n // ================================================================\n // Guest approval — signed URL, no auth required (GET)\n // GET /approvals/guest/:id?action=approve&expires=...&sig=...\n // ================================================================\n const guestApprovalMatch = pathname.match(/^\\/approvals\\/guest\\/([a-f0-9-]+)$/);\n if (guestApprovalMatch && req.method === \"GET\") {\n const clientIp = req.headers[\"x-forwarded-for\"]?.toString().split(\",\")[0]?.trim() || req.socket.remoteAddress || \"unknown\";\n if (sendIpRateLimit(res, clientIp, corsHeaders)) return;\n const stepRunId = guestApprovalMatch[1];\n const urlParams = new URL(req.url || \"\", `http://${req.headers.host}`).searchParams;\n const action = urlParams.get(\"action\") || \"\";\n const expires = urlParams.get(\"expires\") || \"\";\n const sig = urlParams.get(\"sig\") || \"\";\n\n if (!action || !expires || !sig) {\n jsonResponse(res, 400, { error: \"Missing action, expires, or sig parameter\" }, corsHeaders);\n return;\n }\n if (new Date(expires) < new Date()) {\n jsonResponse(res, 410, { error: \"This approval link has expired\" }, corsHeaders);\n return;\n }\n if (!verifyGuestApprovalSignature(stepRunId, action, expires, sig)) {\n jsonResponse(res, 403, { error: \"Invalid signature\" }, corsHeaders);\n return;\n }\n\n const guestSupabase = getServiceClient();\n\n const { data: approval } = await guestSupabase.from(\"workflow_approval_requests\")\n .select(\"id, store_id, run_id, status\").eq(\"step_run_id\", stepRunId).limit(1);\n if (!approval?.length) {\n jsonResponse(res, 404, { error: \"Approval not found\" }, corsHeaders);\n return;\n }\n if (approval[0].status !== \"pending\") {\n jsonResponse(res, 409, { error: `Approval already ${approval[0].status}` }, corsHeaders);\n return;\n }\n\n const isApprove = action === \"approve\" || action === \"approved\";\n const { data: guestResult, error: guestErr } = await guestSupabase.rpc(\"respond_to_approval\", {\n p_approval_id: approval[0].id,\n p_store_id: approval[0].store_id,\n p_response: isApprove ? \"approved\" : \"rejected\",\n p_response_data: { guest: true, action },\n p_responded_by: null,\n });\n\n if (guestErr) {\n jsonResponse(res, 500, { success: false, error: guestErr.message }, corsHeaders);\n return;\n }\n\n if (guestResult?.success && approval[0].run_id) {\n try { await executeInlineChain(guestSupabase, approval[0].run_id); } catch (err) { log.error({ err: (err as Error).message, runId: approval[0].run_id }, \"inline chain failed after guest approval\"); }\n }\n\n res.writeHead(200, { \"Content-Type\": \"text/html\", ...corsHeaders });\n res.end(`<!DOCTYPE html><html><body style=\"font-family:system-ui;text-align:center;padding:40px\">\n <h2>${isApprove ? \"Approved\" : \"Rejected\"}</h2>\n <p>Your response has been recorded. You can close this window.</p>\n </body></html>`);\n return;\n }\n\n // ================================================================\n // Webchat — anonymous access for embedded chat widgets\n // POST /webchat/channels/:id/messages — send message (+ agent auto-reply)\n // GET /webchat/channels/:id/history — load conversation history\n // GET /webchat/widget.js — serve compiled widget JS\n // ================================================================\n // Webchat CORS: allow any origin (widget is embedded on customer sites)\n const webchatCors = { ...corsHeaders, \"Access-Control-Allow-Origin\": \"*\" };\n\n const webchatMsgMatch = pathname.match(/^\\/webchat\\/channels\\/([a-f0-9-]+)\\/messages$/);\n if (webchatMsgMatch && req.method === \"POST\") {\n const clientIp = req.headers[\"x-forwarded-for\"]?.toString().split(\",\")[0]?.trim() || req.socket.remoteAddress || \"unknown\";\n if (sendIpRateLimit(res, clientIp, webchatCors)) return;\n\n let rawBody: string;\n try { rawBody = await readBody(req); } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, webchatCors);\n return;\n }\n\n const channelId = webchatMsgMatch[1];\n let wcBody: any;\n try { wcBody = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, webchatCors);\n return;\n }\n\n if (!wcBody.content || typeof wcBody.content !== \"string\") {\n jsonResponse(res, 400, { error: \"content (string) is required\" }, webchatCors);\n return;\n }\n if (wcBody.content.length > 5000) {\n jsonResponse(res, 400, { error: \"Message too long (max 5000 characters)\" }, webchatCors);\n return;\n }\n\n const supabase = getServiceClient();\n\n // Verify channel exists and is a webchat channel\n const { data: channel } = await supabase\n .from(\"channels\")\n .select(\"id, store_id, node_id, agent_id, type, config\")\n .eq(\"id\", channelId)\n .eq(\"type\", \"webchat\")\n .single();\n if (!channel) {\n jsonResponse(res, 404, { error: \"Webchat channel not found\" }, webchatCors);\n return;\n }\n\n // Rate limit per store (best-effort)\n try {\n const planCheck = await checkPlanLimits(supabase, channel.store_id, \"message\");\n if (!planCheck.allowed) {\n jsonResponse(res, 429, { error: planCheck.reason || \"Plan limit reached\" }, webchatCors);\n return;\n }\n } catch { /* billing tables may not exist yet */ }\n\n const senderId = (wcBody.sender_id as string) || \"anonymous\";\n\n // Resolve conversation: reuse if sender had activity < 30 min ago, else new UUID\n let conversationId: string = (wcBody.conversation_id as string) || \"\";\n if (!conversationId) {\n const thirtyMinAgo = new Date(Date.now() - 30 * 60 * 1000).toISOString();\n const { data: recent } = await supabase\n .from(\"channel_messages\")\n .select(\"conversation_id\")\n .eq(\"channel_id\", channelId)\n .eq(\"sender_id\", senderId)\n .gt(\"created_at\", thirtyMinAgo)\n .not(\"conversation_id\", \"is\", null)\n .order(\"created_at\", { ascending: false })\n .limit(1);\n conversationId = (recent?.length && recent[0].conversation_id) || randomUUID();\n }\n\n // Insert inbound message\n const { data: message, error: msgErr } = await supabase\n .from(\"channel_messages\")\n .insert({\n store_id: channel.store_id,\n channel_id: channelId,\n direction: \"inbound\",\n sender_id: senderId,\n sender_name: wcBody.sender_name || \"Visitor\",\n content: wcBody.content,\n content_type: \"text\",\n metadata: { source: \"webchat\", ip: clientIp, widget_version: \"1.0.0\" },\n agent_id: channel.agent_id,\n conversation_id: conversationId,\n })\n .select(\"id, direction, content, conversation_id, created_at\")\n .single();\n\n if (msgErr) {\n jsonResponse(res, 500, { error: msgErr.message }, webchatCors);\n return;\n }\n\n // Track usage + channel stats (best-effort)\n incrementUsage(supabase, channel.store_id, { messages_in: 1 }).catch(() => {});\n try { await supabase.rpc(\"increment_channel_stats\", { p_channel_id: channelId }); } catch { /* ok */ }\n\n // Auto-invoke agent if assigned\n let agentResponse: any = null;\n if (channel.agent_id && webchatAgentInvoker) {\n try {\n const result = await webchatAgentInvoker(supabase, channel.agent_id, wcBody.content, channel.store_id, conversationId);\n if (result.success && result.response) {\n const { data: outMsg } = await supabase\n .from(\"channel_messages\")\n .insert({\n store_id: channel.store_id,\n channel_id: channelId,\n direction: \"outbound\",\n sender_id: \"agent\",\n sender_name: \"AI Agent\",\n content: result.response,\n content_type: \"text\",\n metadata: { agent_id: channel.agent_id, auto_response: true, source: \"webchat\" },\n agent_id: channel.agent_id,\n conversation_id: conversationId,\n })\n .select(\"id, direction, content, conversation_id, created_at\")\n .single();\n agentResponse = outMsg;\n incrementUsage(supabase, channel.store_id, { messages_out: 1, agent_invocations: 1 }).catch(() => {});\n }\n } catch (err) {\n log.error({ err: (err as Error).message }, \"webchat agent error\");\n }\n }\n\n jsonResponse(res, 201, { success: true, message, agent_response: agentResponse, conversation_id: conversationId }, webchatCors);\n return;\n }\n\n // GET /webchat/channels/:id/history — load conversation history for widget\n const webchatHistoryMatch = pathname.match(/^\\/webchat\\/channels\\/([a-f0-9-]+)\\/history$/);\n if (webchatHistoryMatch && req.method === \"GET\") {\n const clientIp = req.headers[\"x-forwarded-for\"]?.toString().split(\",\")[0]?.trim() || req.socket.remoteAddress || \"unknown\";\n if (sendIpRateLimit(res, clientIp, webchatCors)) return;\n\n const channelId = webchatHistoryMatch[1];\n const params = url.searchParams;\n const senderId = params.get(\"sender_id\") || \"\";\n const reqConvId = params.get(\"conversation_id\") || \"\";\n\n if (!senderId) {\n jsonResponse(res, 400, { error: \"sender_id query parameter required\" }, webchatCors);\n return;\n }\n\n const supabase = getServiceClient();\n\n // Verify channel is webchat type\n const { data: wcChannel } = await supabase\n .from(\"channels\")\n .select(\"id, type\")\n .eq(\"id\", channelId)\n .eq(\"type\", \"webchat\")\n .single();\n if (!wcChannel) {\n jsonResponse(res, 404, { error: \"Webchat channel not found\" }, webchatCors);\n return;\n }\n\n // Get messages — by conversation_id if available, or by sender\n // P0 FIX: Always filter by sender_id to prevent cross-sender data leak\n let query = supabase\n .from(\"channel_messages\")\n .select(\"id, direction, sender_id, sender_name, content, content_type, created_at\")\n .eq(\"channel_id\", channelId);\n\n // P0 FIX: Validate senderId against strict pattern to prevent PostgREST filter injection\n // Only allow alphanumeric characters, hyphens, and underscores (blocks .eq., .neq., dots, etc.)\n if (!/^[a-zA-Z0-9_-]+$/.test(senderId)) {\n jsonResponse(res, 400, { error: \"Invalid sender_id format\" }, webchatCors);\n return;\n }\n if (reqConvId) {\n // P0 FIX: Use parameterized .in() filter instead of string interpolation in .or()\n query = query.eq(\"conversation_id\", reqConvId)\n .in(\"sender_id\", [senderId, \"agent\"]);\n } else {\n query = query.in(\"sender_id\", [senderId, \"agent\"]);\n }\n\n const { data: messages, error: histErr } = await query\n .order(\"created_at\", { ascending: true })\n .limit(50);\n\n if (histErr) {\n jsonResponse(res, 500, { error: histErr.message }, webchatCors);\n return;\n }\n\n jsonResponse(res, 200, { success: true, messages: messages || [] }, webchatCors);\n return;\n }\n\n // GET /webchat/widget.js — serve compiled widget JavaScript\n if (pathname === \"/webchat/widget.js\" && req.method === \"GET\") {\n const fs = await import(\"node:fs\");\n const path = await import(\"node:path\");\n // Try multiple possible locations for the built widget file\n const possiblePaths = [\n path.join(import.meta.dirname || __dirname, \"../../dist/webchat/widget.js\"),\n path.join(import.meta.dirname || __dirname, \"../../../dist/webchat/widget.js\"),\n path.join(process.cwd(), \"dist/webchat/widget.js\"),\n ];\n\n let widgetJs: string | null = null;\n for (const p of possiblePaths) {\n try {\n widgetJs = fs.readFileSync(p, \"utf-8\");\n break;\n } catch { /* try next */ }\n }\n\n if (widgetJs) {\n res.writeHead(200, {\n \"Content-Type\": \"application/javascript\",\n \"Cache-Control\": \"public, max-age=3600\",\n ...webchatCors,\n });\n res.end(widgetJs);\n } else {\n res.writeHead(200, {\n \"Content-Type\": \"application/javascript\",\n ...webchatCors,\n });\n res.end('console.warn(\"[WhaleChat] Widget JS not built. Run: npx esbuild src/webchat/widget.ts --bundle --minify --outfile=dist/webchat/widget.js\");');\n }\n return;\n }\n\n // ================================================================\n // Billing & Usage routes\n // ================================================================\n if (pathname.startsWith(\"/usage\") || pathname.startsWith(\"/billing/\")) {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n if (!token) {\n req.resume();\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n let rawBody: string;\n try { rawBody = await readBody(req); } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let billingBody: any = null;\n try { if (rawBody) billingBody = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n const supabase = getServiceClient();\n // Extract userId from JWT for checkout/portal endpoints\n let billingUserId: string | undefined;\n try {\n const payload = JSON.parse(Buffer.from(token.split(\".\")[1], \"base64url\").toString());\n billingUserId = payload.sub;\n } catch { /* not a JWT — service role key */ }\n const result = await handleBillingRoutes(pathname, req.method || \"GET\", billingBody, supabase, {\n userId: billingUserId,\n isServiceRole: safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT),\n });\n\n if (result) {\n jsonResponse(res, result.status, result.body, corsHeaders);\n } else {\n jsonResponse(res, 404, { error: `No route: ${req.method} ${pathname}` }, corsHeaders);\n }\n return;\n }\n\n // ================================================================\n // Node & Channel management routes (supports GET, POST, PUT, DELETE)\n // Must be before the method gate since GET /channels/:id/messages is valid\n // ================================================================\n if (pathname.startsWith(\"/nodes\") || pathname.startsWith(\"/channels\")) {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n if (!token) {\n req.resume();\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let nodeBody: any = null;\n try { if (rawBody) nodeBody = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n const supabase = getServiceClient();\n\n let userId: string | undefined;\n const isServiceRole = safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n if (!isServiceRole) {\n const { data: { user: authUser } } = await supabase.auth.getUser(token);\n if (authUser) userId = authUser.id;\n }\n\n const result = await handleNodeRoutes(pathname, req.method || \"GET\", nodeBody, supabase, {\n userId,\n isServiceRole,\n rawToken: token,\n }, url.searchParams);\n\n if (result) {\n jsonResponse(res, result.status, result.body, corsHeaders);\n } else {\n jsonResponse(res, 404, { error: `No route: ${req.method} ${pathname}` }, corsHeaders);\n }\n return;\n }\n\n // ================================================================\n // Session API routes (supports GET, POST)\n // Must be before the method gate since GET /sessions is valid\n // ================================================================\n if (pathname.startsWith(\"/sessions\")) {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n if (!token) {\n req.resume();\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n const supabase = getServiceClient();\n let userId: string | undefined;\n const isServiceRole = safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n if (!isServiceRole) {\n const { data: { user: authUser } } = await supabase.auth.getUser(token);\n if (authUser) userId = authUser.id;\n }\n const handled = await handleSessionRoutes(req, res, pathname, url, corsHeaders, supabase, {\n userId,\n isServiceRole,\n });\n if (!handled) {\n jsonResponse(res, 404, { error: `No route: ${req.method} ${pathname}` }, corsHeaders);\n }\n return;\n }\n\n if (req.method !== \"POST\" && req.method !== \"DELETE\" && req.method !== \"PUT\") {\n jsonResponse(res, 405, { error: \"Method not allowed\" }, corsHeaders);\n return;\n }\n\n try {\n // ================================================================\n // Phase 4.2: Resume conversation from checkpoint\n // POST /conversations/:id/resume\n // ================================================================\n const resumeMatch = pathname.match(/^\\/conversations\\/([a-f0-9-]+)\\/resume$/);\n if (resumeMatch && req.method === \"POST\") {\n const convId = resumeMatch[1];\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n\n if (!isInternal) {\n const { data: { user: authUser }, error: authError } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n }\n\n // Drain the request body (even if we don't use it) to prevent Fly proxy stalls\n try { await readBody(req); } catch { /* body not needed */ }\n\n const checkpoint = await loadCheckpoint(supabase, convId);\n if (!checkpoint) {\n jsonResponse(res, 404, { error: \"No checkpoint found for this conversation\" }, corsHeaders);\n return;\n }\n\n // Parse messages back from serialized form\n let parsedMessages: unknown[];\n try {\n parsedMessages = JSON.parse(checkpoint.messages);\n } catch {\n jsonResponse(res, 422, { error: \"Checkpoint messages corrupted\" }, corsHeaders);\n return;\n }\n\n jsonResponse(res, 200, {\n success: true,\n conversation_id: checkpoint.conversation_id,\n turn: checkpoint.turn,\n messages: parsedMessages,\n tokens_used: checkpoint.tokens_used,\n cost_so_far: checkpoint.cost_so_far,\n tools_used: checkpoint.tools_used,\n checkpointed_at: checkpoint.created_at,\n }, corsHeaders);\n return;\n }\n\n // ================================================================\n // Phase 2: Approval response endpoint\n // POST /approvals/:id/respond\n // ================================================================\n const approvalMatch = pathname.match(/^\\/approvals\\/([a-f0-9-]+)\\/respond$/);\n if (approvalMatch) {\n const approvalId = approvalMatch[1];\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n let userId: string | null = null;\n\n if (!isInternal) {\n const { data: { user: authUser }, error: authError } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n userId = authUser.id;\n }\n\n let rawBody: string;\n try { rawBody = await readBody(req); } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let body: any;\n try { body = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n if (!body.status) {\n jsonResponse(res, 400, { error: \"status required (approved/rejected)\" }, corsHeaders);\n return;\n }\n\n // Get store_id from approval\n const { data: approval } = await supabase.from(\"workflow_approval_requests\")\n .select(\"store_id, run_id\").eq(\"id\", approvalId).single();\n if (!approval) {\n jsonResponse(res, 404, { error: \"Approval not found\" }, corsHeaders);\n return;\n }\n\n // P1 FIX: Verify user has access to the approval's store\n if (!isInternal && userId) {\n const { data: approvalMembership } = await supabase.from(\"store_members\")\n .select(\"id\").eq(\"store_id\", approval.store_id).eq(\"user_id\", userId).single();\n if (!approvalMembership) {\n jsonResponse(res, 403, { error: \"Not authorized to respond to this approval\" }, corsHeaders);\n return;\n }\n }\n\n const { data: result, error } = await supabase.rpc(\"respond_to_approval\", {\n p_approval_id: approvalId,\n p_store_id: approval.store_id,\n p_response: body.status,\n p_response_data: body.response_data || {},\n p_responded_by: userId || body.responded_by || null,\n });\n\n if (error) {\n jsonResponse(res, 500, { success: false, error: error.message }, corsHeaders);\n return;\n }\n\n // Inline resume — execute next step immediately\n if (result?.success && approval.run_id) {\n try {\n await executeInlineChain(supabase, approval.run_id);\n } catch (err) {\n log.error({ err: (err as Error).message }, \"inline chain failed after approval\");\n }\n }\n\n jsonResponse(res, result?.success ? 200 : 422, result, corsHeaders);\n return;\n }\n\n // ================================================================\n // Waitpoint completion — API endpoint\n // POST /waitpoints/:token/complete\n // ================================================================\n const waitpointMatch = pathname.match(/^\\/waitpoints\\/([a-f0-9-]+)\\/complete$/);\n if (waitpointMatch) {\n const token = waitpointMatch[1];\n const authHeader = req.headers.authorization;\n const authToken = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(authToken, FLY_INTERNAL_SECRET) || safeCompare(authToken, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(authToken, SERVICE_ROLE_JWT);\n\n if (!isInternal && !authToken) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n\n let rawBody: string;\n try { rawBody = await readBody(req); } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n let body: any;\n try { body = JSON.parse(rawBody || \"{}\"); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n\n // Find waitpoint\n const { data: wp } = await supabase.from(\"waitpoint_tokens\")\n .select(\"id, run_id, step_run_id, store_id, expires_at, status\")\n .eq(\"token\", token).single();\n if (!wp) {\n jsonResponse(res, 404, { error: \"Waitpoint token not found\" }, corsHeaders);\n return;\n }\n if (wp.status === \"completed\") {\n jsonResponse(res, 409, { error: \"Waitpoint already completed\" }, corsHeaders);\n return;\n }\n if (new Date(wp.expires_at) < new Date()) {\n jsonResponse(res, 410, { error: \"Waitpoint expired\" }, corsHeaders);\n return;\n }\n\n // Complete it\n await supabase.from(\"waitpoint_tokens\").update({\n status: \"completed\", completion_data: body.data || {}, completed_at: new Date().toISOString(),\n }).eq(\"id\", wp.id);\n\n await supabase.from(\"workflow_step_runs\").update({\n status: \"pending\", input: { waitpoint_completed: true, waitpoint_data: body.data || {} },\n }).eq(\"id\", wp.step_run_id).eq(\"status\", \"waiting\");\n\n // Inline resume\n try { await executeInlineChain(supabase, wp.run_id); } catch (err) { log.error({ err: (err as Error).message, runId: wp.run_id }, \"inline chain failed after waitpoint\"); }\n\n jsonResponse(res, 200, { success: true, run_id: wp.run_id }, corsHeaders);\n return;\n }\n\n // ================================================================\n // Webhook ingestion — no auth required (uses HMAC verification)\n // POST /webhooks/:slug\n // ================================================================\n const webhookMatch = pathname.match(/^\\/webhooks\\/([a-zA-Z0-9_-]+)$/);\n if (webhookMatch) {\n const whClientIp = req.headers[\"x-forwarded-for\"]?.toString().split(\",\")[0]?.trim() || req.socket.remoteAddress || \"unknown\";\n if (sendIpRateLimit(res, whClientIp, corsHeaders)) return;\n const slug = webhookMatch[1];\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n const headers: Record<string, string> = {};\n for (const [k, v] of Object.entries(req.headers)) {\n if (typeof v === \"string\") headers[k] = v;\n }\n\n const result = await handleWebhookIngestion(supabase, slug, rawBody, headers);\n\n // Phase 1: Inline execution for webhook-triggered workflows\n if (result.body.run_id && result.status === 200) {\n try {\n await executeInlineChain(supabase, result.body.run_id as string);\n } catch (err) {\n log.error({ err: (err as Error).message }, \"webhook inline chain error\");\n }\n }\n\n jsonResponse(res, result.status, result.body, corsHeaders);\n return;\n }\n\n // ================================================================\n // Fire event — service-role or internal auth\n // POST /events\n // ================================================================\n if (pathname === \"/events\") {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n\n // Verify user auth if not internal\n if (!isInternal) {\n const { data: { user: authUser }, error: authError } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n }\n\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let body: any;\n try { body = JSON.parse(rawBody || \"{}\"); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n if (!body.store_id || !body.event_type) {\n jsonResponse(res, 400, { error: \"store_id and event_type required\" }, corsHeaders);\n return;\n }\n\n // Idempotency: if client provides idempotency_key, check for duplicate\n if (body.idempotency_key) {\n const { data: existing } = await supabase.from(\"workflow_events\")\n .select(\"id\")\n .eq(\"idempotency_key\", body.idempotency_key)\n .limit(1);\n if (existing && existing.length > 0) {\n jsonResponse(res, 200, { success: true, event_id: existing[0].id, deduplicated: true }, corsHeaders);\n return;\n }\n }\n\n const { data: eventId, error: fireErr } = await supabase.rpc(\"fire_event\", {\n p_store_id: body.store_id,\n p_event_type: body.event_type,\n p_event_payload: body.payload || {},\n p_source: body.source || \"api\",\n });\n\n if (fireErr) {\n jsonResponse(res, 500, { success: false, error: fireErr.message }, corsHeaders);\n } else {\n jsonResponse(res, 200, { success: true, event_id: eventId }, corsHeaders);\n }\n return;\n }\n\n // ================================================================\n // Internal workflow processing — verified by internal secret\n // POST /workflows/process\n // ================================================================\n if (pathname === \"/workflows/process\") {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n if (!FLY_INTERNAL_SECRET || (!safeCompare(token, FLY_INTERNAL_SECRET) && !safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) && !safeCompare(token, SERVICE_ROLE_JWT))) {\n jsonResponse(res, 401, { error: \"Unauthorized\" }, corsHeaders);\n return;\n }\n\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n rawBody = \"{}\";\n }\n\n let body: any;\n try { body = JSON.parse(rawBody || \"{}\"); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n const supabase = getServiceClient();\n const result = await processWorkflowSteps(supabase, body.batch_size || 10);\n jsonResponse(res, 200, { success: true, ...result }, corsHeaders);\n return;\n }\n\n // ================================================================\n // Start workflow run — service-role or user auth\n // POST /workflows/start\n // ================================================================\n if (pathname === \"/workflows/start\") {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n\n // Verify user auth if not internal\n if (!isInternal) {\n const { data: { user: authUser }, error: authError } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n }\n\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let body: any;\n try { body = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n\n // P0 FIX: Verify the workflow belongs to the requesting store before starting a run\n if (body.workflow_id && body.store_id) {\n const { data: wfOwner, error: wfOwnerErr } = await supabase\n .from(\"workflows\")\n .select(\"id\")\n .eq(\"id\", body.workflow_id)\n .eq(\"store_id\", body.store_id)\n .single();\n if (wfOwnerErr || !wfOwner) {\n jsonResponse(res, 403, { error: \"Workflow does not belong to this store\" }, corsHeaders);\n return;\n }\n }\n\n const { data, error } = await supabase.rpc(\"start_workflow_run\", {\n p_workflow_id: body.workflow_id,\n p_store_id: body.store_id,\n p_trigger_type: body.trigger_type || \"api\",\n p_trigger_payload: body.trigger_payload || {},\n p_idempotency_key: body.idempotency_key || null,\n });\n\n if (error) {\n jsonResponse(res, 500, { success: false, error: error.message }, corsHeaders);\n } else {\n // Phase 4: Set version_id if workflow has a published version\n // Phase 1: Inline execution for API-triggered workflows\n if (data?.success && data.run_id && !data.deduplicated) {\n try {\n const { data: wf } = await supabase.from(\"workflows\")\n .select(\"published_version_id\").eq(\"id\", body.workflow_id).single();\n if (wf?.published_version_id) {\n await supabase.from(\"workflow_runs\").update({ version_id: wf.published_version_id }).eq(\"id\", data.run_id);\n }\n await executeInlineChain(supabase, data.run_id);\n } catch (err) {\n log.error({ err: (err as Error).message }, \"start-inline chain error\");\n }\n }\n jsonResponse(res, data?.success ? 200 : 422, data, corsHeaders);\n }\n return;\n }\n\n // ================================================================\n // Standard auth gate for all other POST routes\n // ================================================================\n log.info({ method: req.method, path: pathname, contentLength: req.headers[\"content-length\"] || \"?\" }, \"request\");\n const authHeader = req.headers.authorization;\n if (!authHeader?.startsWith(\"Bearer \")) {\n req.resume(); // drain body to avoid Fly proxy stall\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n // Read body FIRST — before async auth calls (getUser, rate_limit).\n // Node.js request streams are paused until consumed. If we do async network\n // calls before reading, the TCP receive buffer fills up and Fly's proxy\n // stalls with \"error writing a body to connection\" on large requests.\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large (max 500MB)\" }, corsHeaders);\n return;\n }\n\n const token = authHeader.substring(7);\n const supabase = getServiceClient();\n\n // Check service-role key\n let user: { id: string; email?: string } | null = null;\n const isServiceRole = safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isServiceRole) {\n try {\n const {\n data: { user: authUser },\n error: authError,\n } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n user = authUser;\n } catch (authErr) {\n log.error({ err: (authErr as Error).message }, \"auth getUser failed\");\n jsonResponse(res, 502, { error: \"Auth service unavailable, please retry\" }, corsHeaders);\n return;\n }\n }\n\n // In-memory token-bucket rate limiting (sole rate check — no DB round-trip)\n {\n const tier = isServiceRole ? \"serviceRole\" as const : user ? \"authenticated\" as const : \"unauthenticated\" as const;\n const rateLimitKey = user ? `user:${user.id}` : `ip:${req.socket.remoteAddress || \"unknown\"}`;\n const memResult = rateLimiter.checkRequest(rateLimitKey, tier);\n if (!memResult.allowed) {\n res.writeHead(429, {\n \"Retry-After\": String(Math.ceil(memResult.retryAfterMs / 1000)),\n \"X-RateLimit-Remaining\": \"0\",\n \"X-RateLimit-Bucket\": memResult.bucket,\n \"Content-Type\": \"application/json\",\n ...corsHeaders,\n });\n res.end(JSON.stringify({ error: \"Rate limit exceeded\" }));\n return;\n }\n }\n\n let body: any;\n try {\n body = JSON.parse(rawBody);\n } catch (parseErr) {\n const errMsg = parseErr instanceof Error ? parseErr.message : String(parseErr);\n const bodyLen = rawBody.length;\n const tail = bodyLen > 200 ? rawBody.slice(bodyLen - 200) : rawBody;\n log.error({ bodyLen, errMsg, tail }, \"JSON parse failed on request body\");\n jsonResponse(res, 400, {\n error: \"Invalid JSON in request body\",\n detail: errMsg,\n body_length: bodyLen,\n }, corsHeaders);\n return;\n }\n\n // Anthropic API proxy mode\n if (body.mode === \"proxy\") {\n await handleProxy(res, body, corsHeaders);\n return;\n }\n\n // Audio transcription mode (OpenAI Whisper)\n if (body.mode === \"transcribe\") {\n const { audio_base64, media_type, store_id } = body;\n if (!audio_base64 || !media_type) {\n jsonResponse(res, 400, { error: \"audio_base64 and media_type required\" }, corsHeaders);\n return;\n }\n const sid = store_id || body.storeId;\n if (!sid) {\n jsonResponse(res, 400, { error: \"store_id required for transcription (needed to resolve OpenAI API key)\" }, corsHeaders);\n return;\n }\n const result = await handleTranscribe(supabase, sid, audio_base64, media_type);\n jsonResponse(res, result.success ? 200 : 422, result, corsHeaders);\n return;\n }\n\n // Conversation compaction mode (Haiku summarization for non-Anthropic providers)\n if (body.mode === \"compact\") {\n const { messages: compactMessages, system_prompt } = body;\n if (!compactMessages || !Array.isArray(compactMessages) || !system_prompt) {\n jsonResponse(res, 400, { error: \"messages (array) and system_prompt required\" }, corsHeaders);\n return;\n }\n const anthropic = new Anthropic({ apiKey: ANTHROPIC_API_KEY });\n // Sanitize user-provided system prompt before passing to compaction\n const sanitizedCompactPrompt = sanitizeAndLog(system_prompt, \"compactionEndpoint\");\n const compactionResult = await generateCompaction({\n anthropic,\n messages: compactMessages,\n systemPrompt: sanitizedCompactPrompt,\n });\n jsonResponse(\n res,\n compactionResult.success ? 200 : 422,\n {\n success: compactionResult.success,\n compaction_content: compactionResult.content,\n error: compactionResult.error,\n },\n corsHeaders,\n );\n return;\n }\n\n // Direct tool execution mode\n if (body.mode === \"tool\") {\n const { tool_name, args, store_id, conversation_id, trace_id } = body;\n if (!tool_name) {\n jsonResponse(res, 400, { error: \"tool_name required\" }, corsHeaders);\n return;\n }\n\n // Resolve and validate store_id (server-derived, not blindly trusted)\n const resolvedToolStoreId = await resolveAndValidateStoreId(\n supabase, store_id || body.storeId, user, isServiceRole, token, body.userId\n );\n if (!resolvedToolStoreId && !isServiceRole) {\n jsonResponse(res, 400, { error: \"store_id required for tool execution\" }, corsHeaders);\n return;\n }\n const validToolStoreId = resolvedToolStoreId || store_id;\n\n // Phase 7.2: Per-tool rate limiting\n const toolUserId = user?.id || body.userId || \"anon\";\n const toolLimit = rateLimiter.checkToolLimit(toolUserId, tool_name);\n if (!toolLimit.allowed) {\n res.writeHead(429, {\n \"Retry-After\": String(Math.ceil(toolLimit.retryAfterMs / 1000)),\n \"X-RateLimit-Remaining\": \"0\",\n \"X-RateLimit-Bucket\": toolLimit.bucket,\n \"Content-Type\": \"application/json\",\n ...corsHeaders,\n });\n res.end(JSON.stringify({ error: `Tool rate limit exceeded for ${tool_name}` }));\n return;\n }\n // Load user tools if this is a user_tool__ prefixed call\n let utRows: UserToolRow[] | undefined;\n if (tool_name.startsWith(\"user_tool__\") && validToolStoreId) {\n const { rows } = await loadUserTools(supabase, validToolStoreId);\n utRows = rows;\n }\n const result = await executeTool(\n supabase,\n tool_name,\n (args || {}) as Record<string, unknown>,\n validToolStoreId || undefined,\n trace_id || undefined,\n user?.id || body.userId || null,\n user?.email || body.userEmail || null,\n body.source || \"whale-code\",\n conversation_id || undefined,\n utRows,\n );\n // Always 200 for tool results — success/failure is in the JSON body.\n // HTTP 500 causes MCP clients to throw before reading the error message.\n jsonResponse(res, 200, result, corsHeaders);\n return;\n }\n\n // Streaming tool execution mode (NDJSON) — for tools with live progress (kali, etc.)\n if (body.mode === \"tool_stream\") {\n const { tool_name, args, store_id } = body;\n if (!tool_name) {\n jsonResponse(res, 400, { error: \"tool_name required\" }, corsHeaders);\n return;\n }\n\n // Resolve and validate store_id\n const resolvedStreamStoreId = await resolveAndValidateStoreId(\n supabase, store_id || body.storeId, user, isServiceRole, token, body.userId\n );\n if (!resolvedStreamStoreId && !isServiceRole) {\n jsonResponse(res, 400, { error: \"store_id required for tool execution\" }, corsHeaders);\n return;\n }\n const validStreamStoreId = resolvedStreamStoreId || store_id;\n\n // Phase 7.2: Per-tool rate limiting (stream mode)\n const streamToolUserId = user?.id || body.userId || \"anon\";\n const streamToolLimit = rateLimiter.checkToolLimit(streamToolUserId, tool_name);\n if (!streamToolLimit.allowed) {\n res.writeHead(429, {\n \"Retry-After\": String(Math.ceil(streamToolLimit.retryAfterMs / 1000)),\n \"X-RateLimit-Remaining\": \"0\",\n \"X-RateLimit-Bucket\": streamToolLimit.bucket,\n \"Content-Type\": \"application/json\",\n ...corsHeaders,\n });\n res.end(JSON.stringify({ error: `Tool rate limit exceeded for ${tool_name}` }));\n return;\n }\n\n res.writeHead(200, {\n \"Content-Type\": \"application/x-ndjson\",\n \"Transfer-Encoding\": \"chunked\",\n ...corsHeaders,\n });\n\n const onToolProgress = (_name: string, progress: unknown) => {\n try {\n // Structured status events from kali — relay as type \"status\" for CLI ToolProgress handling\n const p = progress as Record<string, unknown>;\n if (p && p.type === \"status\" && p.progress) {\n res.write(JSON.stringify({ type: \"status\", progress: p.progress }) + \"\\n\");\n } else {\n res.write(JSON.stringify({ type: \"progress\", progress }) + \"\\n\");\n }\n } catch { /* client disconnected */ }\n };\n\n try {\n const result = await executeTool(\n supabase,\n tool_name,\n (args || {}) as Record<string, unknown>,\n validStreamStoreId || undefined,\n body.trace_id || undefined,\n user?.id || body.userId || null,\n user?.email || body.userEmail || null,\n body.source || \"whale-code-stream\",\n body.conversation_id || undefined,\n undefined,\n undefined,\n onToolProgress,\n );\n\n res.write(JSON.stringify({ type: \"result\", ...result }) + \"\\n\");\n } catch (err) {\n res.write(JSON.stringify({ type: \"result\", success: false, error: sanitizeError(err) }) + \"\\n\");\n }\n\n res.end();\n return;\n }\n\n // CLI telemetry ingest — batch of spans from Whale Code CLI\n if (body.mode === \"telemetry_ingest\") {\n const spans: Record<string, unknown>[] = body.spans;\n if (!Array.isArray(spans) || spans.length === 0) {\n jsonResponse(res, 400, { error: \"spans array required\" }, corsHeaders);\n return;\n }\n // Cap at 500 spans per request to prevent abuse\n const batch = spans.slice(0, 500);\n let queued = 0;\n for (const raw of batch) {\n try {\n // Enforce store_id from auth context, not client-provided\n const resolvedStoreId = await resolveAndValidateStoreId(\n supabase, raw.store_id as string || body.store_id, user, isServiceRole, token, body.userId,\n );\n raw.store_id = resolvedStoreId || raw.store_id || null;\n raw.user_id = raw.user_id || user?.id || body.userId || null;\n raw.user_email = raw.user_email || user?.email || body.userEmail || null;\n queueSpan(auditRowToSpan(raw));\n queued++;\n } catch {\n // Skip malformed spans\n }\n }\n\n // Also upsert ai_conversations row if conversation_id provided\n if (body.conversation_id && body.store_id) {\n try {\n const convStoreId = await resolveAndValidateStoreId(\n supabase, body.store_id, user, isServiceRole, token, body.userId,\n );\n if (convStoreId) {\n await supabase.from(\"ai_conversations\").upsert({\n id: body.conversation_id,\n store_id: convStoreId,\n user_id: user?.id || body.userId || null,\n title: body.conversation_title || \"CLI Session\",\n metadata: {\n source: body.source || \"whale_cli\",\n hostname: body.hostname,\n version: body.version,\n },\n }, { onConflict: \"id\" });\n }\n } catch {\n // Non-critical — spans still ingested\n }\n }\n\n jsonResponse(res, 200, { success: true, queued }, corsHeaders);\n return;\n }\n\n // Agent chat mode (SSE)\n await handleAgentChat(req, res, supabase, body, user, isServiceRole, token, corsHeaders);\n } catch (err) {\n if (!res.headersSent) {\n jsonResponse(res, 500, { error: sanitizeError(err) }, corsHeaders);\n }\n }\n});\n\n// Wire executors into workflow engine (extracted modules — no inline duplicates)\nwireToolExecutor();\nwireAgentExecutor();\nwireBroadcasters();\n\n// Wire both channel and webchat to the same invoker\nsetNodeAgentInvoker(invokeAgentForChannel);\nwebchatAgentInvoker = invokeAgentForChannel;\n\n// Start persistent workflow worker loop (extracted module)\nstartWorkerLoop();\n\n// Initialize shared Supabase client with retry logic before server starts\ninitSupabase(SUPABASE_URL, SUPABASE_SERVICE_ROLE_KEY);\n\nserver.listen(PORT, () => {\n log.info({ port: PORT, supabaseUrl: SUPABASE_URL, runtime: process.version }, \"server listening\");\n\n // Initialize code worker pool for fast code step execution\n try {\n initWorkerPool();\n const stats = getPoolStats();\n log.info({ workers: stats.total }, \"code worker pool initialized\");\n workerPoolReady = true;\n } catch (err: any) {\n log.error({ err: err.message }, \"worker pool init failed\");\n }\n\n // Initialize local agent WebSocket gateway\n try {\n initLocalAgentGateway(server);\n } catch (err: any) {\n log.error({ err: err.message }, \"local-agent gateway init failed\");\n }\n\n // Phase 3: Start pg LISTEN for real-time SSE streaming\n setupPgListen().catch((err) => {\n log.error({ err: err.message }, \"pg-listen setup failed\");\n });\n\n // Phase 4.2: Mark orphaned conversations as resumable\n const serverBootTime = new Date();\n markOrphaned(getServiceClient(), serverBootTime)\n .then((count) => {\n if (count > 0) log.info({ count }, \"orphaned conversations marked resumable\");\n })\n .catch((err) => {\n log.warn({ err: (err as Error).message }, \"markOrphaned failed (table may not exist yet)\");\n });\n});\n\n// ============================================================================\n// GRACEFUL SHUTDOWN\n// ============================================================================\n\nasync function gracefulShutdown(signal: string) {\n log.info({ signal, activeRequests }, \"received shutdown signal, shutting down gracefully\");\n\n // 1. Stop accepting new connections\n server.close(() => {\n log.info(\"HTTP server closed\");\n });\n\n // 2. Clear workflow worker + SSE cleanup intervals\n stopWorkerLoop();\n clearInterval(sseCleanupInterval);\n\n // 3. Close all SSE client connections\n const sseClients = getSseClients();\n for (const [, clients] of sseClients) {\n for (const res of clients) {\n try { res.end(); } catch { /* client already disconnected — benign */ }\n }\n clients.clear();\n }\n sseClients.clear();\n\n // 3b. Flush ClickHouse span buffer before shutdown (prevents data loss on crash)\n try {\n await flushSpans();\n log.info(\"span buffer flushed\");\n } catch (err) { log.error({ err: (err as Error).message }, \"span buffer flush error\"); }\n\n // 4. Shut down code worker pool\n try {\n shutdownPool();\n log.info(\"worker pool shut down\");\n } catch (err) { log.error({ err: (err as Error).message }, \"worker pool shutdown error\"); }\n\n // 4b. Shut down local agent gateway\n try {\n shutdownAgentGateway();\n } catch (err) { log.error({ err: (err as Error).message }, \"agent gateway shutdown error\"); }\n\n // 4c. Shut down rate limiter\n rateLimiter.shutdown();\n\n // 5. Close pg LISTEN connection\n closePgClient();\n\n // 6. Wait for active requests to drain (up to 25 seconds)\n const drainStart = Date.now();\n const drainInterval = setInterval(() => {\n if (activeRequests <= 0 || Date.now() - drainStart > 25_000) {\n clearInterval(drainInterval);\n log.info({ activeRequests }, \"drain complete, exiting\");\n process.exit(activeRequests > 0 ? 1 : 0);\n }\n log.info({ activeRequests }, \"waiting for active requests to drain...\");\n }, 1000);\n\n // 7. Force exit after 30 seconds if graceful shutdown hangs (increased from 10s)\n setTimeout(() => {\n log.fatal({ activeRequests }, \"graceful shutdown timed out after 30s, forcing exit\");\n process.exit(1);\n }, 30_000).unref();\n}\n\nprocess.on(\"SIGTERM\", () => gracefulShutdown(\"SIGTERM\"));\nprocess.on(\"SIGINT\", () => gracefulShutdown(\"SIGINT\"));\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["http","randomUUID","Anthropic","createLogger","log","sanitizeError","handleProxy","handleNodeRoutes","setNodeAgentInvoker","handleTranscribe","handleBillingRoutes","incrementUsage","checkPlanLimits","handleSessionRoutes","generateCompaction","initLocalAgentGateway","shutdownGateway","shutdownAgentGateway","getGatewayStats","initSupabase","getServiceClient","loadCheckpoint","markOrphaned","rateLimiter","sanitizeAndLog","generateOpenApiSpec","generateOpenApiSpecSync","processWorkflowSteps","handleWebhookIngestion","executeInlineChain","initWorkerPool","getPoolStats","shutdownPool","verifyGuestApprovalSignature","loadUserTools","executeTool","flushSpans","queueSpan","auditRowToSpan","safeCompare","getCorsHeaders","jsonResponse","readBody","sendIpRateLimit","resolveAndValidateStoreId","getSseClients","safeSseWrite","sendWorkflowSSE","getTotalSseClients","sseCleanupInterval","MAX_SSE_CLIENTS_PER_RUN","MAX_SSE_TOTAL_CLIENTS","setupPgListen","closePgClient","pgListenReady","handleAgentChat","wireToolExecutor","wireAgentExecutor","wireBroadcasters","invokeAgentForChannel","startWorkerLoop","stopWorkerLoop","getCircuitBreakerStats","process","on","reason","_promise","error","err","fatal","exit","PORT","parseInt","env","SUPABASE_URL","SUPABASE_SERVICE_ROLE_KEY","SERVICE_ROLE_JWT","ANTHROPIC_API_KEY","FLY_INTERNAL_SECRET","console","warn","workerPoolReady","isReady","webchatAgentInvoker","activeRequests","server","createServer","req","res","origin","headers","corsHeaders","method","url","ready","status","agentStats","cbStats","version","npm_package_version","uptime","Math","floor","pg_listen","worker_pool","local_agents","total_agents","circuit_breakers","spec","writeHead","end","JSON","stringify","fallback","URL","host","pathname","match","runId","split","authHeader","authorization","token","startsWith","substring","isInternal","sb","data","user","authUser","authError","auth","getUser","sseRun","from","select","eq","single","membership","store_id","id","sseClients","existingClients","get","size","Connection","run","stepRuns","order","ascending","type","steps","has","set","Set","add","cleanup","clearInterval","heartbeat","clients","delete","setInterval","guestApprovalMatch","clientIp","toString","trim","socket","remoteAddress","stepRunId","urlParams","searchParams","action","expires","sig","Date","guestSupabase","approval","limit","length","isApprove","guestResult","guestErr","rpc","p_approval_id","p_store_id","p_response","p_response_data","guest","p_responded_by","success","message","run_id","webchatCors","webchatMsgMatch","rawBody","channelId","wcBody","parse","content","supabase","channel","planCheck","allowed","senderId","sender_id","conversationId","conversation_id","thirtyMinAgo","now","toISOString","recent","gt","not","msgErr","insert","channel_id","direction","sender_name","content_type","metadata","source","ip","widget_version","agent_id","messages_in","catch","p_channel_id","agentResponse","result","response","outMsg","auto_response","messages_out","agent_invocations","agent_response","webchatHistoryMatch","params","reqConvId","wcChannel","query","test","in","messages","histErr","fs","path","possiblePaths","join","import","meta","dirname","__dirname","cwd","widgetJs","p","readFileSync","resume","billingBody","billingUserId","payload","Buffer","sub","userId","isServiceRole","body","nodeBody","rawToken","handled","resumeMatch","convId","checkpoint","parsedMessages","turn","tokens_used","cost_so_far","tools_used","checkpointed_at","created_at","approvalMatch","approvalId","approvalMembership","response_data","responded_by","waitpointMatch","authToken","wp","expires_at","update","completion_data","completed_at","input","waitpoint_completed","waitpoint_data","step_run_id","webhookMatch","whClientIp","slug","k","v","Object","entries","event_type","idempotency_key","existing","event_id","deduplicated","eventId","fireErr","p_event_type","p_event_payload","p_source","batch_size","workflow_id","wfOwner","wfOwnerErr","p_workflow_id","p_trigger_type","trigger_type","p_trigger_payload","trigger_payload","p_idempotency_key","wf","published_version_id","version_id","info","contentLength","authErr","tier","rateLimitKey","memResult","checkRequest","String","ceil","retryAfterMs","bucket","parseErr","errMsg","Error","bodyLen","tail","slice","detail","body_length","mode","audio_base64","media_type","sid","storeId","compactMessages","system_prompt","Array","isArray","anthropic","apiKey","sanitizedCompactPrompt","compactionResult","systemPrompt","compaction_content","tool_name","args","trace_id","resolvedToolStoreId","validToolStoreId","toolUserId","toolLimit","checkToolLimit","utRows","rows","undefined","email","userEmail","resolvedStreamStoreId","validStreamStoreId","streamToolUserId","streamToolLimit","onToolProgress","_name","progress","write","spans","batch","queued","raw","resolvedStoreId","user_id","user_email","convStoreId","upsert","title","conversation_title","hostname","onConflict","headersSent","listen","port","supabaseUrl","runtime","stats","workers","total","serverBootTime","then","count","gracefulShutdown","signal","close","clear","shutdown","drainStart","drainInterval","setTimeout","unref"],"sources":["../../src/server/index.ts"],"sourcesContent":["// server/index.ts — Unified Node.js agent server for Fly.io\n// All CLI optimizations: prompt caching, retry, loop detection, parallel tools,\n// model-aware context management, cost tracking, compaction block handling\n//\n// Shares agent-core with CLI via src/shared/agent-core.ts\n\nimport http from \"node:http\";\nimport { randomUUID } from \"node:crypto\";\nimport { type SupabaseClient } from \"@supabase/supabase-js\";\nimport Anthropic from \"@anthropic-ai/sdk\";\nimport { createLogger } from \"./lib/logger.js\";\n\nconst log = createLogger(\"server\");\n\nimport {\n sanitizeError,\n} from \"../shared/agent-core.js\";\nimport { handleProxy } from \"./proxy-handlers.js\";\nimport { handleNodeRoutes, setNodeAgentInvoker, type SenderContext } from \"./handlers/nodes.js\";\nimport { handleTranscribe } from \"./handlers/transcription.js\";\nimport { handleBillingRoutes, incrementUsage, checkPlanLimits } from \"./handlers/billing.js\";\nimport { handleSessionRoutes } from \"./handlers/sessions-handlers.js\";\nimport { generateCompaction } from \"./lib/compaction-service.js\";\nimport { initLocalAgentGateway, shutdownGateway as shutdownAgentGateway, getGatewayStats } from \"./local-agent-gateway.js\";\nimport { initSupabase, getServiceClient } from \"./lib/supabase-client.js\";\nimport { loadCheckpoint, markOrphaned } from \"./lib/session-checkpoint.js\";\nimport { rateLimiter } from \"./lib/rate-limiter.js\";\nimport { sanitizeAndLog } from \"./lib/prompt-sanitizer.js\";\nimport { generateOpenApiSpec, generateOpenApiSpecSync } from \"./handlers/api-docs.js\";\n\nimport { processWorkflowSteps, handleWebhookIngestion, executeInlineChain, initWorkerPool, getPoolStats, shutdownPool, verifyGuestApprovalSignature } from \"./handlers/workflows.js\";\nimport {\n loadUserTools,\n executeTool,\n type UserToolRow,\n flushSpans,\n} from \"./tool-router.js\";\nimport { queueSpan, auditRowToSpan } from \"./lib/clickhouse-buffer.js\";\n\n// Extracted modules — single source of truth (no inline duplicates)\nimport { safeCompare, getCorsHeaders, jsonResponse, readBody } from \"./server-helpers.js\";\nimport { sendIpRateLimit } from \"./server-rate-limit.js\";\nimport { resolveAndValidateStoreId } from \"./server-store.js\";\nimport { getSseClients, safeSseWrite, sendWorkflowSSE, getTotalSseClients, sseCleanupInterval, MAX_SSE_CLIENTS_PER_RUN, MAX_SSE_TOTAL_CLIENTS, setupPgListen, closePgClient, pgListenReady } from \"./server-sse.js\";\nimport { handleAgentChat } from \"./server-chat.js\";\nimport { wireToolExecutor, wireAgentExecutor, wireBroadcasters, invokeAgentForChannel } from \"./server-executors.js\";\nimport { startWorkerLoop, stopWorkerLoop } from \"./server-worker.js\";\nimport { getCircuitBreakerStats } from \"./server-store-circuit-breaker.js\";\n\n// ============================================================================\n// PROCESS ERROR HANDLERS\n// ============================================================================\n\nprocess.on(\"unhandledRejection\", (reason, _promise) => {\n log.error({ err: reason }, \"unhandled rejection\");\n});\n\nprocess.on(\"uncaughtException\", (err) => {\n log.fatal({ err }, \"uncaught exception\");\n process.exit(1);\n});\n\n// ============================================================================\n// ENV CONFIG\n// ============================================================================\n\nconst PORT = parseInt(process.env.PORT || \"8080\", 10);\nconst SUPABASE_URL = process.env.SUPABASE_URL!;\nconst SUPABASE_SERVICE_ROLE_KEY = process.env.SUPABASE_SERVICE_ROLE_KEY!;\nconst SERVICE_ROLE_JWT = process.env.SERVICE_ROLE_JWT || \"\";\nconst ANTHROPIC_API_KEY = process.env.ANTHROPIC_API_KEY!;\nconst FLY_INTERNAL_SECRET = process.env.FLY_INTERNAL_SECRET || \"\";\nif (!FLY_INTERNAL_SECRET) {\n console.warn(\"[SECURITY] FLY_INTERNAL_SECRET is not set — internal endpoints are unprotected\");\n}\n\n// ============================================================================\n// READINESS STATE\n// ============================================================================\n\nlet workerPoolReady = false;\n\nfunction isReady(): boolean {\n return workerPoolReady; // PG listen is optional (SSE only)\n}\n\n// Webchat agent invoker — set later to avoid circular deps (same as node agent invoker)\nlet webchatAgentInvoker: ((\n supabase: SupabaseClient,\n agentId: string,\n message: string,\n storeId: string,\n conversationId: string,\n senderContext?: SenderContext,\n) => Promise<{ success: boolean; response?: string; error?: string }>) | null = null;\n\n// ============================================================================\n// HTTP SERVER\n// ============================================================================\n\n// Connection tracking for graceful shutdown draining\nlet activeRequests = 0;\n\nconst server = http.createServer(async (req, res) => {\n activeRequests++;\n res.on(\"close\", () => { activeRequests--; });\n\n const origin = req.headers.origin || \"\";\n const corsHeaders = getCorsHeaders(origin);\n\n // Health check — readiness-aware for Fly.io\n if (req.method === \"GET\" && (req.url === \"/\" || req.url === \"/health\")) {\n const ready = isReady();\n const status = ready ? 200 : 503;\n const agentStats = getGatewayStats();\n const cbStats = getCircuitBreakerStats();\n jsonResponse(res, status, {\n status: ready ? \"ok\" : \"starting\",\n version: process.env.npm_package_version || \"6.4.0\",\n uptime: Math.floor(process.uptime()),\n pg_listen: pgListenReady,\n worker_pool: workerPoolReady,\n local_agents: agentStats.total_agents,\n circuit_breakers: cbStats,\n }, corsHeaders);\n return;\n }\n\n // OpenAPI spec — proxy from gateway, no auth required (for Scalar docs viewer)\n if (req.method === \"GET\" && req.url === \"/openapi.json\") {\n try {\n const spec = await generateOpenApiSpec();\n res.writeHead(200, { ...corsHeaders, \"Content-Type\": \"application/json\", \"Cache-Control\": \"public, max-age=300\" });\n res.end(JSON.stringify(spec));\n } catch {\n // Fall back to cached or minimal spec\n const fallback = generateOpenApiSpecSync();\n res.writeHead(200, { ...corsHeaders, \"Content-Type\": \"application/json\", \"Cache-Control\": \"public, max-age=60\" });\n res.end(JSON.stringify(fallback));\n }\n return;\n }\n\n // CORS preflight\n if (req.method === \"OPTIONS\") {\n res.writeHead(204, corsHeaders);\n res.end();\n return;\n }\n\n const url = new URL(req.url || \"/\", `http://${req.headers.host || \"localhost\"}`);\n const pathname = url.pathname;\n\n // ================================================================\n // Phase 3: SSE stream for workflow run progress\n // GET /workflows/runs/:id/stream\n // ================================================================\n if (req.method === \"GET\" && pathname.match(/^\\/workflows\\/runs\\/[a-f0-9-]+\\/stream$/)) {\n const runId = pathname.split(\"/\")[3];\n\n // Auth check\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n if (!isInternal) {\n const sb = getServiceClient();\n const { data: { user: authUser }, error: authError } = await sb.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n // P1 FIX: Verify user belongs to the run's store (prevent cross-store SSE snooping)\n const { data: sseRun } = await sb.from(\"workflow_runs\")\n .select(\"store_id\").eq(\"id\", runId).single();\n if (sseRun) {\n const { data: membership } = await sb.from(\"store_members\")\n .select(\"id\").eq(\"store_id\", sseRun.store_id).eq(\"user_id\", authUser.id).single();\n if (!membership) {\n jsonResponse(res, 403, { error: \"Not authorized to view this run\" }, corsHeaders);\n return;\n }\n }\n }\n\n // H6 FIX: Enforce per-run and total client limits\n const sseClients = getSseClients();\n const existingClients = sseClients.get(runId)?.size || 0;\n if (existingClients >= MAX_SSE_CLIENTS_PER_RUN) {\n jsonResponse(res, 429, { error: \"Too many SSE clients for this run\" }, corsHeaders);\n return;\n }\n if (getTotalSseClients() >= MAX_SSE_TOTAL_CLIENTS) {\n jsonResponse(res, 429, { error: \"Too many total SSE connections\" }, corsHeaders);\n return;\n }\n\n // Start SSE stream\n res.writeHead(200, {\n \"Content-Type\": \"text/event-stream\",\n \"Cache-Control\": \"no-cache\",\n Connection: \"keep-alive\",\n ...corsHeaders,\n });\n\n // Send snapshot\n const sb = getServiceClient();\n const { data: run } = await sb.from(\"workflow_runs\")\n .select(\"id, workflow_id, status, trigger_type, current_step_key, error_message, error_step_key, started_at, completed_at, duration_ms\")\n .eq(\"id\", runId).single();\n const { data: stepRuns } = await sb.from(\"workflow_step_runs\")\n .select(\"id, step_key, step_type, status, error_message, duration_ms, started_at, completed_at\")\n .eq(\"run_id\", runId).order(\"created_at\", { ascending: true });\n\n sendWorkflowSSE(res, { type: \"snapshot\", run, steps: stepRuns || [] });\n\n // Register client\n if (!sseClients.has(runId)) sseClients.set(runId, new Set());\n sseClients.get(runId)!.add(res);\n\n // Cleanup on disconnect\n const cleanup = () => {\n clearInterval(heartbeat);\n const clients = sseClients.get(runId);\n if (clients) {\n clients.delete(res);\n if (clients.size === 0) sseClients.delete(runId);\n }\n };\n\n // Heartbeat — uses safeSseWrite so dead connections are cleaned up immediately\n const heartbeat = setInterval(() => {\n if (!safeSseWrite(res, `: heartbeat\\n\\n`, cleanup)) {\n clearInterval(heartbeat);\n }\n }, 15_000);\n\n req.on(\"close\", cleanup);\n req.on(\"error\", cleanup);\n return;\n }\n\n // ================================================================\n // Guest approval — signed URL, no auth required (GET)\n // GET /approvals/guest/:id?action=approve&expires=...&sig=...\n // ================================================================\n const guestApprovalMatch = pathname.match(/^\\/approvals\\/guest\\/([a-f0-9-]+)$/);\n if (guestApprovalMatch && req.method === \"GET\") {\n const clientIp = req.headers[\"x-forwarded-for\"]?.toString().split(\",\")[0]?.trim() || req.socket.remoteAddress || \"unknown\";\n if (sendIpRateLimit(res, clientIp, corsHeaders)) return;\n const stepRunId = guestApprovalMatch[1];\n const urlParams = new URL(req.url || \"\", `http://${req.headers.host}`).searchParams;\n const action = urlParams.get(\"action\") || \"\";\n const expires = urlParams.get(\"expires\") || \"\";\n const sig = urlParams.get(\"sig\") || \"\";\n\n if (!action || !expires || !sig) {\n jsonResponse(res, 400, { error: \"Missing action, expires, or sig parameter\" }, corsHeaders);\n return;\n }\n if (new Date(expires) < new Date()) {\n jsonResponse(res, 410, { error: \"This approval link has expired\" }, corsHeaders);\n return;\n }\n if (!verifyGuestApprovalSignature(stepRunId, action, expires, sig)) {\n jsonResponse(res, 403, { error: \"Invalid signature\" }, corsHeaders);\n return;\n }\n\n const guestSupabase = getServiceClient();\n\n const { data: approval } = await guestSupabase.from(\"workflow_approval_requests\")\n .select(\"id, store_id, run_id, status\").eq(\"step_run_id\", stepRunId).limit(1);\n if (!approval?.length) {\n jsonResponse(res, 404, { error: \"Approval not found\" }, corsHeaders);\n return;\n }\n if (approval[0].status !== \"pending\") {\n jsonResponse(res, 409, { error: `Approval already ${approval[0].status}` }, corsHeaders);\n return;\n }\n\n const isApprove = action === \"approve\" || action === \"approved\";\n const { data: guestResult, error: guestErr } = await guestSupabase.rpc(\"respond_to_approval\", {\n p_approval_id: approval[0].id,\n p_store_id: approval[0].store_id,\n p_response: isApprove ? \"approved\" : \"rejected\",\n p_response_data: { guest: true, action },\n p_responded_by: null,\n });\n\n if (guestErr) {\n jsonResponse(res, 500, { success: false, error: guestErr.message }, corsHeaders);\n return;\n }\n\n if (guestResult?.success && approval[0].run_id) {\n try { await executeInlineChain(guestSupabase, approval[0].run_id); } catch (err) { log.error({ err: (err as Error).message, runId: approval[0].run_id }, \"inline chain failed after guest approval\"); }\n }\n\n res.writeHead(200, { \"Content-Type\": \"text/html\", ...corsHeaders });\n res.end(`<!DOCTYPE html><html><body style=\"font-family:system-ui;text-align:center;padding:40px\">\n <h2>${isApprove ? \"Approved\" : \"Rejected\"}</h2>\n <p>Your response has been recorded. You can close this window.</p>\n </body></html>`);\n return;\n }\n\n // ================================================================\n // Webchat — anonymous access for embedded chat widgets\n // POST /webchat/channels/:id/messages — send message (+ agent auto-reply)\n // GET /webchat/channels/:id/history — load conversation history\n // GET /webchat/widget.js — serve compiled widget JS\n // ================================================================\n // Webchat CORS: allow any origin (widget is embedded on customer sites)\n const webchatCors = { ...corsHeaders, \"Access-Control-Allow-Origin\": \"*\" };\n\n const webchatMsgMatch = pathname.match(/^\\/webchat\\/channels\\/([a-f0-9-]+)\\/messages$/);\n if (webchatMsgMatch && req.method === \"POST\") {\n const clientIp = req.headers[\"x-forwarded-for\"]?.toString().split(\",\")[0]?.trim() || req.socket.remoteAddress || \"unknown\";\n if (sendIpRateLimit(res, clientIp, webchatCors)) return;\n\n let rawBody: string;\n try { rawBody = await readBody(req); } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, webchatCors);\n return;\n }\n\n const channelId = webchatMsgMatch[1];\n let wcBody: any;\n try { wcBody = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, webchatCors);\n return;\n }\n\n if (!wcBody.content || typeof wcBody.content !== \"string\") {\n jsonResponse(res, 400, { error: \"content (string) is required\" }, webchatCors);\n return;\n }\n if (wcBody.content.length > 5000) {\n jsonResponse(res, 400, { error: \"Message too long (max 5000 characters)\" }, webchatCors);\n return;\n }\n\n const supabase = getServiceClient();\n\n // Verify channel exists and is a webchat channel\n const { data: channel } = await supabase\n .from(\"channels\")\n .select(\"id, store_id, node_id, agent_id, type, config\")\n .eq(\"id\", channelId)\n .eq(\"type\", \"webchat\")\n .single();\n if (!channel) {\n jsonResponse(res, 404, { error: \"Webchat channel not found\" }, webchatCors);\n return;\n }\n\n // Rate limit per store (best-effort)\n try {\n const planCheck = await checkPlanLimits(supabase, channel.store_id, \"message\");\n if (!planCheck.allowed) {\n jsonResponse(res, 429, { error: planCheck.reason || \"Plan limit reached\" }, webchatCors);\n return;\n }\n } catch { /* billing tables may not exist yet */ }\n\n const senderId = (wcBody.sender_id as string) || \"anonymous\";\n\n // Resolve conversation: reuse if sender had activity < 30 min ago, else new UUID\n let conversationId: string = (wcBody.conversation_id as string) || \"\";\n if (!conversationId) {\n const thirtyMinAgo = new Date(Date.now() - 30 * 60 * 1000).toISOString();\n const { data: recent } = await supabase\n .from(\"channel_messages\")\n .select(\"conversation_id\")\n .eq(\"channel_id\", channelId)\n .eq(\"sender_id\", senderId)\n .gt(\"created_at\", thirtyMinAgo)\n .not(\"conversation_id\", \"is\", null)\n .order(\"created_at\", { ascending: false })\n .limit(1);\n conversationId = (recent?.length && recent[0].conversation_id) || randomUUID();\n }\n\n // Insert inbound message\n const { data: message, error: msgErr } = await supabase\n .from(\"channel_messages\")\n .insert({\n store_id: channel.store_id,\n channel_id: channelId,\n direction: \"inbound\",\n sender_id: senderId,\n sender_name: wcBody.sender_name || \"Visitor\",\n content: wcBody.content,\n content_type: \"text\",\n metadata: { source: \"webchat\", ip: clientIp, widget_version: \"1.0.0\" },\n agent_id: channel.agent_id,\n conversation_id: conversationId,\n })\n .select(\"id, direction, content, conversation_id, created_at\")\n .single();\n\n if (msgErr) {\n jsonResponse(res, 500, { error: msgErr.message }, webchatCors);\n return;\n }\n\n // Track usage + channel stats (best-effort)\n incrementUsage(supabase, channel.store_id, { messages_in: 1 }).catch(() => {});\n try { await supabase.rpc(\"increment_channel_stats\", { p_channel_id: channelId }); } catch { /* ok */ }\n\n // Auto-invoke agent if assigned\n let agentResponse: any = null;\n if (channel.agent_id && webchatAgentInvoker) {\n try {\n const result = await webchatAgentInvoker(supabase, channel.agent_id, wcBody.content, channel.store_id, conversationId);\n if (result.success && result.response) {\n const { data: outMsg } = await supabase\n .from(\"channel_messages\")\n .insert({\n store_id: channel.store_id,\n channel_id: channelId,\n direction: \"outbound\",\n sender_id: \"agent\",\n sender_name: \"AI Agent\",\n content: result.response,\n content_type: \"text\",\n metadata: { agent_id: channel.agent_id, auto_response: true, source: \"webchat\" },\n agent_id: channel.agent_id,\n conversation_id: conversationId,\n })\n .select(\"id, direction, content, conversation_id, created_at\")\n .single();\n agentResponse = outMsg;\n incrementUsage(supabase, channel.store_id, { messages_out: 1, agent_invocations: 1 }).catch(() => {});\n }\n } catch (err) {\n log.error({ err: (err as Error).message }, \"webchat agent error\");\n }\n }\n\n jsonResponse(res, 201, { success: true, message, agent_response: agentResponse, conversation_id: conversationId }, webchatCors);\n return;\n }\n\n // GET /webchat/channels/:id/history — load conversation history for widget\n const webchatHistoryMatch = pathname.match(/^\\/webchat\\/channels\\/([a-f0-9-]+)\\/history$/);\n if (webchatHistoryMatch && req.method === \"GET\") {\n const clientIp = req.headers[\"x-forwarded-for\"]?.toString().split(\",\")[0]?.trim() || req.socket.remoteAddress || \"unknown\";\n if (sendIpRateLimit(res, clientIp, webchatCors)) return;\n\n const channelId = webchatHistoryMatch[1];\n const params = url.searchParams;\n const senderId = params.get(\"sender_id\") || \"\";\n const reqConvId = params.get(\"conversation_id\") || \"\";\n\n if (!senderId) {\n jsonResponse(res, 400, { error: \"sender_id query parameter required\" }, webchatCors);\n return;\n }\n\n const supabase = getServiceClient();\n\n // Verify channel is webchat type\n const { data: wcChannel } = await supabase\n .from(\"channels\")\n .select(\"id, type\")\n .eq(\"id\", channelId)\n .eq(\"type\", \"webchat\")\n .single();\n if (!wcChannel) {\n jsonResponse(res, 404, { error: \"Webchat channel not found\" }, webchatCors);\n return;\n }\n\n // Get messages — by conversation_id if available, or by sender\n // P0 FIX: Always filter by sender_id to prevent cross-sender data leak\n let query = supabase\n .from(\"channel_messages\")\n .select(\"id, direction, sender_id, sender_name, content, content_type, created_at\")\n .eq(\"channel_id\", channelId);\n\n // P0 FIX: Validate senderId against strict pattern to prevent PostgREST filter injection\n // Only allow alphanumeric characters, hyphens, and underscores (blocks .eq., .neq., dots, etc.)\n if (!/^[a-zA-Z0-9_-]+$/.test(senderId)) {\n jsonResponse(res, 400, { error: \"Invalid sender_id format\" }, webchatCors);\n return;\n }\n if (reqConvId) {\n // P0 FIX: Use parameterized .in() filter instead of string interpolation in .or()\n query = query.eq(\"conversation_id\", reqConvId)\n .in(\"sender_id\", [senderId, \"agent\"]);\n } else {\n query = query.in(\"sender_id\", [senderId, \"agent\"]);\n }\n\n const { data: messages, error: histErr } = await query\n .order(\"created_at\", { ascending: true })\n .limit(50);\n\n if (histErr) {\n jsonResponse(res, 500, { error: histErr.message }, webchatCors);\n return;\n }\n\n jsonResponse(res, 200, { success: true, messages: messages || [] }, webchatCors);\n return;\n }\n\n // GET /webchat/widget.js — serve compiled widget JavaScript\n if (pathname === \"/webchat/widget.js\" && req.method === \"GET\") {\n const fs = await import(\"node:fs\");\n const path = await import(\"node:path\");\n // Try multiple possible locations for the built widget file\n const possiblePaths = [\n path.join(import.meta.dirname || __dirname, \"../../dist/webchat/widget.js\"),\n path.join(import.meta.dirname || __dirname, \"../../../dist/webchat/widget.js\"),\n path.join(process.cwd(), \"dist/webchat/widget.js\"),\n ];\n\n let widgetJs: string | null = null;\n for (const p of possiblePaths) {\n try {\n widgetJs = fs.readFileSync(p, \"utf-8\");\n break;\n } catch { /* try next */ }\n }\n\n if (widgetJs) {\n res.writeHead(200, {\n \"Content-Type\": \"application/javascript\",\n \"Cache-Control\": \"public, max-age=3600\",\n ...webchatCors,\n });\n res.end(widgetJs);\n } else {\n res.writeHead(200, {\n \"Content-Type\": \"application/javascript\",\n ...webchatCors,\n });\n res.end('console.warn(\"[WhaleChat] Widget JS not built. Run: npx esbuild src/webchat/widget.ts --bundle --minify --outfile=dist/webchat/widget.js\");');\n }\n return;\n }\n\n // ================================================================\n // Billing & Usage routes\n // ================================================================\n if (pathname.startsWith(\"/usage\") || pathname.startsWith(\"/billing/\")) {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n if (!token) {\n req.resume();\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n let rawBody: string;\n try { rawBody = await readBody(req); } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let billingBody: any = null;\n try { if (rawBody) billingBody = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n const supabase = getServiceClient();\n // Extract userId from JWT for checkout/portal endpoints\n let billingUserId: string | undefined;\n try {\n const payload = JSON.parse(Buffer.from(token.split(\".\")[1], \"base64url\").toString());\n billingUserId = payload.sub;\n } catch { /* not a JWT — service role key */ }\n const result = await handleBillingRoutes(pathname, req.method || \"GET\", billingBody, supabase, {\n userId: billingUserId,\n isServiceRole: safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT),\n });\n\n if (result) {\n jsonResponse(res, result.status, result.body, corsHeaders);\n } else {\n jsonResponse(res, 404, { error: `No route: ${req.method} ${pathname}` }, corsHeaders);\n }\n return;\n }\n\n // ================================================================\n // Node & Channel management routes (supports GET, POST, PUT, DELETE)\n // Must be before the method gate since GET /channels/:id/messages is valid\n // ================================================================\n if (pathname.startsWith(\"/nodes\") || pathname.startsWith(\"/channels\")) {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n if (!token) {\n req.resume();\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let nodeBody: any = null;\n try { if (rawBody) nodeBody = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n const supabase = getServiceClient();\n\n let userId: string | undefined;\n const isServiceRole = safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n if (!isServiceRole) {\n const { data: { user: authUser } } = await supabase.auth.getUser(token);\n if (authUser) userId = authUser.id;\n }\n\n const result = await handleNodeRoutes(pathname, req.method || \"GET\", nodeBody, supabase, {\n userId,\n isServiceRole,\n rawToken: token,\n }, url.searchParams);\n\n if (result) {\n jsonResponse(res, result.status, result.body, corsHeaders);\n } else {\n jsonResponse(res, 404, { error: `No route: ${req.method} ${pathname}` }, corsHeaders);\n }\n return;\n }\n\n // ================================================================\n // Session API routes (supports GET, POST)\n // Must be before the method gate since GET /sessions is valid\n // ================================================================\n if (pathname.startsWith(\"/sessions\")) {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n if (!token) {\n req.resume();\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n const supabase = getServiceClient();\n let userId: string | undefined;\n const isServiceRole = safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n if (!isServiceRole) {\n const { data: { user: authUser } } = await supabase.auth.getUser(token);\n if (authUser) userId = authUser.id;\n }\n const handled = await handleSessionRoutes(req, res, pathname, url, corsHeaders, supabase, {\n userId,\n isServiceRole,\n });\n if (!handled) {\n jsonResponse(res, 404, { error: `No route: ${req.method} ${pathname}` }, corsHeaders);\n }\n return;\n }\n\n if (req.method !== \"POST\" && req.method !== \"DELETE\" && req.method !== \"PUT\") {\n jsonResponse(res, 405, { error: \"Method not allowed\" }, corsHeaders);\n return;\n }\n\n try {\n // ================================================================\n // Phase 4.2: Resume conversation from checkpoint\n // POST /conversations/:id/resume\n // ================================================================\n const resumeMatch = pathname.match(/^\\/conversations\\/([a-f0-9-]+)\\/resume$/);\n if (resumeMatch && req.method === \"POST\") {\n const convId = resumeMatch[1];\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n\n if (!isInternal) {\n const { data: { user: authUser }, error: authError } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n }\n\n // Drain the request body (even if we don't use it) to prevent Fly proxy stalls\n try { await readBody(req); } catch { /* body not needed */ }\n\n const checkpoint = await loadCheckpoint(supabase, convId);\n if (!checkpoint) {\n jsonResponse(res, 404, { error: \"No checkpoint found for this conversation\" }, corsHeaders);\n return;\n }\n\n // Parse messages back from serialized form\n let parsedMessages: unknown[];\n try {\n parsedMessages = JSON.parse(checkpoint.messages);\n } catch {\n jsonResponse(res, 422, { error: \"Checkpoint messages corrupted\" }, corsHeaders);\n return;\n }\n\n jsonResponse(res, 200, {\n success: true,\n conversation_id: checkpoint.conversation_id,\n turn: checkpoint.turn,\n messages: parsedMessages,\n tokens_used: checkpoint.tokens_used,\n cost_so_far: checkpoint.cost_so_far,\n tools_used: checkpoint.tools_used,\n checkpointed_at: checkpoint.created_at,\n }, corsHeaders);\n return;\n }\n\n // ================================================================\n // Phase 2: Approval response endpoint\n // POST /approvals/:id/respond\n // ================================================================\n const approvalMatch = pathname.match(/^\\/approvals\\/([a-f0-9-]+)\\/respond$/);\n if (approvalMatch) {\n const approvalId = approvalMatch[1];\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n let userId: string | null = null;\n\n if (!isInternal) {\n const { data: { user: authUser }, error: authError } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n userId = authUser.id;\n }\n\n let rawBody: string;\n try { rawBody = await readBody(req); } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let body: any;\n try { body = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n if (!body.status) {\n jsonResponse(res, 400, { error: \"status required (approved/rejected)\" }, corsHeaders);\n return;\n }\n\n // Get store_id from approval\n const { data: approval } = await supabase.from(\"workflow_approval_requests\")\n .select(\"store_id, run_id\").eq(\"id\", approvalId).single();\n if (!approval) {\n jsonResponse(res, 404, { error: \"Approval not found\" }, corsHeaders);\n return;\n }\n\n // P1 FIX: Verify user has access to the approval's store\n if (!isInternal && userId) {\n const { data: approvalMembership } = await supabase.from(\"store_members\")\n .select(\"id\").eq(\"store_id\", approval.store_id).eq(\"user_id\", userId).single();\n if (!approvalMembership) {\n jsonResponse(res, 403, { error: \"Not authorized to respond to this approval\" }, corsHeaders);\n return;\n }\n }\n\n const { data: result, error } = await supabase.rpc(\"respond_to_approval\", {\n p_approval_id: approvalId,\n p_store_id: approval.store_id,\n p_response: body.status,\n p_response_data: body.response_data || {},\n p_responded_by: userId || body.responded_by || null,\n });\n\n if (error) {\n jsonResponse(res, 500, { success: false, error: error.message }, corsHeaders);\n return;\n }\n\n // Inline resume — execute next step immediately\n if (result?.success && approval.run_id) {\n try {\n await executeInlineChain(supabase, approval.run_id);\n } catch (err) {\n log.error({ err: (err as Error).message }, \"inline chain failed after approval\");\n }\n }\n\n jsonResponse(res, result?.success ? 200 : 422, result, corsHeaders);\n return;\n }\n\n // ================================================================\n // Waitpoint completion — API endpoint\n // POST /waitpoints/:token/complete\n // ================================================================\n const waitpointMatch = pathname.match(/^\\/waitpoints\\/([a-f0-9-]+)\\/complete$/);\n if (waitpointMatch) {\n const token = waitpointMatch[1];\n const authHeader = req.headers.authorization;\n const authToken = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(authToken, FLY_INTERNAL_SECRET) || safeCompare(authToken, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(authToken, SERVICE_ROLE_JWT);\n\n if (!isInternal && !authToken) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n\n let rawBody: string;\n try { rawBody = await readBody(req); } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n let body: any;\n try { body = JSON.parse(rawBody || \"{}\"); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n\n // Find waitpoint\n const { data: wp } = await supabase.from(\"waitpoint_tokens\")\n .select(\"id, run_id, step_run_id, store_id, expires_at, status\")\n .eq(\"token\", token).single();\n if (!wp) {\n jsonResponse(res, 404, { error: \"Waitpoint token not found\" }, corsHeaders);\n return;\n }\n if (wp.status === \"completed\") {\n jsonResponse(res, 409, { error: \"Waitpoint already completed\" }, corsHeaders);\n return;\n }\n if (new Date(wp.expires_at) < new Date()) {\n jsonResponse(res, 410, { error: \"Waitpoint expired\" }, corsHeaders);\n return;\n }\n\n // Complete it\n await supabase.from(\"waitpoint_tokens\").update({\n status: \"completed\", completion_data: body.data || {}, completed_at: new Date().toISOString(),\n }).eq(\"id\", wp.id);\n\n await supabase.from(\"workflow_step_runs\").update({\n status: \"pending\", input: { waitpoint_completed: true, waitpoint_data: body.data || {} },\n }).eq(\"id\", wp.step_run_id).eq(\"status\", \"waiting\");\n\n // Inline resume\n try { await executeInlineChain(supabase, wp.run_id); } catch (err) { log.error({ err: (err as Error).message, runId: wp.run_id }, \"inline chain failed after waitpoint\"); }\n\n jsonResponse(res, 200, { success: true, run_id: wp.run_id }, corsHeaders);\n return;\n }\n\n // ================================================================\n // Webhook ingestion — no auth required (uses HMAC verification)\n // POST /webhooks/:slug\n // ================================================================\n const webhookMatch = pathname.match(/^\\/webhooks\\/([a-zA-Z0-9_-]+)$/);\n if (webhookMatch) {\n const whClientIp = req.headers[\"x-forwarded-for\"]?.toString().split(\",\")[0]?.trim() || req.socket.remoteAddress || \"unknown\";\n if (sendIpRateLimit(res, whClientIp, corsHeaders)) return;\n const slug = webhookMatch[1];\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n const headers: Record<string, string> = {};\n for (const [k, v] of Object.entries(req.headers)) {\n if (typeof v === \"string\") headers[k] = v;\n }\n\n const result = await handleWebhookIngestion(supabase, slug, rawBody, headers);\n\n // Phase 1: Inline execution for webhook-triggered workflows\n if (result.body.run_id && result.status === 200) {\n try {\n await executeInlineChain(supabase, result.body.run_id as string);\n } catch (err) {\n log.error({ err: (err as Error).message }, \"webhook inline chain error\");\n }\n }\n\n jsonResponse(res, result.status, result.body, corsHeaders);\n return;\n }\n\n // ================================================================\n // Fire event — service-role or internal auth\n // POST /events\n // ================================================================\n if (pathname === \"/events\") {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n\n // Verify user auth if not internal\n if (!isInternal) {\n const { data: { user: authUser }, error: authError } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n }\n\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let body: any;\n try { body = JSON.parse(rawBody || \"{}\"); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n if (!body.store_id || !body.event_type) {\n jsonResponse(res, 400, { error: \"store_id and event_type required\" }, corsHeaders);\n return;\n }\n\n // Idempotency: if client provides idempotency_key, check for duplicate\n if (body.idempotency_key) {\n const { data: existing } = await supabase.from(\"workflow_events\")\n .select(\"id\")\n .eq(\"idempotency_key\", body.idempotency_key)\n .limit(1);\n if (existing && existing.length > 0) {\n jsonResponse(res, 200, { success: true, event_id: existing[0].id, deduplicated: true }, corsHeaders);\n return;\n }\n }\n\n const { data: eventId, error: fireErr } = await supabase.rpc(\"fire_event\", {\n p_store_id: body.store_id,\n p_event_type: body.event_type,\n p_event_payload: body.payload || {},\n p_source: body.source || \"api\",\n });\n\n if (fireErr) {\n jsonResponse(res, 500, { success: false, error: fireErr.message }, corsHeaders);\n } else {\n jsonResponse(res, 200, { success: true, event_id: eventId }, corsHeaders);\n }\n return;\n }\n\n // ================================================================\n // Internal workflow processing — verified by internal secret\n // POST /workflows/process\n // ================================================================\n if (pathname === \"/workflows/process\") {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n if (!FLY_INTERNAL_SECRET || (!safeCompare(token, FLY_INTERNAL_SECRET) && !safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) && !safeCompare(token, SERVICE_ROLE_JWT))) {\n jsonResponse(res, 401, { error: \"Unauthorized\" }, corsHeaders);\n return;\n }\n\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n rawBody = \"{}\";\n }\n\n let body: any;\n try { body = JSON.parse(rawBody || \"{}\"); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n const supabase = getServiceClient();\n const result = await processWorkflowSteps(supabase, body.batch_size || 10);\n jsonResponse(res, 200, { success: true, ...result }, corsHeaders);\n return;\n }\n\n // ================================================================\n // Start workflow run — service-role or user auth\n // POST /workflows/start\n // ================================================================\n if (pathname === \"/workflows/start\") {\n const authHeader = req.headers.authorization;\n const token = authHeader?.startsWith(\"Bearer \") ? authHeader.substring(7) : \"\";\n const isInternal = safeCompare(token, FLY_INTERNAL_SECRET) || safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isInternal && !token) {\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n const supabase = getServiceClient();\n\n // Verify user auth if not internal\n if (!isInternal) {\n const { data: { user: authUser }, error: authError } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n }\n\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large\" }, corsHeaders);\n return;\n }\n\n let body: any;\n try { body = JSON.parse(rawBody); } catch {\n jsonResponse(res, 400, { error: \"Invalid JSON\" }, corsHeaders);\n return;\n }\n\n // P0 FIX: Verify the workflow belongs to the requesting store before starting a run\n if (body.workflow_id && body.store_id) {\n const { data: wfOwner, error: wfOwnerErr } = await supabase\n .from(\"workflows\")\n .select(\"id\")\n .eq(\"id\", body.workflow_id)\n .eq(\"store_id\", body.store_id)\n .single();\n if (wfOwnerErr || !wfOwner) {\n jsonResponse(res, 403, { error: \"Workflow does not belong to this store\" }, corsHeaders);\n return;\n }\n }\n\n const { data, error } = await supabase.rpc(\"start_workflow_run\", {\n p_workflow_id: body.workflow_id,\n p_store_id: body.store_id,\n p_trigger_type: body.trigger_type || \"api\",\n p_trigger_payload: body.trigger_payload || {},\n p_idempotency_key: body.idempotency_key || null,\n });\n\n if (error) {\n jsonResponse(res, 500, { success: false, error: error.message }, corsHeaders);\n } else {\n // Phase 4: Set version_id if workflow has a published version\n // Phase 1: Inline execution for API-triggered workflows\n if (data?.success && data.run_id && !data.deduplicated) {\n try {\n const { data: wf } = await supabase.from(\"workflows\")\n .select(\"published_version_id\").eq(\"id\", body.workflow_id).single();\n if (wf?.published_version_id) {\n await supabase.from(\"workflow_runs\").update({ version_id: wf.published_version_id }).eq(\"id\", data.run_id);\n }\n await executeInlineChain(supabase, data.run_id);\n } catch (err) {\n log.error({ err: (err as Error).message }, \"start-inline chain error\");\n }\n }\n jsonResponse(res, data?.success ? 200 : 422, data, corsHeaders);\n }\n return;\n }\n\n // ================================================================\n // Standard auth gate for all other POST routes\n // ================================================================\n log.info({ method: req.method, path: pathname, contentLength: req.headers[\"content-length\"] || \"?\" }, \"request\");\n const authHeader = req.headers.authorization;\n if (!authHeader?.startsWith(\"Bearer \")) {\n req.resume(); // drain body to avoid Fly proxy stall\n jsonResponse(res, 401, { error: \"Missing authorization\" }, corsHeaders);\n return;\n }\n\n // Read body FIRST — before async auth calls (getUser, rate_limit).\n // Node.js request streams are paused until consumed. If we do async network\n // calls before reading, the TCP receive buffer fills up and Fly's proxy\n // stalls with \"error writing a body to connection\" on large requests.\n let rawBody: string;\n try {\n rawBody = await readBody(req);\n } catch {\n jsonResponse(res, 413, { error: \"Request body too large (max 500MB)\" }, corsHeaders);\n return;\n }\n\n const token = authHeader.substring(7);\n const supabase = getServiceClient();\n\n // Check service-role key\n let user: { id: string; email?: string } | null = null;\n const isServiceRole = safeCompare(token, SUPABASE_SERVICE_ROLE_KEY) || safeCompare(token, SERVICE_ROLE_JWT);\n\n if (!isServiceRole) {\n try {\n const {\n data: { user: authUser },\n error: authError,\n } = await supabase.auth.getUser(token);\n if (authError || !authUser) {\n jsonResponse(res, 401, { error: \"Invalid or expired token\" }, corsHeaders);\n return;\n }\n user = authUser;\n } catch (authErr) {\n log.error({ err: (authErr as Error).message }, \"auth getUser failed\");\n jsonResponse(res, 502, { error: \"Auth service unavailable, please retry\" }, corsHeaders);\n return;\n }\n }\n\n // In-memory token-bucket rate limiting (sole rate check — no DB round-trip)\n {\n const tier = isServiceRole ? \"serviceRole\" as const : user ? \"authenticated\" as const : \"unauthenticated\" as const;\n const rateLimitKey = user ? `user:${user.id}` : `ip:${req.socket.remoteAddress || \"unknown\"}`;\n const memResult = rateLimiter.checkRequest(rateLimitKey, tier);\n if (!memResult.allowed) {\n res.writeHead(429, {\n \"Retry-After\": String(Math.ceil(memResult.retryAfterMs / 1000)),\n \"X-RateLimit-Remaining\": \"0\",\n \"X-RateLimit-Bucket\": memResult.bucket,\n \"Content-Type\": \"application/json\",\n ...corsHeaders,\n });\n res.end(JSON.stringify({ error: \"Rate limit exceeded\" }));\n return;\n }\n }\n\n let body: any;\n try {\n body = JSON.parse(rawBody);\n } catch (parseErr) {\n const errMsg = parseErr instanceof Error ? parseErr.message : String(parseErr);\n const bodyLen = rawBody.length;\n const tail = bodyLen > 200 ? rawBody.slice(bodyLen - 200) : rawBody;\n log.error({ bodyLen, errMsg, tail }, \"JSON parse failed on request body\");\n jsonResponse(res, 400, {\n error: \"Invalid JSON in request body\",\n detail: errMsg,\n body_length: bodyLen,\n }, corsHeaders);\n return;\n }\n\n // Anthropic API proxy mode\n if (body.mode === \"proxy\") {\n await handleProxy(res, body, corsHeaders);\n return;\n }\n\n // Audio transcription mode (OpenAI Whisper)\n if (body.mode === \"transcribe\") {\n const { audio_base64, media_type, store_id } = body;\n if (!audio_base64 || !media_type) {\n jsonResponse(res, 400, { error: \"audio_base64 and media_type required\" }, corsHeaders);\n return;\n }\n const sid = store_id || body.storeId;\n if (!sid) {\n jsonResponse(res, 400, { error: \"store_id required for transcription (needed to resolve OpenAI API key)\" }, corsHeaders);\n return;\n }\n const result = await handleTranscribe(supabase, sid, audio_base64, media_type);\n jsonResponse(res, result.success ? 200 : 422, result, corsHeaders);\n return;\n }\n\n // Conversation compaction mode (Haiku summarization for non-Anthropic providers)\n if (body.mode === \"compact\") {\n const { messages: compactMessages, system_prompt } = body;\n if (!compactMessages || !Array.isArray(compactMessages) || !system_prompt) {\n jsonResponse(res, 400, { error: \"messages (array) and system_prompt required\" }, corsHeaders);\n return;\n }\n const anthropic = new Anthropic({ apiKey: ANTHROPIC_API_KEY });\n // Sanitize user-provided system prompt before passing to compaction\n const sanitizedCompactPrompt = sanitizeAndLog(system_prompt, \"compactionEndpoint\");\n const compactionResult = await generateCompaction({\n anthropic,\n messages: compactMessages,\n systemPrompt: sanitizedCompactPrompt,\n });\n jsonResponse(\n res,\n compactionResult.success ? 200 : 422,\n {\n success: compactionResult.success,\n compaction_content: compactionResult.content,\n error: compactionResult.error,\n },\n corsHeaders,\n );\n return;\n }\n\n // Direct tool execution mode\n if (body.mode === \"tool\") {\n const { tool_name, args, store_id, conversation_id, trace_id } = body;\n if (!tool_name) {\n jsonResponse(res, 400, { error: \"tool_name required\" }, corsHeaders);\n return;\n }\n\n // Resolve and validate store_id (server-derived, not blindly trusted)\n const resolvedToolStoreId = await resolveAndValidateStoreId(\n supabase, store_id || body.storeId, user, isServiceRole, token, body.userId\n );\n if (!resolvedToolStoreId && !isServiceRole) {\n jsonResponse(res, 400, { error: \"store_id required for tool execution\" }, corsHeaders);\n return;\n }\n const validToolStoreId = resolvedToolStoreId || store_id;\n\n // Phase 7.2: Per-tool rate limiting\n const toolUserId = user?.id || body.userId || \"anon\";\n const toolLimit = rateLimiter.checkToolLimit(toolUserId, tool_name);\n if (!toolLimit.allowed) {\n res.writeHead(429, {\n \"Retry-After\": String(Math.ceil(toolLimit.retryAfterMs / 1000)),\n \"X-RateLimit-Remaining\": \"0\",\n \"X-RateLimit-Bucket\": toolLimit.bucket,\n \"Content-Type\": \"application/json\",\n ...corsHeaders,\n });\n res.end(JSON.stringify({ error: `Tool rate limit exceeded for ${tool_name}` }));\n return;\n }\n // Load user tools if this is a user_tool__ prefixed call\n let utRows: UserToolRow[] | undefined;\n if (tool_name.startsWith(\"user_tool__\") && validToolStoreId) {\n const { rows } = await loadUserTools(supabase, validToolStoreId);\n utRows = rows;\n }\n const result = await executeTool(\n supabase,\n tool_name,\n (args || {}) as Record<string, unknown>,\n validToolStoreId || undefined,\n trace_id || undefined,\n user?.id || body.userId || null,\n user?.email || body.userEmail || null,\n body.source || \"whale-code\",\n conversation_id || undefined,\n utRows,\n );\n // Always 200 for tool results — success/failure is in the JSON body.\n // HTTP 500 causes MCP clients to throw before reading the error message.\n jsonResponse(res, 200, result, corsHeaders);\n return;\n }\n\n // Streaming tool execution mode (NDJSON) — for tools with live progress (kali, etc.)\n if (body.mode === \"tool_stream\") {\n const { tool_name, args, store_id } = body;\n if (!tool_name) {\n jsonResponse(res, 400, { error: \"tool_name required\" }, corsHeaders);\n return;\n }\n\n // Resolve and validate store_id\n const resolvedStreamStoreId = await resolveAndValidateStoreId(\n supabase, store_id || body.storeId, user, isServiceRole, token, body.userId\n );\n if (!resolvedStreamStoreId && !isServiceRole) {\n jsonResponse(res, 400, { error: \"store_id required for tool execution\" }, corsHeaders);\n return;\n }\n const validStreamStoreId = resolvedStreamStoreId || store_id;\n\n // Phase 7.2: Per-tool rate limiting (stream mode)\n const streamToolUserId = user?.id || body.userId || \"anon\";\n const streamToolLimit = rateLimiter.checkToolLimit(streamToolUserId, tool_name);\n if (!streamToolLimit.allowed) {\n res.writeHead(429, {\n \"Retry-After\": String(Math.ceil(streamToolLimit.retryAfterMs / 1000)),\n \"X-RateLimit-Remaining\": \"0\",\n \"X-RateLimit-Bucket\": streamToolLimit.bucket,\n \"Content-Type\": \"application/json\",\n ...corsHeaders,\n });\n res.end(JSON.stringify({ error: `Tool rate limit exceeded for ${tool_name}` }));\n return;\n }\n\n res.writeHead(200, {\n \"Content-Type\": \"application/x-ndjson\",\n \"Transfer-Encoding\": \"chunked\",\n ...corsHeaders,\n });\n\n const onToolProgress = (_name: string, progress: unknown) => {\n try {\n // Structured status events from kali — relay as type \"status\" for CLI ToolProgress handling\n const p = progress as Record<string, unknown>;\n if (p && p.type === \"status\" && p.progress) {\n res.write(JSON.stringify({ type: \"status\", progress: p.progress }) + \"\\n\");\n } else {\n res.write(JSON.stringify({ type: \"progress\", progress }) + \"\\n\");\n }\n } catch { /* client disconnected */ }\n };\n\n try {\n const result = await executeTool(\n supabase,\n tool_name,\n (args || {}) as Record<string, unknown>,\n validStreamStoreId || undefined,\n body.trace_id || undefined,\n user?.id || body.userId || null,\n user?.email || body.userEmail || null,\n body.source || \"whale-code-stream\",\n body.conversation_id || undefined,\n undefined,\n undefined,\n onToolProgress,\n );\n\n res.write(JSON.stringify({ type: \"result\", ...result }) + \"\\n\");\n } catch (err) {\n res.write(JSON.stringify({ type: \"result\", success: false, error: sanitizeError(err) }) + \"\\n\");\n }\n\n res.end();\n return;\n }\n\n // CLI telemetry ingest — batch of spans from Whale Code CLI\n if (body.mode === \"telemetry_ingest\") {\n const spans: Record<string, unknown>[] = body.spans;\n if (!Array.isArray(spans) || spans.length === 0) {\n jsonResponse(res, 400, { error: \"spans array required\" }, corsHeaders);\n return;\n }\n // Cap at 500 spans per request to prevent abuse\n const batch = spans.slice(0, 500);\n let queued = 0;\n for (const raw of batch) {\n try {\n // Enforce store_id from auth context, not client-provided\n const resolvedStoreId = await resolveAndValidateStoreId(\n supabase, raw.store_id as string || body.store_id, user, isServiceRole, token, body.userId,\n );\n raw.store_id = resolvedStoreId || raw.store_id || null;\n raw.user_id = raw.user_id || user?.id || body.userId || null;\n raw.user_email = raw.user_email || user?.email || body.userEmail || null;\n queueSpan(auditRowToSpan(raw));\n queued++;\n } catch {\n // Skip malformed spans\n }\n }\n\n // Also upsert ai_conversations row if conversation_id provided\n if (body.conversation_id && body.store_id) {\n try {\n const convStoreId = await resolveAndValidateStoreId(\n supabase, body.store_id, user, isServiceRole, token, body.userId,\n );\n if (convStoreId) {\n await supabase.from(\"ai_conversations\").upsert({\n id: body.conversation_id,\n store_id: convStoreId,\n user_id: user?.id || body.userId || null,\n title: body.conversation_title || \"CLI Session\",\n metadata: {\n source: body.source || \"whale_cli\",\n hostname: body.hostname,\n version: body.version,\n },\n }, { onConflict: \"id\" });\n }\n } catch {\n // Non-critical — spans still ingested\n }\n }\n\n jsonResponse(res, 200, { success: true, queued }, corsHeaders);\n return;\n }\n\n // Agent chat mode (SSE)\n await handleAgentChat(req, res, supabase, body, user, isServiceRole, token, corsHeaders);\n } catch (err) {\n if (!res.headersSent) {\n jsonResponse(res, 500, { error: sanitizeError(err) }, corsHeaders);\n }\n }\n});\n\n// Wire executors into workflow engine (extracted modules — no inline duplicates)\nwireToolExecutor();\nwireAgentExecutor();\nwireBroadcasters();\n\n// Wire both channel and webchat to the same invoker\nsetNodeAgentInvoker(invokeAgentForChannel);\nwebchatAgentInvoker = invokeAgentForChannel;\n\n// Start persistent workflow worker loop (extracted module)\nstartWorkerLoop();\n\n// Initialize shared Supabase client with retry logic before server starts\ninitSupabase(SUPABASE_URL, SUPABASE_SERVICE_ROLE_KEY);\n\nserver.listen(PORT, () => {\n log.info({ port: PORT, supabaseUrl: SUPABASE_URL, runtime: process.version }, \"server listening\");\n\n // Initialize code worker pool for fast code step execution\n try {\n initWorkerPool();\n const stats = getPoolStats();\n log.info({ workers: stats.total }, \"code worker pool initialized\");\n workerPoolReady = true;\n } catch (err: any) {\n log.error({ err: err.message }, \"worker pool init failed\");\n }\n\n // Initialize local agent WebSocket gateway\n try {\n initLocalAgentGateway(server);\n } catch (err: any) {\n log.error({ err: err.message }, \"local-agent gateway init failed\");\n }\n\n // Phase 3: Start pg LISTEN for real-time SSE streaming\n setupPgListen().catch((err) => {\n log.error({ err: err.message }, \"pg-listen setup failed\");\n });\n\n // Phase 4.2: Mark orphaned conversations as resumable\n const serverBootTime = new Date();\n markOrphaned(getServiceClient(), serverBootTime)\n .then((count) => {\n if (count > 0) log.info({ count }, \"orphaned conversations marked resumable\");\n })\n .catch((err) => {\n log.warn({ err: (err as Error).message }, \"markOrphaned failed (table may not exist yet)\");\n });\n});\n\n// ============================================================================\n// GRACEFUL SHUTDOWN\n// ============================================================================\n\nasync function gracefulShutdown(signal: string) {\n log.info({ signal, activeRequests }, \"received shutdown signal, shutting down gracefully\");\n\n // 1. Stop accepting new connections\n server.close(() => {\n log.info(\"HTTP server closed\");\n });\n\n // 2. Clear workflow worker + SSE cleanup intervals\n stopWorkerLoop();\n clearInterval(sseCleanupInterval);\n\n // 3. Close all SSE client connections\n const sseClients = getSseClients();\n for (const [, clients] of sseClients) {\n for (const res of clients) {\n try { res.end(); } catch { /* client already disconnected — benign */ }\n }\n clients.clear();\n }\n sseClients.clear();\n\n // 3b. Flush ClickHouse span buffer before shutdown (prevents data loss on crash)\n try {\n await flushSpans();\n log.info(\"span buffer flushed\");\n } catch (err) { log.error({ err: (err as Error).message }, \"span buffer flush error\"); }\n\n // 4. Shut down code worker pool\n try {\n shutdownPool();\n log.info(\"worker pool shut down\");\n } catch (err) { log.error({ err: (err as Error).message }, \"worker pool shutdown error\"); }\n\n // 4b. Shut down local agent gateway\n try {\n shutdownAgentGateway();\n } catch (err) { log.error({ err: (err as Error).message }, \"agent gateway shutdown error\"); }\n\n // 4c. Shut down rate limiter\n rateLimiter.shutdown();\n\n // 5. Close pg LISTEN connection\n closePgClient();\n\n // 6. Wait for active requests to drain (up to 25 seconds)\n const drainStart = Date.now();\n const drainInterval = setInterval(() => {\n if (activeRequests <= 0 || Date.now() - drainStart > 25_000) {\n clearInterval(drainInterval);\n log.info({ activeRequests }, \"drain complete, exiting\");\n process.exit(activeRequests > 0 ? 1 : 0);\n }\n log.info({ activeRequests }, \"waiting for active requests to drain...\");\n }, 1000);\n\n // 7. Force exit after 30 seconds if graceful shutdown hangs (increased from 10s)\n setTimeout(() => {\n log.fatal({ activeRequests }, \"graceful shutdown timed out after 30s, forcing exit\");\n process.exit(1);\n }, 30_000).unref();\n}\n\nprocess.on(\"SIGTERM\", () => gracefulShutdown(\"SIGTERM\"));\nprocess.on(\"SIGINT\", () => gracefulShutdown(\"SIGINT\"));\n"],"mappings":"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","ignoreList":[]}