@nlabs/lex 1.55.1 → 1.55.2

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.
package/README.md CHANGED
@@ -148,6 +148,18 @@ lex dev --config ./custom.webpack.js
148
148
  lex dev --usePublicIp
149
149
  ```
150
150
 
151
+ Configure the default `lex dev` port in `lex.config.mjs`:
152
+
153
+ ```javascript
154
+ export default {
155
+ dev: {
156
+ port: 4200
157
+ }
158
+ };
159
+ ```
160
+
161
+ `--port` takes precedence over `dev.port`.
162
+
151
163
  **Public IP Caching**: Lex automatically caches your public IP address for 1 week to reduce API calls. Use `--usePublicIp` to force refresh the cache when needed.
152
164
 
153
165
  **Static Assets**: If your HTML template references static assets (like favicon.ico, manifest.json, or images) with absolute paths, ensure these files exist in your source directory or use relative paths to avoid webpack compilation errors.
@@ -174,6 +186,22 @@ lex serverless --debug --printOutput
174
186
 
175
187
  **Configuration**: Configure your serverless functions in `lex.config.mjs`. See the [Serverless Documentation](src/commands/serverless/serverless.docs.md) for detailed configuration options.
176
188
 
189
+ ```javascript
190
+ export default {
191
+ serverless: {
192
+ custom: {
193
+ 'serverless-offline': {
194
+ httpPort: 3100,
195
+ httpsPort: 3101,
196
+ wsPort: 3102
197
+ }
198
+ }
199
+ }
200
+ };
201
+ ```
202
+
203
+ `--httpPort`, `--httpsPort`, and `--wsPort` override these config values.
204
+
177
205
  **Environment Variables**: The serverless command automatically loads environment variables from `.env`, `.env.local`, and `.env.development` files, with command-line variables taking precedence.
178
206
 
179
207
  ### **Production Builds**
@@ -310,6 +338,7 @@ Lex provides extensive configuration options through the `lex.config.js` file. H
310
338
  |--------|------|---------|-------------|---------|
311
339
  | `entryHTML` | `string` | `'index.html'` | HTML template file | `entryHTML: 'app.html'` |
312
340
  | `entryJs` | `string` | `'index.js'` | Main JavaScript entry file | `entryJs: 'main.tsx'` |
341
+ | `dev.port` | `number` | `3000` | Default port used by `lex dev` when `--port` is not passed | `dev: { port: 4200 }` |
313
342
  | `outputFile` | `string` | `undefined` | Specific output filename | `outputFile: 'bundle.js'` |
314
343
  | `outputFullPath` | `string` | `path.resolve('./lib')` | Absolute output path for build artifacts. Used by webpack dev server for static file serving. | `outputFullPath: '/absolute/build'` |
315
344
  | `outputHash` | `boolean` | `false` | Add hash to output filenames | `outputHash: true` |
@@ -18,6 +18,9 @@ export interface AIConfig {
18
18
  maxTokens?: number;
19
19
  temperature?: number;
20
20
  }
21
+ export interface DevConfig {
22
+ port?: number;
23
+ }
21
24
  export interface ESLintConfig {
22
25
  [key: string]: unknown;
23
26
  extends?: string[];
@@ -27,6 +30,7 @@ export interface LexConfigType {
27
30
  ai?: AIConfig;
28
31
  configFiles?: string[];
29
32
  copyFiles?: string[];
33
+ dev?: DevConfig;
30
34
  entryHTML?: string;
31
35
  entryJs?: string;
32
36
  env?: object;
package/lib/LexConfig.js CHANGED
@@ -414,4 +414,4 @@ _define_property(LexConfig, "config", {
414
414
  ...defaultConfigValues
415
415
  });
416
416
 
417
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/LexConfig.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 findFileUp from 'find-file-up';\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Options} from '@swc/core';\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface VitestConfig {\n  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  vitest?: VitestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  swc?: SWCOptions;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  vitest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2023',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getPackageDir = (): string => {\n  const cwd = process.cwd();\n  const currentPkgPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(currentPkgPath)) {\n    try {\n      const pkg = JSON.parse(readFileSync(currentPkgPath, 'utf8'));\n      if(!pkg.workspaces) {\n        return cwd;\n      }\n    } catch{\n      return cwd;\n    }\n  }\n\n  let searchDir = cwd;\n\n  for(let i = 0; i < 10; i++) {\n    const pkgPath = pathResolve(searchDir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n\n        if(!pkg.workspaces) {\n          return searchDir;\n        }\n      } catch{\n        // Continue searching\n      }\n    }\n\n    const parent = dirname(searchDir);\n\n    if(parent === searchDir) {\n      break;\n    }\n    searchDir = parent;\n  }\n\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n\n  for(const format of configFormats) {\n    const configPath = findFileUp.sync(`lex.config.${format}`, cwd, 5);\n\n    if(configPath) {\n      return dirname(configPath);\n    }\n  }\n\n  return cwd;\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const packageDir = getPackageDir();\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(packageDir, 'tsconfig.build.json');\n\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n\n    const rootBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(rootBuildConfig)) {\n      return rootBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(packageDir, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n\n    const rootLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n\n    if(existsSync(rootLintConfig)) {\n      return rootLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(packageDir, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n\n    const rootTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n\n    if(existsSync(rootTestConfig)) {\n      return rootTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(packageDir, configName);\n\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const rootConfigPath = pathResolve(cwd, configName);\n\n  if(existsSync(rootConfigPath)) {\n    return rootConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n\n  return pathResolve(lexDir, configName);\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {entryJs, sourceFullPath, targetEnvironment} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n\n    LexConfig.config.swc.jsc.parser = {\n      syntax: 'typescript',\n      tsx: true\n    };\n\n    if(targetEnvironment === 'web') {\n      LexConfig.config.swc.jsc.transform = {\n        react: {\n          runtime: 'automatic'\n        }\n      };\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const packageDir = getPackageDir();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(packageDir, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(packageDir, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n    const packageDir = getPackageDir();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(packageDir, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(packageDir, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(packageDir, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(packageDir, params.sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            // eslint-disable-next-line no-console\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const packageDir = getPackageDir();\n    const tsconfigPath: string = pathResolve(packageDir, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const lexDir = LexConfig.getLexDir();\n      const baseConfigPath = pathResolve(lexDir, 'tsconfig.base.json');\n      const templateConfigPath = pathResolve(lexDir, 'tsconfig.template.json');\n      const sourcePath = existsSync(baseConfigPath) ? baseConfigPath : templateConfigPath;\n\n      if(existsSync(sourcePath)) {\n        writeFileSync(tsconfigPath, readFileSync(sourcePath));\n      }\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\n    ];\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}\n\nexport type SWCOptions = Options;\n"],"names":["findFileUp","existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","vitest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getPackageDir","currentPkgPath","pkg","JSON","parse","workspaces","searchDir","i","pkgPath","parent","configFormats","format","configPath","sync","getTypeScriptConfigPath","configName","packageDir","projectBuildConfig","rootBuildConfig","projectLintConfig","rootLintConfig","projectTestConfig","rootTestConfig","projectConfigPath","rootConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configBaseName","configExists","potentialPath","ext","configContent","configJson","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","baseConfigPath","templateConfigPath","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
417
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/LexConfig.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 findFileUp from 'find-file-up';\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Options} from '@swc/core';\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface VitestConfig {\n  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\n\nexport interface DevConfig {\n  port?: number;\n}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  dev?: DevConfig;\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  vitest?: VitestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  swc?: SWCOptions;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  vitest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2023',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getPackageDir = (): string => {\n  const cwd = process.cwd();\n  const currentPkgPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(currentPkgPath)) {\n    try {\n      const pkg = JSON.parse(readFileSync(currentPkgPath, 'utf8'));\n      if(!pkg.workspaces) {\n        return cwd;\n      }\n    } catch{\n      return cwd;\n    }\n  }\n\n  let searchDir = cwd;\n\n  for(let i = 0; i < 10; i++) {\n    const pkgPath = pathResolve(searchDir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n\n        if(!pkg.workspaces) {\n          return searchDir;\n        }\n      } catch{\n        // Continue searching\n      }\n    }\n\n    const parent = dirname(searchDir);\n\n    if(parent === searchDir) {\n      break;\n    }\n    searchDir = parent;\n  }\n\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n\n  for(const format of configFormats) {\n    const configPath = findFileUp.sync(`lex.config.${format}`, cwd, 5);\n\n    if(configPath) {\n      return dirname(configPath);\n    }\n  }\n\n  return cwd;\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const packageDir = getPackageDir();\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(packageDir, 'tsconfig.build.json');\n\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n\n    const rootBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(rootBuildConfig)) {\n      return rootBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(packageDir, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n\n    const rootLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n\n    if(existsSync(rootLintConfig)) {\n      return rootLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(packageDir, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n\n    const rootTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n\n    if(existsSync(rootTestConfig)) {\n      return rootTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(packageDir, configName);\n\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const rootConfigPath = pathResolve(cwd, configName);\n\n  if(existsSync(rootConfigPath)) {\n    return rootConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n\n  return pathResolve(lexDir, configName);\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {entryJs, sourceFullPath, targetEnvironment} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n\n    LexConfig.config.swc.jsc.parser = {\n      syntax: 'typescript',\n      tsx: true\n    };\n\n    if(targetEnvironment === 'web') {\n      LexConfig.config.swc.jsc.transform = {\n        react: {\n          runtime: 'automatic'\n        }\n      };\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const packageDir = getPackageDir();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(packageDir, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(packageDir, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n    const packageDir = getPackageDir();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(packageDir, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(packageDir, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(packageDir, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(packageDir, params.sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            // eslint-disable-next-line no-console\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const packageDir = getPackageDir();\n    const tsconfigPath: string = pathResolve(packageDir, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const lexDir = LexConfig.getLexDir();\n      const baseConfigPath = pathResolve(lexDir, 'tsconfig.base.json');\n      const templateConfigPath = pathResolve(lexDir, 'tsconfig.template.json');\n      const sourcePath = existsSync(baseConfigPath) ? baseConfigPath : templateConfigPath;\n\n      if(existsSync(sourcePath)) {\n        writeFileSync(tsconfigPath, readFileSync(sourcePath));\n      }\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\n    ];\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}\n\nexport type SWCOptions = Options;\n"],"names":["findFileUp","existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","vitest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getPackageDir","currentPkgPath","pkg","JSON","parse","workspaces","searchDir","i","pkgPath","parent","configFormats","format","configPath","sync","getTypeScriptConfigPath","configName","packageDir","projectBuildConfig","rootBuildConfig","projectLintConfig","rootLintConfig","projectTestConfig","rootTestConfig","projectConfigPath","rootConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configBaseName","configExists","potentialPath","ext","configContent","configJson","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","baseConfigPath","templateConfigPath","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
@@ -12,4 +12,5 @@ export interface DevOptions {
12
12
  readonly variables?: string;
13
13
  }
14
14
  export type DevCallback = (status: number) => void;
15
+ export declare const DEFAULT_DEV_PORT = 3000;
15
16
  export declare const dev: (cmd: DevOptions, callback?: DevCallback) => Promise<number>;
@@ -23,6 +23,18 @@ try {
23
23
  currentFilename = process.cwd();
24
24
  currentDirname = process.cwd();
25
25
  }
26
+ // default port used by the development server when none is provided
27
+ export const DEFAULT_DEV_PORT = 3000;
28
+ const parsePort = (portValue)=>{
29
+ if (portValue === undefined || portValue === null || portValue === '') {
30
+ return undefined;
31
+ }
32
+ const parsed = Number(portValue);
33
+ if (Number.isInteger(parsed) && parsed > 0) {
34
+ return parsed;
35
+ }
36
+ return undefined;
37
+ };
26
38
  const getCacheDir = ()=>{
27
39
  const cacheDir = join(homedir(), '.lex-cache');
28
40
  if (!existsSync(cacheDir)) {
@@ -107,7 +119,7 @@ const getNetworkAddresses = ()=>{
107
119
  }
108
120
  return addresses;
109
121
  };
110
- const displayServerStatus = (port = 3000, quiet, publicIp)=>{
122
+ const displayServerStatus = (port = DEFAULT_DEV_PORT, quiet, publicIp)=>{
111
123
  if (quiet) {
112
124
  return;
113
125
  }
@@ -138,11 +150,12 @@ const displayServerStatus = (port = 3000, quiet, publicIp)=>{
138
150
  console.log(`\n${statusBox}\n`);
139
151
  };
140
152
  export const dev = async (cmd, callback = ()=>({}))=>{
141
- const { bundleAnalyzer, cliName = 'Lex', config, format = 'esm', open = false, port = 3000, quiet, remove, translations = false, usePublicIp, variables } = cmd;
153
+ const { bundleAnalyzer, cliName = 'Lex', config, format = 'esm', open = false, port: cliPort, quiet, remove, translations = false, usePublicIp, variables } = cmd;
142
154
  const spinner = createSpinner(quiet);
143
155
  log(`${cliName} start development server...`, 'info', quiet);
144
156
  await LexConfig.parseConfig(cmd);
145
- const { outputFullPath, useTypescript } = LexConfig.config;
157
+ const { dev: devConfig, outputFullPath, useTypescript } = LexConfig.config;
158
+ const finalPort = parsePort(cliPort) ?? parsePort(devConfig?.port) ?? DEFAULT_DEV_PORT;
146
159
  let variablesObj = {
147
160
  NODE_ENV: 'development'
148
161
  };
@@ -223,7 +236,7 @@ export const dev = async (cmd, callback = ()=>({}))=>{
223
236
  ...process.env,
224
237
  LEX_QUIET: quiet,
225
238
  WEBPACK_DEV_OPEN: open,
226
- WEBPACK_DEV_PORT: port.toString()
239
+ WEBPACK_DEV_PORT: finalPort.toString()
227
240
  },
228
241
  stdio: 'pipe'
229
242
  });
@@ -242,7 +255,7 @@ export const dev = async (cmd, callback = ()=>({}))=>{
242
255
  displayServerStatus(portToShow, quiet);
243
256
  }
244
257
  };
245
- let detectedPort = port;
258
+ let detectedPort = finalPort;
246
259
  childProcess.stdout?.on('data', (data)=>{
247
260
  const output = data.toString();
248
261
  handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');
@@ -290,4 +303,4 @@ export const dev = async (cmd, callback = ()=>({}))=>{
290
303
  }
291
304
  };
292
305
 
293
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/dev/dev.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 {execa} from 'execa';\nimport {existsSync, readFileSync, writeFileSync, mkdirSync} from 'fs';\nimport https from 'https';\nimport {networkInterfaces, homedir} from 'os';\nimport {dirname, resolve as pathResolve, join} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, handleWebpackProgress, removeFiles} from '../../utils/app.js';\nimport {resolveWebpackPaths} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {processTranslations} from '../../utils/translations.js';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  // eslint-disable-next-line no-eval\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch{\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface DevOptions {\n  readonly bundleAnalyzer?: boolean;\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly format?: string;\n  readonly open?: boolean;\n  readonly port?: number;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly translations?: boolean;\n  readonly usePublicIp?: boolean;\n  readonly variables?: string;\n}\n\nexport type DevCallback = (status: number) => void;\n\ninterface PublicIpCache {\n  ip: string;\n  timestamp: number;\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    const oneWeekMs = 7 * 24 * 60 * 60 * 1000;\n\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  https.get('https://api.ipify.org', (res) => {\n    let data = '';\n    res.on('data', (chunk) => (data += chunk));\n    res.on('end', () => {\n      const ip = data.trim();\n      if(ip) {\n        writePublicIpCache(ip);\n      }\n      resolve(ip);\n    });\n  }).on('error', () => resolve(undefined));\n});\n\nconst getNetworkAddresses = () => {\n  const interfaces = networkInterfaces();\n  const addresses = {\n    local: 'localhost',\n    private: null,\n    public: null\n  };\n\n  for(const name of Object.keys(interfaces)) {\n    const networkInterface = interfaces[name];\n    if(!networkInterface) {\n      continue;\n    }\n\n    for(const iface of networkInterface) {\n      if(iface.family === 'IPv4' && !iface.internal) {\n        const ip = iface.address;\n\n        if(ip.startsWith('10.') || ip.startsWith('192.168.') || ip.startsWith('172.')) {\n          if(!addresses.private) {\n            addresses.private = ip;\n          }\n        } else {\n          if(!addresses.public) {\n            addresses.public = ip;\n          }\n        }\n      }\n    }\n  }\n\n  return addresses;\n};\n\nconst displayServerStatus = (port: number = 3000, quiet: boolean, publicIp?: string) => {\n  if(quiet) {\n    return;\n  }\n\n  const addresses = getNetworkAddresses();\n  const localUrl = `http://localhost:${port}`;\n  const privateUrl = addresses.private ? `http://${addresses.private}:${port}` : null;\n  let publicUrl = null;\n  if(publicIp) {\n    publicUrl = `http://${publicIp}:${port}`;\n  } else if(addresses.public) {\n    publicUrl = `http://${addresses.public}:${port}`;\n  }\n\n  let urlLines = `${chalk.green('Local:')}     ${chalk.underline(localUrl)}\\n`;\n\n  if(privateUrl) {\n    urlLines += `${chalk.green('Private:')}   ${chalk.underline(privateUrl)}\\n`;\n  }\n\n  if(publicUrl) {\n    urlLines += `${chalk.green('Public:')}    ${chalk.underline(publicUrl)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🚀 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  // eslint-disable-next-line no-console\n  console.log(`\\n${statusBox}\\n`);\n};\n\nexport const dev = async (cmd: DevOptions, callback: DevCallback = () => ({})): Promise<number> => {\n  const {bundleAnalyzer, cliName = 'Lex', config, format = 'esm', open = false, port = 3000, quiet, remove, translations = false, usePublicIp, variables} = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} start development server...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, useTypescript} = LexConfig.config;\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  if(useTypescript) {\n    LexConfig.checkTypescriptConfig();\n  }\n\n  if(remove) {\n    spinner.start('Cleaning output directory...');\n\n    await removeFiles(outputFullPath || '');\n\n    spinner.succeed('Successfully cleaned output directory!');\n  }\n\n  if(translations) {\n    spinner.start('Processing translations...');\n\n    try {\n      const sourcePath = LexConfig.config.sourceFullPath || process.cwd();\n      const outputPath = LexConfig.config.outputFullPath || 'lib';\n\n      await processTranslations(sourcePath, outputPath, quiet);\n      spinner.succeed('Translations processed successfully!');\n    } catch(translationError) {\n      log(`\\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);\n      spinner.fail('Failed to process translations.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    const {webpackConfig: resolvedConfig} = resolveWebpackPaths(currentDirname);\n    webpackConfig = resolvedConfig;\n  }\n\n  const {webpackPath} = resolveWebpackPaths(currentDirname);\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--watch',\n    '--config', webpackConfig\n  ];\n\n  if(bundleAnalyzer) {\n    webpackOptions.push('--bundleAnalyzer');\n  }\n\n  try {\n    let executablePath = webpackPath;\n    let finalWebpackOptions: string[];\n\n    if(webpackPath === 'npx') {\n      finalWebpackOptions = ['webpack', ...webpackOptions];\n    } else if(webpackPath.endsWith('.js')) {\n      executablePath = 'node';\n      finalWebpackOptions = [webpackPath, ...webpackOptions];\n    } else {\n      finalWebpackOptions = webpackOptions;\n    }\n\n    spinner.start('Starting development server...');\n\n    const childProcess = execa(executablePath, finalWebpackOptions, {\n      encoding: 'utf8',\n      env: {\n        ...process.env,\n        LEX_QUIET: quiet,\n        WEBPACK_DEV_OPEN: open,\n        WEBPACK_DEV_PORT: port.toString()\n      },\n      stdio: 'pipe'\n    } as any);\n\n    let serverStarted = false;\n    let statusShown = false;\n    const showStatusOnce = (portToShow: number) => {\n      if(statusShown) {\n        return;\n      }\n      statusShown = true;\n      if(usePublicIp) {\n        fetchPublicIp(usePublicIp).then((publicIp) => {\n          displayServerStatus(portToShow, quiet, publicIp);\n        });\n      } else {\n        displayServerStatus(portToShow, quiet);\n      }\n    };\n    let detectedPort = port;\n\n    childProcess.stdout?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');\n\n      if(!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {\n        serverStarted = true;\n        spinner.succeed('Development server started.');\n\n        const portMatch = output.match(/Local:\\s*http:\\/\\/[^:]+:(\\d+)/) ||\n          output.match(/http:\\/\\/localhost:(\\d+)/) ||\n          output.match(/port:\\s*(\\d+)/) ||\n          output.match(/listening on port (\\d+)/) ||\n          output.match(/WebpackPluginServe listening on port (\\d+)/);\n        if(portMatch) {\n          detectedPort = parseInt(portMatch[1]);\n        }\n\n        showStatusOnce(detectedPort);\n      }\n    });\n\n    childProcess.stderr?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');\n\n      if(!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {\n        serverStarted = true;\n        spinner.succeed('Development server started.');\n\n        const portMatch = output.match(/Local:\\s*http:\\/\\/[^:]+:(\\d+)/) ||\n          output.match(/http:\\/\\/localhost:(\\d+)/) ||\n          output.match(/port:\\s*(\\d+)/) ||\n          output.match(/listening on port (\\d+)/) ||\n          output.match(/WebpackPluginServe listening on port (\\d+)/);\n        if(portMatch) {\n          detectedPort = parseInt(portMatch[1]);\n        }\n\n        showStatusOnce(detectedPort);\n      }\n    });\n\n    setTimeout(() => {\n      if(!serverStarted) {\n        spinner.succeed('Development server started.');\n        showStatusOnce(detectedPort);\n      }\n    }, 5000);\n\n    await childProcess;\n\n    if(!serverStarted) {\n      spinner.succeed('Development server started.');\n      showStatusOnce(detectedPort);\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    spinner.fail('There was an error while running Webpack.');\n\n    callback(1);\n    return 1;\n  }\n};"],"names":["boxen","chalk","execa","existsSync","readFileSync","writeFileSync","mkdirSync","https","networkInterfaces","homedir","dirname","resolve","pathResolve","join","LexConfig","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","log","processTranslations","currentFilename","currentDirname","eval","process","cwd","getCacheDir","cacheDir","recursive","getCachePath","readPublicIpCache","cachePath","cacheData","cache","JSON","parse","oneWeekMs","Date","now","timestamp","writePublicIpCache","ip","stringify","fetchPublicIp","forceRefresh","Promise","cached","get","res","data","on","chunk","trim","undefined","getNetworkAddresses","interfaces","addresses","local","private","public","name","Object","keys","networkInterface","iface","family","internal","address","startsWith","displayServerStatus","port","quiet","publicIp","localUrl","privateUrl","publicUrl","urlLines","green","underline","statusBox","cyan","bold","yellow","backgroundColor","borderColor","borderStyle","margin","padding","console","dev","cmd","callback","bundleAnalyzer","cliName","config","format","open","remove","translations","usePublicIp","variables","spinner","parseConfig","outputFullPath","useTypescript","variablesObj","NODE_ENV","_error","env","checkTypescriptConfig","start","succeed","sourcePath","sourceFullPath","outputPath","translationError","message","fail","webpackConfig","isRelativeConfig","substr","resolvedConfig","webpackPath","webpackOptions","push","executablePath","finalWebpackOptions","endsWith","childProcess","encoding","LEX_QUIET","WEBPACK_DEV_OPEN","WEBPACK_DEV_PORT","toString","stdio","serverStarted","statusShown","showStatusOnce","portToShow","then","detectedPort","stdout","output","includes","portMatch","match","parseInt","stderr","setTimeout","error"],"mappings":"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"}
306
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/dev/dev.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 {execa} from 'execa';\nimport {existsSync, readFileSync, writeFileSync, mkdirSync} from 'fs';\nimport https from 'https';\nimport {networkInterfaces, homedir} from 'os';\nimport {dirname, resolve as pathResolve, join} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, handleWebpackProgress, removeFiles} from '../../utils/app.js';\nimport {resolveWebpackPaths} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {processTranslations} from '../../utils/translations.js';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  // eslint-disable-next-line no-eval\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch{\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface DevOptions {\n  readonly bundleAnalyzer?: boolean;\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly format?: string;\n  readonly open?: boolean;\n  readonly port?: number;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly translations?: boolean;\n  readonly usePublicIp?: boolean;\n  readonly variables?: string;\n}\n\nexport type DevCallback = (status: number) => void;\n\n// default port used by the development server when none is provided\nexport const DEFAULT_DEV_PORT = 3000;\n\ninterface PublicIpCache {\n  ip: string;\n  timestamp: number;\n}\n\nconst parsePort = (portValue: unknown): number | undefined => {\n  if(portValue === undefined || portValue === null || portValue === '') {\n    return undefined;\n  }\n\n  const parsed = Number(portValue);\n  if(Number.isInteger(parsed) && parsed > 0) {\n    return parsed;\n  }\n\n  return undefined;\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    const oneWeekMs = 7 * 24 * 60 * 60 * 1000;\n\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  https.get('https://api.ipify.org', (res) => {\n    let data = '';\n    res.on('data', (chunk) => (data += chunk));\n    res.on('end', () => {\n      const ip = data.trim();\n      if(ip) {\n        writePublicIpCache(ip);\n      }\n      resolve(ip);\n    });\n  }).on('error', () => resolve(undefined));\n});\n\nconst getNetworkAddresses = () => {\n  const interfaces = networkInterfaces();\n  const addresses = {\n    local: 'localhost',\n    private: null,\n    public: null\n  };\n\n  for(const name of Object.keys(interfaces)) {\n    const networkInterface = interfaces[name];\n    if(!networkInterface) {\n      continue;\n    }\n\n    for(const iface of networkInterface) {\n      if(iface.family === 'IPv4' && !iface.internal) {\n        const ip = iface.address;\n\n        if(ip.startsWith('10.') || ip.startsWith('192.168.') || ip.startsWith('172.')) {\n          if(!addresses.private) {\n            addresses.private = ip;\n          }\n        } else {\n          if(!addresses.public) {\n            addresses.public = ip;\n          }\n        }\n      }\n    }\n  }\n\n  return addresses;\n};\n\nconst displayServerStatus = (port: number = DEFAULT_DEV_PORT, quiet: boolean, publicIp?: string) => {\n  if(quiet) {\n    return;\n  }\n\n  const addresses = getNetworkAddresses();\n  const localUrl = `http://localhost:${port}`;\n  const privateUrl = addresses.private ? `http://${addresses.private}:${port}` : null;\n  let publicUrl = null;\n  if(publicIp) {\n    publicUrl = `http://${publicIp}:${port}`;\n  } else if(addresses.public) {\n    publicUrl = `http://${addresses.public}:${port}`;\n  }\n\n  let urlLines = `${chalk.green('Local:')}     ${chalk.underline(localUrl)}\\n`;\n\n  if(privateUrl) {\n    urlLines += `${chalk.green('Private:')}   ${chalk.underline(privateUrl)}\\n`;\n  }\n\n  if(publicUrl) {\n    urlLines += `${chalk.green('Public:')}    ${chalk.underline(publicUrl)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🚀 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  // eslint-disable-next-line no-console\n  console.log(`\\n${statusBox}\\n`);\n};\n\nexport const dev = async (cmd: DevOptions, callback: DevCallback = () => ({})): Promise<number> => {\n  const {bundleAnalyzer, cliName = 'Lex', config, format = 'esm', open = false, port: cliPort, quiet, remove, translations = false, usePublicIp, variables} = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} start development server...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {dev: devConfig, outputFullPath, useTypescript} = LexConfig.config;\n  const finalPort = parsePort(cliPort) ?? parsePort(devConfig?.port) ?? DEFAULT_DEV_PORT;\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  if(useTypescript) {\n    LexConfig.checkTypescriptConfig();\n  }\n\n  if(remove) {\n    spinner.start('Cleaning output directory...');\n\n    await removeFiles(outputFullPath || '');\n\n    spinner.succeed('Successfully cleaned output directory!');\n  }\n\n  if(translations) {\n    spinner.start('Processing translations...');\n\n    try {\n      const sourcePath = LexConfig.config.sourceFullPath || process.cwd();\n      const outputPath = LexConfig.config.outputFullPath || 'lib';\n\n      await processTranslations(sourcePath, outputPath, quiet);\n      spinner.succeed('Translations processed successfully!');\n    } catch(translationError) {\n      log(`\\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);\n      spinner.fail('Failed to process translations.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    const {webpackConfig: resolvedConfig} = resolveWebpackPaths(currentDirname);\n    webpackConfig = resolvedConfig;\n  }\n\n  const {webpackPath} = resolveWebpackPaths(currentDirname);\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--watch',\n    '--config', webpackConfig\n  ];\n\n  if(bundleAnalyzer) {\n    webpackOptions.push('--bundleAnalyzer');\n  }\n\n  try {\n    let executablePath = webpackPath;\n    let finalWebpackOptions: string[];\n\n    if(webpackPath === 'npx') {\n      finalWebpackOptions = ['webpack', ...webpackOptions];\n    } else if(webpackPath.endsWith('.js')) {\n      executablePath = 'node';\n      finalWebpackOptions = [webpackPath, ...webpackOptions];\n    } else {\n      finalWebpackOptions = webpackOptions;\n    }\n\n    spinner.start('Starting development server...');\n\n    const childProcess = execa(executablePath, finalWebpackOptions, {\n      encoding: 'utf8',\n      env: {\n        ...process.env,\n        LEX_QUIET: quiet,\n        WEBPACK_DEV_OPEN: open,\n        WEBPACK_DEV_PORT: finalPort.toString()\n      },\n      stdio: 'pipe'\n    } as any);\n\n    let serverStarted = false;\n    let statusShown = false;\n    const showStatusOnce = (portToShow: number) => {\n      if(statusShown) {\n        return;\n      }\n      statusShown = true;\n      if(usePublicIp) {\n        fetchPublicIp(usePublicIp).then((publicIp) => {\n          displayServerStatus(portToShow, quiet, publicIp);\n        });\n      } else {\n        displayServerStatus(portToShow, quiet);\n      }\n    };\n    let detectedPort = finalPort;\n\n    childProcess.stdout?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');\n\n      if(!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {\n        serverStarted = true;\n        spinner.succeed('Development server started.');\n\n        const portMatch = output.match(/Local:\\s*http:\\/\\/[^:]+:(\\d+)/) ||\n          output.match(/http:\\/\\/localhost:(\\d+)/) ||\n          output.match(/port:\\s*(\\d+)/) ||\n          output.match(/listening on port (\\d+)/) ||\n          output.match(/WebpackPluginServe listening on port (\\d+)/);\n        if(portMatch) {\n          detectedPort = parseInt(portMatch[1]);\n        }\n\n        showStatusOnce(detectedPort);\n      }\n    });\n\n    childProcess.stderr?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');\n\n      if(!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {\n        serverStarted = true;\n        spinner.succeed('Development server started.');\n\n        const portMatch = output.match(/Local:\\s*http:\\/\\/[^:]+:(\\d+)/) ||\n          output.match(/http:\\/\\/localhost:(\\d+)/) ||\n          output.match(/port:\\s*(\\d+)/) ||\n          output.match(/listening on port (\\d+)/) ||\n          output.match(/WebpackPluginServe listening on port (\\d+)/);\n        if(portMatch) {\n          detectedPort = parseInt(portMatch[1]);\n        }\n\n        showStatusOnce(detectedPort);\n      }\n    });\n\n    setTimeout(() => {\n      if(!serverStarted) {\n        spinner.succeed('Development server started.');\n        showStatusOnce(detectedPort);\n      }\n    }, 5000);\n\n    await childProcess;\n\n    if(!serverStarted) {\n      spinner.succeed('Development server started.');\n      showStatusOnce(detectedPort);\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    spinner.fail('There was an error while running Webpack.');\n\n    callback(1);\n    return 1;\n  }\n};\n"],"names":["boxen","chalk","execa","existsSync","readFileSync","writeFileSync","mkdirSync","https","networkInterfaces","homedir","dirname","resolve","pathResolve","join","LexConfig","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","log","processTranslations","currentFilename","currentDirname","eval","process","cwd","DEFAULT_DEV_PORT","parsePort","portValue","undefined","parsed","Number","isInteger","getCacheDir","cacheDir","recursive","getCachePath","readPublicIpCache","cachePath","cacheData","cache","JSON","parse","oneWeekMs","Date","now","timestamp","writePublicIpCache","ip","stringify","fetchPublicIp","forceRefresh","Promise","cached","get","res","data","on","chunk","trim","getNetworkAddresses","interfaces","addresses","local","private","public","name","Object","keys","networkInterface","iface","family","internal","address","startsWith","displayServerStatus","port","quiet","publicIp","localUrl","privateUrl","publicUrl","urlLines","green","underline","statusBox","cyan","bold","yellow","backgroundColor","borderColor","borderStyle","margin","padding","console","dev","cmd","callback","bundleAnalyzer","cliName","config","format","open","cliPort","remove","translations","usePublicIp","variables","spinner","parseConfig","devConfig","outputFullPath","useTypescript","finalPort","variablesObj","NODE_ENV","_error","env","checkTypescriptConfig","start","succeed","sourcePath","sourceFullPath","outputPath","translationError","message","fail","webpackConfig","isRelativeConfig","substr","resolvedConfig","webpackPath","webpackOptions","push","executablePath","finalWebpackOptions","endsWith","childProcess","encoding","LEX_QUIET","WEBPACK_DEV_OPEN","WEBPACK_DEV_PORT","toString","stdio","serverStarted","statusShown","showStatusOnce","portToShow","then","detectedPort","stdout","output","includes","portMatch","match","parseInt","stderr","setTimeout","error"],"mappings":"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"}
@@ -760,9 +760,9 @@ export const serverless = async (cmd, callback = ()=>({}))=>{
760
760
  const n = typeof v === 'number' ? v : parseInt(String(v));
761
761
  return Number.isFinite(n) ? n : fallback;
762
762
  };
