@nlabs/lex 1.51.7 → 1.52.1

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.
@@ -653,4 +653,4 @@ export const serverless = async (cmd, callback = ()=>({}))=>{
653
653
  }
654
654
  };
655
655
 
656
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/serverless/serverless.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport express from 'express';\nimport {readFileSync, existsSync, mkdirSync, writeFileSync} from 'fs';\nimport {homedir} from 'os';\nimport {resolve as pathResolve, join} from 'path';\nimport {WebSocketServer} from 'ws';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, removeFiles} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface ServerlessOptions {\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly host?: string;\n  readonly httpPort?: number;\n  readonly httpsPort?: number;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly test?: boolean;\n  readonly usePublicIp?: boolean;\n  readonly variables?: string;\n  readonly wsPort?: number;\n}\n\nexport type ServerlessCallback = (status: number) => void;\n\ninterface PublicIpCache {\n  ip: string;\n  timestamp: number;\n}\n\ninterface ServerlessHandler {\n  readonly handler: string;\n  readonly events?: Array<{\n    readonly http?: {\n      readonly cors?: boolean;\n      readonly method?: string;\n      readonly path?: string;\n    };\n    readonly websocket?: {\n      readonly route?: string;\n    };\n  }>;\n}\n\ninterface ServerlessConfig {\n  readonly custom?: {\n    readonly 'serverless-offline'?: {\n      readonly cors?: boolean;\n      readonly host?: string;\n      readonly httpPort?: number;\n      readonly httpsPort?: number;\n      readonly wsPort?: number;\n    };\n  };\n  readonly functions?: Record<string, ServerlessHandler>;\n}\n\nconst getCacheDir = (): string => {\n  const cacheDir = join(homedir(), '.lex-cache');\n  if(!existsSync(cacheDir)) {\n    mkdirSync(cacheDir, {recursive: true});\n  }\n  return cacheDir;\n};\n\nconst getCachePath = (): string => join(getCacheDir(), 'public-ip.json');\n\nconst readPublicIpCache = (): PublicIpCache | null => {\n  const cachePath = getCachePath();\n  if(!existsSync(cachePath)) {\n    return null;\n  }\n\n  try {\n    const cacheData = readFileSync(cachePath, 'utf8');\n    const cache: PublicIpCache = JSON.parse(cacheData);\n\n    // Check if cache is older than 1 week\n    const oneWeekMs = 7 * 24 * 60 * 60 * 1000;\n    if(Date.now() - cache.timestamp > oneWeekMs) {\n      return null;\n    }\n\n    return cache;\n  } catch{\n    return null;\n  }\n};\n\nconst writePublicIpCache = (ip: string): void => {\n  const cachePath = getCachePath();\n  const cache: PublicIpCache = {\n    ip,\n    timestamp: Date.now()\n  };\n  writeFileSync(cachePath, JSON.stringify(cache, null, 2));\n};\n\nconst fetchPublicIp = (forceRefresh: boolean = false): Promise<string | undefined> => new Promise((resolve) => {\n  if(!forceRefresh) {\n    const cached = readPublicIpCache();\n    if(cached) {\n      resolve(cached.ip);\n      return;\n    }\n  }\n\n  // Use fetch instead of https\n  fetch('https://api.ipify.org')\n    .then((res) => res.text())\n    .then((data) => {\n      const ip = data.trim();\n      if(ip) {\n        writePublicIpCache(ip);\n      }\n      resolve(ip);\n    })\n    .catch(() => resolve(undefined));\n});\n\nconst displayServerStatus = (\n  httpPort: number,\n  httpsPort: number,\n  wsPort: number,\n  host: string,\n  quiet: boolean,\n  publicIp?: string\n) => {\n  if(quiet) {\n    return;\n  }\n\n  const httpUrl = `http://${host}:${httpPort}`;\n  const httpsUrl = `https://${host}:${httpsPort}`;\n  const wsUrl = `ws://${host}:${wsPort}`;\n  const wssUrl = `wss://${host}:${wsPort}`;\n\n  let urlLines = `${chalk.green('HTTP:')}      ${chalk.underline(httpUrl)}\\n`;\n  urlLines += `${chalk.green('HTTPS:')}     ${chalk.underline(httpsUrl)}\\n`;\n  urlLines += `${chalk.green('WebSocket:')} ${chalk.underline(wsUrl)}\\n`;\n  urlLines += `${chalk.green('WSS:')}       ${chalk.underline(wssUrl)}\\n`;\n\n  if(publicIp) {\n    urlLines += `\\n${chalk.green('Public:')}    ${chalk.underline(`http://${publicIp}:${httpPort}`)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🚀 Serverless Development Server Running')}\\n\\n${urlLines}\\n` +\n    `${chalk.yellow('Press Ctrl+C to stop the server')}`,\n    {\n      backgroundColor: '#1a1a1a',\n      borderColor: 'cyan',\n      borderStyle: 'round',\n      margin: 1,\n      padding: 1\n    }\n  );\n\n  console.log(`\\n${statusBox}\\n`);\n};\n\nconst loadHandler = async (handlerPath: string, outputDir: string) => {\n  try {\n    const fullPath = pathResolve(outputDir, handlerPath);\n    log(`Loading handler from: ${fullPath}`, 'info', false);\n\n    if(!existsSync(fullPath)) {\n      throw new Error(`Handler file not found: ${fullPath}`);\n    }\n\n    // Dynamic import of the handler with better error handling\n    try {\n      const handlerModule = await import(fullPath);\n      log(`Handler module loaded: ${Object.keys(handlerModule)}`, 'info', false);\n\n      const handler = handlerModule.default || handlerModule.handler || handlerModule;\n      log(`Handler found: ${typeof handler}`, 'info', false);\n\n      return handler;\n    } catch(importError) {\n      log(`Import error for handler ${handlerPath}: ${importError.message}`, 'error', false);\n      return null;\n    }\n  } catch(error) {\n    log(`Error loading handler ${handlerPath}: ${error.message}`, 'error', false);\n    return null;\n  }\n};\n\nconst captureConsoleLogs = (handler: (event: any, context: any) => Promise<any>, quiet: boolean) => {\n  if(quiet) {\n    return handler;\n  }\n\n  return async (event: any, context: any) => {\n    // Capture console.log, console.error, etc.\n    const originalConsoleLog = console.log;\n    const originalConsoleError = console.error;\n    const originalConsoleWarn = console.warn;\n    const originalConsoleInfo = console.info;\n\n    const logs: string[] = [];\n\n    console.log = (...args: any[]) => {\n      logs.push(`[LOG] ${args.join(' ')}`);\n      originalConsoleLog(...args);\n    };\n\n    console.error = (...args: any[]) => {\n      logs.push(`[ERROR] ${args.join(' ')}`);\n      originalConsoleError(...args);\n    };\n\n    console.warn = (...args: any[]) => {\n      logs.push(`[WARN] ${args.join(' ')}`);\n      originalConsoleWarn(...args);\n    };\n\n    console.info = (...args: any[]) => {\n      logs.push(`[INFO] ${args.join(' ')}`);\n      originalConsoleInfo(...args);\n    };\n\n    try {\n      const result = await handler(event, context);\n\n      // Output captured logs\n      if(logs.length > 0) {\n        console.log(chalk.gray('--- Handler Console Output ---'));\n        logs.forEach((log) => console.log(chalk.gray(log)));\n        console.log(chalk.gray('--- End Handler Console Output ---'));\n      }\n\n      return result;\n    } finally {\n      // Restore original console methods\n      console.log = originalConsoleLog;\n      console.error = originalConsoleError;\n      console.warn = originalConsoleWarn;\n      console.info = originalConsoleInfo;\n    }\n  };\n};\n\nconst createExpressServer = async (\n  config: ServerlessConfig,\n  outputDir: string,\n  httpPort: number,\n  host: string,\n  quiet: boolean,\n  debug: boolean\n) => {\n  const app = express();\n\n  // Enable CORS\n  app.use((req, res, next) => {\n    res.header('Access-Control-Allow-Origin', '*');\n    res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, PATCH, OPTIONS');\n    res.header('Access-Control-Allow-Headers', '*');\n    res.header('Access-Control-Allow-Credentials', 'true');\n\n    if(req.method === 'OPTIONS') {\n      res.sendStatus(200);\n    } else {\n      next();\n    }\n  });\n\n  // Parse JSON bodies\n  app.use(express.json());\n\n  // Load GraphQL handler\n  const loadGraphQLSchema = async () => {\n    try {\n      // Try to find a GraphQL handler\n      let graphqlHandler = null;\n\n      if(config.functions) {\n        for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event.http && event.http.path) {\n                // Look for GraphQL endpoints\n                if(event.http.path === '/public' || event.http.path === '/graphql') {\n                  graphqlHandler = await loadHandler(functionConfig.handler, outputDir);\n                  break;\n                }\n              }\n            }\n          }\n          if(graphqlHandler) {\n            break;\n          }\n        }\n      }\n\n      if(graphqlHandler) {\n        log('Found GraphQL handler', 'info', quiet);\n        return graphqlHandler;\n      }\n      return null;\n    } catch(error) {\n      log(`Error loading GraphQL handler: ${error.message}`, 'error', quiet);\n      return null;\n    }\n  };\n\n  // Set up GraphQL handler for GraphQL requests\n  try {\n    const graphqlHandler = await loadGraphQLSchema();\n    if(graphqlHandler) {\n      // Find the GraphQL path from the serverless config\n      let graphqlPath = '/graphql'; // default fallback\n\n      if(config.functions) {\n        for(const [_functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event?.http?.path) {\n                graphqlPath = event.http.path;\n                break;\n              }\n            }\n          }\n          if(graphqlPath !== '/graphql') {\n            break;\n          }\n        }\n      }\n\n      // Set up GraphQL endpoint with enhanced console.log capture\n      app.use(graphqlPath, async (req, res) => {\n        // GraphQL Debug Logging\n        if(debug && req.body && req.body.query) {\n          log('🔍 GraphQL Debug Mode: Analyzing request...', 'info', false);\n          log(`📝 GraphQL Query: ${req.body.query}`, 'info', false);\n          if(req.body.variables) {\n            log(`📊 GraphQL Variables: ${JSON.stringify(req.body.variables, null, 2)}`, 'info', false);\n          }\n          if(req.body.operationName) {\n            log(`🏷️  GraphQL Operation: ${req.body.operationName}`, 'info', false);\n          }\n        }\n\n        // Enhanced console.log capture\n        const originalConsoleLog = console.log;\n        const logs: string[] = [];\n\n        console.log = (...args) => {\n          const logMessage = args.map((arg) =>\n            (typeof arg === 'object' ? JSON.stringify(arg, null, 2) : String(arg))\n          ).join(' ');\n          logs.push(logMessage);\n          originalConsoleLog(`[GraphQL] ${logMessage}`);\n        };\n\n        // Create context for the handler\n        const context = {\n          awsRequestId: 'test-request-id',\n          functionName: 'graphql',\n          functionVersion: '$LATEST',\n          getRemainingTimeInMillis: () => 30000,\n          invokedFunctionArn: 'arn:aws:lambda:us-east-1:123456789012:function:graphql',\n          logGroupName: '/aws/lambda/graphql',\n          logStreamName: 'test-log-stream',\n          req,\n          res\n        };\n\n        // Wrap handler with console log capture\n        const wrappedHandler = captureConsoleLogs(graphqlHandler, quiet);\n\n        try {\n          // Call the handler with GraphQL parameters\n          const result = await wrappedHandler({\n            body: JSON.stringify(req.body),\n            headers: req.headers,\n            httpMethod: 'POST',\n            path: graphqlPath,\n            queryStringParameters: {}\n          }, context);\n\n          // Restore console.log\n          console.log = originalConsoleLog;\n\n          // Handle the result\n          if(result && typeof result === 'object' && result.statusCode) {\n            res.status(result.statusCode);\n            if(result.headers) {\n              Object.entries(result.headers).forEach(([key, value]) => {\n                res.setHeader(key, String(value));\n              });\n            }\n            res.send(result.body);\n          } else {\n            res.json(result);\n          }\n        } catch(error) {\n          // Restore console.log\n          console.log = originalConsoleLog;\n          log(`GraphQL handler error: ${error.message}`, 'error', false);\n          res.status(500).json({error: error.message});\n        }\n      });\n\n      log(`GraphQL endpoint available at http://${host}:${httpPort}${graphqlPath}`, 'info', quiet);\n    }\n  } catch(error) {\n    log(`Error setting up GraphQL: ${error.message}`, 'error', quiet);\n  }\n\n  // Fallback for non-GraphQL routes - handle all remaining routes\n  app.use('/', async (req, res) => {\n    try {\n      const url = req.url || '/';\n      const method = req.method || 'GET';\n      const pathname = req.path || url.split('?')[0]; // Extract pathname without query string\n\n      log(`${method} ${url} (pathname: ${pathname})`, 'info', false);\n\n      // Find matching function\n      let matchedFunction = null;\n\n      if(config.functions) {\n        for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event.http) {\n                const eventPath = event.http.path || '/';\n                const eventMethod = event.http.method || 'GET';\n\n                // Improved path matching - compare pathname without query string\n                if(eventPath && eventPath === pathname && eventMethod === method) {\n                  matchedFunction = functionName;\n                  break;\n                }\n              }\n            }\n          }\n          if(matchedFunction) {\n            break;\n          }\n        }\n      }\n\n      if(matchedFunction && config.functions[matchedFunction]) {\n        // Resolve handler path relative to output directory\n        const handlerPath = config.functions[matchedFunction].handler;\n        const handler = await loadHandler(handlerPath, outputDir);\n\n        if(handler) {\n          const wrappedHandler = captureConsoleLogs(handler, quiet);\n\n          const event = {\n            body: req.body,\n            headers: req.headers,\n            httpMethod: method,\n            path: url,\n            queryStringParameters: req.query\n          };\n\n          const context = {\n            awsRequestId: 'test-request-id',\n            functionName: matchedFunction,\n            functionVersion: '$LATEST',\n            getRemainingTimeInMillis: () => 30000,\n            invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,\n            logGroupName: `/aws/lambda/${matchedFunction}`,\n            logStreamName: 'test-log-stream',\n            memoryLimitInMB: '128'\n          };\n\n          try {\n            const result = await wrappedHandler(event, context);\n\n            if(result && typeof result === 'object' && result.statusCode) {\n              res.status(result.statusCode);\n              if(result.headers) {\n                Object.entries(result.headers).forEach(([key, value]) => {\n                  res.setHeader(key, String(value));\n                });\n              }\n              res.send(result.body);\n            } else {\n              res.json(result);\n            }\n          } catch(error) {\n            log(`Handler error: ${error.message}`, 'error', false);\n            res.status(500).json({error: error.message});\n          }\n        } else {\n          res.status(404).json({error: 'Handler not found'});\n        }\n      } else {\n        res.status(404).json({error: 'Function not found'});\n      }\n    } catch(error) {\n      log(`Route handling error: ${error.message}`, 'error', false);\n      res.status(500).json({error: error.message});\n    }\n  });\n\n  return app;\n};\n\nconst createWebSocketServer = (\n  config: ServerlessConfig,\n  outputDir: string,\n  wsPort: number,\n  quiet: boolean,\n  debug: boolean\n) => {\n  const wss = new WebSocketServer({port: wsPort});\n\n  wss.on('connection', async (ws, req) => {\n    log(`WebSocket connection established: ${req.url}`, 'info', false);\n\n    ws.on('message', async (message) => {\n      try {\n        const data = JSON.parse(message.toString());\n\n        // Find matching WebSocket function\n        let matchedFunction = null;\n\n        if(config.functions) {\n          for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n            if(functionConfig.events) {\n              for(const event of functionConfig.events) {\n                if(event.websocket) {\n                  const route = event.websocket.route || '$connect';\n                  if(route === '$default' || route === data.action) {\n                    matchedFunction = functionName;\n                    break;\n                  }\n                }\n              }\n            }\n            if(matchedFunction) {\n              break;\n            }\n          }\n        }\n\n        if(matchedFunction && config.functions[matchedFunction]) {\n          const handler = await loadHandler(config.functions[matchedFunction].handler, outputDir);\n\n          if(handler) {\n            // Wrap handler with console log capture\n            const wrappedHandler = captureConsoleLogs(handler, quiet);\n            const event = {\n              body: data.body || null,\n              requestContext: {\n                apiGateway: {\n                  endpoint: `ws://localhost:${wsPort}`\n                },\n                connectionId: 'test-connection-id',\n                routeKey: data.action || '$default'\n              }\n            };\n\n            const context = {\n              awsRequestId: 'test-request-id',\n              functionName: matchedFunction,\n              functionVersion: '$LATEST',\n              getRemainingTimeInMillis: () => 30000,\n              invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,\n              logGroupName: `/aws/lambda/${matchedFunction}`,\n              logStreamName: 'test-log-stream',\n              memoryLimitInMB: '128'\n            };\n\n            const result = await wrappedHandler(event, context);\n\n            // Handle Lambda response format for WebSocket\n            if(result && typeof result === 'object' && result.statusCode) {\n              // This is a Lambda response object, extract the body\n              const body = result.body || '';\n              ws.send(body);\n            } else {\n              // This is a direct response, stringify it\n              ws.send(JSON.stringify(result));\n            }\n          } else {\n            ws.send(JSON.stringify({error: 'Handler not found'}));\n          }\n        } else {\n          ws.send(JSON.stringify({error: 'WebSocket function not found'}));\n        }\n      } catch(error) {\n        log(`WebSocket error: ${error.message}`, 'error', false);\n        ws.send(JSON.stringify({error: error.message}));\n      }\n    });\n\n    ws.on('close', () => {\n      log('WebSocket connection closed', 'info', false);\n    });\n  });\n\n  return wss;\n};\n\nconst loadEnvFile = (envPath: string): Record<string, string> => {\n  const envVars: Record<string, string> = {};\n\n  if(!existsSync(envPath)) {\n    return envVars;\n  }\n\n  try {\n    const envContent = readFileSync(envPath, 'utf8');\n    const lines = envContent.split('\\n');\n\n    for(const line of lines) {\n      const trimmedLine = line.trim();\n\n      // Skip empty lines and comments\n      if(!trimmedLine || trimmedLine.startsWith('#')) {\n        continue;\n      }\n\n      // Parse KEY=value format\n      const equalIndex = trimmedLine.indexOf('=');\n      if(equalIndex > 0) {\n        const key = trimmedLine.substring(0, equalIndex).trim();\n        const value = trimmedLine.substring(equalIndex + 1).trim();\n\n        // Remove quotes if present\n        const cleanValue = value.replace(/^[\"']|[\"']$/g, '');\n\n        if(key) {\n          envVars[key] = cleanValue;\n        }\n      }\n    }\n  } catch(error) {\n    log(`Warning: Could not load .env file at ${envPath}: ${error.message}`, 'warn', false);\n  }\n\n  return envVars;\n};\n\nexport const serverless = async (\n  cmd: ServerlessOptions,\n  callback: ServerlessCallback = () => ({})\n): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    debug = false,\n    host = 'localhost',\n    httpPort = 3000,\n    httpsPort = 3001,\n    quiet = false,\n    remove = false,\n    test = false,\n    usePublicIp,\n    variables,\n    wsPort = 3002\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} starting serverless development server...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath} = LexConfig.config;\n\n  // Load environment variables from .env files\n  const envPaths = [\n    pathResolve(process.cwd(), '.env'),\n    pathResolve(process.cwd(), '.env.local'),\n    pathResolve(process.cwd(), '.env.development')\n  ];\n\n  let envVars: Record<string, string> = {};\n\n  // Load from .env files in order (later files override earlier ones)\n  for(const envPath of envPaths) {\n    const fileEnvVars = loadEnvFile(envPath);\n    if(Object.keys(fileEnvVars).length > 0) {\n      log(`Loaded environment variables from: ${envPath}`, 'info', quiet);\n    }\n    envVars = {...envVars, ...fileEnvVars};\n  }\n\n  // Start with default NODE_ENV and loaded .env variables\n  let variablesObj: object = {NODE_ENV: 'development', ...envVars};\n\n  // Override with command line variables if provided\n  if(variables) {\n    try {\n      const cliVars = JSON.parse(variables);\n      variablesObj = {...variablesObj, ...cliVars};\n    } catch(_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  // If in test mode, exit early after loading environment variables\n  if(test) {\n    log('Test mode: Environment variables loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  if(remove) {\n    spinner.start('Cleaning output directory...');\n    await removeFiles(outputFullPath || '');\n    spinner.succeed('Successfully cleaned output directory!');\n  }\n\n  // Load serverless configuration\n  let serverlessConfig: ServerlessConfig = {};\n\n  try {\n    const configPath = config || pathResolve(process.cwd(), 'lex.config.mjs');\n    log(`Loading serverless config from: ${configPath}`, 'info', quiet);\n\n    if(existsSync(configPath)) {\n      const configModule = await import(configPath);\n      serverlessConfig = configModule.default?.serverless || configModule.serverless || {};\n      log('Serverless config loaded successfully', 'info', quiet);\n      log(`Loaded functions: ${Object.keys(serverlessConfig.functions || {}).join(', ')}`, 'info', quiet);\n    } else {\n      log(`No serverless config found at ${configPath}, using defaults`, 'warn', quiet);\n    }\n  } catch(error) {\n    log(`Error loading serverless config: ${error.message}`, 'error', quiet);\n    // Don't exit, continue with empty config\n  }\n\n  // Merge config with command line options\n  const finalConfig: ServerlessConfig = {\n    ...serverlessConfig,\n    custom: {\n      'serverless-offline': {\n        cors: serverlessConfig.custom?.['serverless-offline']?.cors !== false,\n        host: serverlessConfig.custom?.['serverless-offline']?.host || host,\n        httpPort: serverlessConfig.custom?.['serverless-offline']?.httpPort || httpPort,\n        httpsPort: serverlessConfig.custom?.['serverless-offline']?.httpsPort || httpsPort,\n        wsPort: serverlessConfig.custom?.['serverless-offline']?.wsPort || wsPort\n      }\n    }\n  };\n\n  const outputDir = outputFullPath || 'lib';\n  log(`Using output directory: ${outputDir}`, 'info', quiet);\n\n  try {\n    spinner.start('Starting serverless development server...');\n\n    const httpPort = finalConfig.custom!['serverless-offline']!.httpPort!;\n    const wsPort = finalConfig.custom!['serverless-offline']!.wsPort!;\n    const host = finalConfig.custom!['serverless-offline']!.host!;\n\n    log(`Creating HTTP server on ${host}:${httpPort}`, 'info', quiet);\n    log(`Creating WebSocket server on port ${wsPort}`, 'info', quiet);\n\n    // Create Express server\n    const expressApp = await createExpressServer(\n      finalConfig,\n      outputDir,\n      httpPort,\n      host,\n      quiet,\n      debug\n    );\n\n    // Create WebSocket server\n    const wsServer = createWebSocketServer(\n      finalConfig,\n      outputDir,\n      wsPort,\n      quiet,\n      debug\n    );\n\n    // Handle server errors\n    wsServer.on('error', (error) => {\n      log(`WebSocket server error: ${error.message}`, 'error', quiet);\n      spinner.fail('Failed to start WebSocket server.');\n      callback(1);\n      return;\n    });\n\n    // Start Express server\n    const server = expressApp.listen(httpPort, host, () => {\n      spinner.succeed('Serverless development server started.');\n\n      displayServerStatus(\n        httpPort,\n        finalConfig.custom!['serverless-offline']!.httpsPort!,\n        wsPort,\n        host,\n        quiet\n      );\n\n      fetchPublicIp(usePublicIp).then((publicIp) => {\n        if(publicIp) {\n          displayServerStatus(\n            httpPort,\n            finalConfig.custom!['serverless-offline']!.httpsPort!,\n            wsPort,\n            host,\n            quiet,\n            publicIp\n          );\n        }\n      });\n    });\n\n    // Handle Express server errors\n    server.on('error', (error) => {\n      log(`Express server error: ${error.message}`, 'error', quiet);\n      spinner.fail('Failed to start Express server.');\n      callback(1);\n      return;\n    });\n\n    // Handle graceful shutdown\n    const shutdown = () => {\n      log('\\nShutting down serverless development server...', 'info', quiet);\n      server.close();\n      wsServer.close();\n      callback(0);\n    };\n\n    process.on('SIGINT', shutdown);\n    process.on('SIGTERM', shutdown);\n\n    // Keep the process alive\n    process.stdin.resume();\n\n    log('Serverless development server is running. Press Ctrl+C to stop.', 'info', quiet);\n\n    // Don't call callback here, let the process stay alive\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('Failed to start serverless development server.');\n    callback(1);\n    return 1;\n  }\n};"],"names":["boxen","chalk","express","readFileSync","existsSync","mkdirSync","writeFileSync","homedir","resolve","pathResolve","join","WebSocketServer","LexConfig","createSpinner","removeFiles","log","getCacheDir","cacheDir","recursive","getCachePath","readPublicIpCache","cachePath","cacheData","cache","JSON","parse","oneWeekMs","Date","now","timestamp","writePublicIpCache","ip","stringify","fetchPublicIp","forceRefresh","Promise","cached","fetch","then","res","text","data","trim","catch","undefined","displayServerStatus","httpPort","httpsPort","wsPort","host","quiet","publicIp","httpUrl","httpsUrl","wsUrl","wssUrl","urlLines","green","underline","statusBox","cyan","bold","yellow","backgroundColor","borderColor","borderStyle","margin","padding","console","loadHandler","handlerPath","outputDir","fullPath","Error","handlerModule","Object","keys","handler","default","importError","message","error","captureConsoleLogs","event","context","originalConsoleLog","originalConsoleError","originalConsoleWarn","warn","originalConsoleInfo","info","logs","args","push","result","length","gray","forEach","createExpressServer","config","debug","app","use","req","next","header","method","sendStatus","json","loadGraphQLSchema","graphqlHandler","functions","functionName","functionConfig","entries","events","http","path","graphqlPath","_functionName","body","query","variables","operationName","logMessage","map","arg","String","awsRequestId","functionVersion","getRemainingTimeInMillis","invokedFunctionArn","logGroupName","logStreamName","wrappedHandler","headers","httpMethod","queryStringParameters","statusCode","status","key","value","setHeader","send","url","pathname","split","matchedFunction","eventPath","eventMethod","memoryLimitInMB","createWebSocketServer","wss","port","on","ws","toString","websocket","route","action","requestContext","apiGateway","endpoint","connectionId","routeKey","loadEnvFile","envPath","envVars","envContent","lines","line","trimmedLine","startsWith","equalIndex","indexOf","substring","cleanValue","replace","serverless","cmd","callback","cliName","remove","test","usePublicIp","spinner","parseConfig","outputFullPath","envPaths","process","cwd","fileEnvVars","variablesObj","NODE_ENV","cliVars","_error","env","start","succeed","serverlessConfig","configPath","configModule","finalConfig","custom","cors","expressApp","wsServer","fail","server","listen","shutdown","close","stdin","resume"],"mappings":"AAAA;;;CAGC,GACD,OAAOA,WAAW,QAAQ;AAC1B,OAAOC,WAAW,QAAQ;AAC1B,OAAOC,aAAa,UAAU;AAC9B,SAAQC,YAAY,EAAEC,UAAU,EAAEC,SAAS,EAAEC,aAAa,QAAO,KAAK;AACtE,SAAQC,OAAO,QAAO,KAAK;AAC3B,SAAQC,WAAWC,WAAW,EAAEC,IAAI,QAAO,OAAO;AAClD,SAAQC,eAAe,QAAO,KAAK;AAEnC,SAAQC,SAAS,QAAO,qBAAqB;AAC7C,SAAQC,aAAa,EAAEC,WAAW,QAAO,qBAAqB;AAC9D,SAAQC,GAAG,QAAO,qBAAqB;AAmDvC,MAAMC,cAAc;IAClB,MAAMC,WAAWP,KAAKH,WAAW;IACjC,IAAG,CAACH,WAAWa,WAAW;QACxBZ,UAAUY,UAAU;YAACC,WAAW;QAAI;IACtC;IACA,OAAOD;AACT;AAEA,MAAME,eAAe,IAAcT,KAAKM,eAAe;AAEvD,MAAMI,oBAAoB;IACxB,MAAMC,YAAYF;IAClB,IAAG,CAACf,WAAWiB,YAAY;QACzB,OAAO;IACT;IAEA,IAAI;QACF,MAAMC,YAAYnB,aAAakB,WAAW;QAC1C,MAAME,QAAuBC,KAAKC,KAAK,CAACH;QAExC,sCAAsC;QACtC,MAAMI,YAAY,IAAI,KAAK,KAAK,KAAK;QACrC,IAAGC,KAAKC,GAAG,KAAKL,MAAMM,SAAS,GAAGH,WAAW;YAC3C,OAAO;QACT;QAEA,OAAOH;IACT,EAAE,OAAK;QACL,OAAO;IACT;AACF;AAEA,MAAMO,qBAAqB,CAACC;IAC1B,MAAMV,YAAYF;IAClB,MAAMI,QAAuB;QAC3BQ;QACAF,WAAWF,KAAKC,GAAG;IACrB;IACAtB,cAAce,WAAWG,KAAKQ,SAAS,CAACT,OAAO,MAAM;AACvD;AAEA,MAAMU,gBAAgB,CAACC,eAAwB,KAAK,GAAkC,IAAIC,QAAQ,CAAC3B;QACjG,IAAG,CAAC0B,cAAc;YAChB,MAAME,SAAShB;YACf,IAAGgB,QAAQ;gBACT5B,QAAQ4B,OAAOL,EAAE;gBACjB;YACF;QACF;QAEA,6BAA6B;QAC7BM,MAAM,yBACHC,IAAI,CAAC,CAACC,MAAQA,IAAIC,IAAI,IACtBF,IAAI,CAAC,CAACG;YACL,MAAMV,KAAKU,KAAKC,IAAI;YACpB,IAAGX,IAAI;gBACLD,mBAAmBC;YACrB;YACAvB,QAAQuB;QACV,GACCY,KAAK,CAAC,IAAMnC,QAAQoC;IACzB;AAEA,MAAMC,sBAAsB,CAC1BC,UACAC,WACAC,QACAC,MACAC,OACAC;IAEA,IAAGD,OAAO;QACR;IACF;IAEA,MAAME,UAAU,CAAC,OAAO,EAAEH,KAAK,CAAC,EAAEH,UAAU;IAC5C,MAAMO,WAAW,CAAC,QAAQ,EAAEJ,KAAK,CAAC,EAAEF,WAAW;IAC/C,MAAMO,QAAQ,CAAC,KAAK,EAAEL,KAAK,CAAC,EAAED,QAAQ;IACtC,MAAMO,SAAS,CAAC,MAAM,EAAEN,KAAK,CAAC,EAAED,QAAQ;IAExC,IAAIQ,WAAW,GAAGvD,MAAMwD,KAAK,CAAC,SAAS,MAAM,EAAExD,MAAMyD,SAAS,CAACN,SAAS,EAAE,CAAC;IAC3EI,YAAY,GAAGvD,MAAMwD,KAAK,CAAC,UAAU,KAAK,EAAExD,MAAMyD,SAAS,CAACL,UAAU,EAAE,CAAC;IACzEG,YAAY,GAAGvD,MAAMwD,KAAK,CAAC,cAAc,CAAC,EAAExD,MAAMyD,SAAS,CAACJ,OAAO,EAAE,CAAC;IACtEE,YAAY,GAAGvD,MAAMwD,KAAK,CAAC,QAAQ,OAAO,EAAExD,MAAMyD,SAAS,CAACH,QAAQ,EAAE,CAAC;IAEvE,IAAGJ,UAAU;QACXK,YAAY,CAAC,EAAE,EAAEvD,MAAMwD,KAAK,CAAC,WAAW,IAAI,EAAExD,MAAMyD,SAAS,CAAC,CAAC,OAAO,EAAEP,SAAS,CAAC,EAAEL,UAAU,EAAE,EAAE,CAAC;IACrG;IAEA,MAAMa,YAAY3D,MAChB,GAAGC,MAAM2D,IAAI,CAACC,IAAI,CAAC,4CAA4C,IAAI,EAAEL,SAAS,EAAE,CAAC,GACjF,GAAGvD,MAAM6D,MAAM,CAAC,oCAAoC,EACpD;QACEC,iBAAiB;QACjBC,aAAa;QACbC,aAAa;QACbC,QAAQ;QACRC,SAAS;IACX;IAGFC,QAAQrD,GAAG,CAAC,CAAC,EAAE,EAAE4C,UAAU,EAAE,CAAC;AAChC;AAEA,MAAMU,cAAc,OAAOC,aAAqBC;IAC9C,IAAI;QACF,MAAMC,WAAW/D,YAAY8D,WAAWD;QACxCvD,IAAI,CAAC,sBAAsB,EAAEyD,UAAU,EAAE,QAAQ;QAEjD,IAAG,CAACpE,WAAWoE,WAAW;YACxB,MAAM,IAAIC,MAAM,CAAC,wBAAwB,EAAED,UAAU;QACvD;QAEA,2DAA2D;QAC3D,IAAI;YACF,MAAME,gBAAgB,MAAM,MAAM,CAACF;YACnCzD,IAAI,CAAC,uBAAuB,EAAE4D,OAAOC,IAAI,CAACF,gBAAgB,EAAE,QAAQ;YAEpE,MAAMG,UAAUH,cAAcI,OAAO,IAAIJ,cAAcG,OAAO,IAAIH;YAClE3D,IAAI,CAAC,eAAe,EAAE,OAAO8D,SAAS,EAAE,QAAQ;YAEhD,OAAOA;QACT,EAAE,OAAME,aAAa;YACnBhE,IAAI,CAAC,yBAAyB,EAAEuD,YAAY,EAAE,EAAES,YAAYC,OAAO,EAAE,EAAE,SAAS;YAChF,OAAO;QACT;IACF,EAAE,OAAMC,OAAO;QACblE,IAAI,CAAC,sBAAsB,EAAEuD,YAAY,EAAE,EAAEW,MAAMD,OAAO,EAAE,EAAE,SAAS;QACvE,OAAO;IACT;AACF;AAEA,MAAME,qBAAqB,CAACL,SAAqD3B;IAC/E,IAAGA,OAAO;QACR,OAAO2B;IACT;IAEA,OAAO,OAAOM,OAAYC;QACxB,2CAA2C;QAC3C,MAAMC,qBAAqBjB,QAAQrD,GAAG;QACtC,MAAMuE,uBAAuBlB,QAAQa,KAAK;QAC1C,MAAMM,sBAAsBnB,QAAQoB,IAAI;QACxC,MAAMC,sBAAsBrB,QAAQsB,IAAI;QAExC,MAAMC,OAAiB,EAAE;QAEzBvB,QAAQrD,GAAG,GAAG,CAAC,GAAG6E;YAChBD,KAAKE,IAAI,CAAC,CAAC,MAAM,EAAED,KAAKlF,IAAI,CAAC,MAAM;YACnC2E,sBAAsBO;QACxB;QAEAxB,QAAQa,KAAK,GAAG,CAAC,GAAGW;YAClBD,KAAKE,IAAI,CAAC,CAAC,QAAQ,EAAED,KAAKlF,IAAI,CAAC,MAAM;YACrC4E,wBAAwBM;QAC1B;QAEAxB,QAAQoB,IAAI,GAAG,CAAC,GAAGI;YACjBD,KAAKE,IAAI,CAAC,CAAC,OAAO,EAAED,KAAKlF,IAAI,CAAC,MAAM;YACpC6E,uBAAuBK;QACzB;QAEAxB,QAAQsB,IAAI,GAAG,CAAC,GAAGE;YACjBD,KAAKE,IAAI,CAAC,CAAC,OAAO,EAAED,KAAKlF,IAAI,CAAC,MAAM;YACpC+E,uBAAuBG;QACzB;QAEA,IAAI;YACF,MAAME,SAAS,MAAMjB,QAAQM,OAAOC;YAEpC,uBAAuB;YACvB,IAAGO,KAAKI,MAAM,GAAG,GAAG;gBAClB3B,QAAQrD,GAAG,CAACd,MAAM+F,IAAI,CAAC;gBACvBL,KAAKM,OAAO,CAAC,CAAClF,MAAQqD,QAAQrD,GAAG,CAACd,MAAM+F,IAAI,CAACjF;gBAC7CqD,QAAQrD,GAAG,CAACd,MAAM+F,IAAI,CAAC;YACzB;YAEA,OAAOF;QACT,SAAU;YACR,mCAAmC;YACnC1B,QAAQrD,GAAG,GAAGsE;YACdjB,QAAQa,KAAK,GAAGK;YAChBlB,QAAQoB,IAAI,GAAGD;YACfnB,QAAQsB,IAAI,GAAGD;QACjB;IACF;AACF;AAEA,MAAMS,sBAAsB,OAC1BC,QACA5B,WACAzB,UACAG,MACAC,OACAkD;IAEA,MAAMC,MAAMnG;IAEZ,cAAc;IACdmG,IAAIC,GAAG,CAAC,CAACC,KAAKhE,KAAKiE;QACjBjE,IAAIkE,MAAM,CAAC,+BAA+B;QAC1ClE,IAAIkE,MAAM,CAAC,gCAAgC;QAC3ClE,IAAIkE,MAAM,CAAC,gCAAgC;QAC3ClE,IAAIkE,MAAM,CAAC,oCAAoC;QAE/C,IAAGF,IAAIG,MAAM,KAAK,WAAW;YAC3BnE,IAAIoE,UAAU,CAAC;QACjB,OAAO;YACLH;QACF;IACF;IAEA,oBAAoB;IACpBH,IAAIC,GAAG,CAACpG,QAAQ0G,IAAI;IAEpB,uBAAuB;IACvB,MAAMC,oBAAoB;QACxB,IAAI;YACF,gCAAgC;YAChC,IAAIC,iBAAiB;YAErB,IAAGX,OAAOY,SAAS,EAAE;gBACnB,KAAI,MAAM,CAACC,cAAcC,eAAe,IAAItC,OAAOuC,OAAO,CAACf,OAAOY,SAAS,EAAG;oBAC5E,IAAGE,eAAeE,MAAM,EAAE;wBACxB,KAAI,MAAMhC,SAAS8B,eAAeE,MAAM,CAAE;4BACxC,IAAGhC,MAAMiC,IAAI,IAAIjC,MAAMiC,IAAI,CAACC,IAAI,EAAE;gCAChC,6BAA6B;gCAC7B,IAAGlC,MAAMiC,IAAI,CAACC,IAAI,KAAK,aAAalC,MAAMiC,IAAI,CAACC,IAAI,KAAK,YAAY;oCAClEP,iBAAiB,MAAMzC,YAAY4C,eAAepC,OAAO,EAAEN;oCAC3D;gCACF;4BACF;wBACF;oBACF;oBACA,IAAGuC,gBAAgB;wBACjB;oBACF;gBACF;YACF;YAEA,IAAGA,gBAAgB;gBACjB/F,IAAI,yBAAyB,QAAQmC;gBACrC,OAAO4D;YACT;YACA,OAAO;QACT,EAAE,OAAM7B,OAAO;YACblE,IAAI,CAAC,+BAA+B,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS9B;YAChE,OAAO;QACT;IACF;IAEA,8CAA8C;IAC9C,IAAI;QACF,MAAM4D,iBAAiB,MAAMD;QAC7B,IAAGC,gBAAgB;YACjB,mDAAmD;YACnD,IAAIQ,cAAc,YAAY,mBAAmB;YAEjD,IAAGnB,OAAOY,SAAS,EAAE;gBACnB,KAAI,MAAM,CAACQ,eAAeN,eAAe,IAAItC,OAAOuC,OAAO,CAACf,OAAOY,SAAS,EAAG;oBAC7E,IAAGE,eAAeE,MAAM,EAAE;wBACxB,KAAI,MAAMhC,SAAS8B,eAAeE,MAAM,CAAE;4BACxC,IAAGhC,OAAOiC,MAAMC,MAAM;gCACpBC,cAAcnC,MAAMiC,IAAI,CAACC,IAAI;gCAC7B;4BACF;wBACF;oBACF;oBACA,IAAGC,gBAAgB,YAAY;wBAC7B;oBACF;gBACF;YACF;YAEA,4DAA4D;YAC5DjB,IAAIC,GAAG,CAACgB,aAAa,OAAOf,KAAKhE;gBAC/B,wBAAwB;gBACxB,IAAG6D,SAASG,IAAIiB,IAAI,IAAIjB,IAAIiB,IAAI,CAACC,KAAK,EAAE;oBACtC1G,IAAI,+CAA+C,QAAQ;oBAC3DA,IAAI,CAAC,kBAAkB,EAAEwF,IAAIiB,IAAI,CAACC,KAAK,EAAE,EAAE,QAAQ;oBACnD,IAAGlB,IAAIiB,IAAI,CAACE,SAAS,EAAE;wBACrB3G,IAAI,CAAC,sBAAsB,EAAES,KAAKQ,SAAS,CAACuE,IAAIiB,IAAI,CAACE,SAAS,EAAE,MAAM,IAAI,EAAE,QAAQ;oBACtF;oBACA,IAAGnB,IAAIiB,IAAI,CAACG,aAAa,EAAE;wBACzB5G,IAAI,CAAC,wBAAwB,EAAEwF,IAAIiB,IAAI,CAACG,aAAa,EAAE,EAAE,QAAQ;oBACnE;gBACF;gBAEA,+BAA+B;gBAC/B,MAAMtC,qBAAqBjB,QAAQrD,GAAG;gBACtC,MAAM4E,OAAiB,EAAE;gBAEzBvB,QAAQrD,GAAG,GAAG,CAAC,GAAG6E;oBAChB,MAAMgC,aAAahC,KAAKiC,GAAG,CAAC,CAACC,MAC1B,OAAOA,QAAQ,WAAWtG,KAAKQ,SAAS,CAAC8F,KAAK,MAAM,KAAKC,OAAOD,MACjEpH,IAAI,CAAC;oBACPiF,KAAKE,IAAI,CAAC+B;oBACVvC,mBAAmB,CAAC,UAAU,EAAEuC,YAAY;gBAC9C;gBAEA,iCAAiC;gBACjC,MAAMxC,UAAU;oBACd4C,cAAc;oBACdhB,cAAc;oBACdiB,iBAAiB;oBACjBC,0BAA0B,IAAM;oBAChCC,oBAAoB;oBACpBC,cAAc;oBACdC,eAAe;oBACf9B;oBACAhE;gBACF;gBAEA,wCAAwC;gBACxC,MAAM+F,iBAAiBpD,mBAAmB4B,gBAAgB5D;gBAE1D,IAAI;oBACF,2CAA2C;oBAC3C,MAAM4C,SAAS,MAAMwC,eAAe;wBAClCd,MAAMhG,KAAKQ,SAAS,CAACuE,IAAIiB,IAAI;wBAC7Be,SAAShC,IAAIgC,OAAO;wBACpBC,YAAY;wBACZnB,MAAMC;wBACNmB,uBAAuB,CAAC;oBAC1B,GAAGrD;oBAEH,sBAAsB;oBACtBhB,QAAQrD,GAAG,GAAGsE;oBAEd,oBAAoB;oBACpB,IAAGS,UAAU,OAAOA,WAAW,YAAYA,OAAO4C,UAAU,EAAE;wBAC5DnG,IAAIoG,MAAM,CAAC7C,OAAO4C,UAAU;wBAC5B,IAAG5C,OAAOyC,OAAO,EAAE;4BACjB5D,OAAOuC,OAAO,CAACpB,OAAOyC,OAAO,EAAEtC,OAAO,CAAC,CAAC,CAAC2C,KAAKC,MAAM;gCAClDtG,IAAIuG,SAAS,CAACF,KAAKb,OAAOc;4BAC5B;wBACF;wBACAtG,IAAIwG,IAAI,CAACjD,OAAO0B,IAAI;oBACtB,OAAO;wBACLjF,IAAIqE,IAAI,CAACd;oBACX;gBACF,EAAE,OAAMb,OAAO;oBACb,sBAAsB;oBACtBb,QAAQrD,GAAG,GAAGsE;oBACdtE,IAAI,CAAC,uBAAuB,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS;oBACxDzC,IAAIoG,MAAM,CAAC,KAAK/B,IAAI,CAAC;wBAAC3B,OAAOA,MAAMD,OAAO;oBAAA;gBAC5C;YACF;YAEAjE,IAAI,CAAC,qCAAqC,EAAEkC,KAAK,CAAC,EAAEH,WAAWwE,aAAa,EAAE,QAAQpE;QACxF;IACF,EAAE,OAAM+B,OAAO;QACblE,IAAI,CAAC,0BAA0B,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS9B;IAC7D;IAEA,gEAAgE;IAChEmD,IAAIC,GAAG,CAAC,KAAK,OAAOC,KAAKhE;QACvB,IAAI;YACF,MAAMyG,MAAMzC,IAAIyC,GAAG,IAAI;YACvB,MAAMtC,SAASH,IAAIG,MAAM,IAAI;YAC7B,MAAMuC,WAAW1C,IAAIc,IAAI,IAAI2B,IAAIE,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,wCAAwC;YAExFnI,IAAI,GAAG2F,OAAO,CAAC,EAAEsC,IAAI,YAAY,EAAEC,SAAS,CAAC,CAAC,EAAE,QAAQ;YAExD,yBAAyB;YACzB,IAAIE,kBAAkB;YAEtB,IAAGhD,OAAOY,SAAS,EAAE;gBACnB,KAAI,MAAM,CAACC,cAAcC,eAAe,IAAItC,OAAOuC,OAAO,CAACf,OAAOY,SAAS,EAAG;oBAC5E,IAAGE,eAAeE,MAAM,EAAE;wBACxB,KAAI,MAAMhC,SAAS8B,eAAeE,MAAM,CAAE;4BACxC,IAAGhC,MAAMiC,IAAI,EAAE;gCACb,MAAMgC,YAAYjE,MAAMiC,IAAI,CAACC,IAAI,IAAI;gCACrC,MAAMgC,cAAclE,MAAMiC,IAAI,CAACV,MAAM,IAAI;gCAEzC,iEAAiE;gCACjE,IAAG0C,aAAaA,cAAcH,YAAYI,gBAAgB3C,QAAQ;oCAChEyC,kBAAkBnC;oCAClB;gCACF;4BACF;wBACF;oBACF;oBACA,IAAGmC,iBAAiB;wBAClB;oBACF;gBACF;YACF;YAEA,IAAGA,mBAAmBhD,OAAOY,SAAS,CAACoC,gBAAgB,EAAE;gBACvD,oDAAoD;gBACpD,MAAM7E,cAAc6B,OAAOY,SAAS,CAACoC,gBAAgB,CAACtE,OAAO;gBAC7D,MAAMA,UAAU,MAAMR,YAAYC,aAAaC;gBAE/C,IAAGM,SAAS;oBACV,MAAMyD,iBAAiBpD,mBAAmBL,SAAS3B;oBAEnD,MAAMiC,QAAQ;wBACZqC,MAAMjB,IAAIiB,IAAI;wBACde,SAAShC,IAAIgC,OAAO;wBACpBC,YAAY9B;wBACZW,MAAM2B;wBACNP,uBAAuBlC,IAAIkB,KAAK;oBAClC;oBAEA,MAAMrC,UAAU;wBACd4C,cAAc;wBACdhB,cAAcmC;wBACdlB,iBAAiB;wBACjBC,0BAA0B,IAAM;wBAChCC,oBAAoB,CAAC,+CAA+C,EAAEgB,iBAAiB;wBACvFf,cAAc,CAAC,YAAY,EAAEe,iBAAiB;wBAC9Cd,eAAe;wBACfiB,iBAAiB;oBACnB;oBAEA,IAAI;wBACF,MAAMxD,SAAS,MAAMwC,eAAenD,OAAOC;wBAE3C,IAAGU,UAAU,OAAOA,WAAW,YAAYA,OAAO4C,UAAU,EAAE;4BAC5DnG,IAAIoG,MAAM,CAAC7C,OAAO4C,UAAU;4BAC5B,IAAG5C,OAAOyC,OAAO,EAAE;gCACjB5D,OAAOuC,OAAO,CAACpB,OAAOyC,OAAO,EAAEtC,OAAO,CAAC,CAAC,CAAC2C,KAAKC,MAAM;oCAClDtG,IAAIuG,SAAS,CAACF,KAAKb,OAAOc;gCAC5B;4BACF;4BACAtG,IAAIwG,IAAI,CAACjD,OAAO0B,IAAI;wBACtB,OAAO;4BACLjF,IAAIqE,IAAI,CAACd;wBACX;oBACF,EAAE,OAAMb,OAAO;wBACblE,IAAI,CAAC,eAAe,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS;wBAChDzC,IAAIoG,MAAM,CAAC,KAAK/B,IAAI,CAAC;4BAAC3B,OAAOA,MAAMD,OAAO;wBAAA;oBAC5C;gBACF,OAAO;oBACLzC,IAAIoG,MAAM,CAAC,KAAK/B,IAAI,CAAC;wBAAC3B,OAAO;oBAAmB;gBAClD;YACF,OAAO;gBACL1C,IAAIoG,MAAM,CAAC,KAAK/B,IAAI,CAAC;oBAAC3B,OAAO;gBAAoB;YACnD;QACF,EAAE,OAAMA,OAAO;YACblE,IAAI,CAAC,sBAAsB,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS;YACvDzC,IAAIoG,MAAM,CAAC,KAAK/B,IAAI,CAAC;gBAAC3B,OAAOA,MAAMD,OAAO;YAAA;QAC5C;IACF;IAEA,OAAOqB;AACT;AAEA,MAAMkD,wBAAwB,CAC5BpD,QACA5B,WACAvB,QACAE,OACAkD;IAEA,MAAMoD,MAAM,IAAI7I,gBAAgB;QAAC8I,MAAMzG;IAAM;IAE7CwG,IAAIE,EAAE,CAAC,cAAc,OAAOC,IAAIpD;QAC9BxF,IAAI,CAAC,kCAAkC,EAAEwF,IAAIyC,GAAG,EAAE,EAAE,QAAQ;QAE5DW,GAAGD,EAAE,CAAC,WAAW,OAAO1E;YACtB,IAAI;gBACF,MAAMvC,OAAOjB,KAAKC,KAAK,CAACuD,QAAQ4E,QAAQ;gBAExC,mCAAmC;gBACnC,IAAIT,kBAAkB;gBAEtB,IAAGhD,OAAOY,SAAS,EAAE;oBACnB,KAAI,MAAM,CAACC,cAAcC,eAAe,IAAItC,OAAOuC,OAAO,CAACf,OAAOY,SAAS,EAAG;wBAC5E,IAAGE,eAAeE,MAAM,EAAE;4BACxB,KAAI,MAAMhC,SAAS8B,eAAeE,MAAM,CAAE;gCACxC,IAAGhC,MAAM0E,SAAS,EAAE;oCAClB,MAAMC,QAAQ3E,MAAM0E,SAAS,CAACC,KAAK,IAAI;oCACvC,IAAGA,UAAU,cAAcA,UAAUrH,KAAKsH,MAAM,EAAE;wCAChDZ,kBAAkBnC;wCAClB;oCACF;gCACF;4BACF;wBACF;wBACA,IAAGmC,iBAAiB;4BAClB;wBACF;oBACF;gBACF;gBAEA,IAAGA,mBAAmBhD,OAAOY,SAAS,CAACoC,gBAAgB,EAAE;oBACvD,MAAMtE,UAAU,MAAMR,YAAY8B,OAAOY,SAAS,CAACoC,gBAAgB,CAACtE,OAAO,EAAEN;oBAE7E,IAAGM,SAAS;wBACV,wCAAwC;wBACxC,MAAMyD,iBAAiBpD,mBAAmBL,SAAS3B;wBACnD,MAAMiC,QAAQ;4BACZqC,MAAM/E,KAAK+E,IAAI,IAAI;4BACnBwC,gBAAgB;gCACdC,YAAY;oCACVC,UAAU,CAAC,eAAe,EAAElH,QAAQ;gCACtC;gCACAmH,cAAc;gCACdC,UAAU3H,KAAKsH,MAAM,IAAI;4BAC3B;wBACF;wBAEA,MAAM3E,UAAU;4BACd4C,cAAc;4BACdhB,cAAcmC;4BACdlB,iBAAiB;4BACjBC,0BAA0B,IAAM;4BAChCC,oBAAoB,CAAC,+CAA+C,EAAEgB,iBAAiB;4BACvFf,cAAc,CAAC,YAAY,EAAEe,iBAAiB;4BAC9Cd,eAAe;4BACfiB,iBAAiB;wBACnB;wBAEA,MAAMxD,SAAS,MAAMwC,eAAenD,OAAOC;wBAE3C,8CAA8C;wBAC9C,IAAGU,UAAU,OAAOA,WAAW,YAAYA,OAAO4C,UAAU,EAAE;4BAC5D,qDAAqD;4BACrD,MAAMlB,OAAO1B,OAAO0B,IAAI,IAAI;4BAC5BmC,GAAGZ,IAAI,CAACvB;wBACV,OAAO;4BACL,0CAA0C;4BAC1CmC,GAAGZ,IAAI,CAACvH,KAAKQ,SAAS,CAAC8D;wBACzB;oBACF,OAAO;wBACL6D,GAAGZ,IAAI,CAACvH,KAAKQ,SAAS,CAAC;4BAACiD,OAAO;wBAAmB;oBACpD;gBACF,OAAO;oBACL0E,GAAGZ,IAAI,CAACvH,KAAKQ,SAAS,CAAC;wBAACiD,OAAO;oBAA8B;gBAC/D;YACF,EAAE,OAAMA,OAAO;gBACblE,IAAI,CAAC,iBAAiB,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS;gBAClD2E,GAAGZ,IAAI,CAACvH,KAAKQ,SAAS,CAAC;oBAACiD,OAAOA,MAAMD,OAAO;gBAAA;YAC9C;QACF;QAEA2E,GAAGD,EAAE,CAAC,SAAS;YACb3I,IAAI,+BAA+B,QAAQ;QAC7C;IACF;IAEA,OAAOyI;AACT;AAEA,MAAMa,cAAc,CAACC;IACnB,MAAMC,UAAkC,CAAC;IAEzC,IAAG,CAACnK,WAAWkK,UAAU;QACvB,OAAOC;IACT;IAEA,IAAI;QACF,MAAMC,aAAarK,aAAamK,SAAS;QACzC,MAAMG,QAAQD,WAAWtB,KAAK,CAAC;QAE/B,KAAI,MAAMwB,QAAQD,MAAO;YACvB,MAAME,cAAcD,KAAKhI,IAAI;YAE7B,gCAAgC;YAChC,IAAG,CAACiI,eAAeA,YAAYC,UAAU,CAAC,MAAM;gBAC9C;YACF;YAEA,yBAAyB;YACzB,MAAMC,aAAaF,YAAYG,OAAO,CAAC;YACvC,IAAGD,aAAa,GAAG;gBACjB,MAAMjC,MAAM+B,YAAYI,SAAS,CAAC,GAAGF,YAAYnI,IAAI;gBACrD,MAAMmG,QAAQ8B,YAAYI,SAAS,CAACF,aAAa,GAAGnI,IAAI;gBAExD,2BAA2B;gBAC3B,MAAMsI,aAAanC,MAAMoC,OAAO,CAAC,gBAAgB;gBAEjD,IAAGrC,KAAK;oBACN2B,OAAO,CAAC3B,IAAI,GAAGoC;gBACjB;YACF;QACF;IACF,EAAE,OAAM/F,OAAO;QACblE,IAAI,CAAC,qCAAqC,EAAEuJ,QAAQ,EAAE,EAAErF,MAAMD,OAAO,EAAE,EAAE,QAAQ;IACnF;IAEA,OAAOuF;AACT;AAEA,OAAO,MAAMW,aAAa,OACxBC,KACAC,WAA+B,IAAO,CAAA,CAAC,CAAA,CAAE;IAEzC,MAAM,EACJC,UAAU,KAAK,EACflF,MAAM,EACNC,QAAQ,KAAK,EACbnD,OAAO,WAAW,EAClBH,WAAW,IAAI,EACfC,YAAY,IAAI,EAChBG,QAAQ,KAAK,EACboI,SAAS,KAAK,EACdC,OAAO,KAAK,EACZC,WAAW,EACX9D,SAAS,EACT1E,SAAS,IAAI,EACd,GAAGmI;IAEJ,MAAMM,UAAU5K,cAAcqC;IAE9BnC,IAAI,GAAGsK,QAAQ,0CAA0C,CAAC,EAAE,QAAQnI;IAEpE,MAAMtC,UAAU8K,WAAW,CAACP;IAE5B,MAAM,EAACQ,cAAc,EAAC,GAAG/K,UAAUuF,MAAM;IAEzC,6CAA6C;IAC7C,MAAMyF,WAAW;QACfnL,YAAYoL,QAAQC,GAAG,IAAI;QAC3BrL,YAAYoL,QAAQC,GAAG,IAAI;QAC3BrL,YAAYoL,QAAQC,GAAG,IAAI;KAC5B;IAED,IAAIvB,UAAkC,CAAC;IAEvC,oEAAoE;IACpE,KAAI,MAAMD,WAAWsB,SAAU;QAC7B,MAAMG,cAAc1B,YAAYC;QAChC,IAAG3F,OAAOC,IAAI,CAACmH,aAAahG,MAAM,GAAG,GAAG;YACtChF,IAAI,CAAC,mCAAmC,EAAEuJ,SAAS,EAAE,QAAQpH;QAC/D;QACAqH,UAAU;YAAC,GAAGA,OAAO;YAAE,GAAGwB,WAAW;QAAA;IACvC;IAEA,wDAAwD;IACxD,IAAIC,eAAuB;QAACC,UAAU;QAAe,GAAG1B,OAAO;IAAA;IAE/D,mDAAmD;IACnD,IAAG7C,WAAW;QACZ,IAAI;YACF,MAAMwE,UAAU1K,KAAKC,KAAK,CAACiG;YAC3BsE,eAAe;gBAAC,GAAGA,YAAY;gBAAE,GAAGE,OAAO;YAAA;QAC7C,EAAE,OAAMC,QAAQ;YACdpL,IAAI,CAAC,EAAE,EAAEsK,QAAQ,gEAAgE,CAAC,EAAE,SAASnI;YAC7FkI,SAAS;YACT,OAAO;QACT;IACF;IAEAS,QAAQO,GAAG,GAAG;QAAC,GAAGP,QAAQO,GAAG;QAAE,GAAGJ,YAAY;IAAA;IAE9C,kEAAkE;IAClE,IAAGT,MAAM;QACPxK,IAAI,oDAAoD,QAAQmC;QAChEkI,SAAS;QACT,OAAO;IACT;IAEA,IAAGE,QAAQ;QACTG,QAAQY,KAAK,CAAC;QACd,MAAMvL,YAAY6K,kBAAkB;QACpCF,QAAQa,OAAO,CAAC;IAClB;IAEA,gCAAgC;IAChC,IAAIC,mBAAqC,CAAC;IAE1C,IAAI;QACF,MAAMC,aAAarG,UAAU1F,YAAYoL,QAAQC,GAAG,IAAI;QACxD/K,IAAI,CAAC,gCAAgC,EAAEyL,YAAY,EAAE,QAAQtJ;QAE7D,IAAG9C,WAAWoM,aAAa;YACzB,MAAMC,eAAe,MAAM,MAAM,CAACD;YAClCD,mBAAmBE,aAAa3H,OAAO,EAAEoG,cAAcuB,aAAavB,UAAU,IAAI,CAAC;YACnFnK,IAAI,yCAAyC,QAAQmC;YACrDnC,IAAI,CAAC,kBAAkB,EAAE4D,OAAOC,IAAI,CAAC2H,iBAAiBxF,SAAS,IAAI,CAAC,GAAGrG,IAAI,CAAC,OAAO,EAAE,QAAQwC;QAC/F,OAAO;YACLnC,IAAI,CAAC,8BAA8B,EAAEyL,WAAW,gBAAgB,CAAC,EAAE,QAAQtJ;QAC7E;IACF,EAAE,OAAM+B,OAAO;QACblE,IAAI,CAAC,iCAAiC,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS9B;IAClE,yCAAyC;IAC3C;IAEA,yCAAyC;IACzC,MAAMwJ,cAAgC;QACpC,GAAGH,gBAAgB;QACnBI,QAAQ;YACN,sBAAsB;gBACpBC,MAAML,iBAAiBI,MAAM,EAAE,CAAC,qBAAqB,EAAEC,SAAS;gBAChE3J,MAAMsJ,iBAAiBI,MAAM,EAAE,CAAC,qBAAqB,EAAE1J,QAAQA;gBAC/DH,UAAUyJ,iBAAiBI,MAAM,EAAE,CAAC,qBAAqB,EAAE7J,YAAYA;gBACvEC,WAAWwJ,iBAAiBI,MAAM,EAAE,CAAC,qBAAqB,EAAE5J,aAAaA;gBACzEC,QAAQuJ,iBAAiBI,MAAM,EAAE,CAAC,qBAAqB,EAAE3J,UAAUA;YACrE;QACF;IACF;IAEA,MAAMuB,YAAYoH,kBAAkB;IACpC5K,IAAI,CAAC,wBAAwB,EAAEwD,WAAW,EAAE,QAAQrB;IAEpD,IAAI;QACFuI,QAAQY,KAAK,CAAC;QAEd,MAAMvJ,WAAW4J,YAAYC,MAAM,AAAC,CAAC,qBAAqB,CAAE7J,QAAQ;QACpE,MAAME,SAAS0J,YAAYC,MAAM,AAAC,CAAC,qBAAqB,CAAE3J,MAAM;QAChE,MAAMC,OAAOyJ,YAAYC,MAAM,AAAC,CAAC,qBAAqB,CAAE1J,IAAI;QAE5DlC,IAAI,CAAC,wBAAwB,EAAEkC,KAAK,CAAC,EAAEH,UAAU,EAAE,QAAQI;QAC3DnC,IAAI,CAAC,kCAAkC,EAAEiC,QAAQ,EAAE,QAAQE;QAE3D,wBAAwB;QACxB,MAAM2J,aAAa,MAAM3G,oBACvBwG,aACAnI,WACAzB,UACAG,MACAC,OACAkD;QAGF,0BAA0B;QAC1B,MAAM0G,WAAWvD,sBACfmD,aACAnI,WACAvB,QACAE,OACAkD;QAGF,uBAAuB;QACvB0G,SAASpD,EAAE,CAAC,SAAS,CAACzE;YACpBlE,IAAI,CAAC,wBAAwB,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS9B;YACzDuI,QAAQsB,IAAI,CAAC;YACb3B,SAAS;YACT;QACF;QAEA,uBAAuB;QACvB,MAAM4B,SAASH,WAAWI,MAAM,CAACnK,UAAUG,MAAM;YAC/CwI,QAAQa,OAAO,CAAC;YAEhBzJ,oBACEC,UACA4J,YAAYC,MAAM,AAAC,CAAC,qBAAqB,CAAE5J,SAAS,EACpDC,QACAC,MACAC;YAGFjB,cAAcuJ,aAAalJ,IAAI,CAAC,CAACa;gBAC/B,IAAGA,UAAU;oBACXN,oBACEC,UACA4J,YAAYC,MAAM,AAAC,CAAC,qBAAqB,CAAE5J,SAAS,EACpDC,QACAC,MACAC,OACAC;gBAEJ;YACF;QACF;QAEA,+BAA+B;QAC/B6J,OAAOtD,EAAE,CAAC,SAAS,CAACzE;YAClBlE,IAAI,CAAC,sBAAsB,EAAEkE,MAAMD,OAAO,EAAE,EAAE,SAAS9B;YACvDuI,QAAQsB,IAAI,CAAC;YACb3B,SAAS;YACT;QACF;QAEA,2BAA2B;QAC3B,MAAM8B,WAAW;YACfnM,IAAI,oDAAoD,QAAQmC;YAChE8J,OAAOG,KAAK;YACZL,SAASK,KAAK;YACd/B,SAAS;QACX;QAEAS,QAAQnC,EAAE,CAAC,UAAUwD;QACrBrB,QAAQnC,EAAE,CAAC,WAAWwD;QAEtB,yBAAyB;QACzBrB,QAAQuB,KAAK,CAACC,MAAM;QAEpBtM,IAAI,mEAAmE,QAAQmC;QAE/E,uDAAuD;QACvD,OAAO;IACT,EAAE,OAAM+B,OAAO;QACblE,IAAI,CAAC,EAAE,EAAEsK,QAAQ,QAAQ,EAAEpG,MAAMD,OAAO,EAAE,EAAE,SAAS9B;QACrDuI,QAAQsB,IAAI,CAAC;QACb3B,SAAS;QACT,OAAO;IACT;AACF,EAAE"}
656
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/serverless/serverless.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport express from 'express';\nimport {readFileSync, existsSync, mkdirSync, writeFileSync} from 'fs';\nimport {homedir} from 'os';\nimport {resolve as pathResolve, join} from 'path';\nimport {WebSocketServer} from 'ws';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, removeFiles} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface ServerlessOptions {\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly host?: string;\n  readonly httpPort?: number;\n  readonly httpsPort?: number;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly test?: boolean;\n  readonly usePublicIp?: boolean;\n  readonly variables?: string;\n  readonly wsPort?: number;\n}\n\nexport type ServerlessCallback = (status: number)=> void;\n\ninterface PublicIpCache {\n  ip: string;\n  timestamp: number;\n}\n\ninterface ServerlessHandler {\n  readonly handler: string;\n  readonly events?: Array<{\n    readonly http?: {\n      readonly cors?: boolean;\n      readonly method?: string;\n      readonly path?: string;\n    };\n    readonly websocket?: {\n      readonly route?: string;\n    };\n  }>;\n}\n\ninterface ServerlessConfig {\n  readonly custom?: {\n    readonly 'serverless-offline'?: {\n      readonly cors?: boolean;\n      readonly host?: string;\n      readonly httpPort?: number;\n      readonly httpsPort?: number;\n      readonly wsPort?: number;\n    };\n  };\n  readonly functions?: Record<string, ServerlessHandler>;\n}\n\nconst getCacheDir = (): string => {\n  const cacheDir = join(homedir(), '.lex-cache');\n  if(!existsSync(cacheDir)) {\n    mkdirSync(cacheDir, {recursive: true});\n  }\n  return cacheDir;\n};\n\nconst getCachePath = (): string => join(getCacheDir(), 'public-ip.json');\n\nconst readPublicIpCache = (): PublicIpCache | null => {\n  const cachePath = getCachePath();\n  if(!existsSync(cachePath)) {\n    return null;\n  }\n\n  try {\n    const cacheData = readFileSync(cachePath, 'utf8');\n    const cache: PublicIpCache = JSON.parse(cacheData);\n\n    // Check if cache is older than 1 week\n    const oneWeekMs = 7 * 24 * 60 * 60 * 1000;\n    if(Date.now() - cache.timestamp > oneWeekMs) {\n      return null;\n    }\n\n    return cache;\n  } catch{\n    return null;\n  }\n};\n\nconst writePublicIpCache = (ip: string): void => {\n  const cachePath = getCachePath();\n  const cache: PublicIpCache = {\n    ip,\n    timestamp: Date.now()\n  };\n  writeFileSync(cachePath, JSON.stringify(cache, null, 2));\n};\n\nconst fetchPublicIp = (forceRefresh: boolean = false): Promise<string | undefined> => new Promise((resolve) => {\n  if(!forceRefresh) {\n    const cached = readPublicIpCache();\n    if(cached) {\n      resolve(cached.ip);\n      return;\n    }\n  }\n\n  // Use fetch instead of https\n  fetch('https://api.ipify.org')\n    .then((res) => res.text())\n    .then((data) => {\n      const ip = data.trim();\n      if(ip) {\n        writePublicIpCache(ip);\n      }\n      resolve(ip);\n    })\n    .catch(() => resolve(undefined));\n});\n\nconst displayServerStatus = (\n  httpPort: number,\n  httpsPort: number,\n  wsPort: number,\n  host: string,\n  quiet: boolean,\n  publicIp?: string\n) => {\n  if(quiet) {\n    return;\n  }\n\n  const httpUrl = `http://${host}:${httpPort}`;\n  const httpsUrl = `https://${host}:${httpsPort}`;\n  const wsUrl = `ws://${host}:${wsPort}`;\n  const wssUrl = `wss://${host}:${wsPort}`;\n\n  let urlLines = `${chalk.green('HTTP:')}      ${chalk.underline(httpUrl)}\\n`;\n  urlLines += `${chalk.green('HTTPS:')}     ${chalk.underline(httpsUrl)}\\n`;\n  urlLines += `${chalk.green('WebSocket:')} ${chalk.underline(wsUrl)}\\n`;\n  urlLines += `${chalk.green('WSS:')}       ${chalk.underline(wssUrl)}\\n`;\n\n  if(publicIp) {\n    urlLines += `\\n${chalk.green('Public:')}    ${chalk.underline(`http://${publicIp}:${httpPort}`)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🚀 Serverless Development Server Running')}\\n\\n${urlLines}\\n` +\n    `${chalk.yellow('Press Ctrl+C to stop the server')}`,\n    {\n      backgroundColor: '#1a1a1a',\n      borderColor: 'cyan',\n      borderStyle: 'round',\n      margin: 1,\n      padding: 1\n    }\n  );\n\n  console.log(`\\n${statusBox}\\n`);\n};\n\nconst loadHandler = async (handlerPath: string, outputDir: string) => {\n  try {\n    const fullPath = pathResolve(outputDir, handlerPath);\n    log(`Loading handler from: ${fullPath}`, 'info', false);\n\n    if(!existsSync(fullPath)) {\n      throw new Error(`Handler file not found: ${fullPath}`);\n    }\n\n    // Dynamic import of the handler with better error handling\n    try {\n      const handlerModule = await import(fullPath);\n      log(`Handler module loaded: ${Object.keys(handlerModule)}`, 'info', false);\n\n      const handler = handlerModule.default || handlerModule.handler || handlerModule;\n      log(`Handler found: ${typeof handler}`, 'info', false);\n\n      return handler;\n    } catch(importError) {\n      log(`Import error for handler ${handlerPath}: ${importError.message}`, 'error', false);\n      return null;\n    }\n  } catch(error) {\n    log(`Error loading handler ${handlerPath}: ${error.message}`, 'error', false);\n    return null;\n  }\n};\n\nconst captureConsoleLogs = (handler: (event: any, context: any)=> Promise<any>, quiet: boolean) => {\n  if(quiet) {\n    return handler;\n  }\n\n  return async (event: any, context: any) => {\n    // Capture console.log, console.error, etc.\n    const originalConsoleLog = console.log;\n    const originalConsoleError = console.error;\n    const originalConsoleWarn = console.warn;\n    const originalConsoleInfo = console.info;\n\n    const logs: string[] = [];\n\n    console.log = (...args: any[]) => {\n      logs.push(`[LOG] ${args.join(' ')}`);\n      originalConsoleLog(...args);\n    };\n\n    console.error = (...args: any[]) => {\n      logs.push(`[ERROR] ${args.join(' ')}`);\n      originalConsoleError(...args);\n    };\n\n    console.warn = (...args: any[]) => {\n      logs.push(`[WARN] ${args.join(' ')}`);\n      originalConsoleWarn(...args);\n    };\n\n    console.info = (...args: any[]) => {\n      logs.push(`[INFO] ${args.join(' ')}`);\n      originalConsoleInfo(...args);\n    };\n\n    try {\n      const result = await handler(event, context);\n\n      // Output captured logs\n      if(logs.length > 0) {\n        console.log(chalk.gray('--- Handler Console Output ---'));\n        logs.forEach((log) => console.log(chalk.gray(log)));\n        console.log(chalk.gray('--- End Handler Console Output ---'));\n      }\n\n      return result;\n    } finally {\n      // Restore original console methods\n      console.log = originalConsoleLog;\n      console.error = originalConsoleError;\n      console.warn = originalConsoleWarn;\n      console.info = originalConsoleInfo;\n    }\n  };\n};\n\nconst createExpressServer = async (\n  config: ServerlessConfig,\n  outputDir: string,\n  httpPort: number,\n  host: string,\n  quiet: boolean,\n  debug: boolean\n) => {\n  const app = express();\n\n  // Enable CORS\n  app.use((req, res, next) => {\n    res.header('Access-Control-Allow-Origin', '*');\n    res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, PATCH, OPTIONS');\n    res.header('Access-Control-Allow-Headers', '*');\n    res.header('Access-Control-Allow-Credentials', 'true');\n\n    if(req.method === 'OPTIONS') {\n      res.sendStatus(200);\n    } else {\n      next();\n    }\n  });\n\n  // Parse JSON bodies\n  app.use(express.json());\n\n  // Load GraphQL handler\n  const loadGraphQLSchema = async () => {\n    try {\n      // Try to find a GraphQL handler\n      let graphqlHandler = null;\n\n      if(config.functions) {\n        for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event.http && event.http.path) {\n                // Look for GraphQL endpoints\n                if(event.http.path === '/public' || event.http.path === '/graphql') {\n                  graphqlHandler = await loadHandler(functionConfig.handler, outputDir);\n                  break;\n                }\n              }\n            }\n          }\n          if(graphqlHandler) {\n            break;\n          }\n        }\n      }\n\n      if(graphqlHandler) {\n        log('Found GraphQL handler', 'info', quiet);\n        return graphqlHandler;\n      }\n      return null;\n    } catch(error) {\n      log(`Error loading GraphQL handler: ${error.message}`, 'error', quiet);\n      return null;\n    }\n  };\n\n  // Set up GraphQL handler for GraphQL requests\n  try {\n    const graphqlHandler = await loadGraphQLSchema();\n    if(graphqlHandler) {\n      // Find the GraphQL path from the serverless config\n      let graphqlPath = '/graphql'; // default fallback\n\n      if(config.functions) {\n        for(const [_functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event?.http?.path) {\n                graphqlPath = event.http.path;\n                break;\n              }\n            }\n          }\n          if(graphqlPath !== '/graphql') {\n            break;\n          }\n        }\n      }\n\n      // Set up GraphQL endpoint with enhanced console.log capture\n      app.use(graphqlPath, async (req, res) => {\n        // GraphQL Debug Logging\n        if(debug && req.body && req.body.query) {\n          log('🔍 GraphQL Debug Mode: Analyzing request...', 'info', false);\n          log(`📝 GraphQL Query: ${req.body.query}`, 'info', false);\n          if(req.body.variables) {\n            log(`📊 GraphQL Variables: ${JSON.stringify(req.body.variables, null, 2)}`, 'info', false);\n          }\n          if(req.body.operationName) {\n            log(`🏷️  GraphQL Operation: ${req.body.operationName}`, 'info', false);\n          }\n        }\n\n        // Enhanced console.log capture\n        const originalConsoleLog = console.log;\n        const logs: string[] = [];\n\n        console.log = (...args) => {\n          const logMessage = args.map((arg) =>\n            (typeof arg === 'object' ? JSON.stringify(arg, null, 2) : String(arg))\n          ).join(' ');\n          logs.push(logMessage);\n          originalConsoleLog(`[GraphQL] ${logMessage}`);\n        };\n\n        // Create context for the handler\n        const context = {\n          awsRequestId: 'test-request-id',\n          functionName: 'graphql',\n          functionVersion: '$LATEST',\n          getRemainingTimeInMillis: () => 30000,\n          invokedFunctionArn: 'arn:aws:lambda:us-east-1:123456789012:function:graphql',\n          logGroupName: '/aws/lambda/graphql',\n          logStreamName: 'test-log-stream',\n          req,\n          res\n        };\n\n        // Wrap handler with console log capture\n        const wrappedHandler = captureConsoleLogs(graphqlHandler, quiet);\n\n        try {\n          // Call the handler with GraphQL parameters\n          const result = await wrappedHandler({\n            body: JSON.stringify(req.body),\n            headers: req.headers,\n            httpMethod: 'POST',\n            path: graphqlPath,\n            queryStringParameters: {}\n          }, context);\n\n          // Restore console.log\n          console.log = originalConsoleLog;\n\n          // Handle the result\n          if(result && typeof result === 'object' && result.statusCode) {\n            res.status(result.statusCode);\n            if(result.headers) {\n              Object.entries(result.headers).forEach(([key, value]) => {\n                res.setHeader(key, String(value));\n              });\n            }\n            res.send(result.body);\n          } else {\n            res.json(result);\n          }\n        } catch(error) {\n          // Restore console.log\n          console.log = originalConsoleLog;\n          log(`GraphQL handler error: ${error.message}`, 'error', false);\n          res.status(500).json({error: error.message});\n        }\n      });\n\n      log(`GraphQL endpoint available at http://${host}:${httpPort}${graphqlPath}`, 'info', quiet);\n    }\n  } catch(error) {\n    log(`Error setting up GraphQL: ${error.message}`, 'error', quiet);\n  }\n\n  // Fallback for non-GraphQL routes - handle all remaining routes\n  app.use('/', async (req, res) => {\n    try {\n      const url = req.url || '/';\n      const method = req.method || 'GET';\n      const pathname = req.path || url.split('?')[0]; // Extract pathname without query string\n\n      log(`${method} ${url} (pathname: ${pathname})`, 'info', false);\n\n      // Find matching function\n      let matchedFunction = null;\n\n      if(config.functions) {\n        for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event.http) {\n                const eventPath = event.http.path || '/';\n                const eventMethod = event.http.method || 'GET';\n\n                // Improved path matching - compare pathname without query string\n                if(eventPath && eventPath === pathname && eventMethod === method) {\n                  matchedFunction = functionName;\n                  break;\n                }\n              }\n            }\n          }\n          if(matchedFunction) {\n            break;\n          }\n        }\n      }\n\n      if(matchedFunction && config.functions[matchedFunction]) {\n        // Resolve handler path relative to output directory\n        const handlerPath = config.functions[matchedFunction].handler;\n        const handler = await loadHandler(handlerPath, outputDir);\n\n        if(handler) {\n          const wrappedHandler = captureConsoleLogs(handler, quiet);\n\n          const event = {\n            body: req.body,\n            headers: req.headers,\n            httpMethod: method,\n            path: url,\n            queryStringParameters: req.query\n          };\n\n          const context = {\n            awsRequestId: 'test-request-id',\n            functionName: matchedFunction,\n            functionVersion: '$LATEST',\n            getRemainingTimeInMillis: () => 30000,\n            invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,\n            logGroupName: `/aws/lambda/${matchedFunction}`,\n            logStreamName: 'test-log-stream',\n            memoryLimitInMB: '128'\n          };\n\n          try {\n            const result = await wrappedHandler(event, context);\n\n            if(result && typeof result === 'object' && result.statusCode) {\n              res.status(result.statusCode);\n              if(result.headers) {\n                Object.entries(result.headers).forEach(([key, value]) => {\n                  res.setHeader(key, String(value));\n                });\n              }\n              res.send(result.body);\n            } else {\n              res.json(result);\n            }\n          } catch(error) {\n            log(`Handler error: ${error.message}`, 'error', false);\n            res.status(500).json({error: error.message});\n          }\n        } else {\n          res.status(404).json({error: 'Handler not found'});\n        }\n      } else {\n        res.status(404).json({error: 'Function not found'});\n      }\n    } catch(error) {\n      log(`Route handling error: ${error.message}`, 'error', false);\n      res.status(500).json({error: error.message});\n    }\n  });\n\n  return app;\n};\n\nconst createWebSocketServer = (\n  config: ServerlessConfig,\n  outputDir: string,\n  wsPort: number,\n  quiet: boolean,\n  debug: boolean\n) => {\n  const wss = new WebSocketServer({port: wsPort});\n\n  wss.on('connection', async (ws, req) => {\n    log(`WebSocket connection established: ${req.url}`, 'info', false);\n\n    ws.on('message', async (message) => {\n      try {\n        const data = JSON.parse(message.toString());\n\n        // Find matching WebSocket function\n        let matchedFunction = null;\n\n        if(config.functions) {\n          for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n            if(functionConfig.events) {\n              for(const event of functionConfig.events) {\n                if(event.websocket) {\n                  const route = event.websocket.route || '$connect';\n                  if(route === '$default' || route === data.action) {\n                    matchedFunction = functionName;\n                    break;\n                  }\n                }\n              }\n            }\n            if(matchedFunction) {\n              break;\n            }\n          }\n        }\n\n        if(matchedFunction && config.functions[matchedFunction]) {\n          const handler = await loadHandler(config.functions[matchedFunction].handler, outputDir);\n\n          if(handler) {\n            // Wrap handler with console log capture\n            const wrappedHandler = captureConsoleLogs(handler, quiet);\n            const event = {\n              body: data.body || null,\n              requestContext: {\n                apiGateway: {\n                  endpoint: `ws://localhost:${wsPort}`\n                },\n                connectionId: 'test-connection-id',\n                routeKey: data.action || '$default'\n              }\n            };\n\n            const context = {\n              awsRequestId: 'test-request-id',\n              functionName: matchedFunction,\n              functionVersion: '$LATEST',\n              getRemainingTimeInMillis: () => 30000,\n              invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,\n              logGroupName: `/aws/lambda/${matchedFunction}`,\n              logStreamName: 'test-log-stream',\n              memoryLimitInMB: '128'\n            };\n\n            const result = await wrappedHandler(event, context);\n\n            // Handle Lambda response format for WebSocket\n            if(result && typeof result === 'object' && result.statusCode) {\n              // This is a Lambda response object, extract the body\n              const body = result.body || '';\n              ws.send(body);\n            } else {\n              // This is a direct response, stringify it\n              ws.send(JSON.stringify(result));\n            }\n          } else {\n            ws.send(JSON.stringify({error: 'Handler not found'}));\n          }\n        } else {\n          ws.send(JSON.stringify({error: 'WebSocket function not found'}));\n        }\n      } catch(error) {\n        log(`WebSocket error: ${error.message}`, 'error', false);\n        ws.send(JSON.stringify({error: error.message}));\n      }\n    });\n\n    ws.on('close', () => {\n      log('WebSocket connection closed', 'info', false);\n    });\n  });\n\n  return wss;\n};\n\nconst loadEnvFile = (envPath: string): Record<string, string> => {\n  const envVars: Record<string, string> = {};\n\n  if(!existsSync(envPath)) {\n    return envVars;\n  }\n\n  try {\n    const envContent = readFileSync(envPath, 'utf8');\n    const lines = envContent.split('\\n');\n\n    for(const line of lines) {\n      const trimmedLine = line.trim();\n\n      // Skip empty lines and comments\n      if(!trimmedLine || trimmedLine.startsWith('#')) {\n        continue;\n      }\n\n      // Parse KEY=value format\n      const equalIndex = trimmedLine.indexOf('=');\n      if(equalIndex > 0) {\n        const key = trimmedLine.substring(0, equalIndex).trim();\n        const value = trimmedLine.substring(equalIndex + 1).trim();\n\n        // Remove quotes if present\n        const cleanValue = value.replace(/^[\"']|[\"']$/g, '');\n\n        if(key) {\n          envVars[key] = cleanValue;\n        }\n      }\n    }\n  } catch(error) {\n    log(`Warning: Could not load .env file at ${envPath}: ${error.message}`, 'warn', false);\n  }\n\n  return envVars;\n};\n\nexport const serverless = async (\n  cmd: ServerlessOptions,\n  callback: ServerlessCallback = () => ({})\n): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    debug = false,\n    host = 'localhost',\n    httpPort = 3000,\n    httpsPort = 3001,\n    quiet = false,\n    remove = false,\n    test = false,\n    usePublicIp,\n    variables,\n    wsPort = 3002\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} starting serverless development server...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath} = LexConfig.config;\n\n  // Load environment variables from .env files\n  const envPaths = [\n    pathResolve(process.cwd(), '.env'),\n    pathResolve(process.cwd(), '.env.local'),\n    pathResolve(process.cwd(), '.env.development')\n  ];\n\n  let envVars: Record<string, string> = {};\n\n  // Load from .env files in order (later files override earlier ones)\n  for(const envPath of envPaths) {\n    const fileEnvVars = loadEnvFile(envPath);\n    if(Object.keys(fileEnvVars).length > 0) {\n      log(`Loaded environment variables from: ${envPath}`, 'info', quiet);\n    }\n    envVars = {...envVars, ...fileEnvVars};\n  }\n\n  // Start with default NODE_ENV and loaded .env variables\n  let variablesObj: object = {NODE_ENV: 'development', ...envVars};\n\n  // Override with command line variables if provided\n  if(variables) {\n    try {\n      const cliVars = JSON.parse(variables);\n      variablesObj = {...variablesObj, ...cliVars};\n    } catch(_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  // If in test mode, exit early after loading environment variables\n  if(test) {\n    log('Test mode: Environment variables loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  if(remove) {\n    spinner.start('Cleaning output directory...');\n    await removeFiles(outputFullPath || '');\n    spinner.succeed('Successfully cleaned output directory!');\n  }\n\n  // Load serverless configuration\n  let serverlessConfig: ServerlessConfig = {};\n\n  try {\n    const configPath = config || pathResolve(process.cwd(), 'lex.config.mjs');\n    log(`Loading serverless config from: ${configPath}`, 'info', quiet);\n\n    if(existsSync(configPath)) {\n      const configModule = await import(configPath);\n      serverlessConfig = configModule.default?.serverless || configModule.serverless || {};\n      log('Serverless config loaded successfully', 'info', quiet);\n      log(`Loaded functions: ${Object.keys(serverlessConfig.functions || {}).join(', ')}`, 'info', quiet);\n    } else {\n      log(`No serverless config found at ${configPath}, using defaults`, 'warn', quiet);\n    }\n  } catch(error) {\n    log(`Error loading serverless config: ${error.message}`, 'error', quiet);\n    // Don't exit, continue with empty config\n  }\n\n  // Merge config with command line options\n  const finalConfig: ServerlessConfig = {\n    ...serverlessConfig,\n    custom: {\n      'serverless-offline': {\n        cors: serverlessConfig.custom?.['serverless-offline']?.cors !== false,\n        host: serverlessConfig.custom?.['serverless-offline']?.host || host,\n        httpPort: serverlessConfig.custom?.['serverless-offline']?.httpPort || httpPort,\n        httpsPort: serverlessConfig.custom?.['serverless-offline']?.httpsPort || httpsPort,\n        wsPort: serverlessConfig.custom?.['serverless-offline']?.wsPort || wsPort\n      }\n    }\n  };\n\n  const outputDir = outputFullPath || 'lib';\n  log(`Using output directory: ${outputDir}`, 'info', quiet);\n\n  try {\n    spinner.start('Starting serverless development server...');\n\n    const httpPort = finalConfig.custom!['serverless-offline']!.httpPort!;\n    const wsPort = finalConfig.custom!['serverless-offline']!.wsPort!;\n    const host = finalConfig.custom!['serverless-offline']!.host!;\n\n    log(`Creating HTTP server on ${host}:${httpPort}`, 'info', quiet);\n    log(`Creating WebSocket server on port ${wsPort}`, 'info', quiet);\n\n    // Create Express server\n    const expressApp = await createExpressServer(\n      finalConfig,\n      outputDir,\n      httpPort,\n      host,\n      quiet,\n      debug\n    );\n\n    // Create WebSocket server\n    const wsServer = createWebSocketServer(\n      finalConfig,\n      outputDir,\n      wsPort,\n      quiet,\n      debug\n    );\n\n    // Handle server errors\n    wsServer.on('error', (error) => {\n      log(`WebSocket server error: ${error.message}`, 'error', quiet);\n      spinner.fail('Failed to start WebSocket server.');\n      callback(1);\n      return;\n    });\n\n    // Start Express server\n    const server = expressApp.listen(httpPort, host, () => {\n      spinner.succeed('Serverless development server started.');\n\n      displayServerStatus(\n        httpPort,\n        finalConfig.custom!['serverless-offline']!.httpsPort!,\n        wsPort,\n        host,\n        quiet\n      );\n\n      fetchPublicIp(usePublicIp).then((publicIp) => {\n        if(publicIp) {\n          displayServerStatus(\n            httpPort,\n            finalConfig.custom!['serverless-offline']!.httpsPort!,\n            wsPort,\n            host,\n            quiet,\n            publicIp\n          );\n        }\n      });\n    });\n\n    // Handle Express server errors\n    server.on('error', (error) => {\n      log(`Express server error: ${error.message}`, 'error', quiet);\n      spinner.fail('Failed to start Express server.');\n      callback(1);\n      return;\n    });\n\n    // Handle graceful shutdown\n    const shutdown = () => {\n      log('\\nShutting down serverless development server...', 'info', quiet);\n      server.close();\n      wsServer.close();\n      callback(0);\n    };\n\n    process.on('SIGINT', shutdown);\n    process.on('SIGTERM', shutdown);\n\n    // Keep the process alive\n    process.stdin.resume();\n\n    log('Serverless development server is running. Press Ctrl+C to stop.', 'info', quiet);\n\n    // Don't call callback here, let the process stay alive\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('Failed to start serverless development server.');\n    callback(1);\n    return 1;\n  }\n};"],"names":["boxen","chalk","express","readFileSync","existsSync","mkdirSync","writeFileSync","homedir","resolve","pathResolve","join","WebSocketServer","LexConfig","createSpinner","removeFiles","log","getCacheDir","cacheDir","recursive","getCachePath","readPublicIpCache","cachePath","cacheData","cache","JSON","parse","oneWeekMs","Date","now","timestamp","writePublicIpCache","ip","stringify","fetchPublicIp","forceRefresh","Promise","cached","fetch","then","res","text","data","trim","catch","undefined","displayServerStatus","httpPort","httpsPort","wsPort","host","quiet","publicIp","httpUrl","httpsUrl","wsUrl","wssUrl","urlLines","green","underline","statusBox","cyan","bold","yellow","backgroundColor","borderColor","borderStyle","margin","padding","console","loadHandler","handlerPath","outputDir","fullPath","Error","handlerModule","Object","keys","handler","default","importError","message","error","captureConsoleLogs","event","context","originalConsoleLog","originalConsoleError","originalConsoleWarn","warn","originalConsoleInfo","info","logs","args","push","result","length","gray","forEach","createExpressServer","config","debug","app","use","req","next","header","method","sendStatus","json","loadGraphQLSchema","graphqlHandler","functions","functionName","functionConfig","entries","events","http","path","graphqlPath","_functionName","body","query","variables","operationName","logMessage","map","arg","String","awsRequestId","functionVersion","getRemainingTimeInMillis","invokedFunctionArn","logGroupName","logStreamName","wrappedHandler","headers","httpMethod","queryStringParameters","statusCode","status","key","value","setHeader","send","url","pathname","split","matchedFunction","eventPath","eventMethod","memoryLimitInMB","createWebSocketServer","wss","port","on","ws","toString","websocket","route","action","requestContext","apiGateway","endpoint","connectionId","routeKey","loadEnvFile","envPath","envVars","envContent","lines","line","trimmedLine","startsWith","equalIndex","indexOf","substring","cleanValue","replace","serverless","cmd","callback","cliName","remove","test","usePublicIp","spinner","parseConfig","outputFullPath","envPaths","process","cwd","fileEnvVars","variablesObj","NODE_ENV","cliVars","_error","env","start","succeed","serverlessConfig","configPath","configModule","finalConfig","custom","cors","expressApp","wsServer","fail","server","listen","shutdown","close","stdin","resume"],"mappings":"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"}
@@ -250,4 +250,4 @@ export const storybook = async (cmd, callback = ()=>({}))=>{
250
250
  }
251
251
  };
252
252
 
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/storybook/storybook.ts"],"sourcesContent":["import chalk from 'chalk';\nimport {execa} from 'execa';\nimport {existsSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {findTailwindCssPath, resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport interface StorybookOptions {\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly open?: boolean;\n  readonly port?: number;\n  readonly quiet?: boolean;\n  readonly static?: boolean;\n  readonly useLexConfig?: boolean;\n  readonly variables?: string;\n  readonly verbose?: boolean;\n}\n\nexport type StorybookCallback = (status: number) => void;\n\nconst findStoryFiles = (): string[] => {\n  const storyPatterns = [\n    '**/*.stories.{ts,tsx,js,jsx}',\n    '**/*.story.{ts,tsx,js,jsx}',\n    '**/stories/**/*.{ts,tsx,js,jsx}'\n  ];\n\n  const storyFiles: string[] = [];\n\n  storyPatterns.forEach((pattern) => {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**', '**/build/**']\n    });\n    storyFiles.push(...files);\n  });\n\n  return storyFiles;\n};\n\nconst checkStorybookInitialization = (): boolean => {\n  const projectConfigDir = pathResolve(process.cwd(), '.storybook');\n  const lexConfigDir = pathResolve(LexConfig.getLexDir(), '.storybook');\n\n  return existsSync(projectConfigDir) || existsSync(lexConfigDir);\n};\n\nconst extractProgressPercentage = (output: string): number | null => {\n  const lines = output.split('\\n');\n  for(const line of lines) {\n    if(line.includes('[webpack.Progress]') && line.includes('%')) {\n      const percentageMatch = line.match(/(\\d+)%/);\n      if(percentageMatch) {\n        return parseInt(percentageMatch[1]);\n      }\n    }\n  }\n  return null;\n};\n\nconst filterAndBeautifyOutput = (output: string, isVerbose: boolean): string => {\n  if(isVerbose) {\n    return output;\n  }\n\n  const lines = output.split('\\n');\n  const filteredLines = lines.filter((line) => {\n    if(line.includes('[webpack.Progress]')) {\n      return false;\n    }\n\n    if(line.includes('Storybook') ||\n      line.includes('Local:') ||\n      line.includes('http://localhost') ||\n      line.includes('info =>') ||\n      line.includes('Starting') ||\n      line.includes('ready') ||\n      line.includes('error') ||\n      line.includes('warning')) {\n      return true;\n    }\n\n    return true;\n  });\n\n  return filteredLines.join('\\n');\n};\n\nconst beautifyOutput = (output: string): string => output\n  .replace(/Storybook v[\\d.]+/g, chalk.cyan('$&'))\n  .replace(/info =>/g, chalk.blue('info =>'))\n  .replace(/Local:/g, chalk.green('Local:'))\n  .replace(/On your network:/g, chalk.green('On your network:'))\n  .replace(/Storybook.*started/g, chalk.green('$&'))\n  .replace(/Storybook.*ready/g, chalk.green('$&'))\n  .replace(/error/g, chalk.red('$&'))\n  .replace(/warning/g, chalk.yellow('$&'))\n  .replace(/(\\d+)%/g, chalk.magenta('$1%'));\n\nexport const storybook = async (cmd: StorybookOptions, callback: StorybookCallback = () => ({})): Promise<number> => {\n  const {cliName = 'Lex', config, open = false, port = 6007, quiet, static: staticBuild = false, useLexConfig = false, variables, verbose = false} = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(chalk.cyan(`${cliName} starting Storybook...`), 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  let variablesObj: object = {NODE_ENV: 'development'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  spinner.start('Finding story files...');\n  const storyFiles = findStoryFiles();\n\n  if(storyFiles.length === 0) {\n    spinner.fail('No story files found in the project.');\n    log('Please create story files with .stories.ts/.stories.js extensions or in a stories/ directory.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  spinner.succeed(`Found ${storyFiles.length} story file(s)`);\n\n  const tailwindCssPath = findTailwindCssPath();\n\n  console.log({tailwindCssPath});\n  if(tailwindCssPath) {\n    if(!quiet) {\n      log(chalk.green(`✓ Tailwind CSS integration detected: ${tailwindCssPath}`), 'info', quiet);\n    }\n  } else {\n    if(!quiet) {\n      log(chalk.yellow('⚠ No Tailwind CSS file found in project'), 'info', quiet);\n      log(chalk.gray('Create a tailwind.css file with @tailwind directives for full Tailwind support'), 'info', quiet);\n    }\n  }\n\n  if(!checkStorybookInitialization()) {\n    spinner.fail('Storybook is not initialized in this project or in Lex.');\n    log('Please run \"npx storybook@latest init\" to set up Storybook in your project, or ensure Lex has a valid .storybook configuration.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const projectConfigDir = pathResolve(process.cwd(), '.storybook');\n  const lexConfigDir = pathResolve(LexConfig.getLexDir(), '.storybook');\n\n  let configDir = config;\n  if(!configDir) {\n    configDir = lexConfigDir;\n    if(!useLexConfig && existsSync(projectConfigDir)) {\n      configDir = projectConfigDir;\n    }\n  }\n\n  if(!quiet) {\n    log(chalk.gray(`Project config dir: ${projectConfigDir} (exists: ${existsSync(projectConfigDir)})`), 'info', quiet);\n    log(chalk.gray(`Lex config dir: ${lexConfigDir} (exists: ${existsSync(lexConfigDir)})`), 'info', quiet);\n    if(useLexConfig) {\n      log(chalk.blue('Using Lex Storybook configuration (--use-lex-config flag)'), 'info', quiet);\n    }\n    log(chalk.gray(`Initial config dir: ${configDir}`), 'info', quiet);\n  }\n\n  if(configDir === lexConfigDir) {\n    if(!quiet) {\n      log(chalk.blue('Using Lex config, will create temporary config in project .storybook directory'), 'info', quiet);\n    }\n    const projectStorybookDir = pathResolve(process.cwd(), '.storybook');\n\n    const fs = await import('fs/promises');\n    await fs.mkdir(projectStorybookDir, {recursive: true});\n\n    const lexMainPath = pathResolve(lexConfigDir, 'main.ts');\n    const projectMainPath = pathResolve(projectStorybookDir, 'main.ts');\n    let mainContent = await fs.readFile(lexMainPath, 'utf8');\n\n    mainContent = mainContent.replace(\n      /stories:\\s*\\[.*?\\]/,\n      `stories: ['${pathResolve(process.cwd(), 'src/**/*.stories.@(ts|tsx)')}', '${pathResolve(process.cwd(), 'src/**/*.mdx')}']`\n    );\n\n    const lexNodeModules = pathResolve(LexConfig.getLexDir(), 'node_modules');\n    mainContent = mainContent.replace(\n      /const lexModule = \\(modulePath: string\\) => resolve\\(getLexNodeModulesPath\\(\\), modulePath\\);/,\n      `const lexModule = (modulePath: string) => resolve('${lexNodeModules}', modulePath);`\n    );\n\n    await fs.writeFile(projectMainPath, mainContent);\n\n    const lexPreviewPath = pathResolve(lexConfigDir, 'preview.tsx');\n    if(existsSync(lexPreviewPath)) {\n      const previewContent = await fs.readFile(lexPreviewPath, 'utf8');\n      await fs.writeFile(pathResolve(projectStorybookDir, 'preview.tsx'), previewContent);\n    }\n\n    configDir = projectStorybookDir;\n  }\n  if(!existsSync(configDir)) {\n    spinner.fail('Storybook configuration not found.');\n    log(`Project config: ${projectConfigDir}`, 'info', quiet);\n    log(`Lex config: ${lexConfigDir}`, 'info', quiet);\n    log('Please run \"npx storybook@latest init\" to set up Storybook in your project, or ensure Lex has a valid .storybook configuration.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const storybookPath = resolveBinaryPath('storybook');\n\n  if(!storybookPath) {\n    log(`\\n${cliName} Error: storybook binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your Storybook installation.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const storybookArgs = [staticBuild ? 'build' : 'dev'];\n  storybookArgs.push('--config-dir', configDir);\n\n  if(port) {\n    storybookArgs.push('--port', port.toString());\n  }\n\n  if(open) {\n    storybookArgs.push('--open');\n  }\n\n  if(staticBuild) {\n    const outputDir = pathResolve(process.cwd(), 'storybook-static');\n    storybookArgs.push('--output-dir', outputDir);\n  }\n\n  if(!quiet) {\n    log(chalk.gray(`Config directory: ${configDir}`), 'info', quiet);\n  }\n\n  process.env.TAILWIND_CSS_PATH = tailwindCssPath;\n\n  try {\n    spinner.start(staticBuild ? 'Building static Storybook...' : 'Starting Storybook development server...');\n\n    const storybookProcess = execa(storybookPath as any, storybookArgs, {\n      encoding: 'utf8',\n      env: {\n        ...process.env,\n        LEX_QUIET: quiet,\n        LEX_VERBOSE: verbose,\n        STORYBOOK_OPEN: open,\n        ...(tailwindCssPath && {TAILWIND_CSS_PATH: tailwindCssPath})\n      } as any,\n      stdio: 'pipe'\n    });\n\n    let urlFound = false;\n    let lastProgressPercentage = 0;\n\n    storybookProcess.stdout?.on('data', (data) => {\n      const output = data.toString();\n      const progressPercentage = extractProgressPercentage(output);\n\n      if(progressPercentage !== null && progressPercentage !== lastProgressPercentage) {\n        lastProgressPercentage = progressPercentage;\n        const action = staticBuild ? 'Building' : 'Starting';\n        (spinner as any).text = `${action} Storybook... ${progressPercentage}%`;\n        process.stdout.write(`\\nWebpack Progress: ${chalk.magenta(`${progressPercentage}%`)}\\n`);\n      }\n\n      const filteredOutput = filterAndBeautifyOutput(output, verbose);\n      const beautifiedOutput = beautifyOutput(filteredOutput);\n\n      if(!urlFound && (output.includes('Local:') || output.includes('http://localhost') || output.includes('Storybook'))) {\n        spinner.succeed(chalk.green('Storybook development server is ready!'));\n        urlFound = true;\n      }\n\n      if(filteredOutput.trim()) {\n        process.stdout.write(beautifiedOutput);\n      }\n    });\n\n    storybookProcess.stderr?.on('data', (data) => {\n      const output = data.toString();\n      const filteredOutput = filterAndBeautifyOutput(output, verbose);\n      const beautifiedOutput = beautifyOutput(filteredOutput);\n\n      if(filteredOutput.trim()) {\n        process.stderr.write(beautifiedOutput);\n      }\n    });\n\n    try {\n      await storybookProcess;\n      if(!urlFound) {\n        spinner.succeed(chalk.green('Storybook development server started.'));\n      }\n      callback(0);\n      return 0;\n    } catch(error) {\n      spinner.fail(chalk.red('There was an error while running storybook.'));\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('There was an error while running storybook.');\n    callback(1);\n    return 1;\n  }\n};"],"names":["chalk","execa","existsSync","sync","globSync","resolve","pathResolve","LexConfig","createSpinner","findTailwindCssPath","resolveBinaryPath","log","findStoryFiles","storyPatterns","storyFiles","forEach","pattern","files","cwd","process","ignore","push","checkStorybookInitialization","projectConfigDir","lexConfigDir","getLexDir","extractProgressPercentage","output","lines","split","line","includes","percentageMatch","match","parseInt","filterAndBeautifyOutput","isVerbose","filteredLines","filter","join","beautifyOutput","replace","cyan","blue","green","red","yellow","magenta","storybook","cmd","callback","cliName","config","open","port","quiet","static","staticBuild","useLexConfig","variables","verbose","spinner","parseConfig","variablesObj","NODE_ENV","JSON","parse","_error","env","start","length","fail","succeed","tailwindCssPath","console","gray","configDir","projectStorybookDir","fs","mkdir","recursive","lexMainPath","projectMainPath","mainContent","readFile","lexNodeModules","writeFile","lexPreviewPath","previewContent","storybookPath","storybookArgs","toString","outputDir","TAILWIND_CSS_PATH","storybookProcess","encoding","LEX_QUIET","LEX_VERBOSE","STORYBOOK_OPEN","stdio","urlFound","lastProgressPercentage","stdout","on","data","progressPercentage","action","text","write","filteredOutput","beautifiedOutput","trim","stderr","error","message"],"mappings":"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"}
253
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/storybook/storybook.ts"],"sourcesContent":["import chalk from 'chalk';\nimport {execa} from 'execa';\nimport {existsSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {findTailwindCssPath, resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport interface StorybookOptions {\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly open?: boolean;\n  readonly port?: number;\n  readonly quiet?: boolean;\n  readonly static?: boolean;\n  readonly useLexConfig?: boolean;\n  readonly variables?: string;\n  readonly verbose?: boolean;\n}\n\nexport type StorybookCallback = (status: number)=> void;\n\nconst findStoryFiles = (): string[] => {\n  const storyPatterns = [\n    '**/*.stories.{ts,tsx,js,jsx}',\n    '**/*.story.{ts,tsx,js,jsx}',\n    '**/stories/**/*.{ts,tsx,js,jsx}'\n  ];\n\n  const storyFiles: string[] = [];\n\n  storyPatterns.forEach((pattern) => {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**', '**/build/**']\n    });\n    storyFiles.push(...files);\n  });\n\n  return storyFiles;\n};\n\nconst checkStorybookInitialization = (): boolean => {\n  const projectConfigDir = pathResolve(process.cwd(), '.storybook');\n  const lexConfigDir = pathResolve(LexConfig.getLexDir(), '.storybook');\n\n  return existsSync(projectConfigDir) || existsSync(lexConfigDir);\n};\n\nconst extractProgressPercentage = (output: string): number | null => {\n  const lines = output.split('\\n');\n  for(const line of lines) {\n    if(line.includes('[webpack.Progress]') && line.includes('%')) {\n      const percentageMatch = line.match(/(\\d+)%/);\n      if(percentageMatch) {\n        return parseInt(percentageMatch[1]);\n      }\n    }\n  }\n  return null;\n};\n\nconst filterAndBeautifyOutput = (output: string, isVerbose: boolean): string => {\n  if(isVerbose) {\n    return output;\n  }\n\n  const lines = output.split('\\n');\n  const filteredLines = lines.filter((line) => {\n    if(line.includes('[webpack.Progress]')) {\n      return false;\n    }\n\n    if(line.includes('Storybook') ||\n      line.includes('Local:') ||\n      line.includes('http://localhost') ||\n      line.includes('info =>') ||\n      line.includes('Starting') ||\n      line.includes('ready') ||\n      line.includes('error') ||\n      line.includes('warning')) {\n      return true;\n    }\n\n    return true;\n  });\n\n  return filteredLines.join('\\n');\n};\n\nconst beautifyOutput = (output: string): string => output\n  .replace(/Storybook v[\\d.]+/g, chalk.cyan('$&'))\n  .replace(/info =>/g, chalk.blue('info =>'))\n  .replace(/Local:/g, chalk.green('Local:'))\n  .replace(/On your network:/g, chalk.green('On your network:'))\n  .replace(/Storybook.*started/g, chalk.green('$&'))\n  .replace(/Storybook.*ready/g, chalk.green('$&'))\n  .replace(/error/g, chalk.red('$&'))\n  .replace(/warning/g, chalk.yellow('$&'))\n  .replace(/(\\d+)%/g, chalk.magenta('$1%'));\n\nexport const storybook = async (cmd: StorybookOptions, callback: StorybookCallback = () => ({})): Promise<number> => {\n  const {cliName = 'Lex', config, open = false, port = 6007, quiet, static: staticBuild = false, useLexConfig = false, variables, verbose = false} = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(chalk.cyan(`${cliName} starting Storybook...`), 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  let variablesObj: object = {NODE_ENV: 'development'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  spinner.start('Finding story files...');\n  const storyFiles = findStoryFiles();\n\n  if(storyFiles.length === 0) {\n    spinner.fail('No story files found in the project.');\n    log('Please create story files with .stories.ts/.stories.js extensions or in a stories/ directory.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  spinner.succeed(`Found ${storyFiles.length} story file(s)`);\n\n  const tailwindCssPath = findTailwindCssPath();\n\n  console.log({tailwindCssPath});\n  if(tailwindCssPath) {\n    if(!quiet) {\n      log(chalk.green(`✓ Tailwind CSS integration detected: ${tailwindCssPath}`), 'info', quiet);\n    }\n  } else {\n    if(!quiet) {\n      log(chalk.yellow('⚠ No Tailwind CSS file found in project'), 'info', quiet);\n      log(chalk.gray('Create a tailwind.css file with @tailwind directives for full Tailwind support'), 'info', quiet);\n    }\n  }\n\n  if(!checkStorybookInitialization()) {\n    spinner.fail('Storybook is not initialized in this project or in Lex.');\n    log('Please run \"npx storybook@latest init\" to set up Storybook in your project, or ensure Lex has a valid .storybook configuration.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const projectConfigDir = pathResolve(process.cwd(), '.storybook');\n  const lexConfigDir = pathResolve(LexConfig.getLexDir(), '.storybook');\n\n  let configDir = config;\n  if(!configDir) {\n    configDir = lexConfigDir;\n    if(!useLexConfig && existsSync(projectConfigDir)) {\n      configDir = projectConfigDir;\n    }\n  }\n\n  if(!quiet) {\n    log(chalk.gray(`Project config dir: ${projectConfigDir} (exists: ${existsSync(projectConfigDir)})`), 'info', quiet);\n    log(chalk.gray(`Lex config dir: ${lexConfigDir} (exists: ${existsSync(lexConfigDir)})`), 'info', quiet);\n    if(useLexConfig) {\n      log(chalk.blue('Using Lex Storybook configuration (--use-lex-config flag)'), 'info', quiet);\n    }\n    log(chalk.gray(`Initial config dir: ${configDir}`), 'info', quiet);\n  }\n\n  if(configDir === lexConfigDir) {\n    if(!quiet) {\n      log(chalk.blue('Using Lex config, will create temporary config in project .storybook directory'), 'info', quiet);\n    }\n    const projectStorybookDir = pathResolve(process.cwd(), '.storybook');\n\n    const fs = await import('fs/promises');\n    await fs.mkdir(projectStorybookDir, {recursive: true});\n\n    const lexMainPath = pathResolve(lexConfigDir, 'main.ts');\n    const projectMainPath = pathResolve(projectStorybookDir, 'main.ts');\n    let mainContent = await fs.readFile(lexMainPath, 'utf8');\n\n    mainContent = mainContent.replace(\n      /stories:\\s*\\[.*?\\]/,\n      `stories: ['${pathResolve(process.cwd(), 'src/**/*.stories.@(ts|tsx)')}', '${pathResolve(process.cwd(), 'src/**/*.mdx')}']`\n    );\n\n    const lexNodeModules = pathResolve(LexConfig.getLexDir(), 'node_modules');\n    mainContent = mainContent.replace(\n      /const lexModule = \\(modulePath: string\\) => resolve\\(getLexNodeModulesPath\\(\\), modulePath\\);/,\n      `const lexModule = (modulePath: string) => resolve('${lexNodeModules}', modulePath);`\n    );\n\n    await fs.writeFile(projectMainPath, mainContent);\n\n    const lexPreviewPath = pathResolve(lexConfigDir, 'preview.tsx');\n    if(existsSync(lexPreviewPath)) {\n      const previewContent = await fs.readFile(lexPreviewPath, 'utf8');\n      await fs.writeFile(pathResolve(projectStorybookDir, 'preview.tsx'), previewContent);\n    }\n\n    configDir = projectStorybookDir;\n  }\n  if(!existsSync(configDir)) {\n    spinner.fail('Storybook configuration not found.');\n    log(`Project config: ${projectConfigDir}`, 'info', quiet);\n    log(`Lex config: ${lexConfigDir}`, 'info', quiet);\n    log('Please run \"npx storybook@latest init\" to set up Storybook in your project, or ensure Lex has a valid .storybook configuration.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const storybookPath = resolveBinaryPath('storybook');\n\n  if(!storybookPath) {\n    log(`\\n${cliName} Error: storybook binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your Storybook installation.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const storybookArgs = [staticBuild ? 'build' : 'dev'];\n  storybookArgs.push('--config-dir', configDir);\n\n  if(port) {\n    storybookArgs.push('--port', port.toString());\n  }\n\n  if(open) {\n    storybookArgs.push('--open');\n  }\n\n  if(staticBuild) {\n    const outputDir = pathResolve(process.cwd(), 'storybook-static');\n    storybookArgs.push('--output-dir', outputDir);\n  }\n\n  if(!quiet) {\n    log(chalk.gray(`Config directory: ${configDir}`), 'info', quiet);\n  }\n\n  process.env.TAILWIND_CSS_PATH = tailwindCssPath;\n\n  try {\n    spinner.start(staticBuild ? 'Building static Storybook...' : 'Starting Storybook development server...');\n\n    const storybookProcess = execa(storybookPath as any, storybookArgs, {\n      encoding: 'utf8',\n      env: {\n        ...process.env,\n        LEX_QUIET: quiet,\n        LEX_VERBOSE: verbose,\n        STORYBOOK_OPEN: open,\n        ...(tailwindCssPath && {TAILWIND_CSS_PATH: tailwindCssPath})\n      } as any,\n      stdio: 'pipe'\n    });\n\n    let urlFound = false;\n    let lastProgressPercentage = 0;\n\n    storybookProcess.stdout?.on('data', (data) => {\n      const output = data.toString();\n      const progressPercentage = extractProgressPercentage(output);\n\n      if(progressPercentage !== null && progressPercentage !== lastProgressPercentage) {\n        lastProgressPercentage = progressPercentage;\n        const action = staticBuild ? 'Building' : 'Starting';\n        (spinner as any).text = `${action} Storybook... ${progressPercentage}%`;\n        process.stdout.write(`\\nWebpack Progress: ${chalk.magenta(`${progressPercentage}%`)}\\n`);\n      }\n\n      const filteredOutput = filterAndBeautifyOutput(output, verbose);\n      const beautifiedOutput = beautifyOutput(filteredOutput);\n\n      if(!urlFound && (output.includes('Local:') || output.includes('http://localhost') || output.includes('Storybook'))) {\n        spinner.succeed(chalk.green('Storybook development server is ready!'));\n        urlFound = true;\n      }\n\n      if(filteredOutput.trim()) {\n        process.stdout.write(beautifiedOutput);\n      }\n    });\n\n    storybookProcess.stderr?.on('data', (data) => {\n      const output = data.toString();\n      const filteredOutput = filterAndBeautifyOutput(output, verbose);\n      const beautifiedOutput = beautifyOutput(filteredOutput);\n\n      if(filteredOutput.trim()) {\n        process.stderr.write(beautifiedOutput);\n      }\n    });\n\n    try {\n      await storybookProcess;\n      if(!urlFound) {\n        spinner.succeed(chalk.green('Storybook development server started.'));\n      }\n      callback(0);\n      return 0;\n    } catch(error) {\n      spinner.fail(chalk.red('There was an error while running storybook.'));\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('There was an error while running storybook.');\n    callback(1);\n    return 1;\n  }\n};"],"names":["chalk","execa","existsSync","sync","globSync","resolve","pathResolve","LexConfig","createSpinner","findTailwindCssPath","resolveBinaryPath","log","findStoryFiles","storyPatterns","storyFiles","forEach","pattern","files","cwd","process","ignore","push","checkStorybookInitialization","projectConfigDir","lexConfigDir","getLexDir","extractProgressPercentage","output","lines","split","line","includes","percentageMatch","match","parseInt","filterAndBeautifyOutput","isVerbose","filteredLines","filter","join","beautifyOutput","replace","cyan","blue","green","red","yellow","magenta","storybook","cmd","callback","cliName","config","open","port","quiet","static","staticBuild","useLexConfig","variables","verbose","spinner","parseConfig","variablesObj","NODE_ENV","JSON","parse","_error","env","start","length","fail","succeed","tailwindCssPath","console","gray","configDir","projectStorybookDir","fs","mkdir","recursive","lexMainPath","projectMainPath","mainContent","readFile","lexNodeModules","writeFile","lexPreviewPath","previewContent","storybookPath","storybookArgs","toString","outputDir","TAILWIND_CSS_PATH","storybookProcess","encoding","LEX_QUIET","LEX_VERBOSE","STORYBOOK_OPEN","stdio","urlFound","lastProgressPercentage","stdout","on","data","progressPercentage","action","text","write","filteredOutput","beautifiedOutput","trim","stderr","error","message"],"mappings":"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"}
@@ -36,4 +36,4 @@ export const versions = (cmd, callback)=>{
36
36
  return Promise.resolve(0);
37
37
  };
38
38
 
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy92ZXJzaW9ucy92ZXJzaW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcblxuaW1wb3J0IHtnZXRMZXhQYWNrYWdlSnNvblBhdGh9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpIHx8ICdOL0EnO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGplc3Q6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5qZXN0KSxcbiAgbGV4OiBwYWNrYWdlSnNvbi52ZXJzaW9uLFxuICBzd2M6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5bJ0Bzd2MvY29yZSddKSxcbiAgdHlwZXNjcmlwdDogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/LnR5cGVzY3JpcHQpLFxuICB3ZWJwYWNrOiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8ud2VicGFjaylcbn07XG5cbmV4cG9ydCBjb25zdCBqc29uVmVyc2lvbnMgPSAobGV4UGFja2FnZXMpID0+IE9iamVjdC5rZXlzKGxleFBhY2thZ2VzKS5yZWR1Y2UoKGxpc3QsIGtleSkgPT4ge1xuICBsaXN0W2tleV0gPSBwYWNrYWdlc1trZXldO1xuICByZXR1cm4gbGlzdDtcbn0sIHt9KTtcblxuZXhwb3J0IGludGVyZmFjZSBWZXJzaW9uc0NtZCB7XG4gIHJlYWRvbmx5IGpzb24/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY29uc3QgdmVyc2lvbnMgPSAoY21kOiBWZXJzaW9uc0NtZCwgY2FsbGJhY2s6IChzdGF0dXM6IG51bWJlcikgPT4gdm9pZCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGlmKGNtZC5qc29uKSB7XG4gICAgY29uc29sZS5sb2coSlNPTi5zdHJpbmdpZnkoanNvblZlcnNpb25zKHBhY2thZ2VzKSkpO1xuICB9IGVsc2Uge1xuICAgIGxvZygnVmVyc2lvbnM6JywgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIExleDogJHtwYWNrYWdlcy5sZXh9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKCcgIC0tLS0tLS0tLS0nLCAnbm90ZScsIGZhbHNlKTtcbiAgICBsb2coYCAgU1dDOiAke3BhY2thZ2VzLnN3Y31gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgSmVzdDogJHtwYWNrYWdlcy5qZXN0fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBUeXBlc2NyaXB0OiAke3BhY2thZ2VzLnR5cGVzY3JpcHR9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFdlYnBhY2s6ICR7cGFja2FnZXMud2VicGFja31gLCAnaW5mbycsIGZhbHNlKTtcbiAgfVxuXG4gIGlmKGNhbGxiYWNrKSB7XG4gICAgY2FsbGJhY2soMCk7XG4gIH1cblxuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDApO1xufTsiXSwibmFtZXMiOlsicmVhZEZpbGVTeW5jIiwiZ2V0TGV4UGFja2FnZUpzb25QYXRoIiwibG9nIiwicGFja2FnZVBhdGgiLCJwYWNrYWdlSnNvbiIsIkpTT04iLCJwYXJzZSIsInBhcnNlVmVyc2lvbiIsInBhY2thZ2VWZXJzaW9uIiwicmVwbGFjZSIsInBhY2thZ2VzIiwiamVzdCIsImRlcGVuZGVuY2llcyIsImxleCIsInZlcnNpb24iLCJzd2MiLCJ0eXBlc2NyaXB0Iiwid2VicGFjayIsImpzb25WZXJzaW9ucyIsImxleFBhY2thZ2VzIiwiT2JqZWN0Iiwia2V5cyIsInJlZHVjZSIsImxpc3QiLCJrZXkiLCJ2ZXJzaW9ucyIsImNtZCIsImNhbGxiYWNrIiwianNvbiIsImNvbnNvbGUiLCJzdHJpbmdpZnkiLCJQcm9taXNlIiwicmVzb2x2ZSJdLCJtYXBwaW5ncyI6IkFBQUE7OztDQUdDLEdBQ0QsU0FBUUEsWUFBWSxRQUFPLEtBQUs7QUFFaEMsU0FBUUMscUJBQXFCLFFBQU8sc0JBQXNCO0FBQzFELFNBQVFDLEdBQUcsUUFBTyxxQkFBcUI7QUFFdkMsTUFBTUMsY0FBY0Y7QUFDcEIsTUFBTUcsY0FBY0MsS0FBS0MsS0FBSyxDQUFDTixhQUFhRyxhQUFhO0FBRXpELE9BQU8sTUFBTUksZUFBZSxDQUFDQyxpQkFBbUNBLGdCQUFnQkMsUUFBUSxPQUFPLE9BQU8sTUFBTTtBQUU1RyxPQUFPLE1BQU1DLFdBQVc7SUFDdEJDLE1BQU1KLGFBQWFILGFBQWFRLGNBQWNEO0lBQzlDRSxLQUFLVCxZQUFZVSxPQUFPO0lBQ3hCQyxLQUFLUixhQUFhSCxhQUFhUSxjQUFjLENBQUMsWUFBWTtJQUMxREksWUFBWVQsYUFBYUgsYUFBYVEsY0FBY0k7SUFDcERDLFNBQVNWLGFBQWFILGFBQWFRLGNBQWNLO0FBQ25ELEVBQUU7QUFFRixPQUFPLE1BQU1DLGVBQWUsQ0FBQ0MsY0FBZ0JDLE9BQU9DLElBQUksQ0FBQ0YsYUFBYUcsTUFBTSxDQUFDLENBQUNDLE1BQU1DO1FBQ2xGRCxJQUFJLENBQUNDLElBQUksR0FBR2QsUUFBUSxDQUFDYyxJQUFJO1FBQ3pCLE9BQU9EO0lBQ1QsR0FBRyxDQUFDLEdBQUc7QUFNUCxPQUFPLE1BQU1FLFdBQVcsQ0FBQ0MsS0FBa0JDO0lBQ3pDLElBQUdELElBQUlFLElBQUksRUFBRTtRQUNYQyxRQUFRM0IsR0FBRyxDQUFDRyxLQUFLeUIsU0FBUyxDQUFDWixhQUFhUjtJQUMxQyxPQUFPO1FBQ0xSLElBQUksYUFBYSxRQUFRO1FBQ3pCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTRyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDWCxJQUFJLGdCQUFnQixRQUFRO1FBQzVCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTSyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDYixJQUFJLENBQUMsUUFBUSxFQUFFUSxTQUFTQyxJQUFJLEVBQUUsRUFBRSxRQUFRO1FBQ3hDVCxJQUFJLENBQUMsY0FBYyxFQUFFUSxTQUFTTSxVQUFVLEVBQUUsRUFBRSxRQUFRO1FBQ3BEZCxJQUFJLENBQUMsV0FBVyxFQUFFUSxTQUFTTyxPQUFPLEVBQUUsRUFBRSxRQUFRO0lBQ2hEO0lBRUEsSUFBR1UsVUFBVTtRQUNYQSxTQUFTO0lBQ1g7SUFFQSxPQUFPSSxRQUFRQyxPQUFPLENBQUM7QUFDekIsRUFBRSJ9
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy92ZXJzaW9ucy92ZXJzaW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcblxuaW1wb3J0IHtnZXRMZXhQYWNrYWdlSnNvblBhdGh9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpIHx8ICdOL0EnO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGplc3Q6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5qZXN0KSxcbiAgbGV4OiBwYWNrYWdlSnNvbi52ZXJzaW9uLFxuICBzd2M6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5bJ0Bzd2MvY29yZSddKSxcbiAgdHlwZXNjcmlwdDogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/LnR5cGVzY3JpcHQpLFxuICB3ZWJwYWNrOiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8ud2VicGFjaylcbn07XG5cbmV4cG9ydCBjb25zdCBqc29uVmVyc2lvbnMgPSAobGV4UGFja2FnZXMpID0+IE9iamVjdC5rZXlzKGxleFBhY2thZ2VzKS5yZWR1Y2UoKGxpc3QsIGtleSkgPT4ge1xuICBsaXN0W2tleV0gPSBwYWNrYWdlc1trZXldO1xuICByZXR1cm4gbGlzdDtcbn0sIHt9KTtcblxuZXhwb3J0IGludGVyZmFjZSBWZXJzaW9uc0NtZCB7XG4gIHJlYWRvbmx5IGpzb24/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY29uc3QgdmVyc2lvbnMgPSAoY21kOiBWZXJzaW9uc0NtZCwgY2FsbGJhY2s6IChzdGF0dXM6IG51bWJlcik9PiB2b2lkKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgaWYoY21kLmpzb24pIHtcbiAgICBjb25zb2xlLmxvZyhKU09OLnN0cmluZ2lmeShqc29uVmVyc2lvbnMocGFja2FnZXMpKSk7XG4gIH0gZWxzZSB7XG4gICAgbG9nKCdWZXJzaW9uczonLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgTGV4OiAke3BhY2thZ2VzLmxleH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coJyAgLS0tLS0tLS0tLScsICdub3RlJywgZmFsc2UpO1xuICAgIGxvZyhgICBTV0M6ICR7cGFja2FnZXMuc3djfWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBKZXN0OiAke3BhY2thZ2VzLmplc3R9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFR5cGVzY3JpcHQ6ICR7cGFja2FnZXMudHlwZXNjcmlwdH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgV2VicGFjazogJHtwYWNrYWdlcy53ZWJwYWNrfWAsICdpbmZvJywgZmFsc2UpO1xuICB9XG5cbiAgaWYoY2FsbGJhY2spIHtcbiAgICBjYWxsYmFjaygwKTtcbiAgfVxuXG4gIHJldHVybiBQcm9taXNlLnJlc29sdmUoMCk7XG59OyJdLCJuYW1lcyI6WyJyZWFkRmlsZVN5bmMiLCJnZXRMZXhQYWNrYWdlSnNvblBhdGgiLCJsb2ciLCJwYWNrYWdlUGF0aCIsInBhY2thZ2VKc29uIiwiSlNPTiIsInBhcnNlIiwicGFyc2VWZXJzaW9uIiwicGFja2FnZVZlcnNpb24iLCJyZXBsYWNlIiwicGFja2FnZXMiLCJqZXN0IiwiZGVwZW5kZW5jaWVzIiwibGV4IiwidmVyc2lvbiIsInN3YyIsInR5cGVzY3JpcHQiLCJ3ZWJwYWNrIiwianNvblZlcnNpb25zIiwibGV4UGFja2FnZXMiLCJPYmplY3QiLCJrZXlzIiwicmVkdWNlIiwibGlzdCIsImtleSIsInZlcnNpb25zIiwiY21kIiwiY2FsbGJhY2siLCJqc29uIiwiY29uc29sZSIsInN0cmluZ2lmeSIsIlByb21pc2UiLCJyZXNvbHZlIl0sIm1hcHBpbmdzIjoiQUFBQTs7O0NBR0MsR0FDRCxTQUFRQSxZQUFZLFFBQU8sS0FBSztBQUVoQyxTQUFRQyxxQkFBcUIsUUFBTyxzQkFBc0I7QUFDMUQsU0FBUUMsR0FBRyxRQUFPLHFCQUFxQjtBQUV2QyxNQUFNQyxjQUFjRjtBQUNwQixNQUFNRyxjQUFjQyxLQUFLQyxLQUFLLENBQUNOLGFBQWFHLGFBQWE7QUFFekQsT0FBTyxNQUFNSSxlQUFlLENBQUNDLGlCQUFtQ0EsZ0JBQWdCQyxRQUFRLE9BQU8sT0FBTyxNQUFNO0FBRTVHLE9BQU8sTUFBTUMsV0FBVztJQUN0QkMsTUFBTUosYUFBYUgsYUFBYVEsY0FBY0Q7SUFDOUNFLEtBQUtULFlBQVlVLE9BQU87SUFDeEJDLEtBQUtSLGFBQWFILGFBQWFRLGNBQWMsQ0FBQyxZQUFZO0lBQzFESSxZQUFZVCxhQUFhSCxhQUFhUSxjQUFjSTtJQUNwREMsU0FBU1YsYUFBYUgsYUFBYVEsY0FBY0s7QUFDbkQsRUFBRTtBQUVGLE9BQU8sTUFBTUMsZUFBZSxDQUFDQyxjQUFnQkMsT0FBT0MsSUFBSSxDQUFDRixhQUFhRyxNQUFNLENBQUMsQ0FBQ0MsTUFBTUM7UUFDbEZELElBQUksQ0FBQ0MsSUFBSSxHQUFHZCxRQUFRLENBQUNjLElBQUk7UUFDekIsT0FBT0Q7SUFDVCxHQUFHLENBQUMsR0FBRztBQU1QLE9BQU8sTUFBTUUsV0FBVyxDQUFDQyxLQUFrQkM7SUFDekMsSUFBR0QsSUFBSUUsSUFBSSxFQUFFO1FBQ1hDLFFBQVEzQixHQUFHLENBQUNHLEtBQUt5QixTQUFTLENBQUNaLGFBQWFSO0lBQzFDLE9BQU87UUFDTFIsSUFBSSxhQUFhLFFBQVE7UUFDekJBLElBQUksQ0FBQyxPQUFPLEVBQUVRLFNBQVNHLEdBQUcsRUFBRSxFQUFFLFFBQVE7UUFDdENYLElBQUksZ0JBQWdCLFFBQVE7UUFDNUJBLElBQUksQ0FBQyxPQUFPLEVBQUVRLFNBQVNLLEdBQUcsRUFBRSxFQUFFLFFBQVE7UUFDdENiLElBQUksQ0FBQyxRQUFRLEVBQUVRLFNBQVNDLElBQUksRUFBRSxFQUFFLFFBQVE7UUFDeENULElBQUksQ0FBQyxjQUFjLEVBQUVRLFNBQVNNLFVBQVUsRUFBRSxFQUFFLFFBQVE7UUFDcERkLElBQUksQ0FBQyxXQUFXLEVBQUVRLFNBQVNPLE9BQU8sRUFBRSxFQUFFLFFBQVE7SUFDaEQ7SUFFQSxJQUFHVSxVQUFVO1FBQ1hBLFNBQVM7SUFDWDtJQUVBLE9BQU9JLFFBQVFDLE9BQU8sQ0FBQztBQUN6QixFQUFFIn0=
@@ -309,4 +309,4 @@ export const callAIService = async (prompt, quiet = false)=>{
309
309
  }
310
310
  };
311
311
 
312
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/aiService.ts"],"sourcesContent":["/**\n * Copyright (c) 2022-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {resolve as pathResolve} from 'path';\nimport readline from 'readline';\n\nimport {AIConfig, LexConfig} from '../LexConfig.js';\nimport {createSpinner} from './app.js';\nimport {log} from './log.js';\n\n// Cursor IDE integration\nexport const callCursorAI = async (prompt: string, _options: AIConfig): Promise<string> => {\n  try {\n    // When running within Cursor IDE, we can write the prompt to a temporary file\n    // that Cursor can use to provide AI assistance\n    log('Using Cursor IDE for AI fixes...', 'info');\n\n    // For now, just log the prompt and return a placeholder\n    // In a real implementation, Cursor would handle this automatically\n    log('AI fix requested via Cursor IDE', 'info');\n\n    const taskMatch = prompt.match(/^(Generate code according to the following request|Explain the following code|Generate comprehensive unit tests|Analyze the following code|Provide guidance on the following development question):/);\n    const task = taskMatch ? taskMatch[1] : '';\n    const isGenerateTask = task.startsWith('Generate code');\n\n    const questionMatch = prompt.match(/(?:Generate code according to the following request|Explain the following code|Generate comprehensive unit tests|Analyze the following code|Provide guidance on the following development question):\\s*([\\s\\S]+?)(?:===CONTEXT===|$)/);\n    const question = questionMatch ? questionMatch[1].trim() : prompt;\n\n    if(question.toLowerCase().includes('how many files') && prompt.includes('Project structure:')) {\n      const projectStructure = prompt.split('Project structure:')[1] || '';\n      const files = projectStructure.trim().split('\\n');\n      return `Based on the project structure provided, there are ${files.length} files in the project.`;\n    }\n\n    if(isGenerateTask) {\n      return `\n# Code Generation Request: \"${question}\"\n\nTo generate code using Cursor's AI capabilities:\n\n1. **Open your project in Cursor IDE** (https://cursor.sh)\n2. Press **Cmd+L** (or Ctrl+L on Windows/Linux) to open the AI chat\n3. Type your request: \"${question}\"\n4. Cursor will generate the code directly in your editor\n\nThe current CLI integration doesn't have direct access to Cursor's code generation capabilities.\n\n**Alternative options:**\n\n1. **Use OpenAI or Anthropic directly:**\n   Configure in your lex.config file:\n   \\`\\`\\`js\n   export default {\n     ai: {\n       provider: 'openai',\n       apiKey: process.env.OPENAI_API_KEY,\n       model: 'gpt-4o'\n     }\n   }\n   \\`\\`\\`\n\n2. **Use Cursor's command line tool:**\n   Install: \\`npm install -g @cursor/cli\\`\n   Run: \\`cursor ai \"${question}\"\\`\n`;\n    }\n\n    return `\nTo use Cursor's AI capabilities for \"${question}\", you need to:\n\n1. Open your project in Cursor IDE (https://cursor.sh)\n2. Use Cursor's built-in AI features by pressing Cmd+K or Cmd+L\n3. Or run the 'cursor' command directly from your terminal\n\nThe current integration is limited and doesn't directly access Cursor's AI capabilities.\n\nFor the best experience with AI code generation:\n- Use Cursor IDE directly\n- Or configure OpenAI or Anthropic as your provider in your lex.config file:\n\n\\`\\`\\`js\n// lex.config.js (or lex.config.mjs, lex.config.cjs, etc.)\nexport default {\n  ai: {\n    provider: 'openai', // or 'anthropic'\n    apiKey: process.env.OPENAI_API_KEY, // or ANTHROPIC_API_KEY\n    model: 'gpt-4o' // or 'claude-3-opus'\n  }\n}\n\\`\\`\\`\n\nThen set your API key as an environment variable:\n\\`\\`\\`\nexport OPENAI_API_KEY=your_key_here\n\\`\\`\\`\n`;\n  } catch(error) {\n    throw new Error(`Cursor AI error: ${error.message}`);\n  }\n};\n\nexport const callOpenAIAI = async (prompt: string, options: AIConfig): Promise<string> => {\n  try {\n    const apiKey = options.apiKey || process.env.OPENAI_API_KEY;\n    if(!apiKey) {\n      throw new Error('OpenAI API key is required. Set it in your lex.config file or as OPENAI_API_KEY environment variable.');\n    }\n\n    const response = await fetch('https://api.openai.com/v1/chat/completions', {\n      body: JSON.stringify({\n        max_tokens: options.maxTokens || 4000,\n        messages: [\n          {content: 'You are a helpful assistant that fixes ESLint errors in code.', role: 'system'},\n          {content: prompt, role: 'user'}\n        ],\n        model: options.model || 'gpt-4o',\n        temperature: options.temperature || 0.1\n      }),\n      headers: {\n        Authorization: `Bearer ${apiKey}`,\n        'Content-Type': 'application/json'\n      },\n      method: 'POST'\n    });\n\n    if(!response.ok) {\n      const error = await response.json();\n      throw new Error(`OpenAI API error: ${error.error?.message || response.statusText}`);\n    }\n\n    const data = await response.json();\n    return data.choices[0].message.content;\n  } catch(error) {\n    throw new Error(`OpenAI AI error: ${error.message}`);\n  }\n};\n\nexport const callAnthropicAI = async (prompt: string, options: AIConfig): Promise<string> => {\n  try {\n    const apiKey = options.apiKey || process.env.ANTHROPIC_API_KEY;\n    if(!apiKey) {\n      throw new Error('Anthropic API key is required. Set it in your lex.config file or as ANTHROPIC_API_KEY environment variable.');\n    }\n\n    const response = await fetch('https://api.anthropic.com/v1/messages', {\n      body: JSON.stringify({\n        max_tokens: options.maxTokens || 4000,\n        messages: [\n          {content: prompt, role: 'user'}\n        ],\n        model: options.model || 'claude-3-sonnet-20240229',\n        temperature: options.temperature || 0.1\n      }),\n      headers: {\n        'Content-Type': 'application/json',\n        'anthropic-version': '2023-06-01',\n        'x-api-key': apiKey\n      },\n      method: 'POST'\n    });\n\n    if(!response.ok) {\n      const error = await response.json();\n      throw new Error(`Anthropic API error: ${error.error?.message || response.statusText}`);\n    }\n\n    const data = await response.json();\n    return data.content[0].text;\n  } catch(error) {\n    throw new Error(`Anthropic AI error: ${error.message}`);\n  }\n};\n\nexport const callCopilotAI = async (prompt: string, _options: AIConfig): Promise<string> => {\n  try {\n    log('GitHub Copilot AI fixes not directly supported. Using manual fix mode.', 'info');\n    return prompt;\n  } catch(error) {\n    throw new Error(`GitHub Copilot AI error: ${error.message}`);\n  }\n};\n\nexport const promptForAIProvider = async (_quiet = false): Promise<'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none'> => {\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout\n  });\n\n  return new Promise((resolve) => {\n    log('\\nNo AI provider configured. Please choose an AI provider:', 'info');\n    log('1. Cursor IDE', 'info');\n    log('2. OpenAI', 'info');\n    log('3. Anthropic', 'info');\n    log('4. GitHub Copilot', 'info');\n    log('5. None (Skip AI features)', 'info');\n\n    rl.question('Enter your choice (1-5): ', (answer) => {\n      rl.close();\n\n      switch(answer) {\n        case '1':\n          resolve('cursor');\n          break;\n        case '2':\n          resolve('openai');\n          break;\n        case '3':\n          resolve('anthropic');\n          break;\n        case '4':\n          resolve('copilot');\n          break;\n        default:\n          resolve('none');\n      }\n    });\n  });\n};\n\nexport const promptForAPIKey = async (provider: string, _quiet = false): Promise<string> => {\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout\n  });\n\n  return new Promise((resolve) => {\n    rl.question(`Please enter your ${provider} API key: `, (answer) => {\n      rl.close();\n      resolve(answer);\n    });\n  });\n};\n\nexport const getAIService = (\n  provider: string,\n  _options: AIConfig\n): (prompt: string, options: AIConfig) => Promise<string> => {\n  switch(provider) {\n    case 'cursor':\n      return callCursorAI;\n    case 'openai':\n      return callOpenAIAI;\n    case 'anthropic':\n      return callAnthropicAI;\n    case 'copilot':\n      return callCopilotAI;\n    default:\n      return async () => 'No AI provider configured';\n  }\n};\n\nexport const callAIService = async (prompt: string, quiet = false): Promise<string> => {\n  const spinner = createSpinner(quiet);\n  spinner.start('Calling AI service to fix code issues...');\n\n  try {\n    const aiConfig = LexConfig.config.ai || {provider: 'none'};\n\n    const isInCursorIDE = process.env.CURSOR_IDE === 'true';\n    if(isInCursorIDE && (aiConfig.provider === 'none' || !aiConfig.provider)) {\n      log('Detected Cursor IDE environment, using Cursor as AI provider', 'info', quiet);\n      aiConfig.provider = 'cursor';\n    }\n\n    if(aiConfig.provider === 'none') {\n      const provider = await promptForAIProvider(quiet);\n\n      if(provider === 'none') {\n        spinner.fail('AI features skipped');\n        return '';\n      }\n\n      aiConfig.provider = provider;\n\n      if(provider !== 'cursor' && provider !== 'copilot' &&\n        !process.env[`${provider.toUpperCase()}_API_KEY`]) {\n        aiConfig.apiKey = await promptForAPIKey(provider, quiet);\n      }\n\n      LexConfig.config.ai = aiConfig;\n\n      // Search for config files in multiple formats like LexConfig.parseConfig does\n      const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n      const configBaseName = 'lex.config';\n      let configPath = '';\n\n      for(const format of configFormats) {\n        const potentialPath = pathResolve(process.cwd(), `./${configBaseName}.${format}`);\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          break;\n        }\n      }\n\n      if(configPath) {\n        try {\n          const configContent = readFileSync(configPath, 'utf8');\n          const updatedConfig = configContent.replace(\n            /ai:.*?[,}]/s,\n            `ai: { provider: '${aiConfig.provider}' },`\n          );\n          writeFileSync(configPath, updatedConfig);\n        } catch(_error) {\n        }\n      }\n    }\n\n    let result = '';\n\n    switch(aiConfig.provider) {\n      case 'cursor':\n        result = await callCursorAI(prompt, aiConfig);\n        log('Cursor IDE AI integration active', 'info', quiet);\n        break;\n      case 'openai':\n        result = await callOpenAIAI(prompt, aiConfig);\n        break;\n      case 'anthropic':\n        result = await callAnthropicAI(prompt, aiConfig);\n        break;\n      case 'copilot':\n        result = await callCopilotAI(prompt, aiConfig);\n        break;\n      default:\n        spinner.fail('No AI provider configured');\n        return '';\n    }\n\n    spinner.succeed('AI code fixes generated successfully');\n    return result;\n  } catch(error) {\n    spinner.fail(`AI service error: ${error.message}`);\n    if(!quiet) {\n      log(error, 'error');\n    }\n    return '';\n  }\n};"],"names":["existsSync","readFileSync","writeFileSync","resolve","pathResolve","readline","LexConfig","createSpinner","log","callCursorAI","prompt","_options","taskMatch","match","task","isGenerateTask","startsWith","questionMatch","question","trim","toLowerCase","includes","projectStructure","split","files","length","error","Error","message","callOpenAIAI","options","apiKey","process","env","OPENAI_API_KEY","response","fetch","body","JSON","stringify","max_tokens","maxTokens","messages","content","role","model","temperature","headers","Authorization","method","ok","json","statusText","data","choices","callAnthropicAI","ANTHROPIC_API_KEY","text","callCopilotAI","promptForAIProvider","_quiet","rl","createInterface","input","stdin","output","stdout","Promise","answer","close","promptForAPIKey","provider","getAIService","callAIService","quiet","spinner","start","aiConfig","config","ai","isInCursorIDE","CURSOR_IDE","fail","toUpperCase","configFormats","configBaseName","configPath","format","potentialPath","cwd","configContent","updatedConfig","replace","_error","result","succeed"],"mappings":"AAAA;;;CAGC,GACD,SAAQA,UAAU,EAAEC,YAAY,EAAEC,aAAa,QAAO,KAAK;AAC3D,SAAQC,WAAWC,WAAW,QAAO,OAAO;AAC5C,OAAOC,cAAc,WAAW;AAEhC,SAAkBC,SAAS,QAAO,kBAAkB;AACpD,SAAQC,aAAa,QAAO,WAAW;AACvC,SAAQC,GAAG,QAAO,WAAW;AAE7B,yBAAyB;AACzB,OAAO,MAAMC,eAAe,OAAOC,QAAgBC;IACjD,IAAI;QACF,8EAA8E;QAC9E,+CAA+C;QAC/CH,IAAI,oCAAoC;QAExC,wDAAwD;QACxD,mEAAmE;QACnEA,IAAI,mCAAmC;QAEvC,MAAMI,YAAYF,OAAOG,KAAK,CAAC;QAC/B,MAAMC,OAAOF,YAAYA,SAAS,CAAC,EAAE,GAAG;QACxC,MAAMG,iBAAiBD,KAAKE,UAAU,CAAC;QAEvC,MAAMC,gBAAgBP,OAAOG,KAAK,CAAC;QACnC,MAAMK,WAAWD,gBAAgBA,aAAa,CAAC,EAAE,CAACE,IAAI,KAAKT;QAE3D,IAAGQ,SAASE,WAAW,GAAGC,QAAQ,CAAC,qBAAqBX,OAAOW,QAAQ,CAAC,uBAAuB;YAC7F,MAAMC,mBAAmBZ,OAAOa,KAAK,CAAC,qBAAqB,CAAC,EAAE,IAAI;YAClE,MAAMC,QAAQF,iBAAiBH,IAAI,GAAGI,KAAK,CAAC;YAC5C,OAAO,CAAC,mDAAmD,EAAEC,MAAMC,MAAM,CAAC,sBAAsB,CAAC;QACnG;QAEA,IAAGV,gBAAgB;YACjB,OAAO,CAAC;4BACc,EAAEG,SAAS;;;;;;uBAMhB,EAAEA,SAAS;;;;;;;;;;;;;;;;;;;;;qBAqBb,EAAEA,SAAS;AAChC,CAAC;QACG;QAEA,OAAO,CAAC;qCACyB,EAAEA,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BhD,CAAC;IACC,EAAE,OAAMQ,OAAO;QACb,MAAM,IAAIC,MAAM,CAAC,iBAAiB,EAAED,MAAME,OAAO,EAAE;IACrD;AACF,EAAE;AAEF,OAAO,MAAMC,eAAe,OAAOnB,QAAgBoB;IACjD,IAAI;QACF,MAAMC,SAASD,QAAQC,MAAM,IAAIC,QAAQC,GAAG,CAACC,cAAc;QAC3D,IAAG,CAACH,QAAQ;YACV,MAAM,IAAIJ,MAAM;QAClB;QAEA,MAAMQ,WAAW,MAAMC,MAAM,8CAA8C;YACzEC,MAAMC,KAAKC,SAAS,CAAC;gBACnBC,YAAYV,QAAQW,SAAS,IAAI;gBACjCC,UAAU;oBACR;wBAACC,SAAS;wBAAiEC,MAAM;oBAAQ;oBACzF;wBAACD,SAASjC;wBAAQkC,MAAM;oBAAM;iBAC/B;gBACDC,OAAOf,QAAQe,KAAK,IAAI;gBACxBC,aAAahB,QAAQgB,WAAW,IAAI;YACtC;YACAC,SAAS;gBACPC,eAAe,CAAC,OAAO,EAAEjB,QAAQ;gBACjC,gBAAgB;YAClB;YACAkB,QAAQ;QACV;QAEA,IAAG,CAACd,SAASe,EAAE,EAAE;YACf,MAAMxB,QAAQ,MAAMS,SAASgB,IAAI;YACjC,MAAM,IAAIxB,MAAM,CAAC,kBAAkB,EAAED,MAAMA,KAAK,EAAEE,WAAWO,SAASiB,UAAU,EAAE;QACpF;QAEA,MAAMC,OAAO,MAAMlB,SAASgB,IAAI;QAChC,OAAOE,KAAKC,OAAO,CAAC,EAAE,CAAC1B,OAAO,CAACe,OAAO;IACxC,EAAE,OAAMjB,OAAO;QACb,MAAM,IAAIC,MAAM,CAAC,iBAAiB,EAAED,MAAME,OAAO,EAAE;IACrD;AACF,EAAE;AAEF,OAAO,MAAM2B,kBAAkB,OAAO7C,QAAgBoB;IACpD,IAAI;QACF,MAAMC,SAASD,QAAQC,MAAM,IAAIC,QAAQC,GAAG,CAACuB,iBAAiB;QAC9D,IAAG,CAACzB,QAAQ;YACV,MAAM,IAAIJ,MAAM;QAClB;QAEA,MAAMQ,WAAW,MAAMC,MAAM,yCAAyC;YACpEC,MAAMC,KAAKC,SAAS,CAAC;gBACnBC,YAAYV,QAAQW,SAAS,IAAI;gBACjCC,UAAU;oBACR;wBAACC,SAASjC;wBAAQkC,MAAM;oBAAM;iBAC/B;gBACDC,OAAOf,QAAQe,KAAK,IAAI;gBACxBC,aAAahB,QAAQgB,WAAW,IAAI;YACtC;YACAC,SAAS;gBACP,gBAAgB;gBAChB,qBAAqB;gBACrB,aAAahB;YACf;YACAkB,QAAQ;QACV;QAEA,IAAG,CAACd,SAASe,EAAE,EAAE;YACf,MAAMxB,QAAQ,MAAMS,SAASgB,IAAI;YACjC,MAAM,IAAIxB,MAAM,CAAC,qBAAqB,EAAED,MAAMA,KAAK,EAAEE,WAAWO,SAASiB,UAAU,EAAE;QACvF;QAEA,MAAMC,OAAO,MAAMlB,SAASgB,IAAI;QAChC,OAAOE,KAAKV,OAAO,CAAC,EAAE,CAACc,IAAI;IAC7B,EAAE,OAAM/B,OAAO;QACb,MAAM,IAAIC,MAAM,CAAC,oBAAoB,EAAED,MAAME,OAAO,EAAE;IACxD;AACF,EAAE;AAEF,OAAO,MAAM8B,gBAAgB,OAAOhD,QAAgBC;IAClD,IAAI;QACFH,IAAI,0EAA0E;QAC9E,OAAOE;IACT,EAAE,OAAMgB,OAAO;QACb,MAAM,IAAIC,MAAM,CAAC,yBAAyB,EAAED,MAAME,OAAO,EAAE;IAC7D;AACF,EAAE;AAEF,OAAO,MAAM+B,sBAAsB,OAAOC,SAAS,KAAK;IACtD,MAAMC,KAAKxD,SAASyD,eAAe,CAAC;QAClCC,OAAO/B,QAAQgC,KAAK;QACpBC,QAAQjC,QAAQkC,MAAM;IACxB;IAEA,OAAO,IAAIC,QAAQ,CAAChE;QAClBK,IAAI,8DAA8D;QAClEA,IAAI,iBAAiB;QACrBA,IAAI,aAAa;QACjBA,IAAI,gBAAgB;QACpBA,IAAI,qBAAqB;QACzBA,IAAI,8BAA8B;QAElCqD,GAAG3C,QAAQ,CAAC,6BAA6B,CAACkD;YACxCP,GAAGQ,KAAK;YAER,OAAOD;gBACL,KAAK;oBACHjE,QAAQ;oBACR;gBACF,KAAK;oBACHA,QAAQ;oBACR;gBACF,KAAK;oBACHA,QAAQ;oBACR;gBACF,KAAK;oBACHA,QAAQ;oBACR;gBACF;oBACEA,QAAQ;YACZ;QACF;IACF;AACF,EAAE;AAEF,OAAO,MAAMmE,kBAAkB,OAAOC,UAAkBX,SAAS,KAAK;IACpE,MAAMC,KAAKxD,SAASyD,eAAe,CAAC;QAClCC,OAAO/B,QAAQgC,KAAK;QACpBC,QAAQjC,QAAQkC,MAAM;IACxB;IAEA,OAAO,IAAIC,QAAQ,CAAChE;QAClB0D,GAAG3C,QAAQ,CAAC,CAAC,kBAAkB,EAAEqD,SAAS,UAAU,CAAC,EAAE,CAACH;YACtDP,GAAGQ,KAAK;YACRlE,QAAQiE;QACV;IACF;AACF,EAAE;AAEF,OAAO,MAAMI,eAAe,CAC1BD,UACA5D;IAEA,OAAO4D;QACL,KAAK;YACH,OAAO9D;QACT,KAAK;YACH,OAAOoB;QACT,KAAK;YACH,OAAO0B;QACT,KAAK;YACH,OAAOG;QACT;YACE,OAAO,UAAY;IACvB;AACF,EAAE;AAEF,OAAO,MAAMe,gBAAgB,OAAO/D,QAAgBgE,QAAQ,KAAK;IAC/D,MAAMC,UAAUpE,cAAcmE;IAC9BC,QAAQC,KAAK,CAAC;IAEd,IAAI;QACF,MAAMC,WAAWvE,UAAUwE,MAAM,CAACC,EAAE,IAAI;YAACR,UAAU;QAAM;QAEzD,MAAMS,gBAAgBhD,QAAQC,GAAG,CAACgD,UAAU,KAAK;QACjD,IAAGD,iBAAkBH,CAAAA,SAASN,QAAQ,KAAK,UAAU,CAACM,SAASN,QAAQ,AAAD,GAAI;YACxE/D,IAAI,gEAAgE,QAAQkE;YAC5EG,SAASN,QAAQ,GAAG;QACtB;QAEA,IAAGM,SAASN,QAAQ,KAAK,QAAQ;YAC/B,MAAMA,WAAW,MAAMZ,oBAAoBe;YAE3C,IAAGH,aAAa,QAAQ;gBACtBI,QAAQO,IAAI,CAAC;gBACb,OAAO;YACT;YAEAL,SAASN,QAAQ,GAAGA;YAEpB,IAAGA,aAAa,YAAYA,aAAa,aACvC,CAACvC,QAAQC,GAAG,CAAC,GAAGsC,SAASY,WAAW,GAAG,QAAQ,CAAC,CAAC,EAAE;gBACnDN,SAAS9C,MAAM,GAAG,MAAMuC,gBAAgBC,UAAUG;YACpD;YAEApE,UAAUwE,MAAM,CAACC,EAAE,GAAGF;YAEtB,8EAA8E;YAC9E,MAAMO,gBAAgB;gBAAC;gBAAM;gBAAO;gBAAO;gBAAM;aAAO;YACxD,MAAMC,iBAAiB;YACvB,IAAIC,aAAa;YAEjB,KAAI,MAAMC,UAAUH,cAAe;gBACjC,MAAMI,gBAAgBpF,YAAY4B,QAAQyD,GAAG,IAAI,CAAC,EAAE,EAAEJ,eAAe,CAAC,EAAEE,QAAQ;gBAChF,IAAGvF,WAAWwF,gBAAgB;oBAC5BF,aAAaE;oBACb;gBACF;YACF;YAEA,IAAGF,YAAY;gBACb,IAAI;oBACF,MAAMI,gBAAgBzF,aAAaqF,YAAY;oBAC/C,MAAMK,gBAAgBD,cAAcE,OAAO,CACzC,eACA,CAAC,iBAAiB,EAAEf,SAASN,QAAQ,CAAC,IAAI,CAAC;oBAE7CrE,cAAcoF,YAAYK;gBAC5B,EAAE,OAAME,QAAQ,CAChB;YACF;QACF;QAEA,IAAIC,SAAS;QAEb,OAAOjB,SAASN,QAAQ;YACtB,KAAK;gBACHuB,SAAS,MAAMrF,aAAaC,QAAQmE;gBACpCrE,IAAI,oCAAoC,QAAQkE;gBAChD;YACF,KAAK;gBACHoB,SAAS,MAAMjE,aAAanB,QAAQmE;gBACpC;YACF,KAAK;gBACHiB,SAAS,MAAMvC,gBAAgB7C,QAAQmE;gBACvC;YACF,KAAK;gBACHiB,SAAS,MAAMpC,cAAchD,QAAQmE;gBACrC;YACF;gBACEF,QAAQO,IAAI,CAAC;gBACb,OAAO;QACX;QAEAP,QAAQoB,OAAO,CAAC;QAChB,OAAOD;IACT,EAAE,OAAMpE,OAAO;QACbiD,QAAQO,IAAI,CAAC,CAAC,kBAAkB,EAAExD,MAAME,OAAO,EAAE;QACjD,IAAG,CAAC8C,OAAO;YACTlE,IAAIkB,OAAO;QACb;QACA,OAAO;IACT;AACF,EAAE"}
312
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/aiService.ts"],"sourcesContent":["/**\n * Copyright (c) 2022-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {resolve as pathResolve} from 'path';\nimport readline from 'readline';\n\nimport {AIConfig, LexConfig} from '../LexConfig.js';\nimport {createSpinner} from './app.js';\nimport {log} from './log.js';\n\n// Cursor IDE integration\nexport const callCursorAI = async (prompt: string, _options: AIConfig): Promise<string> => {\n  try {\n    // When running within Cursor IDE, we can write the prompt to a temporary file\n    // that Cursor can use to provide AI assistance\n    log('Using Cursor IDE for AI fixes...', 'info');\n\n    // For now, just log the prompt and return a placeholder\n    // In a real implementation, Cursor would handle this automatically\n    log('AI fix requested via Cursor IDE', 'info');\n\n    const taskMatch = prompt.match(/^(Generate code according to the following request|Explain the following code|Generate comprehensive unit tests|Analyze the following code|Provide guidance on the following development question):/);\n    const task = taskMatch ? taskMatch[1] : '';\n    const isGenerateTask = task.startsWith('Generate code');\n\n    const questionMatch = prompt.match(/(?:Generate code according to the following request|Explain the following code|Generate comprehensive unit tests|Analyze the following code|Provide guidance on the following development question):\\s*([\\s\\S]+?)(?:===CONTEXT===|$)/);\n    const question = questionMatch ? questionMatch[1].trim() : prompt;\n\n    if(question.toLowerCase().includes('how many files') && prompt.includes('Project structure:')) {\n      const projectStructure = prompt.split('Project structure:')[1] || '';\n      const files = projectStructure.trim().split('\\n');\n      return `Based on the project structure provided, there are ${files.length} files in the project.`;\n    }\n\n    if(isGenerateTask) {\n      return `\n# Code Generation Request: \"${question}\"\n\nTo generate code using Cursor's AI capabilities:\n\n1. **Open your project in Cursor IDE** (https://cursor.sh)\n2. Press **Cmd+L** (or Ctrl+L on Windows/Linux) to open the AI chat\n3. Type your request: \"${question}\"\n4. Cursor will generate the code directly in your editor\n\nThe current CLI integration doesn't have direct access to Cursor's code generation capabilities.\n\n**Alternative options:**\n\n1. **Use OpenAI or Anthropic directly:**\n   Configure in your lex.config file:\n   \\`\\`\\`js\n   export default {\n     ai: {\n       provider: 'openai',\n       apiKey: process.env.OPENAI_API_KEY,\n       model: 'gpt-4o'\n     }\n   }\n   \\`\\`\\`\n\n2. **Use Cursor's command line tool:**\n   Install: \\`npm install -g @cursor/cli\\`\n   Run: \\`cursor ai \"${question}\"\\`\n`;\n    }\n\n    return `\nTo use Cursor's AI capabilities for \"${question}\", you need to:\n\n1. Open your project in Cursor IDE (https://cursor.sh)\n2. Use Cursor's built-in AI features by pressing Cmd+K or Cmd+L\n3. Or run the 'cursor' command directly from your terminal\n\nThe current integration is limited and doesn't directly access Cursor's AI capabilities.\n\nFor the best experience with AI code generation:\n- Use Cursor IDE directly\n- Or configure OpenAI or Anthropic as your provider in your lex.config file:\n\n\\`\\`\\`js\n// lex.config.js (or lex.config.mjs, lex.config.cjs, etc.)\nexport default {\n  ai: {\n    provider: 'openai', // or 'anthropic'\n    apiKey: process.env.OPENAI_API_KEY, // or ANTHROPIC_API_KEY\n    model: 'gpt-4o' // or 'claude-3-opus'\n  }\n}\n\\`\\`\\`\n\nThen set your API key as an environment variable:\n\\`\\`\\`\nexport OPENAI_API_KEY=your_key_here\n\\`\\`\\`\n`;\n  } catch(error) {\n    throw new Error(`Cursor AI error: ${error.message}`);\n  }\n};\n\nexport const callOpenAIAI = async (prompt: string, options: AIConfig): Promise<string> => {\n  try {\n    const apiKey = options.apiKey || process.env.OPENAI_API_KEY;\n    if(!apiKey) {\n      throw new Error('OpenAI API key is required. Set it in your lex.config file or as OPENAI_API_KEY environment variable.');\n    }\n\n    const response = await fetch('https://api.openai.com/v1/chat/completions', {\n      body: JSON.stringify({\n        max_tokens: options.maxTokens || 4000,\n        messages: [\n          {content: 'You are a helpful assistant that fixes ESLint errors in code.', role: 'system'},\n          {content: prompt, role: 'user'}\n        ],\n        model: options.model || 'gpt-4o',\n        temperature: options.temperature || 0.1\n      }),\n      headers: {\n        Authorization: `Bearer ${apiKey}`,\n        'Content-Type': 'application/json'\n      },\n      method: 'POST'\n    });\n\n    if(!response.ok) {\n      const error = await response.json();\n      throw new Error(`OpenAI API error: ${error.error?.message || response.statusText}`);\n    }\n\n    const data = await response.json();\n    return data.choices[0].message.content;\n  } catch(error) {\n    throw new Error(`OpenAI AI error: ${error.message}`);\n  }\n};\n\nexport const callAnthropicAI = async (prompt: string, options: AIConfig): Promise<string> => {\n  try {\n    const apiKey = options.apiKey || process.env.ANTHROPIC_API_KEY;\n    if(!apiKey) {\n      throw new Error('Anthropic API key is required. Set it in your lex.config file or as ANTHROPIC_API_KEY environment variable.');\n    }\n\n    const response = await fetch('https://api.anthropic.com/v1/messages', {\n      body: JSON.stringify({\n        max_tokens: options.maxTokens || 4000,\n        messages: [\n          {content: prompt, role: 'user'}\n        ],\n        model: options.model || 'claude-3-sonnet-20240229',\n        temperature: options.temperature || 0.1\n      }),\n      headers: {\n        'Content-Type': 'application/json',\n        'anthropic-version': '2023-06-01',\n        'x-api-key': apiKey\n      },\n      method: 'POST'\n    });\n\n    if(!response.ok) {\n      const error = await response.json();\n      throw new Error(`Anthropic API error: ${error.error?.message || response.statusText}`);\n    }\n\n    const data = await response.json();\n    return data.content[0].text;\n  } catch(error) {\n    throw new Error(`Anthropic AI error: ${error.message}`);\n  }\n};\n\nexport const callCopilotAI = async (prompt: string, _options: AIConfig): Promise<string> => {\n  try {\n    log('GitHub Copilot AI fixes not directly supported. Using manual fix mode.', 'info');\n    return prompt;\n  } catch(error) {\n    throw new Error(`GitHub Copilot AI error: ${error.message}`);\n  }\n};\n\nexport const promptForAIProvider = async (_quiet = false): Promise<'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none'> => {\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout\n  });\n\n  return new Promise((resolve) => {\n    log('\\nNo AI provider configured. Please choose an AI provider:', 'info');\n    log('1. Cursor IDE', 'info');\n    log('2. OpenAI', 'info');\n    log('3. Anthropic', 'info');\n    log('4. GitHub Copilot', 'info');\n    log('5. None (Skip AI features)', 'info');\n\n    rl.question('Enter your choice (1-5): ', (answer) => {\n      rl.close();\n\n      switch(answer) {\n        case '1':\n          resolve('cursor');\n          break;\n        case '2':\n          resolve('openai');\n          break;\n        case '3':\n          resolve('anthropic');\n          break;\n        case '4':\n          resolve('copilot');\n          break;\n        default:\n          resolve('none');\n      }\n    });\n  });\n};\n\nexport const promptForAPIKey = async (provider: string, _quiet = false): Promise<string> => {\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout\n  });\n\n  return new Promise((resolve) => {\n    rl.question(`Please enter your ${provider} API key: `, (answer) => {\n      rl.close();\n      resolve(answer);\n    });\n  });\n};\n\nexport const getAIService = (\n  provider: string,\n  _options: AIConfig\n): (prompt: string, options: AIConfig)=> Promise<string> => {\n  switch(provider) {\n    case 'cursor':\n      return callCursorAI;\n    case 'openai':\n      return callOpenAIAI;\n    case 'anthropic':\n      return callAnthropicAI;\n    case 'copilot':\n      return callCopilotAI;\n    default:\n      return async () => 'No AI provider configured';\n  }\n};\n\nexport const callAIService = async (prompt: string, quiet = false): Promise<string> => {\n  const spinner = createSpinner(quiet);\n  spinner.start('Calling AI service to fix code issues...');\n\n  try {\n    const aiConfig = LexConfig.config.ai || {provider: 'none'};\n\n    const isInCursorIDE = process.env.CURSOR_IDE === 'true';\n    if(isInCursorIDE && (aiConfig.provider === 'none' || !aiConfig.provider)) {\n      log('Detected Cursor IDE environment, using Cursor as AI provider', 'info', quiet);\n      aiConfig.provider = 'cursor';\n    }\n\n    if(aiConfig.provider === 'none') {\n      const provider = await promptForAIProvider(quiet);\n\n      if(provider === 'none') {\n        spinner.fail('AI features skipped');\n        return '';\n      }\n\n      aiConfig.provider = provider;\n\n      if(provider !== 'cursor' && provider !== 'copilot' &&\n        !process.env[`${provider.toUpperCase()}_API_KEY`]) {\n        aiConfig.apiKey = await promptForAPIKey(provider, quiet);\n      }\n\n      LexConfig.config.ai = aiConfig;\n\n      // Search for config files in multiple formats like LexConfig.parseConfig does\n      const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n      const configBaseName = 'lex.config';\n      let configPath = '';\n\n      for(const format of configFormats) {\n        const potentialPath = pathResolve(process.cwd(), `./${configBaseName}.${format}`);\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          break;\n        }\n      }\n\n      if(configPath) {\n        try {\n          const configContent = readFileSync(configPath, 'utf8');\n          const updatedConfig = configContent.replace(\n            /ai:.*?[,}]/s,\n            `ai: { provider: '${aiConfig.provider}' },`\n          );\n          writeFileSync(configPath, updatedConfig);\n        } catch(_error) {\n        }\n      }\n    }\n\n    let result = '';\n\n    switch(aiConfig.provider) {\n      case 'cursor':\n        result = await callCursorAI(prompt, aiConfig);\n        log('Cursor IDE AI integration active', 'info', quiet);\n        break;\n      case 'openai':\n        result = await callOpenAIAI(prompt, aiConfig);\n        break;\n      case 'anthropic':\n        result = await callAnthropicAI(prompt, aiConfig);\n        break;\n      case 'copilot':\n        result = await callCopilotAI(prompt, aiConfig);\n        break;\n      default:\n        spinner.fail('No AI provider configured');\n        return '';\n    }\n\n    spinner.succeed('AI code fixes generated successfully');\n    return result;\n  } catch(error) {\n    spinner.fail(`AI service error: ${error.message}`);\n    if(!quiet) {\n      log(error, 'error');\n    }\n    return '';\n  }\n};"],"names":["existsSync","readFileSync","writeFileSync","resolve","pathResolve","readline","LexConfig","createSpinner","log","callCursorAI","prompt","_options","taskMatch","match","task","isGenerateTask","startsWith","questionMatch","question","trim","toLowerCase","includes","projectStructure","split","files","length","error","Error","message","callOpenAIAI","options","apiKey","process","env","OPENAI_API_KEY","response","fetch","body","JSON","stringify","max_tokens","maxTokens","messages","content","role","model","temperature","headers","Authorization","method","ok","json","statusText","data","choices","callAnthropicAI","ANTHROPIC_API_KEY","text","callCopilotAI","promptForAIProvider","_quiet","rl","createInterface","input","stdin","output","stdout","Promise","answer","close","promptForAPIKey","provider","getAIService","callAIService","quiet","spinner","start","aiConfig","config","ai","isInCursorIDE","CURSOR_IDE","fail","toUpperCase","configFormats","configBaseName","configPath","format","potentialPath","cwd","configContent","updatedConfig","replace","_error","result","succeed"],"mappings":"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"}
@@ -18,7 +18,7 @@ interface FilenamesResult {
18
18
  templatePath: string;
19
19
  templateReact: string;
20
20
  }
21
- export declare const getFilenames: (props: GetFilenamesProps) => FilenamesResult | void;
21
+ export declare const getFilenames: (props: GetFilenamesProps) => FilenamesResult | undefined;
22
22
  export interface Spinner {
23
23
  fail: (text?: string) => void;
24
24
  start: (text?: string) => void;