763
- const effectiveHttpPort = toNumber(cliHttpPort ?? configOffline.httpPort, 5000);
764
- const effectiveHttpsPort = toNumber(cliHttpsPort ?? configOffline.httpsPort, 5001);
765
- const effectiveWsPort = toNumber(cliWsPort ?? configOffline.wsPort, 5002);
763
+ const effectiveHttpPort = toNumber(cliHttpPort ?? configOffline.httpPort, 3100);
764
+ const effectiveHttpsPort = toNumber(cliHttpsPort ?? configOffline.httpsPort, 3101);
765
+ const effectiveWsPort = toNumber(cliWsPort ?? configOffline.wsPort, 3102);
766
766
  const finalConfig = {
767
767
  ...serverlessConfig,
768
768
  custom: {
@@ -831,4 +831,4 @@ export const serverless = async (cmd, callback = ()=>({}))=>{
831
831
  }
832
832
  };
833
833
 
834
- //# 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, isAbsolute} from 'path';\nimport {pathToFileURL} from 'url';\nimport {WebSocketServer} from 'ws';\n\nimport {LexConfig, getPackageDir} 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 resolvePublicIpForDisplay = async (forceRefresh: boolean = false): Promise<string | undefined> => {\n  const timeoutMs = 1500;\n  const timeoutPromise = new Promise<undefined>((resolve) => {\n    setTimeout(() => resolve(undefined), timeoutMs);\n  });\n\n  try {\n    return await Promise.race([fetchPublicIp(forceRefresh), timeoutPromise]);\n  } catch{\n    return undefined;\n  }\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    console.log(`[Serverless] Parsing handler path: ${handlerPath}`);\n\n    // Parse AWS Lambda handler format: \"path/to/file.exportName\" or \"file.exportName\"\n    // Examples: \"index.handler\", \"handlers/api.handler\", \"src/index.default\"\n    const handlerParts = handlerPath.split('.');\n    console.log('[Serverless] Handler parts after split:', handlerParts);\n\n    let filePath: string;\n    let exportName: string | null = null;\n\n    if(handlerParts.length > 1) {\n      // AWS Lambda format: \"file.exportName\"\n      // Take the last part as export name, rest as file path\n      // Handle cases like \"index.handler\" -> file: \"index\", export: \"handler\"\n      // Or \"handlers/api.handler\" -> file: \"handlers/api\", export: \"handler\"\n      exportName = handlerParts[handlerParts.length - 1] || null;\n      filePath = handlerParts.slice(0, -1).join('.');\n      console.log(`[Serverless] Parsed AWS Lambda format - filePath: \"${filePath}\", exportName: \"${exportName}\"`);\n    } else {\n      // Simple format: just the file path\n      filePath = handlerPath;\n      console.log(`[Serverless] Simple format - filePath: \"${filePath}\"`);\n    }\n\n    // Ensure filePath doesn't have the export name in it\n    if(filePath.includes('.handler') || filePath.includes('.default')) {\n      console.error(`[Serverless] WARNING: filePath still contains export name! filePath: \"${filePath}\"`);\n      // Try to fix it - remove the last part if it looks like an export name\n      const pathParts = filePath.split('.');\n      if(pathParts.length > 1) {\n        const lastPart = pathParts[pathParts.length - 1];\n        if(['handler', 'default', 'index'].includes(lastPart) && !exportName) {\n          exportName = lastPart;\n          filePath = pathParts.slice(0, -1).join('.');\n          console.log(`[Serverless] Fixed - filePath: \"${filePath}\", exportName: \"${exportName}\"`);\n        }\n      }\n    }\n\n    // Handle both relative paths and absolute paths\n    let fullPath: string;\n    if(isAbsolute(filePath)) {\n      fullPath = filePath;\n    } else {\n      fullPath = pathResolve(outputDir, filePath);\n    }\n    console.log(`[Serverless] Resolved fullPath (before extensions): ${fullPath}`);\n\n    // Try different extensions if file doesn't exist\n    if(!existsSync(fullPath)) {\n      const extensions = ['.js', '.mjs', '.cjs'];\n      const pathWithoutExt = fullPath.replace(/\\.(js|mjs|cjs)$/, '');\n      console.log(`[Serverless] Trying extensions. Base path: ${pathWithoutExt}`);\n      for(const ext of extensions) {\n        const candidatePath = pathWithoutExt + ext;\n        console.log(`[Serverless] Checking: ${candidatePath} (exists: ${existsSync(candidatePath)})`);\n        if(existsSync(candidatePath)) {\n          fullPath = candidatePath;\n          console.log(`[Serverless] Found file with extension: ${fullPath}`);\n          break;\n        }\n      }\n    } else {\n      console.log(`[Serverless] File exists without trying extensions: ${fullPath}`);\n    }\n\n    console.log(`[Serverless] Final fullPath: ${fullPath}`);\n    console.log(`[Serverless] Export name: ${exportName || 'default/handler'}`);\n    console.log(`[Serverless] File exists: ${existsSync(fullPath)}`);\n\n    if(!existsSync(fullPath)) {\n      console.error(`[Serverless] Handler file not found: ${fullPath}`);\n      console.error(`[Serverless] Output directory: ${outputDir}`);\n      console.error(`[Serverless] Handler path from config: ${handlerPath}`);\n      throw new Error(`Handler file not found: ${fullPath}`);\n    }\n\n    // Dynamic import of the handler with better error handling\n    // Add .js extension if importing TypeScript compiled output\n    const importPath = fullPath.endsWith('.ts') ? fullPath.replace(/\\.ts$/, '.js') : fullPath;\n\n    try {\n      // Convert to file:// URL for ES module imports (required for absolute paths)\n      // Use pathToFileURL to ensure proper file:// URL format\n      const importUrl = pathToFileURL(importPath).href;\n      console.log(`[Serverless] Importing handler from: ${importUrl}`);\n      console.log(`[Serverless] File path: ${importPath}`);\n\n      // Use import() with the file URL\n      // Note: If the handler file has import errors (like missing dependencies),\n      // those will surface here, but that's a handler code issue, not a loader issue\n      const handlerModule = await import(importUrl);\n      console.log(`[Serverless] Handler module loaded successfully. Exports: ${Object.keys(handlerModule).join(', ')}`);\n\n      // Get the handler based on export name or try defaults\n      let handler: any;\n      if(exportName) {\n        handler = handlerModule[exportName];\n        if(!handler) {\n          console.error(`[Serverless] Export \"${exportName}\" not found in module. Available exports: ${Object.keys(handlerModule).join(', ')}`);\n          return null;\n        }\n      } else {\n        // Try default, handler, or the module itself\n        handler = handlerModule.default || handlerModule.handler || handlerModule;\n      }\n\n      console.log(`[Serverless] Handler found: ${typeof handler}, isFunction: ${typeof handler === 'function'}`);\n\n      if(typeof handler !== 'function') {\n        console.error(`[Serverless] Handler is not a function. Type: ${typeof handler}, Value:`, handler);\n        return null;\n      }\n\n      return handler;\n    } catch(importError: any) {\n      console.error(`[Serverless] Import error for handler ${handlerPath}:`, importError.message);\n      console.error('[Serverless] Import error stack:', importError.stack);\n\n      // Check if this is a dependency resolution error (common with ES modules)\n      if(importError.message && importError.message.includes('Cannot find module')) {\n        console.error('[Serverless] This appears to be a dependency resolution error.');\n        console.error('[Serverless] The handler file exists, but one of its imports is failing.');\n        console.error('[Serverless] Check that all dependencies in the handler file are properly installed.');\n        console.error(`[Serverless] Handler file: ${importPath}`);\n        console.error('[Serverless] Make sure the handler and its dependencies are compiled correctly.');\n      }\n\n      return null;\n    }\n  } catch(error: any) {\n    console.error(`[Serverless] Error loading handler ${handlerPath}:`, error.message);\n    console.error('[Serverless] Error stack:', error.stack);\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      // Always log requests (not affected by quiet flag for debugging)\n      console.log(`[Serverless] ${method} ${url} (pathname: ${pathname})`);\n\n      // Find matching function\n      let matchedFunction = null;\n\n      if(config.functions) {\n        const functionNames = Object.keys(config.functions);\n        console.log(`[Serverless] Available functions: ${functionNames.join(', ')}`);\n        console.log('[Serverless] Config functions:', JSON.stringify(config.functions, null, 2));\n\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').toUpperCase();\n                const requestMethod = method.toUpperCase();\n\n                console.log(`[Serverless] Checking function ${functionName}: path=\"${eventPath}\", method=\"${eventMethod}\" against pathname=\"${pathname}\", method=\"${requestMethod}\"`);\n\n                // Improved path matching - compare pathname without query string\n                // Normalize paths (remove trailing slashes for comparison)\n                const normalizedEventPath = eventPath.replace(/\\/$/, '') || '/';\n                const normalizedPathname = pathname.replace(/\\/$/, '') || '/';\n\n                if(normalizedEventPath === normalizedPathname && eventMethod === requestMethod) {\n                  matchedFunction = functionName;\n                  console.log(`[Serverless] ✓ Matched function: ${matchedFunction}`);\n                  break;\n                }\n              }\n            }\n          }\n          if(matchedFunction) {\n            break;\n          }\n        }\n      } else {\n        console.log('[Serverless] No functions found in config');\n      }\n\n      if(matchedFunction && config.functions[matchedFunction]) {\n        // Resolve handler path relative to output directory\n        const handlerPath = config.functions[matchedFunction].handler;\n        console.log(`[Serverless] Loading handler: ${handlerPath} from outputDir: ${outputDir}`);\n        const handler = await loadHandler(handlerPath, outputDir);\n\n        if(handler) {\n          console.log(`[Serverless] Handler loaded successfully, type: ${typeof 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            console.log('[Serverless] Calling handler with event:', JSON.stringify(event, null, 2));\n            const result = await wrappedHandler(event, context);\n            console.log('[Serverless] Handler returned:', JSON.stringify(result, null, 2));\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: any) {\n            console.error('[Serverless] Handler error:', error.message);\n            console.error('[Serverless] Handler error stack:', error.stack);\n            log(`Handler error: ${error.message}`, 'error', false);\n            res.status(500).json({error: error.message});\n          }\n        } else {\n          console.error(`[Serverless] Handler not found for function: ${matchedFunction}`);\n          console.error(`[Serverless] Handler path: ${handlerPath}, Output dir: ${outputDir}`);\n          res.status(404).json({error: 'Handler not found'});\n        }\n      } else {\n        console.error(`[Serverless] Function not found for pathname: ${pathname}, method: ${method}`);\n        console.error(`[Serverless] Available functions: ${config.functions ? Object.keys(config.functions).join(', ') : 'none'}`);\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: cliHost,\n    httpPort: cliHttpPort,\n    httpsPort: cliHttpsPort,\n    quiet = false,\n    remove = false,\n    test = false,\n    usePublicIp,\n    variables,\n    wsPort: cliWsPort\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    // Use getPackageDir to handle npm workspaces correctly\n    const packageDir = getPackageDir();\n\n    // Try multiple config file formats\n    const configFormats = config ? [config] : [\n      pathResolve(packageDir, 'lex.config.mjs'),\n      pathResolve(packageDir, 'lex.config.js'),\n      pathResolve(packageDir, 'lex.config.cjs'),\n      pathResolve(packageDir, 'lex.config.ts')\n    ];\n\n    let configPath: string | null = null;\n    for(const candidatePath of configFormats) {\n      if(existsSync(candidatePath)) {\n        configPath = candidatePath;\n        break;\n      }\n    }\n\n    if(configPath) {\n      log(`Loading serverless config from: ${configPath}`, 'info', quiet);\n      const configModule = await import(configPath);\n      serverlessConfig = configModule.default?.serverless || configModule.serverless || {};\n      log('Serverless config loaded successfully', 'info', quiet);\n      const functionNames = Object.keys(serverlessConfig.functions || {});\n      log(`Loaded functions: ${functionNames.length > 0 ? functionNames.join(', ') : 'none'}`, 'info', quiet);\n\n      // Debug: Print full config if debug mode\n      if(debug) {\n        log(`Full serverless config: ${JSON.stringify(serverlessConfig, null, 2)}`, 'info', false);\n      }\n    } else {\n      log(`No serverless config found. Tried: ${configFormats.join(', ')}`, 'warn', quiet);\n    }\n  } catch(error) {\n    log(`Error loading serverless config: ${error.message}`, 'error', quiet);\n    if(debug) {\n      log(`Config error stack: ${error.stack}`, 'error', false);\n    }\n    // Don't exit, continue with empty config\n  }\n\n  // Merge config with command line options\n  // Determine effective host/ports with correct precedence: CLI > config > defaults\n  const configOffline = serverlessConfig.custom?.['serverless-offline'] || {};\n  const effectiveHost = (cliHost ?? configOffline.host ?? 'localhost') as string;\n  const toNumber = (v: any, fallback: number): number => {\n    if(v === undefined || v === null || v === '') {\n      return fallback;\n    }\n\n    const n = typeof v === 'number' ? v : parseInt(String(v));\n    return Number.isFinite(n) ? n : fallback;\n  };\n  const effectiveHttpPort = toNumber(cliHttpPort ?? configOffline.httpPort, 5000);\n  const effectiveHttpsPort = toNumber(cliHttpsPort ?? configOffline.httpsPort, 5001);\n  const effectiveWsPort = toNumber(cliWsPort ?? configOffline.wsPort, 5002);\n\n  const finalConfig: ServerlessConfig = {\n    ...serverlessConfig,\n    custom: {\n      'serverless-offline': {\n        cors: serverlessConfig.custom?.['serverless-offline']?.cors !== false,\n        host: effectiveHost,\n        httpPort: effectiveHttpPort,\n        httpsPort: effectiveHttpsPort,\n        wsPort: effectiveWsPort\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      void resolvePublicIpForDisplay(usePublicIp).then((publicIp) => {\n        displayServerStatus(\n          httpPort,\n          finalConfig.custom!['serverless-offline']!.httpsPort!,\n          wsPort,\n          host,\n          quiet,\n          publicIp\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};\n"],"names":["boxen","chalk","express","readFileSync","existsSync","mkdirSync","writeFileSync","homedir","resolve","pathResolve","join","isAbsolute","pathToFileURL","WebSocketServer","LexConfig","getPackageDir","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","resolvePublicIpForDisplay","timeoutMs","timeoutPromise","setTimeout","race","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","handlerParts","split","filePath","exportName","length","slice","includes","error","pathParts","lastPart","fullPath","extensions","pathWithoutExt","replace","ext","candidatePath","Error","importPath","endsWith","importUrl","href","handlerModule","Object","keys","handler","default","importError","message","stack","captureConsoleLogs","event","context","originalConsoleLog","originalConsoleError","originalConsoleWarn","warn","originalConsoleInfo","info","logs","args","push","result","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","matchedFunction","functionNames","eventPath","eventMethod","toUpperCase","requestMethod","normalizedEventPath","normalizedPathname","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","serverless","cmd","callback","cliName","cliHost","cliHttpPort","cliHttpsPort","remove","test","usePublicIp","cliWsPort","spinner","parseConfig","outputFullPath","envPaths","process","cwd","fileEnvVars","variablesObj","NODE_ENV","cliVars","_error","env","start","succeed","serverlessConfig","packageDir","configFormats","configPath","configModule","configOffline","custom","effectiveHost","toNumber","v","fallback","n","parseInt","Number","isFinite","effectiveHttpPort","effectiveHttpsPort","effectiveWsPort","finalConfig","cors","expressApp","wsServer","fail","server","listen","shutdown","close","stdin","resume"],"mappings":"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"}
834
+ //# 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, isAbsolute} from 'path';\nimport {pathToFileURL} from 'url';\nimport {WebSocketServer} from 'ws';\n\nimport {LexConfig, getPackageDir} 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 resolvePublicIpForDisplay = async (forceRefresh: boolean = false): Promise<string | undefined> => {\n  const timeoutMs = 1500;\n  const timeoutPromise = new Promise<undefined>((resolve) => {\n    setTimeout(() => resolve(undefined), timeoutMs);\n  });\n\n  try {\n    return await Promise.race([fetchPublicIp(forceRefresh), timeoutPromise]);\n  } catch{\n    return undefined;\n  }\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    console.log(`[Serverless] Parsing handler path: ${handlerPath}`);\n\n    // Parse AWS Lambda handler format: \"path/to/file.exportName\" or \"file.exportName\"\n    // Examples: \"index.handler\", \"handlers/api.handler\", \"src/index.default\"\n    const handlerParts = handlerPath.split('.');\n    console.log('[Serverless] Handler parts after split:', handlerParts);\n\n    let filePath: string;\n    let exportName: string | null = null;\n\n    if(handlerParts.length > 1) {\n      // AWS Lambda format: \"file.exportName\"\n      // Take the last part as export name, rest as file path\n      // Handle cases like \"index.handler\" -> file: \"index\", export: \"handler\"\n      // Or \"handlers/api.handler\" -> file: \"handlers/api\", export: \"handler\"\n      exportName = handlerParts[handlerParts.length - 1] || null;\n      filePath = handlerParts.slice(0, -1).join('.');\n      console.log(`[Serverless] Parsed AWS Lambda format - filePath: \"${filePath}\", exportName: \"${exportName}\"`);\n    } else {\n      // Simple format: just the file path\n      filePath = handlerPath;\n      console.log(`[Serverless] Simple format - filePath: \"${filePath}\"`);\n    }\n\n    // Ensure filePath doesn't have the export name in it\n    if(filePath.includes('.handler') || filePath.includes('.default')) {\n      console.error(`[Serverless] WARNING: filePath still contains export name! filePath: \"${filePath}\"`);\n      // Try to fix it - remove the last part if it looks like an export name\n      const pathParts = filePath.split('.');\n      if(pathParts.length > 1) {\n        const lastPart = pathParts[pathParts.length - 1];\n        if(['handler', 'default', 'index'].includes(lastPart) && !exportName) {\n          exportName = lastPart;\n          filePath = pathParts.slice(0, -1).join('.');\n          console.log(`[Serverless] Fixed - filePath: \"${filePath}\", exportName: \"${exportName}\"`);\n        }\n      }\n    }\n\n    // Handle both relative paths and absolute paths\n    let fullPath: string;\n    if(isAbsolute(filePath)) {\n      fullPath = filePath;\n    } else {\n      fullPath = pathResolve(outputDir, filePath);\n    }\n    console.log(`[Serverless] Resolved fullPath (before extensions): ${fullPath}`);\n\n    // Try different extensions if file doesn't exist\n    if(!existsSync(fullPath)) {\n      const extensions = ['.js', '.mjs', '.cjs'];\n      const pathWithoutExt = fullPath.replace(/\\.(js|mjs|cjs)$/, '');\n      console.log(`[Serverless] Trying extensions. Base path: ${pathWithoutExt}`);\n      for(const ext of extensions) {\n        const candidatePath = pathWithoutExt + ext;\n        console.log(`[Serverless] Checking: ${candidatePath} (exists: ${existsSync(candidatePath)})`);\n        if(existsSync(candidatePath)) {\n          fullPath = candidatePath;\n          console.log(`[Serverless] Found file with extension: ${fullPath}`);\n          break;\n        }\n      }\n    } else {\n      console.log(`[Serverless] File exists without trying extensions: ${fullPath}`);\n    }\n\n    console.log(`[Serverless] Final fullPath: ${fullPath}`);\n    console.log(`[Serverless] Export name: ${exportName || 'default/handler'}`);\n    console.log(`[Serverless] File exists: ${existsSync(fullPath)}`);\n\n    if(!existsSync(fullPath)) {\n      console.error(`[Serverless] Handler file not found: ${fullPath}`);\n      console.error(`[Serverless] Output directory: ${outputDir}`);\n      console.error(`[Serverless] Handler path from config: ${handlerPath}`);\n      throw new Error(`Handler file not found: ${fullPath}`);\n    }\n\n    // Dynamic import of the handler with better error handling\n    // Add .js extension if importing TypeScript compiled output\n    const importPath = fullPath.endsWith('.ts') ? fullPath.replace(/\\.ts$/, '.js') : fullPath;\n\n    try {\n      // Convert to file:// URL for ES module imports (required for absolute paths)\n      // Use pathToFileURL to ensure proper file:// URL format\n      const importUrl = pathToFileURL(importPath).href;\n      console.log(`[Serverless] Importing handler from: ${importUrl}`);\n      console.log(`[Serverless] File path: ${importPath}`);\n\n      // Use import() with the file URL\n      // Note: If the handler file has import errors (like missing dependencies),\n      // those will surface here, but that's a handler code issue, not a loader issue\n      const handlerModule = await import(importUrl);\n      console.log(`[Serverless] Handler module loaded successfully. Exports: ${Object.keys(handlerModule).join(', ')}`);\n\n      // Get the handler based on export name or try defaults\n      let handler: any;\n      if(exportName) {\n        handler = handlerModule[exportName];\n        if(!handler) {\n          console.error(`[Serverless] Export \"${exportName}\" not found in module. Available exports: ${Object.keys(handlerModule).join(', ')}`);\n          return null;\n        }\n      } else {\n        // Try default, handler, or the module itself\n        handler = handlerModule.default || handlerModule.handler || handlerModule;\n      }\n\n      console.log(`[Serverless] Handler found: ${typeof handler}, isFunction: ${typeof handler === 'function'}`);\n\n      if(typeof handler !== 'function') {\n        console.error(`[Serverless] Handler is not a function. Type: ${typeof handler}, Value:`, handler);\n        return null;\n      }\n\n      return handler;\n    } catch(importError: any) {\n      console.error(`[Serverless] Import error for handler ${handlerPath}:`, importError.message);\n      console.error('[Serverless] Import error stack:', importError.stack);\n\n      // Check if this is a dependency resolution error (common with ES modules)\n      if(importError.message && importError.message.includes('Cannot find module')) {\n        console.error('[Serverless] This appears to be a dependency resolution error.');\n        console.error('[Serverless] The handler file exists, but one of its imports is failing.');\n        console.error('[Serverless] Check that all dependencies in the handler file are properly installed.');\n        console.error(`[Serverless] Handler file: ${importPath}`);\n        console.error('[Serverless] Make sure the handler and its dependencies are compiled correctly.');\n      }\n\n      return null;\n    }\n  } catch(error: any) {\n    console.error(`[Serverless] Error loading handler ${handlerPath}:`, error.message);\n    console.error('[Serverless] Error stack:', error.stack);\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      // Always log requests (not affected by quiet flag for debugging)\n      console.log(`[Serverless] ${method} ${url} (pathname: ${pathname})`);\n\n      // Find matching function\n      let matchedFunction = null;\n\n      if(config.functions) {\n        const functionNames = Object.keys(config.functions);\n        console.log(`[Serverless] Available functions: ${functionNames.join(', ')}`);\n        console.log('[Serverless] Config functions:', JSON.stringify(config.functions, null, 2));\n\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').toUpperCase();\n                const requestMethod = method.toUpperCase();\n\n                console.log(`[Serverless] Checking function ${functionName}: path=\"${eventPath}\", method=\"${eventMethod}\" against pathname=\"${pathname}\", method=\"${requestMethod}\"`);\n\n                // Improved path matching - compare pathname without query string\n                // Normalize paths (remove trailing slashes for comparison)\n                const normalizedEventPath = eventPath.replace(/\\/$/, '') || '/';\n                const normalizedPathname = pathname.replace(/\\/$/, '') || '/';\n\n                if(normalizedEventPath === normalizedPathname && eventMethod === requestMethod) {\n                  matchedFunction = functionName;\n                  console.log(`[Serverless] ✓ Matched function: ${matchedFunction}`);\n                  break;\n                }\n              }\n            }\n          }\n          if(matchedFunction) {\n            break;\n          }\n        }\n      } else {\n        console.log('[Serverless] No functions found in config');\n      }\n\n      if(matchedFunction && config.functions[matchedFunction]) {\n        // Resolve handler path relative to output directory\n        const handlerPath = config.functions[matchedFunction].handler;\n        console.log(`[Serverless] Loading handler: ${handlerPath} from outputDir: ${outputDir}`);\n        const handler = await loadHandler(handlerPath, outputDir);\n\n        if(handler) {\n          console.log(`[Serverless] Handler loaded successfully, type: ${typeof 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            console.log('[Serverless] Calling handler with event:', JSON.stringify(event, null, 2));\n            const result = await wrappedHandler(event, context);\n            console.log('[Serverless] Handler returned:', JSON.stringify(result, null, 2));\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: any) {\n            console.error('[Serverless] Handler error:', error.message);\n            console.error('[Serverless] Handler error stack:', error.stack);\n            log(`Handler error: ${error.message}`, 'error', false);\n            res.status(500).json({error: error.message});\n          }\n        } else {\n          console.error(`[Serverless] Handler not found for function: ${matchedFunction}`);\n          console.error(`[Serverless] Handler path: ${handlerPath}, Output dir: ${outputDir}`);\n          res.status(404).json({error: 'Handler not found'});\n        }\n      } else {\n        console.error(`[Serverless] Function not found for pathname: ${pathname}, method: ${method}`);\n        console.error(`[Serverless] Available functions: ${config.functions ? Object.keys(config.functions).join(', ') : 'none'}`);\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: cliHost,\n    httpPort: cliHttpPort,\n    httpsPort: cliHttpsPort,\n    quiet = false,\n    remove = false,\n    test = false,\n    usePublicIp,\n    variables,\n    wsPort: cliWsPort\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    // Use getPackageDir to handle npm workspaces correctly\n    const packageDir = getPackageDir();\n\n    // Try multiple config file formats\n    const configFormats = config ? [config] : [\n      pathResolve(packageDir, 'lex.config.mjs'),\n      pathResolve(packageDir, 'lex.config.js'),\n      pathResolve(packageDir, 'lex.config.cjs'),\n      pathResolve(packageDir, 'lex.config.ts')\n    ];\n\n    let configPath: string | null = null;\n    for(const candidatePath of configFormats) {\n      if(existsSync(candidatePath)) {\n        configPath = candidatePath;\n        break;\n      }\n    }\n\n    if(configPath) {\n      log(`Loading serverless config from: ${configPath}`, 'info', quiet);\n      const configModule = await import(configPath);\n      serverlessConfig = configModule.default?.serverless || configModule.serverless || {};\n      log('Serverless config loaded successfully', 'info', quiet);\n      const functionNames = Object.keys(serverlessConfig.functions || {});\n      log(`Loaded functions: ${functionNames.length > 0 ? functionNames.join(', ') : 'none'}`, 'info', quiet);\n\n      // Debug: Print full config if debug mode\n      if(debug) {\n        log(`Full serverless config: ${JSON.stringify(serverlessConfig, null, 2)}`, 'info', false);\n      }\n    } else {\n      log(`No serverless config found. Tried: ${configFormats.join(', ')}`, 'warn', quiet);\n    }\n  } catch(error) {\n    log(`Error loading serverless config: ${error.message}`, 'error', quiet);\n    if(debug) {\n      log(`Config error stack: ${error.stack}`, 'error', false);\n    }\n    // Don't exit, continue with empty config\n  }\n\n  // Merge config with command line options\n  // Determine effective host/ports with correct precedence: CLI > config > defaults\n  const configOffline = serverlessConfig.custom?.['serverless-offline'] || {};\n  const effectiveHost = (cliHost ?? configOffline.host ?? 'localhost') as string;\n  const toNumber = (v: any, fallback: number): number => {\n    if(v === undefined || v === null || v === '') {\n      return fallback;\n    }\n\n    const n = typeof v === 'number' ? v : parseInt(String(v));\n    return Number.isFinite(n) ? n : fallback;\n  };\n  const effectiveHttpPort = toNumber(cliHttpPort ?? configOffline.httpPort, 3100);\n  const effectiveHttpsPort = toNumber(cliHttpsPort ?? configOffline.httpsPort, 3101);\n  const effectiveWsPort = toNumber(cliWsPort ?? configOffline.wsPort, 3102);\n\n  const finalConfig: ServerlessConfig = {\n    ...serverlessConfig,\n    custom: {\n      'serverless-offline': {\n        cors: serverlessConfig.custom?.['serverless-offline']?.cors !== false,\n        host: effectiveHost,\n        httpPort: effectiveHttpPort,\n        httpsPort: effectiveHttpsPort,\n        wsPort: effectiveWsPort\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      void resolvePublicIpForDisplay(usePublicIp).then((publicIp) => {\n        displayServerStatus(\n          httpPort,\n          finalConfig.custom!['serverless-offline']!.httpsPort!,\n          wsPort,\n          host,\n          quiet,\n          publicIp\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};\n"],"names":["boxen","chalk","express","readFileSync","existsSync","mkdirSync","writeFileSync","homedir","resolve","pathResolve","join","isAbsolute","pathToFileURL","WebSocketServer","LexConfig","getPackageDir","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","resolvePublicIpForDisplay","timeoutMs","timeoutPromise","setTimeout","race","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","handlerParts","split","filePath","exportName","length","slice","includes","error","pathParts","lastPart","fullPath","extensions","pathWithoutExt","replace","ext","candidatePath","Error","importPath","endsWith","importUrl","href","handlerModule","Object","keys","handler","default","importError","message","stack","captureConsoleLogs","event","context","originalConsoleLog","originalConsoleError","originalConsoleWarn","warn","originalConsoleInfo","info","logs","args","push","result","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","matchedFunction","functionNames","eventPath","eventMethod","toUpperCase","requestMethod","normalizedEventPath","normalizedPathname","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","serverless","cmd","callback","cliName","cliHost","cliHttpPort","cliHttpsPort","remove","test","usePublicIp","cliWsPort","spinner","parseConfig","outputFullPath","envPaths","process","cwd","fileEnvVars","variablesObj","NODE_ENV","cliVars","_error","env","start","succeed","serverlessConfig","packageDir","configFormats","configPath","configModule","configOffline","custom","effectiveHost","toNumber","v","fallback","n","parseInt","Number","isFinite","effectiveHttpPort","effectiveHttpsPort","effectiveWsPort","finalConfig","cors","expressApp","wsServer","fail","server","listen","shutdown","close","stdin","resume"],"mappings":"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"}
package/lib/lex.js CHANGED
@@ -13,7 +13,7 @@ import { clean } from './commands/clean/clean.js';
13
13
  import { compile } from './commands/compile/compile.js';
14
14
  import { config } from './commands/config/config.js';
15
15
  import { create } from './commands/create/create.js';
16
- import { dev } from './commands/dev/dev.js';
16
+ import { dev, DEFAULT_DEV_PORT } from './commands/dev/dev.js';
17
17
  import { init } from './commands/init/init.js';
18
18
  import { linked } from './commands/link/link.js';
19
19
  import { lint } from './commands/lint/lint.js';
@@ -57,7 +57,7 @@ program.command('create <type>').option('--outputFile <path>', 'Output filename.
57
57
  program.command('dev').option('--bundleAnalyzer', 'Run bundle analyzer.').option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).').addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: "esm".').choices([
58
58
  'cjs',
59
59
  'esm'
60
- ]).default('esm')).option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).').option('--open', 'Automatically open dev server in a new browser window.').option('--outputPath <path>', 'Output path').option('--port <number>', 'Port number for the development server (default: 3000).').option('--quiet', 'No Lex notifications printed in the console.').option('--remove', 'Removes all files from the output directory before compiling.').option('--sourcePath <path>', 'Source path').option('--translations', 'Process translation files and output flattened JSON.', false).option('--typescript', 'Transpile as Typescript.').option('--usePublicIp', 'Force refresh the cached public IP address.').option('--variables <n>', 'Environment variables to set in "process.env". (ie. "{NODE_ENV: \'development\'}").').option('--watch', 'Watch for changes.').action((cmd)=>dev(cmd, process.exit).then(()=>{}));
60
+ ]).default('esm')).option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).').option('--open', 'Automatically open dev server in a new browser window.').option('--outputPath <path>', 'Output path').option('--port <number>', `Port number for the development server (default: ${DEFAULT_DEV_PORT}).`).option('--quiet', 'No Lex notifications printed in the console.').option('--remove', 'Removes all files from the output directory before compiling.').option('--sourcePath <path>', 'Source path').option('--translations', 'Process translation files and output flattened JSON.', false).option('--typescript', 'Transpile as Typescript.').option('--usePublicIp', 'Force refresh the cached public IP address.').option('--variables <n>', 'Environment variables to set in "process.env". (ie. "{NODE_ENV: \'development\'}").').option('--watch', 'Watch for changes.').action((cmd)=>dev(cmd, process.exit).then(()=>{}));
61
61
  program.command('init <appName> [packageName]').option('--install', 'Install dependencies.').addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices([
62
62
  'npm',
63
63
  'yarn'
@@ -76,7 +76,7 @@ program.command('publish').addOption(new Option('--bump <type>', 'Increments the
76
76
  'npm',
77
77
  'yarn'
78
78
  ]).default('npm')).option('--private', 'Publishes the module as restricted.').option('--quiet', 'No Lex notifications printed in the console.').option('--tag <tag>', 'Registers the published package with the given tag.').action((cmd)=>publish(cmd, process.exit).then(()=>{}));
79
- program.command('serverless').option('--config <path>', 'Custom configuration file path (default: lex.config.mjs).').option('--host <host>', 'Host to bind the server to (default: localhost).').option('--httpPort <port>', 'HTTP server port (default: 3000).').option('--httpsPort <port>', 'HTTPS server port (default: 3001).').option('--wsPort <port>', 'WebSocket server port (default: 3002).').option('--quiet', 'No Lex notifications printed in the console.').option('--remove', 'Removes all files from the output directory before starting.').option('--usePublicIp', 'Force refresh the cached public IP address.').option('--variables <json>', 'Environment variables to set in process.env.').option('--debug', 'Enable GraphQL debug logging to see queries, variables, and operations.').option('--printOutput', 'Print GraphQL response output including status, headers, and body.').action((cmd)=>serverless(cmd, process.exit).then(()=>{}));
79
+ program.command('serverless').option('--config <path>', 'Custom configuration file path (default: lex.config.mjs).').option('--host <host>', 'Host to bind the server to (default: localhost).').option('--httpPort <port>', 'HTTP server port (default: 3100).').option('--httpsPort <port>', 'HTTPS server port (default: 3101).').option('--wsPort <port>', 'WebSocket server port (default: 3102).').option('--quiet', 'No Lex notifications printed in the console.').option('--remove', 'Removes all files from the output directory before starting.').option('--usePublicIp', 'Force refresh the cached public IP address.').option('--variables <json>', 'Environment variables to set in process.env.').option('--debug', 'Enable GraphQL debug logging to see queries, variables, and operations.').option('--printOutput', 'Print GraphQL response output including status, headers, and body.').action((cmd)=>serverless(cmd, process.exit).then(()=>{}));
80
80
  program.command('storybook').option('--config <path>', 'Custom Storybook configuration directory path (ie. .storybook).').option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).').option('--open', 'Automatically open Storybook in a new browser window.').option('--port <number>', 'Port number for the Storybook server.').option('--quiet', 'No Lex notifications printed in the console.').option('--static', 'Build a static Storybook site instead of starting dev server.').option('--variables <n>', 'Environment variables to set in "process.env". (ie. "{STORYBOOK_THEME: \'dark\'}").').option('--verbose', 'Show detailed webpack progress output.').action((cmd)=>storybook(cmd, process.exit).then(()=>{}));
81
81
  program.command('test [files...]').option('--analyze', 'Use AI to analyze test coverage and suggest improvements.', false).option('--debugTests', 'Use AI to debug test failures and suggest fixes.', false).option('--generate', 'Use AI to generate test cases for untested code.', false).option('--bail', 'Exit the test suite immediately upon the first failing test suite.').option('--changedFilesWithAncestor', 'Runs tests related to the current changes and the changes made in the last commit.').option('--changedSince', 'Runs tests related the changes since the provided branch.').option('--ci', 'When this option is provided, Vitest will assume it is running in a CI environment.').option('--clearCache', 'Clear Vitest cache.').option('--collectCoverageFrom <glob>', 'A glob pattern relative to matching the files that coverage info needs to be collected from.').option('--colors', 'Forces test results output highlighting even if stdout is not a TTY.').option('--config <path>', 'Custom Vitest configuration file path (ie. vitest.config.mjs).').option('--debug', 'Print debugging info about your Vitest config.').option('--detectOpenHandles', 'Attempt to collect and print open handles preventing Vitest from exiting cleanly').option('--environment <n>', 'Target environment. "node" or "web". Default: "node".').option('--env', 'The test environment used for all tests. This can point to any file or node module. Examples: happy-dom, jsdom, node or path/to/my-environment.js.').option('--errorOnDeprecated', 'Make calling deprecated APIs throw helpful error messages.').option('--expand', 'Use this flag to show full diffs and errors instead of a patch.').option('--forceExit', 'Force Vitest to exit after all tests have completed running.').option('--json', 'Prints the test results in JSON.').option('--lastCommit', 'Run all tests affected by file changes in the last commit made.').option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).').option('--listTests', 'Lists all tests as JSON that Vitest will run given the arguments, and exits.').option('--logHeapUsage', 'Logs the heap usage after every test.').option('--maxWorkers <num>', 'Specifies the maximum number of workers the worker-pool will spawn for running tests. ').option('--noStackTrace', 'Disables stack trace in test results output.').option('--notify', 'Activates notifications for test results.').option('--onlyChanged', 'un based on which files have changed in the current repository. ').option('--outputFile <filename>', 'Write test results to a file when the --json option is also specified.').option('--passWithNoTests', 'Allows the test suite to pass when no files are found.').option('--quiet', 'No Lex notifications printed in the console.').option('--runInBand', 'Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests.').option('--setup <path>', 'Vitest setup file path.').option('--showConfig', 'Print your Vitest config and then exits.').option('--silent', 'Prevent tests from printing messages through the console.').option('--testLocationInResults', 'Adds a location field to test results.').option('--testNamePattern <regex>', 'Run only tests with a name that matches the regex. ').option('--testPathPattern <regex>', 'A regexp pattern string that is matched against all tests paths before executing the test.').option('--typescript', 'Transpile as Typescript.').option('--update', 'Update snapshots. Runs "vitest --update"').option('--useStderr', 'Divert all output to stderr.').option('--verbose', 'Display individual test results with the test suite hierarchy.').option('--watch <path>', 'Watch files for changes and rerun tests related to changed files.').option('--watchAll', 'Watch files for changes and rerun all tests when something changes.').action((files, options, cmd)=>test(options, cmd.args, files, process.exit).then(()=>{}));
82
82
  program.command('update').option('--interactive', 'Choose which packages to update.').addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices([
@@ -97,4 +97,4 @@ program.command('ai').option('--context', 'Include project context in the AI pro
97
97
  program.command('versions').option('--json', 'Print the version as a JSON object.').action((cmd)=>versions(cmd, process.exit).then(()=>{}));
98
98
  program.version(packageJson.version).parse(process.argv);
99
99
 
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lex.ts"],"sourcesContent":["#!/usr/bin/env node\n/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {Option, program} from 'commander';\nimport {readFileSync} from 'fs';\nimport {createRequire} from 'module';\nimport {dirname, resolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {aiFunction} from './commands/ai/ai.js';\nimport {build} from './commands/build/build.js';\nimport {clean} from './commands/clean/clean.js';\nimport {compile} from './commands/compile/compile.js';\nimport {config} from './commands/config/config.js';\nimport {create} from './commands/create/create.js';\nimport {dev} from './commands/dev/dev.js';\nimport {init} from './commands/init/init.js';\nimport {linked} from './commands/link/link.js';\nimport {lint} from './commands/lint/lint.js';\nimport {migrate} from './commands/migrate/migrate.js';\nimport {publish} from './commands/publish/publish.js';\nimport {serverless} from './commands/serverless/serverless.js';\nimport {storybook} from './commands/storybook/storybook.js';\nimport {test} from './commands/test/test.js';\nimport {update} from './commands/update/update.js';\nimport {upgrade} from './commands/upgrade/upgrade.js';\nimport {versions} from './commands/versions/versions.js';\n\nprocess.env.LEX_ROOT = dirname(fileURLToPath(import.meta.url));\n\nconst lexNodeModules = resolve(dirname(fileURLToPath(import.meta.url)), '../node_modules');\nif(!process.env.NODE_PATH) {\n  process.env.NODE_PATH = lexNodeModules;\n} else if(!process.env.NODE_PATH.split(':').includes(lexNodeModules)) {\n  process.env.NODE_PATH += `:${lexNodeModules}`;\n}\n\nconst require = createRequire(import.meta.url);\n// eslint-disable-next-line no-underscore-dangle\nrequire('module').Module._initPaths();\n\nconst packagePath = fileURLToPath(new URL('../package.json', import.meta.url));\nconst packageJson = JSON.parse(readFileSync(packagePath, 'utf8'));\n\nprogram.command('build')\n  .option('--assist', 'Enable AI assistance for fixing build errors.', false)\n  .option('--analyze', 'Enable AI analysis for build optimization suggestions or invoke webpack-bundle-analyzer plugin.', false)\n  .addOption(new Option('--bundler <n>', 'Bundler to use (\"webpack\" or \"swc\"). Default: \"swc\".').choices(['webpack', 'swc']).default('swc'))\n  .option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).')\n  .option('--configName <value...>', 'Name of the configuration to use.')\n  .option('--defineProcessEnvNodeEnv <value>', 'Sets process.env.NODE_ENV to the specified value. (Currently an alias for `--node-env`)')\n  .option('--devtool <value>', 'A developer tool to enhance debugging (false | eval | [inline-|hidden-|eval-][nosources-][cheap-[module-]]source-map).')\n  .option('--disableInterpret', 'Disable interpret for loading the config file.', false)\n  .option('--entry <value...>', 'A module that is loaded upon startup. Only the last one is exported.')\n  .option('--env <value>', 'Environment passed to the configuration when it is a function.')\n  .option('--failOnWarnings', 'Stop webpack-cli process with non-zero exit code on warnings from webpack', false)\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--json <value>', 'Prints result as JSON or store it in a file.')\n  .option('--lexConfig <path>', 'Lex configuration file path (lex.config.js).')\n  .option('--merge', 'Merge two or more configurations using \"webpack-merge\".', false)\n  .addOption(new Option('--mode <type>', 'Webpack mode (\"production\" or \"development\"). Default: \"development\".').choices(['development', 'production']).default('development'))\n  .option('--name <value>', 'Name of the configuration. Used when loading multiple configurations.')\n  .option('--noDevtool', 'Negative \"devtool\" option.', false)\n  .option('--noStats', 'Negative \"stats\" option.', false)\n  .option('--noTarget', 'Negative \"target\" option.', false)\n  .option('--noWatch', 'Negative \"watch\" option.', false)\n  .option('--noWatchOptionsStdin', 'Negative \"watch-options-stdin\" option.', false)\n  .option('--nodeEnv <value>', 'Sets process.env.NODE_ENV to the specified value.')\n  .option('--outputPath <value>', 'The output directory as **absolute path** (required).')\n  .option('--quiet', 'No Lex notifications printed in the console.', false)\n  .option('--remove', 'Removes all files from the output directory before compiling.', false)\n  .option('--sourcePath <path>', 'Source path')\n  .option('--stats <value>', 'Stats options object or preset name.')\n  .option('--static', 'Creates static HTML files when building app.', false)\n  .option('--target <value>', 'Environment to build for. Environment to build for. An array of environments to build for all of them when possible.')\n  .option('--translations', 'Process translation files and output flattened JSON.', false)\n  .option('--typescript', 'Transpile as Typescript.', false)\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{NODE_ENV: \\'production\\'}\").')\n  .option('--watch', 'Watch for changes.', false)\n  .option('--watchOptionsStdin', 'Stop watching when stdin stream has ended.', false)\n  .action((cmd) => build(cmd, process.exit).then(() => {}));\n\nprogram.command('clean')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--snapshots', 'Remove all \"__snapshots__\" directories.')\n  .action((cmd) => clean(cmd, process.exit).then(() => {}));\n\nprogram.command('config <type>')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--json <path>', 'Save output to json file.')\n  .action((type, cmd) => config(type, cmd, process.exit).then(() => {}));\n\nprogram.command('compile')\n  .option('--config <path>', 'Transpiler configuration file path (ie. tsconfig.json).')\n  .option('--environment <n>', 'Target environment. \"node\" or \"web\". Default: \"node\".')\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--outputPath <path>', 'Output path')\n  .option('--remove', 'Removes all files from the output directory before compiling.')\n  .option('--sourcePath <path>', 'Source path')\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--watch', 'Watches for changes and compiles.')\n  .action((cmd) => compile(cmd, process.exit).then(() => {}));\n\nprogram.command('create <type>')\n  .option('--outputFile <path>', 'Output filename.')\n  .option('--outputName <n>', 'Output name.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--typescript', 'Create Typescript version.')\n  .action((type, cmd) => create(type, cmd, process.exit).then(() => {}));\n\nprogram.command('dev')\n  .option('--bundleAnalyzer', 'Run bundle analyzer.')\n  .option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).')\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--open', 'Automatically open dev server in a new browser window.')\n  .option('--outputPath <path>', 'Output path')\n  .option('--port <number>', 'Port number for the development server (default: 3000).')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--remove', 'Removes all files from the output directory before compiling.')\n  .option('--sourcePath <path>', 'Source path')\n  .option('--translations', 'Process translation files and output flattened JSON.', false)\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--usePublicIp', 'Force refresh the cached public IP address.')\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{NODE_ENV: \\'development\\'}\").')\n  .option('--watch', 'Watch for changes.')\n  .action((cmd) => dev(cmd, process.exit).then(() => {}));\n\nprogram.command('init <appName> [packageName]')\n  .option('--install', 'Install dependencies.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--typescript', 'Use a Typescript based app.')\n  .action((appName, packageName, cmd) => init(appName, packageName, cmd, process.exit).then(() => {}));\n\nprogram.command('linked')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => linked(cmd, process.exit).then(() => {}));\n\nprogram.command('lint')\n  .option('--cache', 'Only check changed files. Default: false.', false)\n  .option('--cacheLocation <path>', 'Path to the cache file or directory.')\n  .option('--color', 'Force enabling of color.', false)\n  .option('--config <path>', 'Use this configuration, overriding .eslintrc.* config options if present. If not specified and no local config exists, Lex will use its default config.')\n  .option('--debug', 'Output debugging information.', false)\n  .option('--envInfo', 'Output execution environment information. Default: false.', false)\n  .option('--env <n>', 'Specify environments.')\n  .option('--fix', 'Apply AI fixes after built-in ESLint fixes (same as --fix).', false)\n  .option('--fixDryRun', 'Automatically fix problems without saving the changes to the file system.', false)\n  .option('--fixType <type>', 'Specify the types of fixes to apply (problem, suggestion, layout).')\n  .option('--format <n>', 'Use a specific output format. Default: stylish.')\n  .option('--global <variables>', 'Define global variables.')\n  .option('--ignorePath <path>', 'Specify path of ignore file.')\n  .option('--ignorePattern <pattern>', 'Pattern of files to ignore (in addition to those in .eslintignore).')\n  .option('--init', 'Run config initialization wizard. Default: false.', false)\n  .option('--maxWarnings <num>', 'Number of warnings to trigger nonzero exit code. Default: -1.')\n  .option('--noColor', 'Force disabling of color.', false)\n  .option('--noEslintrc', 'Disable use of configuration from .eslintrc.*.', false)\n  .option('--noIgnore', 'Disable use of ignore files and patterns.', false)\n  .option('--noInlineConfig', 'Prevent comments from changing config or rules.', false)\n  .option('--outputFile <path>', 'Specify file to write report to.')\n  .option('--parser <n>', 'Specify the parser to be used.')\n  .option('--parserOptions <options>', 'Specify parser options.')\n  .option('--plugin <plugins>', 'Specify plugins.')\n  .option('--printConfig <path>', 'Print the configuration for the given file.')\n  .option('--quiet', 'No Lex notifications printed in the console.', false)\n  .option('--remove-comments', 'Remove all comments except TODOs and copyright notices.', false)\n  .option('--reportUnusedDisableDirectives', 'Adds reported errors for unused eslint-disable directives.', false)\n  .option('--resolvePluginsRelativeTo <path>', 'A folder where plugins should be resolved from.')\n  .option('--rule <path>', 'Specify rules.')\n  .option('--rulesdir <path>', 'Use additional rules from this directory.')\n  .option('--stdin', 'Lint code provided on <STDIN> - Default: false.', false)\n  .option('--stdinFilename <n>', 'Specify filename to process STDIN as.')\n  .action((cmd) => lint(cmd, process.exit).then(() => {}));\n\nprogram.command('migrate')\n  .option('-q, --quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => migrate(cmd, process.exit).then(() => {}));\n\nprogram.command('publish')\n  .addOption(new Option('--bump <type>', 'Increments the version. Types include: major, minor, patch, beta, alpha, rc. Default: \"patch\".').choices(['major', 'minor', 'patch', 'beta', 'alpha', 'rc']).default('patch'))\n  .option('--newVersion <versionNumber>', 'Publish as a specific version.')\n  .option('--otp <code>', 'Provide a two-factor code.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--private', 'Publishes the module as restricted.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--tag <tag>', 'Registers the published package with the given tag.')\n  .action((cmd) => publish(cmd, process.exit).then(() => {}));\n\nprogram.command('serverless')\n  .option('--config <path>', 'Custom configuration file path (default: lex.config.mjs).')\n  .option('--host <host>', 'Host to bind the server to (default: localhost).')\n  .option('--httpPort <port>', 'HTTP server port (default: 3000).')\n  .option('--httpsPort <port>', 'HTTPS server port (default: 3001).')\n  .option('--wsPort <port>', 'WebSocket server port (default: 3002).')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--remove', 'Removes all files from the output directory before starting.')\n  .option('--usePublicIp', 'Force refresh the cached public IP address.')\n  .option('--variables <json>', 'Environment variables to set in process.env.')\n  .option('--debug', 'Enable GraphQL debug logging to see queries, variables, and operations.')\n  .option('--printOutput', 'Print GraphQL response output including status, headers, and body.')\n  .action((cmd) => serverless(cmd, process.exit).then(() => {}));\n\nprogram.command('storybook')\n  .option('--config <path>', 'Custom Storybook configuration directory path (ie. .storybook).')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--open', 'Automatically open Storybook in a new browser window.')\n  .option('--port <number>', 'Port number for the Storybook server.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--static', 'Build a static Storybook site instead of starting dev server.')\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{STORYBOOK_THEME: \\'dark\\'}\").')\n  .option('--verbose', 'Show detailed webpack progress output.')\n  .action((cmd) => storybook(cmd, process.exit).then(() => {}));\n\nprogram.command('test [files...]')\n  .option('--analyze', 'Use AI to analyze test coverage and suggest improvements.', false)\n  .option('--debugTests', 'Use AI to debug test failures and suggest fixes.', false)\n  .option('--generate', 'Use AI to generate test cases for untested code.', false)\n  .option('--bail', 'Exit the test suite immediately upon the first failing test suite.')\n  .option('--changedFilesWithAncestor', 'Runs tests related to the current changes and the changes made in the last commit.')\n  .option('--changedSince', 'Runs tests related the changes since the provided branch.')\n  .option('--ci', 'When this option is provided, Vitest will assume it is running in a CI environment.')\n  .option('--clearCache', 'Clear Vitest cache.')\n  .option('--collectCoverageFrom <glob>', 'A glob pattern relative to matching the files that coverage info needs to be collected from.')\n  .option('--colors', 'Forces test results output highlighting even if stdout is not a TTY.')\n  .option('--config <path>', 'Custom Vitest configuration file path (ie. vitest.config.mjs).')\n  .option('--debug', 'Print debugging info about your Vitest config.')\n  .option('--detectOpenHandles', 'Attempt to collect and print open handles preventing Vitest from exiting cleanly')\n  .option('--environment <n>', 'Target environment. \"node\" or \"web\". Default: \"node\".')\n  .option('--env', 'The test environment used for all tests. This can point to any file or node module. Examples: happy-dom, jsdom, node or path/to/my-environment.js.')\n  .option('--errorOnDeprecated', 'Make calling deprecated APIs throw helpful error messages.')\n  .option('--expand', 'Use this flag to show full diffs and errors instead of a patch.')\n  .option('--forceExit', 'Force Vitest to exit after all tests have completed running.')\n  .option('--json', 'Prints the test results in JSON.')\n  .option('--lastCommit', 'Run all tests affected by file changes in the last commit made.')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--listTests', 'Lists all tests as JSON that Vitest will run given the arguments, and exits.')\n  .option('--logHeapUsage', 'Logs the heap usage after every test.')\n  .option('--maxWorkers <num>', 'Specifies the maximum number of workers the worker-pool will spawn for running tests. ')\n  .option('--noStackTrace', 'Disables stack trace in test results output.')\n  .option('--notify', 'Activates notifications for test results.')\n  .option('--onlyChanged', 'un based on which files have changed in the current repository. ')\n  .option('--outputFile <filename>', 'Write test results to a file when the --json option is also specified.')\n  .option('--passWithNoTests', 'Allows the test suite to pass when no files are found.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--runInBand', 'Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests.')\n  .option('--setup <path>', 'Vitest setup file path.')\n  .option('--showConfig', 'Print your Vitest config and then exits.')\n  .option('--silent', 'Prevent tests from printing messages through the console.')\n  .option('--testLocationInResults', 'Adds a location field to test results.')\n  .option('--testNamePattern <regex>', 'Run only tests with a name that matches the regex. ')\n  .option('--testPathPattern <regex>', 'A regexp pattern string that is matched against all tests paths before executing the test.')\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--update', 'Update snapshots. Runs \"vitest --update\"')\n  .option('--useStderr', 'Divert all output to stderr.')\n  .option('--verbose', 'Display individual test results with the test suite hierarchy.')\n  .option('--watch <path>', 'Watch files for changes and rerun tests related to changed files.')\n  .option('--watchAll', 'Watch files for changes and rerun all tests when something changes.')\n  .action((files, options, cmd) => test(options, cmd.args, files, process.exit).then(() => {}));\n\nprogram.command('update')\n  .option('--interactive', 'Choose which packages to update.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--registry', 'Add a custom registry url.')\n  .action((cmd) => update(cmd, process.exit).then(() => {}));\n\nprogram.command('upgrade')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => upgrade(cmd, process.exit).then(() => {}));\n\nprogram.command('ai')\n  .option('--context', 'Include project context in the AI prompt.', true)\n  .option('--file <path>', 'Specific file to operate on.')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--model <model>', 'AI model to use. Default: gpt-4o.')\n  .option('--prompt <text>', 'The prompt to send to the AI.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .addOption(new Option('--task <task>', 'Type of AI task to perform.').choices(['generate', 'explain', 'test', 'optimize', 'help']).default('help'))\n  .action((cmd) => aiFunction(cmd).then(() => {}));\n\nprogram.command('versions')\n  .option('--json', 'Print the version as a JSON object.')\n  .action((cmd) => versions(cmd, process.exit).then(() => {}));\n\nprogram\n  .version(packageJson.version)\n  .parse(process.argv);\n"],"names":["Option","program","readFileSync","createRequire","dirname","resolve","fileURLToPath","aiFunction","build","clean","compile","config","create","dev","init","linked","lint","migrate","publish","serverless","storybook","test","update","upgrade","versions","process","env","LEX_ROOT","url","lexNodeModules","NODE_PATH","split","includes","require","Module","_initPaths","packagePath","URL","packageJson","JSON","parse","command","option","addOption","choices","default","action","cmd","exit","then","type","appName","packageName","files","options","args","version","argv"],"mappings":"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"}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lex.ts"],"sourcesContent":["#!/usr/bin/env node\n/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {Option, program} from 'commander';\nimport {readFileSync} from 'fs';\nimport {createRequire} from 'module';\nimport {dirname, resolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {aiFunction} from './commands/ai/ai.js';\nimport {build} from './commands/build/build.js';\nimport {clean} from './commands/clean/clean.js';\nimport {compile} from './commands/compile/compile.js';\nimport {config} from './commands/config/config.js';\nimport {create} from './commands/create/create.js';\nimport {dev, DEFAULT_DEV_PORT} from './commands/dev/dev.js';\nimport {init} from './commands/init/init.js';\nimport {linked} from './commands/link/link.js';\nimport {lint} from './commands/lint/lint.js';\nimport {migrate} from './commands/migrate/migrate.js';\nimport {publish} from './commands/publish/publish.js';\nimport {serverless} from './commands/serverless/serverless.js';\nimport {storybook} from './commands/storybook/storybook.js';\nimport {test} from './commands/test/test.js';\nimport {update} from './commands/update/update.js';\nimport {upgrade} from './commands/upgrade/upgrade.js';\nimport {versions} from './commands/versions/versions.js';\n\nprocess.env.LEX_ROOT = dirname(fileURLToPath(import.meta.url));\n\nconst lexNodeModules = resolve(dirname(fileURLToPath(import.meta.url)), '../node_modules');\nif(!process.env.NODE_PATH) {\n  process.env.NODE_PATH = lexNodeModules;\n} else if(!process.env.NODE_PATH.split(':').includes(lexNodeModules)) {\n  process.env.NODE_PATH += `:${lexNodeModules}`;\n}\n\nconst require = createRequire(import.meta.url);\n// eslint-disable-next-line no-underscore-dangle\nrequire('module').Module._initPaths();\n\nconst packagePath = fileURLToPath(new URL('../package.json', import.meta.url));\nconst packageJson = JSON.parse(readFileSync(packagePath, 'utf8'));\n\nprogram.command('build')\n  .option('--assist', 'Enable AI assistance for fixing build errors.', false)\n  .option('--analyze', 'Enable AI analysis for build optimization suggestions or invoke webpack-bundle-analyzer plugin.', false)\n  .addOption(new Option('--bundler <n>', 'Bundler to use (\"webpack\" or \"swc\"). Default: \"swc\".').choices(['webpack', 'swc']).default('swc'))\n  .option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).')\n  .option('--configName <value...>', 'Name of the configuration to use.')\n  .option('--defineProcessEnvNodeEnv <value>', 'Sets process.env.NODE_ENV to the specified value. (Currently an alias for `--node-env`)')\n  .option('--devtool <value>', 'A developer tool to enhance debugging (false | eval | [inline-|hidden-|eval-][nosources-][cheap-[module-]]source-map).')\n  .option('--disableInterpret', 'Disable interpret for loading the config file.', false)\n  .option('--entry <value...>', 'A module that is loaded upon startup. Only the last one is exported.')\n  .option('--env <value>', 'Environment passed to the configuration when it is a function.')\n  .option('--failOnWarnings', 'Stop webpack-cli process with non-zero exit code on warnings from webpack', false)\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--json <value>', 'Prints result as JSON or store it in a file.')\n  .option('--lexConfig <path>', 'Lex configuration file path (lex.config.js).')\n  .option('--merge', 'Merge two or more configurations using \"webpack-merge\".', false)\n  .addOption(new Option('--mode <type>', 'Webpack mode (\"production\" or \"development\"). Default: \"development\".').choices(['development', 'production']).default('development'))\n  .option('--name <value>', 'Name of the configuration. Used when loading multiple configurations.')\n  .option('--noDevtool', 'Negative \"devtool\" option.', false)\n  .option('--noStats', 'Negative \"stats\" option.', false)\n  .option('--noTarget', 'Negative \"target\" option.', false)\n  .option('--noWatch', 'Negative \"watch\" option.', false)\n  .option('--noWatchOptionsStdin', 'Negative \"watch-options-stdin\" option.', false)\n  .option('--nodeEnv <value>', 'Sets process.env.NODE_ENV to the specified value.')\n  .option('--outputPath <value>', 'The output directory as **absolute path** (required).')\n  .option('--quiet', 'No Lex notifications printed in the console.', false)\n  .option('--remove', 'Removes all files from the output directory before compiling.', false)\n  .option('--sourcePath <path>', 'Source path')\n  .option('--stats <value>', 'Stats options object or preset name.')\n  .option('--static', 'Creates static HTML files when building app.', false)\n  .option('--target <value>', 'Environment to build for. Environment to build for. An array of environments to build for all of them when possible.')\n  .option('--translations', 'Process translation files and output flattened JSON.', false)\n  .option('--typescript', 'Transpile as Typescript.', false)\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{NODE_ENV: \\'production\\'}\").')\n  .option('--watch', 'Watch for changes.', false)\n  .option('--watchOptionsStdin', 'Stop watching when stdin stream has ended.', false)\n  .action((cmd) => build(cmd, process.exit).then(() => {}));\n\nprogram.command('clean')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--snapshots', 'Remove all \"__snapshots__\" directories.')\n  .action((cmd) => clean(cmd, process.exit).then(() => {}));\n\nprogram.command('config <type>')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--json <path>', 'Save output to json file.')\n  .action((type, cmd) => config(type, cmd, process.exit).then(() => {}));\n\nprogram.command('compile')\n  .option('--config <path>', 'Transpiler configuration file path (ie. tsconfig.json).')\n  .option('--environment <n>', 'Target environment. \"node\" or \"web\". Default: \"node\".')\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--outputPath <path>', 'Output path')\n  .option('--remove', 'Removes all files from the output directory before compiling.')\n  .option('--sourcePath <path>', 'Source path')\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--watch', 'Watches for changes and compiles.')\n  .action((cmd) => compile(cmd, process.exit).then(() => {}));\n\nprogram.command('create <type>')\n  .option('--outputFile <path>', 'Output filename.')\n  .option('--outputName <n>', 'Output name.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--typescript', 'Create Typescript version.')\n  .action((type, cmd) => create(type, cmd, process.exit).then(() => {}));\n\nprogram.command('dev')\n  .option('--bundleAnalyzer', 'Run bundle analyzer.')\n  .option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).')\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--open', 'Automatically open dev server in a new browser window.')\n  .option('--outputPath <path>', 'Output path')\n  .option('--port <number>', `Port number for the development server (default: ${DEFAULT_DEV_PORT}).`)\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--remove', 'Removes all files from the output directory before compiling.')\n  .option('--sourcePath <path>', 'Source path')\n  .option('--translations', 'Process translation files and output flattened JSON.', false)\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--usePublicIp', 'Force refresh the cached public IP address.')\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{NODE_ENV: \\'development\\'}\").')\n  .option('--watch', 'Watch for changes.')\n  .action((cmd) => dev(cmd, process.exit).then(() => {}));\n\nprogram.command('init <appName> [packageName]')\n  .option('--install', 'Install dependencies.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--typescript', 'Use a Typescript based app.')\n  .action((appName, packageName, cmd) => init(appName, packageName, cmd, process.exit).then(() => {}));\n\nprogram.command('linked')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => linked(cmd, process.exit).then(() => {}));\n\nprogram.command('lint')\n  .option('--cache', 'Only check changed files. Default: false.', false)\n  .option('--cacheLocation <path>', 'Path to the cache file or directory.')\n  .option('--color', 'Force enabling of color.', false)\n  .option('--config <path>', 'Use this configuration, overriding .eslintrc.* config options if present. If not specified and no local config exists, Lex will use its default config.')\n  .option('--debug', 'Output debugging information.', false)\n  .option('--envInfo', 'Output execution environment information. Default: false.', false)\n  .option('--env <n>', 'Specify environments.')\n  .option('--fix', 'Apply AI fixes after built-in ESLint fixes (same as --fix).', false)\n  .option('--fixDryRun', 'Automatically fix problems without saving the changes to the file system.', false)\n  .option('--fixType <type>', 'Specify the types of fixes to apply (problem, suggestion, layout).')\n  .option('--format <n>', 'Use a specific output format. Default: stylish.')\n  .option('--global <variables>', 'Define global variables.')\n  .option('--ignorePath <path>', 'Specify path of ignore file.')\n  .option('--ignorePattern <pattern>', 'Pattern of files to ignore (in addition to those in .eslintignore).')\n  .option('--init', 'Run config initialization wizard. Default: false.', false)\n  .option('--maxWarnings <num>', 'Number of warnings to trigger nonzero exit code. Default: -1.')\n  .option('--noColor', 'Force disabling of color.', false)\n  .option('--noEslintrc', 'Disable use of configuration from .eslintrc.*.', false)\n  .option('--noIgnore', 'Disable use of ignore files and patterns.', false)\n  .option('--noInlineConfig', 'Prevent comments from changing config or rules.', false)\n  .option('--outputFile <path>', 'Specify file to write report to.')\n  .option('--parser <n>', 'Specify the parser to be used.')\n  .option('--parserOptions <options>', 'Specify parser options.')\n  .option('--plugin <plugins>', 'Specify plugins.')\n  .option('--printConfig <path>', 'Print the configuration for the given file.')\n  .option('--quiet', 'No Lex notifications printed in the console.', false)\n  .option('--remove-comments', 'Remove all comments except TODOs and copyright notices.', false)\n  .option('--reportUnusedDisableDirectives', 'Adds reported errors for unused eslint-disable directives.', false)\n  .option('--resolvePluginsRelativeTo <path>', 'A folder where plugins should be resolved from.')\n  .option('--rule <path>', 'Specify rules.')\n  .option('--rulesdir <path>', 'Use additional rules from this directory.')\n  .option('--stdin', 'Lint code provided on <STDIN> - Default: false.', false)\n  .option('--stdinFilename <n>', 'Specify filename to process STDIN as.')\n  .action((cmd) => lint(cmd, process.exit).then(() => {}));\n\nprogram.command('migrate')\n  .option('-q, --quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => migrate(cmd, process.exit).then(() => {}));\n\nprogram.command('publish')\n  .addOption(new Option('--bump <type>', 'Increments the version. Types include: major, minor, patch, beta, alpha, rc. Default: \"patch\".').choices(['major', 'minor', 'patch', 'beta', 'alpha', 'rc']).default('patch'))\n  .option('--newVersion <versionNumber>', 'Publish as a specific version.')\n  .option('--otp <code>', 'Provide a two-factor code.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--private', 'Publishes the module as restricted.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--tag <tag>', 'Registers the published package with the given tag.')\n  .action((cmd) => publish(cmd, process.exit).then(() => {}));\n\nprogram.command('serverless')\n  .option('--config <path>', 'Custom configuration file path (default: lex.config.mjs).')\n  .option('--host <host>', 'Host to bind the server to (default: localhost).')\n  .option('--httpPort <port>', 'HTTP server port (default: 3100).')\n  .option('--httpsPort <port>', 'HTTPS server port (default: 3101).')\n  .option('--wsPort <port>', 'WebSocket server port (default: 3102).')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--remove', 'Removes all files from the output directory before starting.')\n  .option('--usePublicIp', 'Force refresh the cached public IP address.')\n  .option('--variables <json>', 'Environment variables to set in process.env.')\n  .option('--debug', 'Enable GraphQL debug logging to see queries, variables, and operations.')\n  .option('--printOutput', 'Print GraphQL response output including status, headers, and body.')\n  .action((cmd) => serverless(cmd, process.exit).then(() => {}));\n\nprogram.command('storybook')\n  .option('--config <path>', 'Custom Storybook configuration directory path (ie. .storybook).')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--open', 'Automatically open Storybook in a new browser window.')\n  .option('--port <number>', 'Port number for the Storybook server.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--static', 'Build a static Storybook site instead of starting dev server.')\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{STORYBOOK_THEME: \\'dark\\'}\").')\n  .option('--verbose', 'Show detailed webpack progress output.')\n  .action((cmd) => storybook(cmd, process.exit).then(() => {}));\n\nprogram.command('test [files...]')\n  .option('--analyze', 'Use AI to analyze test coverage and suggest improvements.', false)\n  .option('--debugTests', 'Use AI to debug test failures and suggest fixes.', false)\n  .option('--generate', 'Use AI to generate test cases for untested code.', false)\n  .option('--bail', 'Exit the test suite immediately upon the first failing test suite.')\n  .option('--changedFilesWithAncestor', 'Runs tests related to the current changes and the changes made in the last commit.')\n  .option('--changedSince', 'Runs tests related the changes since the provided branch.')\n  .option('--ci', 'When this option is provided, Vitest will assume it is running in a CI environment.')\n  .option('--clearCache', 'Clear Vitest cache.')\n  .option('--collectCoverageFrom <glob>', 'A glob pattern relative to matching the files that coverage info needs to be collected from.')\n  .option('--colors', 'Forces test results output highlighting even if stdout is not a TTY.')\n  .option('--config <path>', 'Custom Vitest configuration file path (ie. vitest.config.mjs).')\n  .option('--debug', 'Print debugging info about your Vitest config.')\n  .option('--detectOpenHandles', 'Attempt to collect and print open handles preventing Vitest from exiting cleanly')\n  .option('--environment <n>', 'Target environment. \"node\" or \"web\". Default: \"node\".')\n  .option('--env', 'The test environment used for all tests. This can point to any file or node module. Examples: happy-dom, jsdom, node or path/to/my-environment.js.')\n  .option('--errorOnDeprecated', 'Make calling deprecated APIs throw helpful error messages.')\n  .option('--expand', 'Use this flag to show full diffs and errors instead of a patch.')\n  .option('--forceExit', 'Force Vitest to exit after all tests have completed running.')\n  .option('--json', 'Prints the test results in JSON.')\n  .option('--lastCommit', 'Run all tests affected by file changes in the last commit made.')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--listTests', 'Lists all tests as JSON that Vitest will run given the arguments, and exits.')\n  .option('--logHeapUsage', 'Logs the heap usage after every test.')\n  .option('--maxWorkers <num>', 'Specifies the maximum number of workers the worker-pool will spawn for running tests. ')\n  .option('--noStackTrace', 'Disables stack trace in test results output.')\n  .option('--notify', 'Activates notifications for test results.')\n  .option('--onlyChanged', 'un based on which files have changed in the current repository. ')\n  .option('--outputFile <filename>', 'Write test results to a file when the --json option is also specified.')\n  .option('--passWithNoTests', 'Allows the test suite to pass when no files are found.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--runInBand', 'Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests.')\n  .option('--setup <path>', 'Vitest setup file path.')\n  .option('--showConfig', 'Print your Vitest config and then exits.')\n  .option('--silent', 'Prevent tests from printing messages through the console.')\n  .option('--testLocationInResults', 'Adds a location field to test results.')\n  .option('--testNamePattern <regex>', 'Run only tests with a name that matches the regex. ')\n  .option('--testPathPattern <regex>', 'A regexp pattern string that is matched against all tests paths before executing the test.')\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--update', 'Update snapshots. Runs \"vitest --update\"')\n  .option('--useStderr', 'Divert all output to stderr.')\n  .option('--verbose', 'Display individual test results with the test suite hierarchy.')\n  .option('--watch <path>', 'Watch files for changes and rerun tests related to changed files.')\n  .option('--watchAll', 'Watch files for changes and rerun all tests when something changes.')\n  .action((files, options, cmd) => test(options, cmd.args, files, process.exit).then(() => {}));\n\nprogram.command('update')\n  .option('--interactive', 'Choose which packages to update.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--registry', 'Add a custom registry url.')\n  .action((cmd) => update(cmd, process.exit).then(() => {}));\n\nprogram.command('upgrade')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => upgrade(cmd, process.exit).then(() => {}));\n\nprogram.command('ai')\n  .option('--context', 'Include project context in the AI prompt.', true)\n  .option('--file <path>', 'Specific file to operate on.')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--model <model>', 'AI model to use. Default: gpt-4o.')\n  .option('--prompt <text>', 'The prompt to send to the AI.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .addOption(new Option('--task <task>', 'Type of AI task to perform.').choices(['generate', 'explain', 'test', 'optimize', 'help']).default('help'))\n  .action((cmd) => aiFunction(cmd).then(() => {}));\n\nprogram.command('versions')\n  .option('--json', 'Print the version as a JSON object.')\n  .action((cmd) => versions(cmd, process.exit).then(() => {}));\n\nprogram\n  .version(packageJson.version)\n  .parse(process.argv);\n"],"names":["Option","program","readFileSync","createRequire","dirname","resolve","fileURLToPath","aiFunction","build","clean","compile","config","create","dev","DEFAULT_DEV_PORT","init","linked","lint","migrate","publish","serverless","storybook","test","update","upgrade","versions","process","env","LEX_ROOT","url","lexNodeModules","NODE_PATH","split","includes","require","Module","_initPaths","packagePath","URL","packageJson","JSON","parse","command","option","addOption","choices","default","action","cmd","exit","then","type","appName","packageName","files","options","args","version","argv"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.55.1",
3
+ "version": "1.55.2",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -83,16 +83,16 @@
83
83
  "dependencies": {
84
84
  "@mdx-js/loader": "^3.1.1",
85
85
  "@nlabs/webpack-plugin-static-site": "*",
86
- "@storybook/addon-docs": "^10.2.12",
87
- "@storybook/addon-links": "^10.2.12",
86
+ "@storybook/addon-docs": "^10.2.17",
87
+ "@storybook/addon-links": "^10.2.17",
88
88
  "@storybook/addon-postcss": "^2.0.0",
89
89
  "@storybook/addon-styling-webpack": "^3.0.0",
90
- "@storybook/addon-themes": "^10.2.12",
91
- "@storybook/cli": "^10.2.12",
92
- "@storybook/react": "^10.2.12",
93
- "@storybook/react-webpack5": "^10.2.12",
90
+ "@storybook/addon-themes": "^10.2.17",
91
+ "@storybook/cli": "^10.2.17",
92
+ "@storybook/react": "^10.2.17",
93
+ "@storybook/react-webpack5": "^10.2.17",
94
94
  "@swc/cli": "^0.8.0",
95
- "@swc/core": "^1.15.13",
95
+ "@swc/core": "^1.15.18",
96
96
  "@tailwindcss/forms": "^0.5.11",
97
97
  "@tailwindcss/nesting": "^0.0.0-insiders.565cd3e",
98
98
  "@tailwindcss/postcss": "4.2.1",
@@ -103,29 +103,29 @@
103
103
  "autoprefixer": "^10.4.27",
104
104
  "boxen": "8.0.1",
105
105
  "buffer": "^6.0.3",
106
- "caniuse-lite": "1.0.30001774",
106
+ "caniuse-lite": "1.0.30001777",
107
107
  "chalk": "^5.6.2",
108
108
  "commander": "^14.0.3",
109
109
  "compare-versions": "^6.1.1",
110
- "compression-webpack-plugin": "^11.1.0",
111
- "copy-webpack-plugin": "^13.0.1",
110
+ "compression-webpack-plugin": "^12.0.0",
111
+ "copy-webpack-plugin": "^14.0.0",
112
112
  "core-js": "^3.48.0",
113
113
  "crypto-js": "^4.2.0",
114
114
  "css-loader": "^7.1.4",
115
- "css-minimizer-webpack-plugin": "^7.0.4",
116
- "cssnano": "^7.1.2",
117
- "dotenv-webpack": "^8.1.1",
115
+ "css-minimizer-webpack-plugin": "^8.0.0",
116
+ "cssnano": "^7.1.3",
117
+ "dotenv-webpack": "^9.0.0",
118
118
  "download-npm-package": "^3.1.12",
119
- "eslint": "^10.0.2",
120
- "eslint-config-styleguidejs": "^5.0.2",
119
+ "eslint": "^10.0.3",
120
+ "eslint-config-styleguidejs": "^5.0.4",
121
121
  "execa": "9.6.1",
122
- "expect": "^30.2.0",
122
+ "expect": "^30.3.0",
123
123
  "express": "^5.2.1",
124
124
  "favicons-webpack-plugin": "^6.0.1",
125
125
  "find-file-up": "^2.0.1",
126
126
  "glob": "^13.0.6",
127
127
  "global": "^4.4.0",
128
- "graphql": "^16.13.0",
128
+ "graphql": "^16.13.1",
129
129
  "graphql-tag": "^2.12.6",
130
130
  "html-loader": "^5.1.0",
131
131
  "html-webpack-plugin": "^5.6.6",
@@ -136,13 +136,13 @@
136
136
  "lodash": "^4.17.23",
137
137
  "luxon": "^3.7.2",
138
138
  "math-expression-evaluator": "^2.0.7",
139
- "mini-css-extract-plugin": "^2.10.0",
140
- "npm-check-updates": "^19.5.0",
141
- "openai": "^6.25.0",
139
+ "mini-css-extract-plugin": "^2.10.1",
140
+ "npm-check-updates": "^19.6.3",
141
+ "openai": "^6.27.0",
142
142
  "ora": "9.3.0",
143
143
  "os-browserify": "^0.3.0",
144
144
  "path-browserify": "^1.0.1",
145
- "postcss": "^8.5.6",
145
+ "postcss": "^8.5.8",
146
146
  "postcss-browser-reporter": "^0.7.0",
147
147
  "postcss-cli": "^11.0.1",
148
148
  "postcss-custom-properties": "^15.0.1",
@@ -155,7 +155,7 @@
155
155
  "postcss-percentage": "^0.0.0",
156
156
  "postcss-preset-env": "^11.2.0",
157
157
  "postcss-simple-vars": "^7.0.1",
158
- "postcss-svgo": "7.1.0",
158
+ "postcss-svgo": "7.1.1",
159
159
  "postcss-url": "10.1.3",
160
160
  "postcss-value-parser": "^4.2.0",
161
161
  "process": "^0.11.10",
@@ -167,12 +167,12 @@
167
167
  "rimraf": "^6.1.3",
168
168
  "semver": "^7.7.4",
169
169
  "source-map-loader": "^5.0.0",
170
- "storybook": "^10.2.12",
170
+ "storybook": "^10.2.17",
171
171
  "stream-browserify": "^3.0.0",
172
172
  "stream-http": "^3.2.0",
173
173
  "style-loader": "^4.0.0",
174
174
  "svg-spritemap-webpack-plugin": "^5.1.0",
175
- "svgo": "4.0.0",
175
+ "svgo": "4.0.1",
176
176
  "swc-loader": "^0.2.7",
177
177
  "tailwindcss": "^4.2.1",
178
178
  "ts-node": "^10.9.2",
@@ -181,7 +181,7 @@
181
181
  "util": "^0.12.5",
182
182
  "vitest": "^4.0.18",
183
183
  "vm-browserify": "^1.1.2",
184
- "webpack": "5.105.2",
184
+ "webpack": "5.105.4",
185
185
  "webpack-bundle-analyzer": "^5.2.0",
186
186
  "webpack-cli": "^6.0.1",
187
187
  "webpack-merge": "^6.0.1",
@@ -191,21 +191,20 @@
191
191
  "devDependencies": {
192
192
  "@types/express": "^5.0.6",
193
193
  "@types/luxon": "^3.7.1",
194
- "@types/node": "^25.3.1",
194
+ "@types/node": "^25.4.0",
195
195
  "@types/ora": "^3.2.0",
196
196
  "@types/react": "^19.2.14",
197
197
  "@types/webpack": "^5.28.5"
198
198
  },
199
199
  "overrides": {
200
200
  "cross-spawn": "^7.0.6",
201
- "fast-xml-parser": ">=5.4.1",
202
201
  "got": "^14.6.6",
203
- "http-cache-semantics": "^4.2.0",
204
202
  "http-proxy-middleware": "^3.0.5",
205
203
  "minimatch": ">=10.2.4",
206
- "postcss": "^8.5.6",
204
+ "postcss": "^8.5.8",
207
205
  "semver-regex": "^4.0.5",
208
- "tmp": "^0.2.5"
206
+ "tmp": "^0.2.5",
207
+ "file-type": "^21.3.1"
209
208
  },
210
209
  "gitHead": "0f5fb22fc0f0ab1abab5adf62afed24c7c87e4a8"
211
210
  }